The present application is the national phase of International Patent Application No. PCT/CN2017/093686 filed on Jul. 20, 2017, which claims priority to Chinese Patent Application No. 201610645910.4, titled “METHOD FOR INTEL PLATFORM DETECTION OF PARAMETERS IN FLASH ROM”, filed on Aug. 9, 2016 with the Chinese Patent Office, both of which are incorporated herein by reference in their entireties.
The present disclosure relates to the technical field of servers, and in particular, to a method for acquiring a parameter in a Flash Rom in an Intel platform.
In design of a PC and a server, a BIOS program is generally stored in a Flash Rom, and many parameters in the Flash Rom are required in a source code. At present, normally a specification provided by a ROM manufacturer is used to retrieve the required parameters to be added into programs. An error of the parameters may cause a crash of a system in a post process, or cause a probability of crash. But generally it is difficult to discover a problem caused by incorrect configuration of the FLASH ROM parameters. In order to facilitate check on the parameters of the Flash Rom, it is necessary to design a method to read these parameters. Detailed parameters of the Flash Rom are stored in a SFDP Table thereof, and any required parameters can be found in the SFDP Table.
It is not required to access the SFDP table for just reading an ID or a size of the Flash Rom. But the detailed parameters in the Flash Rom and supported functions thereof can be acquired only by reading the SFDP Table. An Intel platform has some restrictions on accessing the Flash Rom, that is, any accessing commands can only be used after being stored in an OPMENU register and an OPTYPE register. For example, a command to read the SFDP table is 0x5A. In a case that this command is not in the OPMEUN register, the SFDP cannot be read. In fact, 0x5A is not in the OPMENU register by default, and the two registers are locked at a PEI stage. Therefore, the SFDP table cannot be read after the system is started.
In view of development requirement and deficiency of conventional technology, a method for acquiring a parameter in a Flash Rom in an Intel platform or an ARM platform is provided according to the present disclosure.
The method for acquiring a parameter in a Flash Rom in an Intel platform according to the present disclosure addresses the above technical issue by adopting the following technical solution. Main steps of the technical solution includes: 1) saving, at a PEI stage in booting and before an OPMENU register and an OPTYPE registers are locked, values of the OPMENU register and the OPTYPE register; 2) filling a command 0x5A for reading a SFDP table into the OPMENU register and the OPTYPE register; 3) storing data of the SFDP table in a built HOB; 4) storing, at a DXE stage, data in the HOB into an applied EfiACPIMemoryNVS memory; and 5) reading, by calling a driver in a system, the data from the EfiACPIMemoryNVS memory.
Preferably, after storing the data of the SFDP table in the built HOB, the values of the OPMENU register and the OPTYPE register are restored, and the OPMENU register and the OPTYPE register are locked.
Preferably, a software program and the driver are written at an OS side, and the driver is called to acquire the data of the SFDP table at an application layer.
In comparison with the conventional technology, the method for acquiring a parameter in a Flash Rom in an Intel platform according to the present disclosure has following beneficial effects. According to the present disclosure, the data in the SFDP table is stored in the HOB (hand off block) before the OPMENU register and the OPTYPE register are locked at the PEI stage, and then the data is stored in the EfiACPIMemoryNVS type of memory in the DXE stage. The data can be acquired at the application layer by calling the driver. Therefore, it is convenient to acquire the parameters in the Flash Rom, so as to check whether the parameters are consistent with parameters filled in the program. Therefore, product functions can be increased, an occurrence rate of bugs is reduced, and product stability is improved. All kinds of servers or memories can implement the method by cooperation between upper-layer software codes of a BIOS and an OS, without adding any hardware circuitry.
In order to make objectives, technical solutions and advantages of the present disclosure more clear, hereinafter a method for acquiring a parameter in a Flash Rom in an Intel platform according to the present disclosure is further described in details in conjunction with specific embodiments.
In order to facilitate acquiring various parameters in a Flash Rom, a method for acquiring a parameter in the Flash Rom in an Intel platform is provided according to the present disclosure. The method is implemented by some bios codes. Data in a SFDP table is stored in a HOB (hand off block) before the OPMENU register and the OPTYPE register are locked, and the data is stored in an EfiACPIMemoryNVS type of memory at a DXE stage, so that the data can be acquired at an application layer by calling a driver in a system.
When a system is powered on, the UEFI BIOS boot process roughly includes stages of SEC, PEI, DXE, and BDS. The method for acquiring a parameter in a Flash Rom in an Intel platform described according to the embodiment mainly includes the following steps. In step 1), values of the OPMENU register and the OPTYPE register are saved, before the OPMENU register and the OPTYPE register are locked at the PEI stage in system booting. In step 2), a command 0x5A for reading a SFDP table is filled into the OPMENU register and the OPTYPE register. In step 3), data of the SFDP table is stored into the built HOB. In step 4), the data in the HOB is stored into an applied EfiACPIMemoryNVS memory at the DXE stage, and 5) the data is read from the EfiACPIMemoryNVS memory by calling the driver in the system, so as to check whether the data is consistent with parameters filled in a program.
In step 1, values of the OPMENU register and the OPTYPE register are saved, before the OPMENU register and the OPTYPE register are locked at the PEI stage in booting.
In step 2, the command 0x5A for reading the SFDP table is filled into the OPMENU register and the OPTYPE register.
In step 3, the data of the SFDP table is stored into the built HOB.
In step 4, the values of the OPMENU register and the OPTYPE register are restored, and the OPMENU register and the OPTYPE register are locked.
In step 5, the data in the HOB is stored into the applied EfiACPIMemoryNVS memory at the DXE stage.
In step 6, a software program and a driver are written at an OS side, to read the data of the SFDP table from the EfiACPIMemoryNVS memory.
At the PEI stage after the system is powered on, the OPMENU register and the OPTYPE register of the PCH (namely, a South Bridge) are filled with default values, and the values in the two registers are saved before the registers are locked. Then, the command 0x5A for reading the SFDP table is filled into the OPMENU register and the OPTYPE register. After reading the data of the SFDP table, the data is stored into the built HOB. Then, previous values the OPMENU register and the OPTYPE register are restored. In a subsequent BIOS program, the OPMENU register and the OPTYPE register are locked, so as to prevent a following BIOS program and an OS program from changing the two registers. Finally, the data in the HOB (SFDP table data) is stored in the EfiACPIMemoryNVS type of memory at the DXE stage. Thereby, the data can be acquired at the application layer by calling the driver in the system, so as to check whether the data is consistent with the parameters filled in the program.
The aforementioned specific embodiments are only specific examples of the present disclosure, and the scope of the patent protection of the present disclosure includes, but is not limited to, the aforementioned specific embodiments. What conforms to claims of the present disclosure, or appropriate modification or replacement thereof made by those skilled in the art, should all fall within the scope of the patent protection of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
2016 1 0645910 | Aug 2016 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2017/093686 | 7/20/2017 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2018/028410 | 2/15/2018 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
9778936 | Righi | Oct 2017 | B1 |
10360115 | Tanaka | Jul 2019 | B2 |
20040158828 | Zimmer | Aug 2004 | A1 |
20040243534 | Culter | Dec 2004 | A1 |
20050210222 | Liu | Sep 2005 | A1 |
20060212693 | Cho | Sep 2006 | A1 |
20070055856 | Zimmer | Mar 2007 | A1 |
20080082735 | Shiga | Apr 2008 | A1 |
20080155247 | Zimmer | Jun 2008 | A1 |
20100042821 | Harmer | Feb 2010 | A1 |
20130290778 | Soderlund | Oct 2013 | A1 |
20140052403 | Tang | Feb 2014 | A1 |
20180341497 | Perez Guevara | Nov 2018 | A1 |
Number | Date | Country |
---|---|---|
1776619 | May 2006 | CN |
103150208 | Jun 2013 | CN |
105512571 | Apr 2016 | CN |
105589716 | May 2016 | CN |
106293620 | Jan 2017 | CN |
Entry |
---|
International Search Report for PCT/CN2017/093686 dated Oct. 18, 2017, ISA/CN. |
Number | Date | Country | |
---|---|---|---|
20190095219 A1 | Mar 2019 | US |