ypollset.cpp 1.76 KB
Newer Older
Martin Sustrik's avatar
Martin Sustrik committed
1
/*
2
    Copyright (c) 2007-2010 iMatix Corporation
Martin Sustrik's avatar
Martin Sustrik committed
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
    the terms of the Lesser GNU General Public License as published by
    the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.

    0MQ is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    Lesser GNU General Public License for more details.

    You should have received a copy of the Lesser GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

#include "ypollset.hpp"

Martin Sustrik's avatar
Martin Sustrik committed
22
zmq::ypollset_t::ypollset_t ()
Martin Sustrik's avatar
Martin Sustrik committed
23 24 25
{
}

26 27 28 29
zmq::ypollset_t::~ypollset_t ()
{
}

Martin Sustrik's avatar
Martin Sustrik committed
30
void zmq::ypollset_t::signal (int signal_)
Martin Sustrik's avatar
Martin Sustrik committed
31
{
Martin Sustrik's avatar
Martin Sustrik committed
32
    zmq_assert (signal_ >= 0 && signal_ < wait_signal);
Martin Sustrik's avatar
Martin Sustrik committed
33 34 35 36
    if (bits.btsr (signal_, wait_signal))
        sem.post (); 
}

37
uint64_t zmq::ypollset_t::poll ()
Martin Sustrik's avatar
Martin Sustrik committed
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
{
    signals_t result = 0;
    while (!result) {
        result = bits.izte (signals_t (1) << wait_signal, 0);
        if (!result) {
            sem.wait ();
            result = bits.xchg (0);
        }

        //  If btsr was really atomic, result would never be 0 at this
        //  point, i.e. no looping would be possible. However, to
        //  support even CPU architectures without CAS instruction
        //  we allow btsr to be composed of two independent atomic
        //  operation (set and reset). In such case looping can occur
        //  sporadically.
    }
54
    return (uint64_t) result;      
Martin Sustrik's avatar
Martin Sustrik committed
55 56
}

57
uint64_t zmq::ypollset_t::check ()
Martin Sustrik's avatar
Martin Sustrik committed
58
{
59
    return (uint64_t) bits.xchg (0);
Martin Sustrik's avatar
Martin Sustrik committed
60
}
61 62 63 64 65

zmq::fd_t zmq::ypollset_t::get_fd ()
{
    return retired_fd;
}