Date: Thu, 22 Aug 2013 02:10:23 +0200 From: Mateusz Guzik <mjguzik@gmail.com> To: Yuri <yuri@rawbw.com> Cc: John-Mark Gurney <jmg@funkthat.com>, Roman Divacky <rdivacky@freebsd.org>, current@freebsd.org Subject: Re: How to best overload the fileops ? Message-ID: <20130822001022.GA18115@dft-labs.eu> In-Reply-To: <521552E2.2000008@rawbw.com> References: <521508F4.6030502@rawbw.com> <20130821232113.GD94127@funkthat.com> <521552E2.2000008@rawbw.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, Aug 21, 2013 at 04:53:06PM -0700, Yuri wrote: > On 08/21/2013 16:21, John-Mark Gurney wrote: > >How did this memory get allocated in the first place? Why does it need > >to be free'd in fo_close and not another location? > > It is allocated by the epoll module right after kqueue object is > created and is attached to the opaque field in the file object. > And it should be deallocated when this fd is closed, hence fo_close. > Short answer is provide epollops with your own fo_close and the rest as it is currently in kqueueops. All function are static, but this is not a real problem since you have to modify kern_event.c anyway. I don't know how your code looks like in general, so in case its not clear, simply wrapping sys_kqueue is inherently racy (some other thread may close the fd or even reuse it for something else by the time you try to do anything with it), thus modification of current code is unavoidable. -- Mateusz Guzik <mjguzik gmail.com>
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20130822001022.GA18115>