From owner-freebsd-stable@FreeBSD.ORG Sat Jun 11 01:24:53 2011 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 3F8E2106564A for ; Sat, 11 Jun 2011 01:24:53 +0000 (UTC) (envelope-from delphij@gmail.com) Received: from mail-vx0-f182.google.com (mail-vx0-f182.google.com [209.85.220.182]) by mx1.freebsd.org (Postfix) with ESMTP id E30EE8FC13 for ; Sat, 11 Jun 2011 01:24:52 +0000 (UTC) Received: by vxc34 with SMTP id 34so3749945vxc.13 for ; Fri, 10 Jun 2011 18:24:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc:content-type :content-transfer-encoding; bh=kxAbghUDJXcj65V9S5eqEif4+T6/lXA61+Gg2qgUBmk=; b=TOSsYfPiLylixhFAbkOvSxZTOU2VwTkgbcC68naZvVLPFQ0LQioqWl4vo4nveaCokt 27rUy6SS0cwNfuj4PVQlOWV4zJvaUf7k9j82qWa4VIycJ8HILr7BIbVlqmf4GpeIURci ZytD2Q3s4u72V3VoE3Gdg/pp/NfdpfXYrKwLc= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type:content-transfer-encoding; b=aHIU1Y9aZh5ddMq5wIdWljzc9+l7W/gnQyFvMGLdF9VFagw/RX9mPuIeY7GaUq2l9D 7CDXZPSGG+7s24Su72a/EYSJsJLgnqoEGCh8drYJ4OmUv+8Mk55mmeIcKDRjg2Z+3PE8 QZNidE09Rz5OCl55jaiDAq9BzIqqYglbzRgtk= MIME-Version: 1.0 Received: by 10.52.97.161 with SMTP id eb1mr723685vdb.74.1307755491966; Fri, 10 Jun 2011 18:24:51 -0700 (PDT) Received: by 10.52.108.132 with HTTP; Fri, 10 Jun 2011 18:24:51 -0700 (PDT) In-Reply-To: <20110611005951.GA55990@icarus.home.lan> References: <20110610221525.A1C791CC0B@ptavv.es.net> <4DF2A5AC.6070804@delphij.net> <20110610234227.GA54846@icarus.home.lan> <20110611005951.GA55990@icarus.home.lan> Date: Fri, 10 Jun 2011 18:24:51 -0700 Message-ID: From: Xin LI To: Jeremy Chadwick Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Cc: freebsd-stable@freebsd.org Subject: Re: Unable to boot Lenovo T520 X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 11 Jun 2011 01:24:53 -0000 On Fri, Jun 10, 2011 at 5:59 PM, Jeremy Chadwick wrote: > On Fri, Jun 10, 2011 at 04:48:31PM -0700, Xin LI wrote: >> On Fri, Jun 10, 2011 at 4:42 PM, Jeremy Chadwick >> wrote: >> > On Fri, Jun 10, 2011 at 04:15:56PM -0700, Xin LI wrote: >> >> -----BEGIN PGP SIGNED MESSAGE----- >> >> Hash: SHA256 >> >> >> >> On 06/10/11 15:15, Kevin Oberman wrote: >> >> > I am hitting the problem reported some time ago with atkbd and svn >> >> > 197392. >> >> > >> >> > It's not clear that this has ben finally resolved, but I am still >> >> > hitting it with -stable on my new T520. I really want to get FreeBS= D up >> >> > on it, but I am dead in the water at this time. I guess I'll have t= o >> >> > build a new kernel with any fix and replace the kernel in the ISO. >> >> > >> >> > Also, I am hoping to use it on an amd64 kernel and I am even less s= ure >> >> > that any patch will work on that arch. >> >> > >> >> > The original thread was >> >> > http://freebsd.1045724.n5.nabble.com/svn-rev-197392-hangs-during-bo= ot-td3926276.html >> >> >> >> The fix was not (yet) merged back to 8-STABLE. ??You may use a >> >> 8.0-RELEASE kernel to boot the system temporarily and apply this patc= h: >> >> >> >> http://www.freebsd.org/cgi/cvsweb.cgi/src/sys/dev/atkbdc/atkbd.c.diff= ?r1=3D1.63;r2=3D1.64 >> >> >> >> (If hunk #1 fails to apply, it's Ok to just ignore it). >> > >> > Specifically: >> > >> > http://www.freebsd.org/cgi/cvsweb.cgi/src/sys/dev/atkbdc/atkbd.c#rev1.= 64 >> > >> > - ?? ?? ?? if (x86bios_get_intr(0x15) =3D=3D 0 || x86bios_get_intr(0x1= 6) =3D=3D 0) >> > + ?? ?? ?? if (x86bios_get_intr(0x15) !=3D 0xf000f859 || >> > + ?? ?? ?? ?? ?? x86bios_get_intr(0x16) !=3D 0xf000e82e) >> > >> > What are these magic numbers? ??Where did they come from? ??What do th= ey >> > represent? ??Why are they not documented in the source code/commit >> > itself? ??No offence, but this is an open-source project; anyone looki= ng >> > at this code isn't going to know what those vectors represent. ??The >> > commit message is also lacking (again: magic values not mentioned), an= d >> > expecting a developer to dig through commits/annotations to determine >> > what this piece of code is for is unreasonable. >> > >> > No I'm not in a bad mood (honest!), I just find this kind of thing >> > infuriating the more I dig through kernel source code. >> >> The commit log explicitly say: >> >> Validate INT 15h and 16h vectors more strictly. =C2=A0Traditionally thes= e entry >> points are fixed addresses and (U)EFI CSM specification also mandated th= at. >> Unfortunately, (U)EFI CSM specification does not specifically mention th= is >> is to call service routine via interrupt vector table or to jump directl= y >> to the entry point. =C2=A0As a result, some CSM seems to install two rou= tines >> and acts differently, depending on how it was executed, unfortunately. >> When INT 15h is used, it calls a function pointer (which is probably a U= EFI >> service function). =C2=A0When it jumps directly to the entry point, it e= xecutes >> a simple and traditional INT 15h service routine. =C2=A0Therefore, actua= lly there >> are two possible fixes, i. e., this fix or jumping directly to the fixed >> entry point. =C2=A0However, we chose this fix because a) keyboard typema= tic >> support via BIOS is becoming extremely rarer and b) we cannot support ra= ndom >> service routine installed by a firmware or a boot loader. =C2=A0This sho= uld fix >> Lenovo X220 laptop, specifically. >> >> Be reasonable, please. > > I read the commit message -- sadly it also does not explain what the > numbers mean. =C2=A00xf000f859 and 0xf000e82e appear to be 32-bit vector > addresses (e.g. used for indirect JMP), except nobody explains where > those values came from or what they actually point to. =C2=A0Therefore, t= hey > are "magic values" until they can be defined otherwise. > > Someone digging through the source code is not going to see the commit > message. =C2=A0They're going to have to track it down by hand using cvswe= b or > SVN, just to look at annotations. =C2=A0Don't worry, I don't mean for thi= s to > sound like I'm picking on this single commit -- this kind of craziness > is all over the FreeBSD source tree, and as I said, it's infuriating > when trying to look at the code (it is an open-source project, right?) > and figure out what's going on/why something is the way it is. I'm not in good mood and I find it a waste of my time, sorry for that. I have committed a fix (r222967). Just want to say that Jung-uk have spend a lot of his time investigating and fixing this issue, and I just don't see why people typing that much doesn't want to submit a patch. I think Open Source projects expect everyone there to contribute rather than asking someone else to do the work. Cheers, --=20 Xin LI http://www.delphij.net