mq on kqueue broken after upgrade to FreeBSD 11
    Konstantin Belousov 
    kostikbel at gmail.com
       
    Thu Oct  6 19:17:49 UTC 2016
    
    
  
On Wed, Oct 05, 2016 at 07:09:03PM -0500, Lewis Donzis wrote:
> Sorry, perhaps I wasn???t clear. As I read it, you suggested that you
> "can and should call close()" on the fd in an mqd_t, and my point was
> simply that such practice would obviously be bad because it would
> fail to release resources allocated by mq_open(). So yes, the correct
> way to close an mqueue is via mq_close(), i.e., we???re not meant to
> circumvent the librt functions.
>
> The problem is that it???s not exactly clean that we have mq_*()
> functions for some operations, whereas for others, we???re required to
> convert the mqd_t to an fd. Of course, this is no fault of FreeBSD,
> and perhaps the POSIX folks should have come up with a better way to
> address this. For example, they could have specified a portable way to
> get the underlying fd from an mqd_t and specified what can and cannot
> be done with the fd.
POSIX does not and can not mandate the implementation.  Existence of the
backing fd is pure implementation detail.  Access to the fd through
mq_getfd_np() is some good will service from the implementation which
is supposed to make additional things possible besides the guarantees
of the POSIX spec.
kqueue(2) is not part of the POSIX, same as the use of mq for the
multiplexed wait (select/poll/kqueue).  POSIX intent is that app
code get notifications by events.
    
    
More information about the freebsd-arch
mailing list