2006-04-26 19:54:57 +02:00
|
|
|
|
Intel(R) Platform Innovation Framework for EFI
|
2006-07-06 12:42:42 +02:00
|
|
|
|
EFI Development Kit II (EDK II)
|
|
|
|
|
Root Package 1.00
|
2006-07-18 18:31:13 +02:00
|
|
|
|
2006-07-18
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Intel is a trademark or registered trademark of Intel Corporation or its
|
|
|
|
|
subsidiaries in the United States and other countries.
|
|
|
|
|
* Other names and brands may be claimed as the property of others.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Copyright (c) 2006, Intel Corporation
|
|
|
|
|
|
|
|
|
|
This document provides updates to documentation, along with a description on
|
2006-07-06 12:42:42 +02:00
|
|
|
|
how to install and build the EDK II.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Package Contents
|
|
|
|
|
----------------
|
|
|
|
|
ReleaseNote.txt- These release notes for the package.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
MdePkg - Industry-standard headers and libraries
|
|
|
|
|
Tools - Build -specific tools that are designed to help the
|
|
|
|
|
developer create and modify drivers and libraries
|
|
|
|
|
EdkModulePkg - Reference drivers
|
|
|
|
|
EdkFatBinPkg - Binary DXE drivers for the Fat 32 file system
|
|
|
|
|
EdkShellBinPkg - Binary Shell applications and commands
|
|
|
|
|
EdkNt32Pkg - NT32 Emulation platform reference
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Note: MDE and MDK that appear in other documentation refer to the MdePkg and
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Tools packages, respectively. While, these two packages are the minimum
|
|
|
|
|
requirement for developing EDK II Packageswe recommend that you download all
|
|
|
|
|
of the top-level files listed above.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
The following package is available as a separate project, under a separate
|
|
|
|
|
license, on the TianoCore.org website: https://fat-driver2.tianocore.org
|
2006-07-13 03:45:03 +02:00
|
|
|
|
|
|
|
|
|
EdkFatPkg - A package containing source DXE drivers for the Fat 32 file
|
|
|
|
|
system
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Documents have the following filenames (to download these documents, see <20>Notes
|
|
|
|
|
on Documentation<6F> later in these Release Notes):
|
|
|
|
|
EDK II Module Development Environment Library Specification, v0.58
|
|
|
|
|
(MDE_Library_Spec_0_58.rtf)
|
|
|
|
|
EDK II Build and Packaging Architecture Specification, v0.53
|
|
|
|
|
(Build_Packaging_Spec_0_53.rtf)
|
|
|
|
|
EDK II Platform Configuration Database Infrastructure Description, v0.54
|
|
|
|
|
(PCD_Infrastructure_0_54.rtf)
|
|
|
|
|
EDK II Module Surface Area Specification, v0.51
|
2006-04-26 19:54:57 +02:00
|
|
|
|
(Module_Surface_Area_0_50.rtf)
|
2006-07-13 20:37:28 +02:00
|
|
|
|
EDK II Module Development Environment Package Specification, v0.51
|
|
|
|
|
(MDE_Package_Spec_0_51.rtf)
|
|
|
|
|
EDK II C Coding Standards Specification v0.51
|
|
|
|
|
(C_Coding_Standards_Specification_ 0_51.rtf)
|
2006-07-12 22:39:54 +02:00
|
|
|
|
EDK II Subversion Setup Guide
|
|
|
|
|
(edk2-subversion-setup.rtf)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Pre-Requisites
|
|
|
|
|
--------------
|
|
|
|
|
The following list of tools must be installed on the development workstation
|
2006-07-13 20:37:28 +02:00
|
|
|
|
prior to using the EDK II.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Compiler Tool Chain
|
|
|
|
|
Microsoft* Visual Studio .NET 2003* (http://www.microsoft.com)
|
|
|
|
|
or
|
2006-06-07 02:21:44 +02:00
|
|
|
|
A special GCC version 4.x or later (http://gcc.gnu.org). See below.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Assembler Tool Chain
|
|
|
|
|
Microsoft Macro Assembler, version 6.15 or later
|
|
|
|
|
or
|
2006-05-04 00:45:39 +02:00
|
|
|
|
GNU binutils 2.16.1 or later
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Java Development Kit ( Java 5.0 or later)
|
2006-07-13 14:13:23 +02:00
|
|
|
|
Sun* jdk-1.5.0_06 or later (http://java.sun.com)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
or
|
|
|
|
|
Bea Systems* jrockit-25.2.0-jdk1.5.0_03 or later (http://www.bea.com)
|
|
|
|
|
|
|
|
|
|
Java Tools
|
|
|
|
|
Apache-ANT, version 1.6.5 or later (http://ant.apache.org)
|
2006-05-03 20:10:56 +02:00
|
|
|
|
Ant-contrib, version 1.0b2 or later
|
2006-07-07 11:38:58 +02:00
|
|
|
|
(http://prdownloads.sourceforge.net/ant-contrib/ant-contrib-1.0b2-bin.zip?download)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Saxon8, version 8.1.1
|
|
|
|
|
(http://prdownloads.sourceforge.net/saxon/saxonb8-1-1.zip?download)
|
2006-07-07 11:38:58 +02:00
|
|
|
|
XMLBeans, version 2.1.0 (http://xmlbeans.apache.org)
|
2006-07-13 20:37:28 +02:00
|
|
|
|
DO NOT download the latest XMLBeans, version 2.2.0. It is not compatible
|
|
|
|
|
with Saxon8, version 8.1.1.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Other Tools
|
|
|
|
|
TortoiseSVN version 1.3.3. (http://tortoisesvn.tigris.org/)
|
|
|
|
|
|
|
|
|
|
Optional Tools
|
|
|
|
|
--------------
|
|
|
|
|
Compiler Tool Chains:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Intel(R) C++ Compiler for Windows*, ver. 9.0 or later (http://www.intel.com)
|
|
|
|
|
Intel(R) C Compiler for EFI Byte Code, ver. 1.2 or later
|
2006-05-04 00:45:39 +02:00
|
|
|
|
(http://www.intel.com/cd/software/products/asmo-na/eng/compilers/efibc/index.htm)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Microsoft Driver Development Kit, version 3790.1830 or later
|
2006-05-04 00:45:39 +02:00
|
|
|
|
(http://www.microsoft.com/whdc/devtools/ddk/orderddkcd.mspx)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Microsoft ACPI Source Language Assembler, Version 1.0.13NT or later
|
|
|
|
|
Intel ACPI Component Architecture, version 20060113
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-----------------------------------------------
|
|
|
|
|
Notes on Required Tools (Source Control System)
|
|
|
|
|
-----------------------------------------------
|
2006-07-05 22:41:25 +02:00
|
|
|
|
The EDK II is being managed by the Subversion Source Control on Tianocore.org.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Subversion provides speed, security, and additional features. The
|
2006-04-26 19:54:57 +02:00
|
|
|
|
recommended client is TortoiseSVN version 1.3.3.
|
|
|
|
|
(Available at http://tortoisesvn.tigris.org/)
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
The checkout procedures on the Tianocore.org Web site include
|
|
|
|
|
instructions for the use of Subversion Source Control.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-05 22:41:25 +02:00
|
|
|
|
The URL of the EDK II repository is:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
https://edk2.tianocore.org/svn/edk2/trunk/edk2
|
|
|
|
|
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
--------------------------------------------------------------------
|
|
|
|
|
Notes On Required Tools (With examples for Windows, OS X, and Linux*)
|
|
|
|
|
--------------------------------------------------------------------
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Software Installation Order:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
After installing the compiler tools and your Subversion client, install the
|
|
|
|
|
following required tools in this order:
|
|
|
|
|
1. Java JDK
|
|
|
|
|
2. Apache-Ant
|
|
|
|
|
3. ant-contrib
|
|
|
|
|
4. xmlbeans
|
|
|
|
|
5. saxon8
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Java Development Kit:
|
|
|
|
|
|
|
|
|
|
The Java Environment Variable must be set before attempting to build.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
For Sun JDK (see note below<6F>):
|
2006-07-08 01:39:10 +02:00
|
|
|
|
set JAVA_HOME=c:\Java\jdk1.5.0_06 (Windows example)
|
|
|
|
|
export JAVA_HOME=/Library/Java/Home/ (OS X example)
|
|
|
|
|
export JAVA_HOME=/usr/lib/j2sdk1.5-sun/ (Linux example)
|
|
|
|
|
For Bea Systems:
|
2006-07-07 11:38:58 +02:00
|
|
|
|
set JAVA_HOME=c:\Java\jrockit-R26.0.0-jdk1.5.0_04
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
<20> When using the Sun JDK5.0:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
During installation, you should specify the install directory as C:\Java
|
|
|
|
|
instead of C:\Program Files\(or some other drive letter.) While installing
|
2006-07-13 20:37:28 +02:00
|
|
|
|
to this non-standard location is not required, in practice, it seems to work
|
2006-04-26 19:54:57 +02:00
|
|
|
|
more reliably.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
For the JDK, the install path is C:\Java\jdk1.5.0_06
|
|
|
|
|
For the JRE, the install path is C:\Java\jre1.5.0_06
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Alternatively, you can specify C:\sunjavajdk and C:\sunjavajre.
|
2006-04-27 17:09:06 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
NOTE: You cannot combine the location for the JDK and the JRE, because the
|
|
|
|
|
JRE install removes most of the binaries and libraries installed by the JDK
|
2006-04-26 19:54:57 +02:00
|
|
|
|
install.
|
|
|
|
|
|
|
|
|
|
Java Tools:
|
|
|
|
|
The Apache-ANT requires the ANT_HOME environment variable to be set before
|
|
|
|
|
attempting to build:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
set ANT_HOME=c:\<full path to where ant was installed>
|
2006-07-08 01:39:10 +02:00
|
|
|
|
export ANT_HOME=~/ExternalTools/apache-ant (OS X and Linux example)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
The ant-contrib.jar file should be installed in the %ANT_HOME%\lib
|
|
|
|
|
directory.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
XMLBeans, requires the XMLBEANS_HOME environment variable to be set
|
2006-04-26 19:54:57 +02:00
|
|
|
|
before attempting to build:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
set XMLBEANS_HOME=C:\<full path to where xmlbeans was installed>
|
2006-07-08 01:39:10 +02:00
|
|
|
|
export XMLBEANS_HOME=~/ExternalTools/xmlbeans (OS X and Linux example)
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Copy the saxon8.jar file to the %XMLBEANS_HOME%\lib directory.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
The Ant and XMLBean tools must be in the path.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
MS system example:
|
|
|
|
|
set PATH=%PATH%;%ANT_HOME%\bin;%XMLBEANS_HOME%\bin
|
|
|
|
|
Linux/OS X bash shell example:
|
|
|
|
|
export PATH=$PATH:${ANT_HOME}/bin:${XMLBEANS_HOME}/bin
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
|
|
|
|
--------------------
|
|
|
|
|
A Word on Apache-ANT
|
|
|
|
|
--------------------
|
|
|
|
|
The Apache-ANT program is a build tool that uses XML-based project files.
|
|
|
|
|
Similar to Makefiles, these project files may contain multiple targets. Most
|
|
|
|
|
build.xml files in EDK II are auto-generated; any edits performed on the
|
2006-07-13 20:37:28 +02:00
|
|
|
|
build.xml files will be overwritten by the next build.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
|
|
|
|
Pre-defined targets in the build.xml file include:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
all - This target builds binaries for defined architectures.
|
|
|
|
|
clean - This target removes object files generated by commands.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
cleanall - This target removes all generated files and directories.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
----------------------------
|
|
|
|
|
A Word on the GCC Tool Chain
|
|
|
|
|
----------------------------
|
2006-07-12 22:39:54 +02:00
|
|
|
|
EDK II will not compile with a standard Linux gcc tool chain. While Linux
|
|
|
|
|
distributions are usually based on ELF, EDK II requires a version of gcc
|
|
|
|
|
that is configured to produce PE-COFF images. You will find a script in
|
|
|
|
|
edk2/Tools/gcc that will download, configure, compile, and install a gcc
|
2006-07-13 20:37:28 +02:00
|
|
|
|
4.X cross-compile tool chain for EDK II development. This custom tool chain
|
|
|
|
|
supports the IA-32 architecture. It can be built and run on Cygwin, Linux, and
|
|
|
|
|
many other POSIX-compliant host operating environments. To compile the custom
|
|
|
|
|
gcc tool chain, you need the following tools on your host computer: bash, gcc,
|
|
|
|
|
gmake, curl (or wget).
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
2006-07-26 00:08:33 +02:00
|
|
|
|
Only the MdePkg and EdkModulePkg are currently supported by gcc builds. Other
|
|
|
|
|
builds, such as the EdkNt32Pkg, will not compile with gcc.
|
|
|
|
|
|
|
|
|
|
----------------------------
|
|
|
|
|
A Word on compiling on Linux
|
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
|
|
In order to compile on Linux, you will need to have the e2fsprogs-dev package
|
|
|
|
|
installed. Check your distribution for the rpm, deb or other package format.
|
|
|
|
|
This package contains the uuid library and header that are used by some of the
|
|
|
|
|
host tools.
|
|
|
|
|
|
|
|
|
|
If you are running on x86_64 Linux, then you should install a 64 bit version of
|
|
|
|
|
the Java JDK. The version that was used was jdk-1_5_0_07-linux-amd64-rpm.bin.
|
|
|
|
|
It may be downloaded from sun.com.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
2006-07-26 20:31:53 +02:00
|
|
|
|
-----------------------------------------
|
|
|
|
|
A Word on compiling under Cygwin with gcc
|
|
|
|
|
-----------------------------------------
|
|
|
|
|
|
|
|
|
|
Cygwin is a POSIX style operating environment for Windows. It is possible to
|
|
|
|
|
compile the EDK 2 using gcc and cygwin. There are a few extra steps necessary
|
|
|
|
|
to make this happen. There is a JNI (Java Native Interface) library in the
|
|
|
|
|
Tools. In order to compile this under Cygwin, the 'linux' java headers must be
|
|
|
|
|
installed to the $JAVA_HOME dir on the windows system. To accomplish this, you
|
|
|
|
|
must install the JDK on a linux system, and then copy
|
|
|
|
|
linux:$JAVA_HOME/include/linux/ to windows:$JAVA_HOME/include. These are really
|
|
|
|
|
typedefs needed by gcc.
|
|
|
|
|
|
|
|
|
|
Compiling under cygwin is slow, because the underlying file accesses are slow
|
|
|
|
|
in cygwin. For this reason, we do not encourage the use of cygwin. A true unix
|
|
|
|
|
system will be a superior choice for those wishing to compile with gcc.
|
|
|
|
|
|
|
|
|
|
Make sure that you select the e2fsprogs development package when you install
|
|
|
|
|
cygwin. It is necessary for the GenFvImage tool.
|
|
|
|
|
|
2006-07-12 22:39:54 +02:00
|
|
|
|
-----------------------
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Notes on Documentation
|
2006-07-12 22:39:54 +02:00
|
|
|
|
-----------------------
|
|
|
|
|
The documents are being managed by the Subversion Source Control on
|
|
|
|
|
Tianocore.org. The document repository is "docs" and must be checked out
|
|
|
|
|
separately from the EDK II source tree. Refer to the checkout procedures on
|
2006-07-13 20:37:28 +02:00
|
|
|
|
the Tianocore.org Web site for EDK II.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
|
|
|
|
The URL of the document repository is:
|
|
|
|
|
https://edk2.tianocore.org/svn/edk2/trunk/docs
|
|
|
|
|
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
-------------------------------------------------------------------------------
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Quick Start
|
2006-07-06 16:13:56 +02:00
|
|
|
|
-----------
|
2006-07-13 20:37:28 +02:00
|
|
|
|
(assumes Microsoft Tools and OS environment, for GCC Tools or Linux, see
|
2006-07-12 22:39:54 +02:00
|
|
|
|
"Detailed Starting Instructions" below)
|
|
|
|
|
|
|
|
|
|
Follow the instructions at https://edk2.tianocore.org/servlets/ProjectSource to
|
2006-07-13 20:37:28 +02:00
|
|
|
|
check out the entire EDK II source tree.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
In a command window, change to the top-level directory of the EDK II source.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
To test your tool chain setup and to build the supplied tools, execute:
|
2006-07-12 22:39:54 +02:00
|
|
|
|
c:\MyWork\edkii\> edksetup ForceBuild
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
(The edksetup script is referred to as the setup command throughout the
|
2006-07-12 22:39:54 +02:00
|
|
|
|
rest of this document.)
|
|
|
|
|
NOTE: You should run the setup command at the start of every session.
|
|
|
|
|
This configures the environment to include the TianoTools and the
|
|
|
|
|
Java applications and libraries.
|
|
|
|
|
|
|
|
|
|
You will need to set the WORKSPACE environment variable, or run the edksetup
|
2006-07-13 20:37:28 +02:00
|
|
|
|
script (without any arguments), any time you want to build.
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
|
|
|
|
Set the WORKSPACE environment variable, e.g.:
|
|
|
|
|
|
|
|
|
|
c:\> set WORKSPACE=C:\MyWork\edkii
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
You may need to edit the text files Tools/Conf/target.txt and
|
|
|
|
|
Tools/Conf/tools_def.txt (created by edksetup) using your favorite
|
2006-07-12 22:39:54 +02:00
|
|
|
|
text editor to ensure that the paths to the tools you want to use
|
|
|
|
|
to build EDK II binaries are correct. These files contain the default
|
|
|
|
|
paths (as per the default installation of the tools), so a customized
|
|
|
|
|
install may require this manual process.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Once this is completed, you are ready to test the build, by executing:
|
2006-07-12 22:39:54 +02:00
|
|
|
|
c:\MyWork\edkii\> build
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
This command builds the active platform specified in text file target.txt. If
|
|
|
|
|
the active platform is not specified target.txt, you must execute the build
|
|
|
|
|
command from the sub-directory that contains FPD files. For more information
|
|
|
|
|
about the active platform policy, see the <20>EDK II Build and Packaging
|
|
|
|
|
Architecture Specification.<2E>
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
|
|
|
|
-------------------------------------------------------------------------------
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Detailed Starting Instructions
|
|
|
|
|
------------------------------
|
2006-07-12 22:39:54 +02:00
|
|
|
|
|
2006-04-26 19:54:57 +02:00
|
|
|
|
Follow the instructions at https://edk2.tianocore.org/servlets/ProjectSource to
|
2006-07-13 20:37:28 +02:00
|
|
|
|
check out the entire EDK II source tree.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
In a command window, change to the top-level directory of the EDK II source.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-12 08:40:42 +02:00
|
|
|
|
If the active compiler tool chain is GCC, you must set the
|
|
|
|
|
environment variable, TOOL_CHAIN to "gcc" before running the
|
|
|
|
|
edksetup script. Example: export TOOL_CHAIN=gcc
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
To test your tool chain setup and to build the supplied tools, execute:
|
2006-07-12 08:40:42 +02:00
|
|
|
|
c:\MyWork\edkii\> edksetup ForceBuild
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
On Linux systems, you must source the edksetup.sh file to load the correct
|
2006-07-08 01:39:10 +02:00
|
|
|
|
settings into your shell.
|
|
|
|
|
|
|
|
|
|
. edksetup.sh # Note the dot.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
The edksetup script is referred to as the setup command throughout the
|
|
|
|
|
rest of this document.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
NOTE: You should run the setup command at the start of every session.
|
|
|
|
|
This configures the environment to include the TianoTools and the
|
|
|
|
|
Java applications and libraries.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Any changes to the tool source code or XML Schema documents require that
|
|
|
|
|
you execute the following:
|
2006-07-12 08:40:42 +02:00
|
|
|
|
c:\MyWork\edkii\> edksetup ForceBuild
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
You must set the WORKSPACE environment variable, or run the edksetup
|
|
|
|
|
script (without any arguments), any time you want to build.
|
2006-07-12 08:40:42 +02:00
|
|
|
|
|
|
|
|
|
Set the WORKSPACE environment variable, e.g.:
|
|
|
|
|
|
|
|
|
|
c:\> set WORKSPACE=C:\MyWork\edkii
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
You may need to edit the text files Tools/Conf/target.txt and
|
|
|
|
|
Tools/Conf/tools_def.txt (created by edksetup) using your favorite
|
2006-07-12 22:39:54 +02:00
|
|
|
|
text editor to ensure that the paths to the tools you want to use
|
|
|
|
|
to build EDK II binaries are correct. These files contain the default
|
|
|
|
|
paths (as per the default installation of the tools), so a customized
|
|
|
|
|
tool installation may require this manual process.
|
2006-07-06 16:13:56 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Once this is completed, you are ready to test the build, by executing:
|
2006-07-12 08:40:42 +02:00
|
|
|
|
c:\MyWork\edkii\> build
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
This command builds the active platform specified in text file target.txt. If
|
|
|
|
|
the active platform is not specified, go to the sub-directory that contains FPD
|
|
|
|
|
files and execute the build command. For more information about the active
|
|
|
|
|
platform policy, see the <20>EDK II Build and Packaging Architecture
|
|
|
|
|
Specification.<2E>
|
2006-06-23 01:19:41 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
--------------------------
|
2006-07-06 09:22:25 +02:00
|
|
|
|
Individual Platform Builds
|
2006-07-13 20:37:28 +02:00
|
|
|
|
--------------------------
|
2006-07-06 09:22:25 +02:00
|
|
|
|
After running the setup command, you can build individual platforms.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
In the command window:
|
|
|
|
|
Set the active platform in target.txt, and execute this command:
|
|
|
|
|
c:\<directory>\> build
|
|
|
|
|
or
|
|
|
|
|
cd to the platform (FPD file) that you want to build and execute this command:
|
2006-07-12 08:40:42 +02:00
|
|
|
|
c:\MyWork\edkii\EdkNt32Pkg\> build
|
2006-07-06 09:22:25 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Note that the active platform specified in target.txt overrides the platform
|
|
|
|
|
specified by any FPD file in the current directory. For more information
|
|
|
|
|
about active platform policy, see the <20>EDK II Build and Packaging Architecture
|
|
|
|
|
Specification.<2E>
|
|
|
|
|
|
2006-07-14 08:46:15 +02:00
|
|
|
|
To run the Nt32 emulation platform under Microsoft Windows, go to
|
|
|
|
|
<full build path>\DEBUG\MSFT\IA32 and execute SecMain.exe
|
2006-07-13 20:37:28 +02:00
|
|
|
|
|
|
|
|
|
To exit the Nt32 emulation platform, type <20>reset<65> at the EFI Shell>
|
|
|
|
|
command prompt. Alternatively, from the graphical interface, select the Boot
|
|
|
|
|
Maintenance Manager's <20>Reset System<65> command.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-18 18:31:13 +02:00
|
|
|
|
NOTE: When creating a new platform, the Platform Name is restricted
|
|
|
|
|
to a single word containing alphanumeric characters, underscore, dash,
|
|
|
|
|
and period. The space character and other special characters are
|
|
|
|
|
not allowed.
|
2006-07-14 08:46:15 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-----------------------
|
|
|
|
|
Notes on Symbolic Debug
|
|
|
|
|
-----------------------
|
|
|
|
|
To enable EFI Symbolic Debugging, make sure the target output is set to DEBUG
|
|
|
|
|
in the text file Tools/Conf/target.txt and then modify the FPD <BuildOptions>
|
|
|
|
|
<Options><Option BuildTargets="DEBUG" ToolCode="CC"> and append the following
|
|
|
|
|
compiler options to the string:
|
|
|
|
|
"/D EFI_GENERATE_SYM_FILE", "/D EFI_SYMBOLIC_DEBUG"
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
(If the Option line does not contain "/D EFI_DEBUG", you must add that
|
|
|
|
|
option as well.)
|
2006-05-24 21:51:36 +02:00
|
|
|
|
|
2006-04-26 19:54:57 +02:00
|
|
|
|
------------------------
|
|
|
|
|
Individual Module Builds
|
|
|
|
|
------------------------
|
|
|
|
|
After running the setup command, you can build individual modules.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
In the command window, cd to the module that you want to build, and
|
|
|
|
|
execute the build command:
|
2006-07-12 08:40:42 +02:00
|
|
|
|
c:\MyWork\edkii\MdePkg\Library\BaseLib\> build
|
2006-07-06 09:22:25 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
You must set the active platform in target.txt for individual module builds.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
General Information:
|
|
|
|
|
===============================================================
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Mechanisms
|
2006-04-26 19:54:57 +02:00
|
|
|
|
----------
|
2006-05-04 00:45:39 +02:00
|
|
|
|
A brief overview:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
A) The Surface Area Package Description (SPD) file contains information about
|
|
|
|
|
the modules that the package contains, including the location of all MSA files,
|
|
|
|
|
and public library names and headers that might be provided by a module in the
|
2006-04-26 19:54:57 +02:00
|
|
|
|
package. Packages are defined by SPD files. (Found in the root of the Package
|
2006-07-13 20:37:28 +02:00
|
|
|
|
subdirectory (i.e. EdkNt32Pkg).) The SPD file is further explained in <20>EDK II
|
|
|
|
|
Build and Packaging Architecture Specification.<2E>
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
B) Module Surface Area Definition (MSA) files. A description of a module's
|
|
|
|
|
surface area, with all module specific default flags and features specified.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
For additional details, see the "EDK II Module Surface Area Specification" and
|
|
|
|
|
the "EDK II Build and Packaging Architecture Specification."
|
2006-07-06 16:13:56 +02:00
|
|
|
|
|
|
|
|
|
C) Framework Platform Description (FPD) files. A description of a platform's
|
|
|
|
|
surface are, including a list of modules that are needed by the platform. To
|
|
|
|
|
support individual module builds, developers are not required to provide
|
2006-07-13 20:37:28 +02:00
|
|
|
|
information about specific flash devices, nor flash device layout.
|
|
|
|
|
Specific sections in the FPD file control aspects of the build, such
|
2006-07-06 16:13:56 +02:00
|
|
|
|
as the Supported Architectures and Build Targets, as well as the tool flags
|
|
|
|
|
that are used to create the binary files. A valid platform file can specify
|
|
|
|
|
zero or more modules, so individual modules can be compiled within the context
|
|
|
|
|
of a platform (FPD) definition.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
D) Platform Configuration Database (PCD). A platform database that contains a
|
|
|
|
|
variety of current platform settings or directives that can be accessed by a
|
|
|
|
|
driver or application. The PCD is defined by the PCD_Protocol (This is
|
|
|
|
|
further explained in the "EDK II Platform Configuration Database Infrastructure
|
|
|
|
|
Description."
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-06 16:13:56 +02:00
|
|
|
|
E) Library Class. A library class is a logical grouping of similar functions.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
When developing components, the module surface area declares the class of
|
2006-07-06 16:13:56 +02:00
|
|
|
|
libraries that can be used by the component. The MSA and SPD files can specify
|
2006-07-13 20:37:28 +02:00
|
|
|
|
a recommended instance of the library that a platform integrator (PI) may
|
|
|
|
|
select, however this is only a recommendation. The PI may choose to select a
|
|
|
|
|
different library instance to be used during compilation and linking. All
|
|
|
|
|
library type modules must include header files in their distribution package,
|
|
|
|
|
as well as their MSA files. Components, on the other hand, need provide only an
|
|
|
|
|
MSA file and either source or binary files when distributing packages. The
|
|
|
|
|
Library Classes are further explained in the "EDK II Build and Packaging
|
|
|
|
|
Architecture Specification."
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
=========================================================================
|
|
|
|
|
The common operations by developers of new modules are:
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-----------------------------------------------
|
|
|
|
|
1) Manually creating a new module in a package:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- The module source code must first be created in an appropriate directory
|
|
|
|
|
(under the package the module is to be a part of.)
|
|
|
|
|
- An MSA file must be created, spelling out all aspects of the module.
|
|
|
|
|
- The MSA must be added to the SPD for the package to include the module.
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
2) Adding and Removing modules to and from a package:
|
|
|
|
|
|
|
|
|
|
- Set up environment as Build
|
|
|
|
|
- Adding a module to a package:
|
|
|
|
|
- Generate the MSA file
|
|
|
|
|
- Add a new <Filename> element under <MsaFiles> into
|
|
|
|
|
<PackageDir>\<PackageName>.spd, using arelative path to the package
|
|
|
|
|
- Add a new <ModuleSA> entry under each <FrameworkModules> into the
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<PackageDir>\<PackageName>.fpd file if necessary.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
- Removing a module from a package:
|
|
|
|
|
- Comment out or remove the corresponding <Filename> element under
|
|
|
|
|
<MsaFiles> from <PackageDir>\<PackageName>.spd
|
|
|
|
|
- Comment out or remove the corresponding <ModuleSA> entry under each
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<FrameworkModules> from <PackageDir>\<PackageName>.fpd if necessary.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-------------------------------
|
|
|
|
|
3) Manually creating a package:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- Identify the modules that are to be members of the project.
|
|
|
|
|
- Identify the Variables and Guids required in and of the Package (including
|
2006-07-13 20:37:28 +02:00
|
|
|
|
consumption and production information).
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- Create an SPD file defining these modules and calling out their MSA files.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
- Add a new <Filename> element under <PackageList> into
|
|
|
|
|
Tools\Conf\FrameworkDatabase.db, using the relative path to the workspace.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-----------------------------------------
|
|
|
|
|
4) Declaring a new Protocol in a package:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- This release requires manual editing of the SPD file, adding the protocol
|
|
|
|
|
to the ProtocolDeclarations section of the file.
|
|
|
|
|
- Add the Protocol .h file to the Include\Protocol directory.
|
2006-04-28 00:47:57 +02:00
|
|
|
|
- Add an <Entry> to the <ProtocolDeclarations> element in the
|
|
|
|
|
<PackageName>.spd file
|
2006-07-13 20:37:28 +02:00
|
|
|
|
- Each line contains Protocol base name, followed by the global variable
|
|
|
|
|
name, and the hex value of the Protocol GUID.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Example Protocol Entries (NOTE: The Guid entry is a single line in the SPD
|
|
|
|
|
file):
|
2006-04-28 00:47:57 +02:00
|
|
|
|
<ProtocolDeclarations>
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<Entry Name="Bds">
|
|
|
|
|
<C_Name>gEfiBdsArchProtocolGuid</C_Name>
|
|
|
|
|
<GuidValue>665E3FF6-46CC-11D4-9A38-0090273FC14D</GuidValue>
|
|
|
|
|
<HelpText/>
|
|
|
|
|
</Entry>
|
|
|
|
|
<Entry Name="Cpu">
|
|
|
|
|
<C_Name>gEfiCpuArchProtocolGuid</C_Name>
|
|
|
|
|
<GuidValue>26BACCB1-6F42-11D4-BCE7-0080C73C8881</GuidValue>
|
|
|
|
|
<HelpText/>
|
|
|
|
|
</Entry>
|
|
|
|
|
</ProtocolDeclarations>
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
------------------------------------
|
|
|
|
|
5) Declaring a new PPI in a package:
|
|
|
|
|
- This release requires manual editing of the SPD file
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- Add the PPI .h file to the Include\Ppi directory.
|
2006-04-28 00:47:57 +02:00
|
|
|
|
- Add an <Entry> to the package <PpiDeclarations> element in the
|
|
|
|
|
<PackageName>.spd file
|
2006-07-13 20:37:28 +02:00
|
|
|
|
- Each line contains the PPI base name, followed by the global variable
|
|
|
|
|
name and the hex value of the PPI GUID.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-04-28 00:47:57 +02:00
|
|
|
|
Example Ppi Entries (NOTE: The Guid entry is a single line in the SPD file):
|
|
|
|
|
<PpiDeclarations>
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<Entry Name="BootInRecoveryMode">
|
|
|
|
|
<C_Name>gEfiPeiBootInRecoveryModePpiGuid</C_Name>
|
|
|
|
|
<GuidValue>17EE496A-D8E4-4B9A-94D1-CE8272300850</GuidValue>
|
|
|
|
|
<HelpText/>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
</Entry>
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<Entry Name="CpuIo">
|
|
|
|
|
<C_Name>gEfiPeiCpuIoPpiInServiceTableGuid</C_Name>
|
|
|
|
|
<GuidValue>E6AF1F7B-FC3F-46DA-A828-A3B457A44282</GuidValue>
|
|
|
|
|
<HelpText/>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
</Entry>
|
|
|
|
|
</PpiDeclarations>
|
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
-------------------------------------
|
|
|
|
|
6) Declaring a new GUID in a package:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- This release requires manual editing of the SPD file to include the new
|
2006-04-28 00:47:57 +02:00
|
|
|
|
Guid. This is identical to adding a ProtocolDeclaration or PpiDeclaration
|
2006-07-13 20:37:28 +02:00
|
|
|
|
element, as described above.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
2006-07-13 20:37:28 +02:00
|
|
|
|
------------------------------------------
|
|
|
|
|
7) Declaring a new PCD entry in a package:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- This release requires manual editing of the SPD file to include the new
|
2006-04-28 00:47:57 +02:00
|
|
|
|
PCD. New Pcd entries are added to the PcdDefinitions section of the
|
2006-07-13 20:37:28 +02:00
|
|
|
|
<PackageName>.spd file using the following example for the format
|
|
|
|
|
(NOTE: The hex <Token> value must be unique):
|
2006-04-28 00:47:57 +02:00
|
|
|
|
|
2006-07-07 08:19:08 +02:00
|
|
|
|
<PcdDeclarations>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
<PcdEntry ItemType="FIXED_AT_BUILD">
|
|
|
|
|
<C_Name>PcdMaximumUnicodeStringLength</C_Name>
|
|
|
|
|
<Token>0x00000001</Token>
|
2006-07-07 08:19:08 +02:00
|
|
|
|
<TokenSpaceGuidCName>gEfiMdePkgTokenSpaceGuid</TokenSpaceGuidCName>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
<DatumType>UINT32</DatumType>
|
2006-07-07 08:19:08 +02:00
|
|
|
|
<ValidUsage>FIXED_AT_BUILD</ValidUsage>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
<DefaultValue>1000000</DefaultValue>
|
2006-07-07 08:19:08 +02:00
|
|
|
|
<HelpText>The maximum lengh for unicode string.</HelpText>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
</PcdEntry>
|
2006-07-07 08:19:08 +02:00
|
|
|
|
</PcdDeclarations>
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
------------------------------
|
2006-07-13 20:37:28 +02:00
|
|
|
|
8) Declaring a new Library Class:
|
2006-04-26 19:54:57 +02:00
|
|
|
|
- This release requires manual editing of the SPD file to include the new
|
2006-04-28 00:47:57 +02:00
|
|
|
|
Library Class. New Library Class entries are added to the
|
2006-07-13 20:37:28 +02:00
|
|
|
|
LibraryClassDeclarations section of the <PackageName>.spd file using
|
2006-04-28 00:47:57 +02:00
|
|
|
|
the following example for the format:
|
|
|
|
|
|
|
|
|
|
<LibraryClassDeclarations>
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<LibraryClass Name="BaseLib">
|
2006-04-28 00:47:57 +02:00
|
|
|
|
<IncludeHeader>Include/Library/BaseLib.h</IncludeHeader>
|
2006-07-06 09:22:25 +02:00
|
|
|
|
<HelpText/>
|
|
|
|
|
</LibraryClass>
|
|
|
|
|
<LibraryClass Name="BaseMemoryLib">
|
|
|
|
|
<IncludeHeader>Include/Library/BaseMemoryLib.h</IncludeHeader>
|
|
|
|
|
<HelpText/>
|
|
|
|
|
</LibraryClass>
|
2006-04-28 00:47:57 +02:00
|
|
|
|
</LibraryClassDeclarations>
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
=======================================================
|
2006-07-13 20:37:28 +02:00
|
|
|
|
EDK II Changes Relative to the original EDK:
|
|
|
|
|
--------------------------------------------
|
2006-07-05 22:41:25 +02:00
|
|
|
|
The EDK II represents significant changes in the structure of the EDK.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
Therefore, it is very difficult to isolate all of the changes of this version of
|
|
|
|
|
the EDK with the original EDK.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
Of particular note:
|
|
|
|
|
|
2006-07-05 22:41:25 +02:00
|
|
|
|
1) EDK II contains new hardware feature support for the ICH SMBUS Libraries.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
These libraries are provided to make Memory Reference Code (MRC) development
|
|
|
|
|
easier.
|
2006-07-13 20:37:28 +02:00
|
|
|
|
2) The MDE libraries represent significant changes in source
|
2006-04-26 19:54:57 +02:00
|
|
|
|
(with only limited changes in functionality.) These new libraries conform
|
2006-07-13 20:37:28 +02:00
|
|
|
|
to the "EDK II Module Development Environment Library Specification.<2E>
|
2006-04-26 19:54:57 +02:00
|
|
|
|
3) The Fat Binary and the EDK Shell Binary Packages are functionally identical
|
2006-07-13 20:37:28 +02:00
|
|
|
|
to the original EDK.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
4) The EDK tools directory has been expanded to include more tools and more
|
|
|
|
|
tool functionality.
|
|
|
|
|
5) The EDK NT32 section has been ported to the new build process, but
|
2006-07-13 20:37:28 +02:00
|
|
|
|
functionally remains the same as the original EDK.
|
2006-07-05 22:41:25 +02:00
|
|
|
|
6) The Application "HelloWorld" has been ported to EDK II as well.
|
2006-04-26 19:54:57 +02:00
|
|
|
|
|
|
|
|
|
=======================================================
|
|
|
|
|
Virus scanned by McAfee VirusScan Enterprise 8.0.0, Virus Definitions 4718, no
|
|
|
|
|
virus detected.
|
|
|
|
|
|