我有一个带有一些不同库/对象的模块化 C 项目,只有在满足某些条件时才链接到版本。这个项目是用 GCC 3.4.4 for PowerPC 构建的。
因此,在我的整个项目中,有一些 C 文件使用来自其他模块的功能(这些模块不必添加到构建中)。所以这些函数被声明为extern。
根据版本,包含函数本身的模块是否已链接。为了避免未定义的引用,这些函数使用汇编器宏声明为弱。
我试图用一个例子来说明这一点:
ModuleA.c(核心模块)
extern void bar(void);
void foo(void)
{
// Do some Stuff
bar();
}
ModuleB.c(可选模块)
void bar(void)
{
// Do some stuff
}
ModuleB 并不总是链接到 ModuleA,仅在某些特定的发布版本中。所以有第三个 C-File
weakfuncs.c(核心模块)
#define WEAK(x,y) __asm__(".weak " #x "\n.set " #x "," #y "\n");
void empty_function(void);
__asm__("empty_function:\nblr\n");
WEAK(bar,empty_function)
使用此宏,项目始终构建(如果 ModuleB 已链接,bar()
将从 ModuleB 调用,如果没有 ModuleB 未链接,bar()
将只调用empty_function()
.
由于整个项目中有很多这样的案例,我的前任将所有这些功能都收集在weakfuncs.c
.
到目前为止,这是我只是重用的遗留代码
现在我想用 MinGW (GCC 4.8.1) 为 Windows 编译整个东西。我的问题是编译器似乎对汇编指令有问题:
__asm__("empty_function:\nblr\n");
根本不工作(他不知道blr
命令),但这不是问题,因为我可以像这样在 C 中实现一个空函数:
void empty_function(void)
{
return;
}
WEAK 宏本身
#define WEAK(x,y) __asm__(".weak " #x "\n.set " #x "," #y "\n");
编译没有问题,但没有效果,意思是,未链接的函数将导致“未定义的引用”,即使我确实在它们上运行了 WEAK 宏。
现在我知道在 gcc 中有一种方法可以像这样为函数赋予弱属性:
extern void bar() __attribute__((weak));
这实际上是可行的,但是由于有很多功能都需要适应,所以我更愿意在我weakfuncs.c
的宏中进行调整。
是否有任何汇编程序指令或 C 中的方法可以做到这一点,而无需在整个地方更改所有函数声明?