Re: [Pv-drivers] [PATCH 05/12] VMCI: event handling implementation.

From: Dmitry Torokhov
Date: Tue Oct 30 2012 - 11:59:30 EST


On Tuesday, October 30, 2012 08:50:41 AM Greg KH wrote:
> On Mon, Oct 29, 2012 at 10:01:52PM -0700, Dmitry Torokhov wrote:
> > On Mon, Oct 29, 2012 at 07:26:05PM -0700, Greg KH wrote:
> > > On Mon, Oct 29, 2012 at 06:04:27PM -0700, George Zhang wrote:
> > > > +static void event_signal_destroy(struct kref *kref)
> > > > +{
> > > > + struct vmci_subscription *entry =
> > > > + container_of(kref, struct vmci_subscription, kref);
> > > > +
> > > > + complete(&entry->done);
> > > > +}
> > >
> > > Didn't you just leak memory here? What frees the structure up?
> >
> > event_unregister_subscription() waits for that completion and frees the
> > structure. We want event_unregister_subscription() to wait until all
> > fired callbacks completed before unregister is complete.
>
> So all calls to this can just sit and spin waiting for others to clean
> up? Odd, but ok.

Not all as there is logically only one owner of the subscription so
naturally it waits until all notification callbacks are done.

Frankly we have a change that gets rid of delayed ecvent callbacks
and so the refcounting is no longer needed at all.

Thanks,
Dmitry

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/