From: Rodolfo Giometti <giometti@enneenne.com>
To: Andrew Morton <akpm@linux-foundation.org>
Cc: linux-kernel@vger.kernel.org, dwmw2@infradead.org,
davej@redhat.com, sam@ravnborg.org, greg@kroah.com,
randy.dunlap@oracle.com
Subject: Re: [PATCH 1/7] LinuxPPS core support.
Date: Tue, 1 Apr 2008 10:42:14 +0200 [thread overview]
Message-ID: <20080401084214.GY7279@enneenne.com> (raw)
In-Reply-To: <20080327202531.a924e5d9.akpm@linux-foundation.org>
On Thu, Mar 27, 2008 at 08:25:31PM -0700, Andrew Morton wrote:
> On Tue, 25 Mar 2008 15:44:00 +0100 Rodolfo Giometti <giometti@enneenne.com> wrote:
> > >
> > > As it stands, there might be deadlocks such as when a process which itself
> > > holds a ref on the pps_device (with an open fd?) calls
> > > pps_unregister_source.
> >
> > I can add a wait_event_interruptible in order to allow userland to
> > continue by receiving a signal. It could be acceptable?
>
> There should be no need to "wait" for anything. When the final reference
> to an object is released, that object is cleaned up. Just like we do for
> inodes, dentries, pages, files, and 100 other kernel objects.
>
> The need to wait for something else to go away is a big red flag with
> "busted refcounting" written on it.
>
> > > Also, we need to take care that all processes which were waiting in
> > > pps_unregister_source() get to finish their cleanup before we permit rmmod
> > > to proceed. Is that handled somewhere?
> >
> > I don't understand the problem... this code as been added in order to
> > avoid the case where a pps_event() is called while a process executes
> > the pps_unregister_source(). If more processes try to execute this
> > code the first which enters will execute idr_remove() which prevents
> > another process to reach the wait_event()... is that wrong? =:-o
>
> I was asking you!
>
> We should get the reference counting and object lifetimes sorted out first.
> There should be no "wait for <object> to be released" code. Once that is
> in place, things like rmmod will also sort themselves out: it just won't be
> possible to remove the module while there are live references to objects.
The problem is related to serial and parallel clients.
The PPS source related to a serial port (or a parallel one) uses the
serial (or parallel) IRQ to get PPS timestamps and it could be
possible that a process tries to close the PPS source while another
CPU is runnig the serial IRQ, so I cannot remove the PPS object until
the IRQ handler is finished its job on the PPS object.
For clients (currently none :) which define their own IRQ handler for
PPS timestamps managing the problem doesn't arise at all.
Ciao,
Rodolfo
--
GNU/Linux Solutions e-mail: giometti@enneenne.com
Linux Device Driver giometti@gnudd.com
Embedded Systems giometti@linux.it
UNIX programming phone: +39 349 2432127
next prev parent reply other threads:[~2008-04-01 8:42 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-03-06 12:08 LinuxPPS (RESUBMIT 2): the PPS Linux implementation Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 1/7] LinuxPPS core support Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 2/7] PPS: userland header file for PPS API Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 3/7] PPS: documentation programs and examples Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 4/7] PPS: LinuxPPS clients support Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 5/7] PPS: serial " Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 6/7] PPS: example program to enable PPS support on serial ports Rodolfo Giometti
2008-03-06 12:09 ` [PATCH 7/7] PPS: parallel port clients support Rodolfo Giometti
2008-03-20 20:04 ` [PATCH 5/7] PPS: serial " Andrew Morton
2008-03-21 11:17 ` Rodolfo Giometti
2008-03-21 17:41 ` Andrew Morton
2008-03-25 10:38 ` Rodolfo Giometti
2008-03-20 20:03 ` [PATCH 1/7] LinuxPPS core support Andrew Morton
2008-03-25 14:44 ` Rodolfo Giometti
2008-03-28 3:25 ` Andrew Morton
2008-04-01 8:42 ` Rodolfo Giometti [this message]
2008-04-01 8:55 ` Andrew Morton
2008-04-01 9:50 ` Rodolfo Giometti
2008-04-01 21:45 ` Rodolfo Giometti
2008-04-01 21:57 ` Andrew Morton
2008-03-21 3:36 ` Kay Sievers
2008-03-21 10:56 ` Rodolfo Giometti
2008-03-21 17:00 ` Kay Sievers
2008-03-25 10:48 ` Rodolfo Giometti
2008-03-21 3:50 ` Kay Sievers
2008-03-21 10:57 ` Rodolfo Giometti
2008-03-21 17:01 ` Kay Sievers
2008-03-25 10:53 ` Rodolfo Giometti
2008-03-28 10:21 ` Andrew Morton
2008-04-01 8:59 ` Rodolfo Giometti
2008-04-01 9:09 ` Andrew Morton
2008-04-01 9:40 ` Rodolfo Giometti
2008-03-19 17:29 ` LinuxPPS (RESUBMIT 2): the PPS Linux implementation john stultz
2008-03-19 21:21 ` Andrew Morton
2008-03-19 21:55 ` Dave Jones
-- strict thread matches above, loose matches on Subject: below --
2008-04-10 15:15 LinuxPPS (RESUBMIT 3): " Rodolfo Giometti
2008-04-10 15:15 ` [PATCH 1/7] LinuxPPS core support Rodolfo Giometti
2008-04-10 16:06 [PATCH 5/7] PPS: serial clients support Rodolfo Giometti
2008-04-10 18:22 ` LinuxPPS (RESUBMIT 4): the PPS Linux implementation Rodolfo Giometti
2008-04-10 18:22 ` [PATCH 1/7] LinuxPPS core support Rodolfo Giometti
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080401084214.GY7279@enneenne.com \
--to=giometti@enneenne.com \
--cc=akpm@linux-foundation.org \
--cc=davej@redhat.com \
--cc=dwmw2@infradead.org \
--cc=greg@kroah.com \
--cc=linux-kernel@vger.kernel.org \
--cc=randy.dunlap@oracle.com \
--cc=sam@ravnborg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.