[cfe-dev] extra check in ReplaceUsesOfNonProtoTypeWithRealFunction() ?
Jay Foad
jay.foad at gmail.com
Thu Jun 4 06:23:53 PDT 2009
Hi,
I noticed this code in lib/CodeGen/CodeGenModule.cpp
ReplaceUsesOfNonProtoTypeWithRealFunction():
for (llvm::Value::use_iterator UI = OldFn->use_begin(), E = OldFn->use_end();
UI != E; ) {
// TODO: Do invokes ever occur in C code? If so, we should handle them too.
llvm::CallInst *CI = dyn_cast<llvm::CallInst>(*UI++);
if (!CI) continue;
For safety, I think it should also check:
if (UI.getOperandNo() != 0) continue;
(so that a use of OldFn as an argument in a call isn't mistaken for a
call to OldFn). However, I can't test this change, because I can't
construct any test case that causes
ReplaceUsesOfNonProtoTypeWithRealFunction() to be called. I've been
trying things like:
int f(); /* declaration with no prototype */
int g() { return f(3); }
int f(int i) { return 3; } /* definition */
When is this function supposed to be called?
Thanks,
Jay.
More information about the cfe-dev
mailing list