2

我有一个带有一些不同库/对象的模块化 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 中的方法可以做到这一点,而无需在整个地方更改所有函数声明?

4

1 回答 1

1

那这个呢?

void empty_function(void)
{
    return;
}
#define WEAK(x,y) extern void x() __attribute__((weak, alias(#y)));
于 2013-10-31T10:24:11.797 回答