All of lore.kernel.org
 help / color / mirror / Atom feed
From: Lennart Poettering <lennart@poettering.net>
To: linux-hotplug@vger.kernel.org
Subject: Re: CK.OpenSession(): Do not block on run-seat.d scripts?
Date: Mon, 21 Dec 2009 14:32:11 +0000	[thread overview]
Message-ID: <20091221143210.GA2429@tango.0pointer.de> (raw)
In-Reply-To: <20091221141709.GA2268@piware.de>

On Mon, 21.12.09 15:17, Martin Pitt (martin.pitt@ubuntu.com) wrote:

Heya,

> I'm working on speeding up udev-acl.ck, but I need to discuss that
> with Kay Sievers first.
> 
> However, I wondered why it is synchronous in the first place: The
> hooks are called with a couple of environment variables, but CK does
> not read any kind of result from them. In other words, the scripts
> can't influence session properties, nor abort the creation of a
> session.
> 
> Is there a particular reason for CK to wait on all the hooks? If not,
> I'm happy to work on a patch to call those in the background. The only
> thing to watch out for, as far as I can see, is that a call to the
> hooks must not overlap with the next seat change, so this requires
> some locking.

We'd be very ill advised if (again) we'd do stuff like ACL fixes
asynchronously in parallel to sending out the CK session messages. You
really dont want that, because then clients which listen for session
change messages could not rely on the ACLs being set up correctly when
they get the message.

The dbus messages really need to be the last thing that happens, the
seat.d hooks *must* be finished first, unless you are a sucker for
raciness nightmares.

In HAL this used to be different (i.e. asynchronous), and among other
reasons that's why HAL was broken.

Also note that /usr/lib/ConsoleKit/run-seat.d/udev-acl.ck is actually
*not* a script. I cannot really believe that there is really that much
to optimize here in this area... Except maybe that udev-acl might not
be particularly fast since it iterates through the device list
linearly?

Lennart

-- 
Lennart Poettering                        Red Hat, Inc.
lennart [at] poettering [dot] net
http://0pointer.net/lennart/           GnuPG 0x1A015CC4

      reply	other threads:[~2009-12-21 14:32 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-12-21 14:17 CK.OpenSession(): Do not block on run-seat.d scripts? Martin Pitt
2009-12-21 14:32 ` Lennart Poettering [this message]

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=20091221143210.GA2429@tango.0pointer.de \
    --to=lennart@poettering.net \
    --cc=linux-hotplug@vger.kernel.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.