Date: Fri, 22 Feb 2008 19:29:30 +0200 From: Kostik Belousov <kostikbel@gmail.com> To: Alexander Nedotsukov <bland@bbnest.net> Cc: yokota@freebsd.org, FreeBSD Current <freebsd-current@freebsd.org>, Joe Marcus Marcus Clarke <marcus@freebsd.org> Subject: Re: page fault panic in scioctl and console-kit-daemon Message-ID: <20080222172930.GZ57756@deviant.kiev.zoral.com.ua> In-Reply-To: <20CD87E3-27BC-4789-A51F-BBFDB3258B47@bbnest.net> References: <4796356D.9080809@gmail.com> <20080123051648.GV57756@deviant.kiev.zoral.com.ua> <479796E1.4000500@gmail.com> <1201118159.38742.17.camel@shumai.marcuscom.com> <20080123211149.GA57756@deviant.kiev.zoral.com.ua> <1201123933.62127.9.camel@shumai.marcuscom.com> <20080124124213.GD57756@deviant.kiev.zoral.com.ua> <72E58ECA-D743-4D5E-9222-7129104E4BAC@bbnest.net> <20080221154714.GS57756@deviant.kiev.zoral.com.ua> <20CD87E3-27BC-4789-A51F-BBFDB3258B47@bbnest.net>
next in thread | previous in thread | raw e-mail | index | archive | help
--/CLVNuQCc5gNsroI Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Sat, Feb 23, 2008 at 01:01:59AM +0900, Alexander Nedotsukov wrote: >=20 > On 22.02.2008, at 0:47, Kostik Belousov wrote: >=20 > >On Thu, Feb 21, 2008 at 09:26:16AM +0900, Alexander Nedotsukov wrote: > >>Hi, > >> > >>May I ask to revisit this issue? To me ENXIO is not semantically > >>correct in this particular case. It also turns out that doing > >>workaround in userspace may not be that good as we used to think. I > >>propose is to fix VT_WAITACTIVE so it simply wait for bound device > >>activation. For my understanding this change should not have any > >>impact on existing code. I also removed really strange console =20 > >>cleanup > >>bit sticked in a long time ago (see ioctl() part). > >>It will be nice to see this patch > > > > > >>(successfully tested by our affected users) committed to all =20 > >>branches. > >> > >>Thanks, > >>Alexander. > > > >I mostly agree with the patch, given it is tested. > > > >The first (not important) note is that change of the wait channel from > >the address of the private structure to the address of the cdev could > >cause more spurious wakeups then before. I expect you usermode code to > >deal with it properly. > Do you know any potential wakeup()s around the kernel? I did not see =20 > any spurious wakeups myself nor user reported it so far. However they =20 > are not welcome so if it considered to be unsafe we can use address of = =20 > cdev pointer (&SC_DEV()) which is private to syscons. Nothing prevents any code in the the kernel from performing wakeup on any wait channel. Due to tradition, wait channel is usually an address of some data structure that is owned by the code performing wakeup. I do not know of any other code that uses cdev address as wait channel, The issue of spurious wakeup is not very important per se. I think more essential for the correct operation is the fact that when the user-mode code is executed, console may already be inactive (again). This is quite similar to the unintended wakeups. Does the code handle this ? If yes, I think it shall handle the wakeups too without any additional actions. I underline that this is not an objection against the patch. --/CLVNuQCc5gNsroI Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.8 (FreeBSD) iEYEARECAAYFAke/BnoACgkQC3+MBN1Mb4jzZACcCTZFQLD6WbdRJJvBiJ6EUMQO XckAoLnJNLyW2hm9gsur4QqHIX05btMA =6GpF -----END PGP SIGNATURE----- --/CLVNuQCc5gNsroI--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080222172930.GZ57756>