From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:51632) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1a71tv-0003zS-Hq for qemu-devel@nongnu.org; Thu, 10 Dec 2015 09:09:00 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1a71tp-00067Y-Ve for qemu-devel@nongnu.org; Thu, 10 Dec 2015 09:08:55 -0500 Received: from mx1.redhat.com ([209.132.183.28]:46181) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1a71tp-00067D-QR for qemu-devel@nongnu.org; Thu, 10 Dec 2015 09:08:49 -0500 Received: from int-mx13.intmail.prod.int.phx2.redhat.com (int-mx13.intmail.prod.int.phx2.redhat.com [10.5.11.26]) by mx1.redhat.com (Postfix) with ESMTPS id F14E68CF6F for ; Thu, 10 Dec 2015 14:08:48 +0000 (UTC) From: Laszlo Ersek Message-ID: <5669876E.1040102@redhat.com> Date: Thu, 10 Dec 2015 15:08:46 +0100 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Subject: [Qemu-devel] setting fadt->century List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Michael Tsirkin , Igor Mammedov Cc: Paolo Bonzini , qemu devel list Hi, an edk2-devel discussion made me look at how QEMU builds the FADT, in particular the "century" field. The RTC CMOS RAM index to the century of data value (hundred and thousand year decimals). If this field contains a zero, then the RTC centenary feature is not supported. If this field has a non-zero value, then this field contains an index into RTC RAM space that OSPM can use to program the centenary field. Since the i440fx and Q35 machine types of the i386/x86_64 targets always include the RTC device -- rtc_init() --, and said RTC device supports the "centenary feature" -- see RTC_CENTURY in "hw/timer/mc146818rtc.c" --, I think the fadt_setup() function should set fadt->century to RTC_CENTURY. Do you guys agree? If so, should 2.5 and earlier machine types be shielded from this change? Currently the field is left at zero: [06Ch 0108 1] RTC Century Index : 00 which -- according to analysis done by Ruiyu Ni at Intel -- should cause Linux and Windows 8+ to think the RTC centenary feature is unavailable, and cause Windows 7 to (incorrectly) assume that the offset to use is 0x32. (Which happens to be the right value, but Windows 7 is wrong to assume anything at all). Fixing this would inform Linux and Windows 8+ about the right capabilities of the hardware, plus retrofit the FADT to Windows 7's behavior. Thanks, Laszlo