0

我正在开发一个简单的应用程序,它将作为 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
4

0 回答 0