From: Dmitry Torokhov <dtor_core@ameritech.net>
To: Pavel Machek <pavel@suse.cz>
Cc: linux-kernel@vger.kernel.org, vojtech@suse.cz
Subject: Re: locking in psmouse
Date: Thu, 29 Apr 2004 07:40:17 -0500 [thread overview]
Message-ID: <200404290740.18182.dtor_core@ameritech.net> (raw)
In-Reply-To: <20040429095830.GD390@elf.ucw.cz>
Hi Pavel,
On Thursday 29 April 2004 04:58 am, Pavel Machek wrote:
> Hi!
>
> > > psmouse-base.c does not have any locking. For example psmouse_command
> > > could race with data coming from the mouse, resulting in problem. This
> > > should fix it.
> >
> > Although I am not arguing that locking might be needed in psmouse module I
> > am somewhat confused how it will help in case of data stream coming from the
> > mouse... If mouse sent a byte before the kernel issue a command then it will
> > be delivered by KBC controller and will be processed by the interrupt handler,
> > probably messing up detection process. That's why as soon as we decide that
> > the device behind PS/2 port is some kind of mouse we disable the stream mode.
>
> Does that mean that mouse can not talk while we are sending commands
> to it? That would help a bit.
>
Yes, check psmouse_probe. As soon as PSMOUSE_CMD_RESET_DIS acknowledged mouse
should cease sending motion data. That still leaves possibility of screwing up
detection if you are moving mouse while psmouse doing PSMOUSE_CMD_GETID.
But I don't think we can do much about it as we'd like to know that the device
is some kind of a mouse before we start messing with it.
> Anyway, locking still seems to be needed:
>
> while (psmouse->cmdcnt && timeout--) {
>
> if (psmouse->cmdcnt == 1 && command == PSMOUSE_CMD_RESET_BAT &&
> timeout > 100000) /* do not run in a endless loop */
> timeout = 100000; /* 1 sec */
>
> if (psmouse->cmdcnt == 1 && command == PSMOUSE_CMD_GETID &&
> psmouse->cmdbuf[1] != 0xab && psmouse->cmdbuf[1] != 0xac) {
> psmouse->cmdcnt = 0;
> break;
> }
>
> spin_unlock_irq(&psmouse_lock);
> udelay(1);
> spin_lock_irq(&psmouse_lock);
> }
>
> racing with
>
> if (psmouse->cmdcnt) {
> psmouse->cmdbuf[--psmouse->cmdcnt] = data;
> goto out;
> }
>
> now... if each runs on different CPU, it can be possible that
> psmouse->cmdcnt is seen as 1 but data are not yet in
> psmouse->cmdbuf... Locking seems neccessary here.
I see.. but this particular case can be resolved but rearranging the code to
write command response first and then decrementing the counter... and putting
a barrier? Or just make cmdcnt atomic... spin_lock_irq feels heavier than
absolutely necessary.
--
Dmitry
next prev parent reply other threads:[~2004-04-29 12:40 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-04-28 21:30 locking in psmouse Pavel Machek
2004-04-29 4:47 ` Dmitry Torokhov
2004-04-29 9:58 ` Pavel Machek
2004-04-29 12:40 ` Dmitry Torokhov [this message]
2004-04-29 19:43 ` Pavel Machek
2004-06-06 17:41 ` Vojtech Pavlik
2004-06-06 18:51 ` Pavel Machek
2004-06-06 19:34 ` Vojtech Pavlik
2004-04-29 16:02 ` Vojtech Pavlik
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=200404290740.18182.dtor_core@ameritech.net \
--to=dtor_core@ameritech.net \
--cc=linux-kernel@vger.kernel.org \
--cc=pavel@suse.cz \
--cc=vojtech@suse.cz \
/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.