здоров.
В образовательных целях я решил попробовать собрать прошивку для Cortex-M3 руками с помощью ARM GNU Toolchain. Скачал bare-metal вариант, arm-none-eabi отсюда.
https://developer.arm.com/downloads/-/arm-gnu-toolchain-downloads
Прошивка состоит из файла main.с, в котором main() с пустым циклом, файла startup.S со стандартным содержимым, и файла линкера, взятого из рабочего проекта.
Далее я начинаю компилировать руками.
arm-none-eabi-gcc.exe -Wall -Os -mcpu=cortex-m3 -mthumb -std=c99 -fno-strict-aliasing -fdata-sections -ffunction-sections -c main.c -o main.o
main.c:2:6: warning: return type of 'main' is not 'int' [-Wmain]
2 | void main(void)
| ^~~~
Проверяем:
arm-none-eabi-size -d -t main.o
text data bss dec hex filename
2 0 0 2 2 main.o
2 0 0 2 2 (TOTALS)
Далее:
arm-none-eabi-gcc.exe -Wall -Os -mcpu=cortex-m3 -mthumb -std=c99 -fno-strict-aliasing -fdata-sections -ffunction-sections -c startup.S -o startup.o
Компиляция проходит успешно. Проверяем:
arm-none-eabi-size -d -t startup.o
text data bss dec hex filename
176 0 0 176 b0 startup.o
176 0 0 176 b0 (TOTALS)
И далее я линкую эти два файла:
arm-none-eabi-gcc.exe -Tlinker.ld -specs=nosys.specs -o program.elf main.o startup.o
c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1/../../../../arm-none-eabi/bin/ld.exe: c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1\libc.a(libc_a-closer.o): in function `_close_r':
closer.c:(.text._close_r+0x18): warning: _close is not implemented and will always fail
c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1/../../../../arm-none-eabi/bin/ld.exe: c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1\libc.a(libc_a-lseekr.o): in function `_lseek_r':
lseekr.c:(.text._lseek_r+0x24): warning: _lseek is not implemented and will always fail
c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1/../../../../arm-none-eabi/bin/ld.exe: c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1\libc.a(libc_a-readr.o): in function `_read_r':
readr.c:(.text._read_r+0x24): warning: _read is not implemented and will always fail
c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1/../../../../arm-none-eabi/bin/ld.exe: c:/program files (x86)/arm gnu toolchain arm-none-eabi/12.3 rel1/bin/../lib/gcc/arm-none-eabi/12.3.1\libc.a(libc_a-writer.o): in function `_write_r':
writer.c:(.text._write_r+0x24): warning: _write is not implemented and will always fail
И вот тут начинаются вопросы!
Во-первых, несмотря на то, что я указал nosys.specs, что по идее должно выключить системные вызовы, линкер ругается на то, что их нет.
И главное, несмотря на то, что я не подключал никаких библиотек (они тут и не нужны), размер бинарника составляет порядка 8 кБ!
arm-none-eabi-size -d -t program.elf
text data bss dec hex filename
8976 1372 840 11188 2bb4 program.elf
8976 1372 840 11188 2bb4 (TOTALS)
Что я делаю не так?
Пробовал более старые версии GCC? Там nosys.specs вроде ломали когда-то.
Э? Правда? Офигеть, не знал. Нет, не пробовал.
https://www.reddit.com/r/embedded/comments/13jd4x6/armnoneeabi_tools_issue/
А у вас там принт хеллов ворд нету случаем?
void main(void) { while (1) { } }
Ты можешь использовать и текущий компиль, но просто в проекте сделать стабы этих сисколов. Так советовали в доках на гцц начиная с какой-то версии. Либо забить, так как это варнинг)))))0)0)
Да это-то да. Но хочется разобраться.
М. А там разве не два дефиса должно быть перед specs?
Да вроде нет. Но я проверю.
Обсуждают сегодня