VirtualBox

source: vbox/trunk/src/VBox/Devices/EFI/Firmware2/VBoxPkg/ReadMe.txt@ 47492

Last change on this file since 47492 was 44613, checked in by vboxsync, 12 years ago

Some EFI readme updates.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.7 KB
Line 
1$Id: ReadMe.txt 44613 2013-02-09 13:24:40Z vboxsync $
2
3Setting up the source trees
4===========================
5
6Check out the EDK2 trunk/edk2 to some directory of your choice (the command
7creates an edk2 subdirectory):
8
9 svn checkout \
10 --username guest --password guest \
11 -r${EDK_REV} https://edk2.svn.sourceforge.net/svnroot/edk2/branches/${EDK_BRANCH} edk2
12
13Note! The value of EDK_REV and EDK_BRANCH are found in efi_build.conf and subject to change!
14
15Enter into the edk2 directory and check out EFI/Firmware2/VBoxPkg into a
16VBoxPkg subdirectory:
17
18 svn checkout \
19 http://www.virtualbox.org/svn/vbox/trunk/src/VBox/Devices/EFI/Firmware2/VBoxPkg VBoxPkg
20
21Enter into the VBoxPkg/Include and check out include/iprt and include/VBox:
22
23 svn checkout http://www.virtualbox.org/svn/vbox/trunk/include/iprt iprt
24 svn checkout http://www.virtualbox.org/svn/vbox/trunk/include/VBox VBox
25
26Then copy version-generated.h from
27<VBox-trunk>/out/win.*/*/version-generated.h (into VBoxPkg/include/).
28<VBox-trunk>/out/win.*/*/product-generated.h (into VBoxPkg/include/).
29
30
31Symlink alternative for Vista
32-----------------------------
33
34Say you've got VBox checked out as e:\vbox\trunk and you're on 32-bit Windows
35and having done a debug build. Check out EDK2 somewhere (see above). Then do:
36
37 kmk_ln -s %VBOXSVN%\src\VBox\Devices\EFI\Firmware2\VBoxPkg\ edk2\VBoxPkg
38 kmk_ln -s %VBOXSVN%\include\iprt\ edk2\VBoxPkg\Include\iprt
39 kmk_ln -s %VBOXSVN%\include\VBox\ edk2\VBoxPkg\Include\VBox
40 kmk_ln -s %VBOXSVN%\out\win.x86\debug\version-generated.h edk2\VBoxPkg\Include\version-generated.h
41 kmk_ln -s %VBOXSVN%\out\win.x86\debug\product-generated.h edk2\VBoxPkg\Include\product-generated.h
42
43MinGW for Linux
44================
45
46To install MinGW on Ubuntu systems, just perform
47
48 apt-get install mingw32-binutils mingw32 mingw32-runtime
49
50After that, you can even avoid setting up symlinks, as build script will do
51that automagically.
52
53MinGW-w64 for Linux
54===================
55To build the X64 firmware on Linux, the wimgw-w64 port of mingw is required.
56The binaries are available at:
57
58 http://sourceforge.net/projects/mingw-w64/files/
59
60on recent Ubuntu systems mingw-w64 is available in repository:
61
62 apt-get install mingw-w64
63
64Some non-fatal warnings might appears while compiling on Linux machine so it
65is recommended to disable -Werror at Conf/tools_def.txt:*_UNIXGCC_X64_CC_FLAGS.
66
67While building some versions of wingw-w64/linker might complain that __ModuleEntryPoint wasn't found (and fills entry point field with some default value)
68to fix that, just split the the definition (IA32 and X64),with removing leading underscore '_' for X64 at Conf/tools_def.txt:
69 *_UNIXGCC_*_DLINK_FLAGS=... -entry _$(IMAGE_ENTRY_POINT) ...
70 to
71 *_UNIXGCC_IA32_DLINK_FLAGS=... -entry _$(IMAGE_ENTRY_POINT) ...
72 *_UNIXGCC_X64_DLINK_FLAGS=... -entry $(IMAGE_ENTRY_POINT) ...
73
74Setting up the environment
75==========================
76
77First, enter the VirtualBox environment using tools/env.cmd (and whatever
78local additions you normally use).
79
80Go to the EDK2 source tree you set up in the previous section and run
81VBoxPkg/env.cmd (Windows) and VBoxPkg/env.sh (Unix).
82
83That's it. You can now run build.
84
85
86Patching
87========
88
89VBox guests and hardware required some modifications in EDK2 do before
90building some patches are required:
91
92 svn patch VBoxPkg/udk2010.sr1.patch-*
93
94Note! Check with the efi_build.conf EDK_PATCHES for the correct expansion of
95 the wildcard above. At the time of writing, it's:
96
97 svn patch VBoxPkg/udk2010.sr1.patch-IntelFrameworkModulePkg_Library_GenericBdsLib
98 svn patch VBoxPkg/udk2010.sr1.patch-MdePkg_Include_Library_DebugLib.h
99 svn patch VBoxPkg/udk2010.sr1.patch-MdePkg_Library_BaseIoLibIntrinsic_IoLibGcc.c
100 svn patch VBoxPkg/udk2010.sr1.patch-OvmfPkg_Library_PlatformBdsLib
101 svn patch VBoxPkg/udk2010.sr1.patch-OvmfPkg_OvmfPkgIa32.dsc
102 svn patch VBoxPkg/udk2010.sr1.patch-OvmfPkg_OvmfPkgIa32.fdf
103 svn patch VBoxPkg/udk2010.sr1.patch-OvmfPkg_OvmfPkgX64.dsc
104 svn patch VBoxPkg/udk2010.sr1.patch-OvmfPkg_OvmfPkgX64.fdf
105 svn patch VBoxPkg/udk2010.sr1.patch-PcAtChipsetPkg_Bus_Pci_IdeControllerDxe_IdeController.c
106 svn patch VBoxPkg/udk2010.sr1.patch-ShellPkg_Library_UefiShellLevel3CommandsLib
107 svn patch VBoxPkg/udk2010.sr1.patch-UefiCpuPkg_CpuDxe_CpuGdt.c
108
109
110Building
111========
112Edit Cont/target.txt:
113
114 $ cat Conf/target.txt
115 ACTIVE_PLATFORM = VBoxPkg/VBoxPkgOSE.dsc
116 TARGET = DEBUG
117 TARGET_ARCH = IA32
118 TOOL_CHAIN_CONF = Conf/tools_def.txt
119 TOOL_CHAIN_TAG = UNIXGCC
120 MAX_CONCURRENT_THREAD_NUMBER = 1
121 MULTIPLE_THREAD = Disable
122 BUILD_RULE_CONF = Conf/build_rule.txt
123
124The make program is called 'build' (edk2\BaseTools\Bin\Win32\build.exe). To
125start building just execute 'build'. If you have a multicore machine and run
126into bad build errors, try 'build -n 1' to avoid mixing up errors. For more
127options try 'build --help'.
128
129Note! Seems it's no just 'build', but rather something along the lines of:
130 build -D VBOX=1 -D BUILD_NEW_SHELL=1 -D VBOX_REV=88888
131
132Running
133=======
134
135Copy (or symlink) Build\VBoxPkg\DEBUG_MYTOOLS\FV\VBOX.fd to the
136VirtualBox bin directory as vboxefi.fv.
137 copy e:\edk2\Build\VBoxPkg\DEBUG_MYTOOLS\FV\VBOX.fd e:\vbox\trunk\out\win.x86\debug\bin\VBoxEFI32.fd
138 or
139 kmk_ln -s e:\edk2\Build\VBoxPkg\DEBUG_MYTOOLS\FV\VBOX.fd e:\vbox\trunk\out\win.x86\debug\bin\VBoxEFI32.fd
140
141You need to build have a VirtualBox debug build with the following in your
142Note that these options will not change the VirtualBox behavior only enable
143the EFI feature.
144
145Create a new VM with enabled EFI support.
146
147Currently all there is to see is in the log output and debugger. Suggested
148log setup (debug builds only):
149
150 set VBOX_LOG=dev_efi.e.l2
151 set VBOX_LOG_DEST=stderr
152 set VBOX_LOG_FLAGS=unbuffered msprog thread
153
154And suggested way of starting the VM:
155
156 VirtualBox.exe --startvm efi
157
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette