8

有人在 OS X 上成功编译过TCC吗?

据我所知,这应该是可能的,但是当我运行 make 时,出现以下错误:

$ make
gcc -o tcc tcc.c -DTCC_TARGET_I386 -O2 -g -Wall -fno-strict-aliasing -mpreferred-stack-                boundary=2 -march=i386 -falign-functions=0 -Wno-pointer-sign -Wno-sign-compare -D_FORTIFY_SOURCE=0 -lm -ldl
tcc.c:1: error: CPU you selected does not support x86-64 instruction set
tcc.c:1: error: CPU you selected does not support x86-64 instruction set
tcc.c:1: error: -mpreferred-stack-boundary=2 is not between 4 and 12
make: *** [tcc] Error 1

./configure运行良好并给出以下输出:

$ ./configure 
Binary  directory   /usr/local/bin
TinyCC directory    /usr/local/lib/tcc
Library directory   /usr/local/lib
Include directory   /usr/local/include
Manual directory    /usr/local/man
Doc directory       /usr/local/share/doc/tcc
Target root prefix  
Source path      /Users/aaron/Downloads/tcc-0.9.25
C compiler       gcc
CPU              x86
Big Endian       no
gprof enabled    no
cross compilers  no
use libgcc       no
Creating config.mak and config.h

我很确定这个问题很简单,但我没有在 OS X 上编译足够的程序来了解这些错误......

安装 TCC 的主要目的是获取 libtcc,这样我就可以开始尝试从 Ruby 生成动态代码(以防万一:-p)

谢谢!

4

3 回答 3

28

我刚刚花了一些时间试图让 tcc 在 osx 上运行。我已经包含了几个修复程序,包括上面答案中的一个,现在它们都在http://repo.or.cz/w/tinycc.git的开发存储库中。构建,一些测试和所有示例都应该有效。

我不确定您是否知道,但http://bellard.org/tcc/网站属于启动该项目的 Fabrice Bellard,并没有定期更新。主要是因为没有多少“官方”tcc 版本。tcc 是主要依赖实时资源和更新的项目之一。因此,如果您想再试一次,请访问http://repo.or.cz/w/tinycc.git并获取“mob”分支(不是“master”)。有关详细信息,请参阅http://repo.or.cz/w/tinycc.git,并加入邮件列表以参与其中。

于 2012-03-06T19:24:17.030 回答
4

我现在将合并我的评论。

似乎有几个问题。

  1. 从 Mac OS 10.5 开始,x86 寄存器访问的命名方案发生了变化。请参阅在 OS X 上通过 ucontext 访问 EIP 和 EBP。这将需要破解源代码,直到可以说服维护者支持 Mac OS X。
  2. 支持的可执行格式tcc与 Mac OS X 将本机运行的格式不重叠。但是,XBinary可能会解决这个问题。(我没有找到fink包或MacPorts包,但是还没有安装它。不确定我会不会——这是很深奥的魔法,理论上确实可以做非常坏的事情。)啊。 .. 这也已经出现了:在 OSX 上加载/执行 ELF 文件的可能性
于 2010-09-14T21:42:46.993 回答
3

这些错误可以通过编辑 TCC 包的配置脚本 (ver 0.9.25) 来修复。

在配置脚本中,第 36 行显示 cpu=uname -m 如果您在 Mac OS X 的控制台中运行 uname -m,即使它是 64 位系统,它也会打印“i386”。

一个解决方案是注释掉这一行,并用 cpu=x86_64 替换它,

然后,由于 Mac OS X 中的寄存器命名约定,会出现一些编译错误,正如 dmckee 在这个线程中提到的那样。

我的解决方法是在 1512 行附近的 libtcc.c 中添加几行。最后它看起来像

#ifdef __DARWIN_UNIX03
        *paddr = uc->uc_mcontext->__ss.__rip;
#else
        *paddr = uc->uc_mcontext.gregs[REG_RIP];
#endif
        return 0;
    } else {
#ifdef __DARWIN_UNIX03
        fp = uc->uc_mcontext->__ss.__rbp;
#else
        fp = uc->uc_mcontext.gregs[REG_RBP];
#endif

然后编译。

于 2011-08-17T13:40:58.370 回答