我正在开发一个简单的应用程序,它将作为 UEFI 应用程序在 Intel Galileo 的板上运行。我从一个“Hello, World”应用程序开始,并在下面进行了测试qemu-system-i386
,它运行良好。然后,我在 Galileo EFI Shell 下运行它,它卡住了(什么也没发生,也没有返回任何东西——就像一个永无止境的循环)。我知道 Intel Galileo 的 Quark 处理器是 i586 架构。由于向后兼容性,在 i586 下运行为 i386 编译的应用程序应该没有问题,对吗?还是我错过了什么?
我正在使用 Ubuntu 14.04(32 位)和 GCC 5.4.0(默认)进行开发。另外,我在 3.0.4 版中使用 gnu-efi。
我应该构建一个交叉编译器吗?它会解决我所有的问题吗?有必要吗?
这是一个示例代码:
#include <efi.h>
#include <efilib.h>
EFI_STATUS EFIAPI efi_main(EFI_HANDLE ImageHandle, EFI_SYSTEM_TABLE *SystemTable) {
InitializeLib(ImageHandle, SystemTable);
Print(L"Hello, World!\n");
return EFI_SUCCESS;
}
这是我的Makefile:
ARCH = ia32
OBJS = src/main.o
HEADERS =
TARGET = build/main.efi
EFIINC = lib/gnu-efi/inc
EFIINCS = -I$(EFIINC) -I$(EFIINC)/$(ARCH) -I$(EFIINC)/protocol
LIB = lib/gnu-efi/$(ARCH)/lib
EFILIB = lib/gnu-efi/gnuefi
EFI_CRT_OBJS = $(EFILIB)/crt0-efi-$(ARCH).o
EFI_LDS = $(EFILIB)/elf_$(ARCH)_efi.lds
CFLAGS = $(EFIINCS) -ffreestanding -fno-stack-protector -fpic -fshort-wchar -mno-red-zone -Wall -masm=intel
LDFLAGS = -nostdlib -znocombreloc -T $(EFI_LDS) -shared -Bsymbolic -L $(EFILIB) -L $(LIB) $(EFI_CRT_OBJS)
all: $(TARGET)
build: $(TARGET)
src/%.so: $(OBJS) $(HEADERS)
ld $(LDFLAGS) $(OBJS) -o $@ -l:libefi.a -l:libgnuefi.a
build/%.efi: src/%.so
objcopy -j .text -j .sdata -j .data -j .dynamic \
-j .dynsym -j .rel -j .rela -j .reloc \
--target=efi-app-$(ARCH) $^ $@
run:
qemu-system-i386 bin/OVMF.fd -hda fat:build
.PHONY: all build run