我最近开始探索生成的代码使用C运行时库的方式.
大多数情况下我很好奇,但我也想评估开发C中启动内核所需的最少内容所需的工作量.
所以我开始实现自己的运行时库,但是我遇到了一个小问题.
int main(int argc,char **argv) { return 0; }
使用以下命令编译它:
$g++ -ffreestanding -nostdlib
-fno-builtin -fno-rtti -fno-exceptions -c main.cpp
我收到这个警告:
/usr/bin/ld: warning: cannot find entry symbol _start; defaulting to 00000000080480b8
然后当我尝试执行生成的二进制文件时,我得到一个“分段错误”.
我试图编译“main.cpp”和ASM文件.
[global _start] [extern main] _start: call main
手动链接目标文件与“ld”,我没有警告,但二进制文件仍然提出“分段错误”.
我想我错过了一些东西.例如,系统C库在“__libc_start_main”中执行调用“main”之前和之后可能需要完成的事情.
此外,如果有人对我应该阅读的有关此主题的网站,文档或书籍有任何建议,我将非常感激.
谢谢,
帕特里克
解决方法
好的,感谢QuantumMechanic的链接,我设法找到了问题:
http://www.muppetlabs.com/~breadbox/software/tiny/teensy.html
http://www.muppetlabs.com/~breadbox/software/tiny/teensy.html
我只是忘记了linux编程的基础知识,更重要的是如何处理程序结束.
基本上,我需要生成系统调用中断“exit”来处理程序的结束.
[BITS 32] [global _start] [extern main] _start: call main mov ebx,eax ; Move the returned value in the register used as argument of exit() mov eax,1 ; Indicates the id of the syscall to execute int 0x80 ; Triggers the syscall interrupt
所以现在我可以使用自己的RTL在linux上编译任何C程序来进行一些测试.
请注意,如果永远不会到达“main”函数的末尾,则在内核中不需要它.
谢谢 !