在没有运行时库的Linux下编译C语言

前端之家收集整理的这篇文章主要介绍了在没有运行时库的Linux下编译C语言前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我最近开始探索生成代码使用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

我只是忘记了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”函数的末尾,则在内核中不需要它.

谢谢 !

猜你在找的Linux相关文章