嵌入式開發的時候,我們的編譯一個*.S檔案,並最終產生bin檔案,編譯命令大致如下:
CC=arm-softfloat-linux-gnu-gcc
LD=arm-softfloat-linux-gnu-ld
OBJCOPY=arm-softfloat-linux-gnu-objcopy
$(CC) -g $(CFLAG) -c boot.S #先將boot.S檔案產生boot.o
$(LD) -g -Bstatic -T$(LDFILE) -Ttext 0x12345600 boot.o --start-group -Map boot.map -o boot.elf #再將boot.o產生boot.elf, boot.elf通常就是可執行檔,類似於gcc -o test test.c 中的test檔案,在Linux Shell下輸入./test就可以執行。
$(OBJCOPY) -O binary boot.elf boot.bin #接著將boot.elf->boot.bin,這樣可以縮小代碼尺寸。
運行arm-softfloat-linux-gnu-objdump -h boot.elf 可以查看該檔案的資訊,但是如果變成
arm-softfloat-linux-gnu-objdump -h boot.bin會提示錯誤,為了看boot.bin檔案資訊,輸入:
arm-softfloat-linux-gnu-objdump -h -b binary -m arm boot.bin就可以了。哈哈我也是現學了一招,其中參數-h可以被替換成為-D, -S, -s等等,請用arm-softfloat-linux-gnu-objdump --help查看器中表示的意義。
說說ELF Bin 檔案區別:
我們有了Linux OS,為了運行可執行檔,他們是遵循ELF格式的,通常gcc -o test test.c,產生的test檔案就是ELF格式的,這樣就可以運行了。
arm-softfloat-linux-gnu-objcopy命令將去掉ELF格式的東西,僅僅保留最純的彙編(不知道如何解釋),
在Embedded中,如果上電開始運行,沒有OS系統,如果將ELF格式的檔案燒寫進去,包含一些ELF格式的東西,arm運行碰到這些指令,就會導致失敗,如果用arm-softfloat-linux-gnu-objcopy產生純粹的彙編,程式就可以一步一步運行。