Thanks, Jordan. I change OvmfPkgX64.dsc file as below: [BuildOptions] # GCC:*_UNIXGCC_*_CC_FLAGS = -DMDEPKG_NDEBUG # GCC:RELEASE_*_*_CC_FLAGS = -DMDEPKG_NDEBUG INTEL:RELEASE_*_*_CC_FLAGS = /D MDEPKG_NDEBUG MSFT:RELEASE_*_*_CC_FLAGS = /D MDEPKG_NDEBUG GCC:*_*_*_CC_FLAGS = -mno-mmx -mno-sse
Change to OvmfPkg top directory to build using command line as below: ./build.sh -a x64 -b RELEASE -D FD_SIZE_2MB -n 20 Successfully get OVMF.fd from Build/OvmfX64/RELEASE_GCC44/FV. I check it's size is 2MB. And I test it with qemu. It's also ok. Thank u again. > -----Original Message----- > From: Jordan Justen [mailto:jordan.l.jus...@intel.com] > Sent: 2015年5月19日 0:40 > To: edk2-devel@lists.sourceforge.net; lidonglin; Laszlo Ersek > Cc: edk2-devel@lists.sourceforge.net > Subject: Re: [edk2] question about size of OMVF.fd > > On 2015-05-18 07:15:02, lidonglin wrote: > > Thanks. And I want DEBUG() (which calls DebugPrint function) to work > > in debug version, > > DEBUG() does work in the debug version. It does not work in the release > version. > > > so I chang MdePkg/Include/Library/DebugLib.h : as > > below: > > Origin: > > #if !defined(MDEPKG_NDEBUG) > > #define DEBUG(Expression) \ > > do { \ > > if (DebugPrintEnabled ()) { \ > > _DEBUG (Expression); \ > > After change: > > #if 1 > > #define DEBUG(Expression) \ > > do { \ > > if (DebugPrintEnabled ()) { \ > > _DEBUG (Expression); \ > > > If, for some reason you really want debug enabled in the RELEASE build, then > you should modify OvmfPkg/OvmfPkgX64.dsc to not set MDEPKG_NDEBUG. But, > I don't think you really want to do this. > > > Then build with command line : build.sh -a x64 -b RELEASE -n 20 > > Why not instead build with -b DEBUG? > > Then when you run QEMU, add these parameters: > > -debugcon file:debug.log -global isa-debugcon.iobase=0x402 > > Then after running QEMU, examine the debug.log file to see the debug > messages. The is documented in OvmfPkg/README. > > > Build is ok, but error in Generating as below : > > You ran out of size because you enabled debug mode in the release build flash > size. > > -Jordan > > > Generating FVMAIN_COMPACT FV > > > > > > GenFds.py... > > : error 7000: Failed to generate FV > > > > #######Return Value = 2 > > GenFv: ERROR 3000: Invalid > > the required fv image size 0xd49d0 exceeds the set fv image size > > 0xcc000 > > > > > > ### ['GenFv', '-a', > > > '/mnt/sdg1/edk2-2.1.10/Build/OvmfX64/RELEASE_GCC44/FV/Ffs/FVMAIN_CO > MPA > > CT.inf', '-o', > > > '/mnt/sdg1/edk2-2.1.10/Build/OvmfX64/RELEASE_GCC44/FV/FVMAIN_COMPA > CT.F > > v', '-i', > > > '/mnt/sdg1/edk2-2.1.10/Build/OvmfX64/RELEASE_GCC44/FV/FVMAIN_COMPA > CT.i > > nf'] > > > > > > build.py... > > : error 7000: Failed to execute command > > GenFds -f /mnt/sdg1/edk2-2.1.10/OvmfPkg/OvmfPkgX64.fdf > > --conf=/mnt/sdg1/edk2-2.1.10/Conf -o > > /mnt/sdg1/edk2-2.1.10/Build/OvmfX64/RELEASE_GCC44 -t GCC44 -b > RELEASE > > -p /mnt/sdg1/edk2-2.1.10/OvmfPkg/OvmfPkgX64.dsc -a X64 -D > > "EFI_SOURCE=/mnt/sdg1/edk2-2.1.10/EdkCompatibilityPkg" -D > > "EDK_SOURCE=/mnt/sdg1/edk2-2.1.10/EdkCompatibilityPkg" -D > > "TOOL_CHAIN_TAG=GCC44" -D "TOOLCHAIN=GCC44" -D > "TARGET=RELEASE" -D > > "WORKSPACE=/mnt/sdg1/edk2-2.1.10" -D > > "EDK_TOOLS_PATH=/mnt/sdg1/edk2-2.1.10/BaseTools" -D "ARCH=X64" -D > > "ECP_SOURCE=/mnt/sdg1/edk2-2.1.10/EdkCompatibilityPkg" > > [/mnt/sdg1/edk2-2.1.10] > > > > - Failed - > > Build end time: 10:54:15, May.19 2015 > > Build total time: 00:00:58 > > > > Who knows why? > > > > > -----Original Message----- > > > From: Laszlo Ersek [mailto:ler...@redhat.com] > > > Sent: 2015年5月18日 15:35 > > > To: lidonglin > > > Cc: edk2-devel@lists.sourceforge.net > > > Subject: Re: [edk2] question about size of OMVF.fd > > > > > > On 05/18/15 08:50, lidonglin wrote: > > > > First thanks. And I ask another question. Which function can I > > > > call to print information to serial port or IO port(default 0x402) > > > > when I build RELEASE OVMF ? > > > > > > - The only function that currently enables someone to print to > > > ioport > > > 0x402 (PcdDebugIoPort), and continue, is DebugPrint() in > > > "OvmfPkg/Library/PlatformDebugLibIoPort/DebugLib.c". This function > > > is normally called via the DEBUG() macro (which has no effect if you > > > build OVMF for RELEASE). > > > > > > - You can write to the serial port with SerialPortWrite(), from > > > "MdePkg/Include/Library/SerialPortLib.h". > > > > > > (But, honestly, there is no reason to build OVMF for anything but > > > DEBUG, > > > ever.) > > > > > > Thanks > > > Laszlo > > ---------------------------------------------------------------------- > > -------- One dashboard for servers and applications across > > Physical-Virtual-Cloud Widest out-of-the-box monitoring support with > > 50+ applications Performance metrics, stats and reports that give you > > Actionable Insights Deep dive visibility with transaction tracing > > using APM Insight. > > http://ad.doubleclick.net/ddm/clk/290420510;117567292;y > > _______________________________________________ > > edk2-devel mailing list > > edk2-devel@lists.sourceforge.net > > https://lists.sourceforge.net/lists/listinfo/edk2-devel ------------------------------------------------------------------------------ One dashboard for servers and applications across Physical-Virtual-Cloud Widest out-of-the-box monitoring support with 50+ applications Performance metrics, stats and reports that give you Actionable Insights Deep dive visibility with transaction tracing using APM Insight. http://ad.doubleclick.net/ddm/clk/290420510;117567292;y _______________________________________________ edk2-devel mailing list edk2-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/edk2-devel