lhauch | 53ca26a | 2007-06-20 19:44:27 +0000 | [diff] [blame] | 1 | This directory contains the next generation of EDK II build tools and template files.
|
| 2 | Templates are located in the Conf directory, while the tools executables for
|
| 3 | Microsoft Windows 32-bit Operating Systems are located in the Bin\Win32 directory.
|
| 4 |
|
| 5 | The binary tools will be updated only after passing developer testing.
|
| 6 |
|
| 7 | The BaseTools package will be updated with new tools only after all testing on a set
|
| 8 | of binary tools has successfully completed.
|
| 9 |
|
| 10 | Current state of the tools is Proto-Type - not all tool functions have been implemented
|
| 11 | and there may be bugs in these tools. These tools are under constant development at
|
| 12 | this time.
|
| 13 |
|
jwang36 | c7f7ef1 | 2007-06-25 17:19:31 +0000 | [diff] [blame] | 14 | BaseTools Simple Usage:
|
| 15 | 1) Change the directory to the EDK2 root directory, where the edksetup.bat is
|
| 16 | 2) Run "edksetup.bat NewBuild"
|
| 17 | 3) Set the ACTIVE_PLATFORM to your desired platform description file
|
| 18 | (%WORKSPACE%\Conf\target.txt)
|
| 19 | 4) To build platform, run "build" command in non-module directory
|
| 20 | 5) To build module individually, run "build" command in module directory, i.e. where the
|
| 21 | *.inf file is
|
| 22 |
|
| 23 | Notes:
|
jwang36 | 5157f1d | 2007-08-20 10:37:40 +0000 | [diff] [blame^] | 24 | 1) The tree structure generated by build tools is similar to Ant build system.
|
| 25 | 2) Makefile can be called directly by nmake for both top level platform and module. But
|
jwang36 | c7f7ef1 | 2007-06-25 17:19:31 +0000 | [diff] [blame] | 26 | after you call "nmake cleanall", you have to call "build" command to rebuild platform
|
| 27 | or modules because the AutoGen.* files have been be removed. The "makefile" itself
|
| 28 | cannot generate AutoGen.* files. Only "build" command can.
|
jwang36 | 5157f1d | 2007-08-20 10:37:40 +0000 | [diff] [blame^] | 29 | 3) build.exe in %WORKSPACE%\BaseTools\Bin\Win32 is generated from following revision of
|
| 30 | Python source code:
|
| 31 | r601 <buildtools_project>\BaseTools\Source\Python\Autogen
|
| 32 | r601 <buildtools_project>\BaseTools\Source\Python\Python\build
|
| 33 | r569 <buildtools_project>\BaseTools\Source\Python\Python\Common
|
| 34 | r564 <buildtools_project>\BaseTools\Source\Python\Python\CommonDataClass
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 35 |
|
qhuang8 | 6f5554b | 2007-08-19 01:58:45 +0000 | [diff] [blame] | 36 | Brief usage for Migration Tool MigrationMsa2Inf.exe:
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 37 | 1. Command line format:
|
qhuang8 | 6f5554b | 2007-08-19 01:58:45 +0000 | [diff] [blame] | 38 | MigrationMsa2Inf [options]
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 39 | 2. Input Files:
|
| 40 | A syntactically valid MSA file
|
| 41 | 3. Output Files:
|
| 42 | An extended INF file with possible auto-generated EntryPoint.c, CommonHeader.h/CommonHeader.txt, depending on options and module contents.
|
| 43 | 4. Prerequisite:
|
qhuang8 | dfb780e | 2007-08-14 02:40:53 +0000 | [diff] [blame] | 44 | a. The workspace directory must be specified either by environment variable or -w option.
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 45 | b. The Framework Database file must exist to specify the available packages in current workspace.
|
| 46 | Two possible locations are: (The first location overrides the second)
|
| 47 | $(WORKSPACE)\Tools\Conf\FrameworkDatabase.db
|
| 48 | $(WORKSPACE)\Conf\FrameworkDatabase.db.
|
| 49 | The <PackageList> field in FrameworkDatabase.db lists all available packages in current workspace.
|
| 50 | One example:
|
| 51 | <PackageList>
|
| 52 | <Filename>MdePkg/MdePkg.nspd</Filename>
|
| 53 | <Filename>MdeModulePkg/MdeModulePkg.spd</Filename>
|
| 54 | <Filename>IntelFrameworkPkg/IntelFrameworkPkg.spd</Filename>
|
| 55 | </PackageList>
|
| 56 | The package list in FrameworkDatabase.db is important to the final quality of migration:
|
| 57 | (1) It suggests the new package location: Translate package dependency Guid in MSA to Workspace relative path.
|
| 58 | If the package dependency Guid cannot be found in current workspace a warning message is raised.
|
| 59 | (2) It collects the Protocol/Guid/Ppi GuidCName a package contains.
|
| 60 | The GuidCName acts as "clue" to add e.g. #include <Protocol/DiskIo.h> in CommonHeader.h
|
| 61 |
|
| 62 | 5. Example:
|
| 63 | WORKSAPCE has already been set: $(WORKSPACE) = c:\work\EdkII.
|
| 64 |
|
qhuang8 | 6f5554b | 2007-08-19 01:58:45 +0000 | [diff] [blame] | 65 | a. MigrationMsa2Inf -f c:\work\EdkII\Nt32Pkg\WinNtThunkDxe\WinNtThunk.msa -o c:\work\EdkII\Nt32Pkg\WinNtThunkDxe\WinNtThunk.inf
|
| 66 | b. MigrationMsa2Inf -f c:\work\EdkII\Nt32Pkg\WinNtThunkDxe\WinNtThunk.msa -a
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 67 | Example a & b are equivalent to migrate WinNtThunk driver from EDKII to EDKII' code base.
|
| 68 |
|
qhuang8 | 6f5554b | 2007-08-19 01:58:45 +0000 | [diff] [blame] | 69 | c. MigrationMsa2Inf -f c:\work\EdkII\Nt32Pkg\WinNtThunkDxe\WinNtThunk.msa -a -c
|
qhuang8 | dfb780e | 2007-08-14 02:40:53 +0000 | [diff] [blame] | 70 | The extra "-c" option performs several hardcode mapping due to the naming change in EDKII':
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 71 | OldMdePkg Guid -> MdePkgGuid,
|
| 72 | EdkModulePkg Guid -> MdeModulePkgGuid,
|
| 73 | EdkGraphicsLib -> GraphicsLib
|
| 74 | HiiLib -> HiiLibFramework
|
| 75 | ...
|
| 76 |
|
qhuang8 | 6f5554b | 2007-08-19 01:58:45 +0000 | [diff] [blame] | 77 | d. MigrationMsa2Inf -f c:\work\EdkII\Nt32Pkg\WinNtThunkDxe\WinNtThunk.msa -m
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 78 | The extra "-m" option suppresses the generation of "CommonHeader.h" and leave all C files intact.
|
| 79 | Instead, it generates "CommonHeader.txt". Developers can manually copy its content to a local common header file in a module.
|
| 80 |
|
| 81 | 6. Known Limitations:
|
qhuang8 | dfb780e | 2007-08-14 02:40:53 +0000 | [diff] [blame] | 82 | a. Tool does not handle Exit Boot Services Callback & Virtual Address Changed Event. Developers need to handle it manually.
|
qhuang8 | 2b3b50f | 2007-08-14 02:35:43 +0000 | [diff] [blame] | 83 | b. The #include <Library/AbcLib.h> is based on library class naming convention: The header filename for "AbcLib" class are "AbcLib.h" by convention.
|
| 84 | c. The #include <Guid/Xyz.h>, <Protocol/Xyz.h> and <Ppi/Xyz.h> are added based on gGuidCName listed in MSA.
|
| 85 | If a GuidCName cannot map to a package Guid/Protocol/Ppi header file, a warning message is raised.
|
| 86 | If a module uses the definition in a pakcage Guid/Protocol/Ppi header file without list its associative GuidCName, the build will beak. Developer needs to manually add the include statement.
|
| 87 | d. The [Depex] sections are generated from DXS files with Guid Macro translated to Guid CName by naming convention, etc.
|
| 88 | If tool fails to "guess" the Guid CName from Guid Macro, it will leave the GuidMacro in [Depex] section for manual resolution.
|
| 89 | e. When tool generates [Sources] section, the modifiers for source files are lost. (Need to add proper tool chain, etc)
|
| 90 | f. When tool generates [LibraryClasses] section, the recommended library instances are lost. (No impact to build)
|
| 91 |
|
| 92 |
|
| 93 |
|
jwang36 | 5157f1d | 2007-08-20 10:37:40 +0000 | [diff] [blame^] | 94 | 20-August-2007
|