如果您使用“clang -S -emit-llvm struct.c”编译以下内容
struct _mystruct {
long long int a;
long long int b;
};
struct _mystruct foo(struct _mystruct s) {
s.a += 1;
return s;
}
int main(void) {
struct _mystruct s;
s.a = 8;
s.b = 9;
s = foo(s);
return s.a;
}
...你得到(除其他外):
define { i64, i64 } @foo(i64 %s.coerce0, i64 %s.coerce1) #0 {
为什么 clang 将 foo 的论点一分为二?有什么办法可以阻止它这样做吗?我希望能够从其他 LLVM 生成的代码中调用它,该代码只需要 foo 的一个参数。