[LLVMdev] Inline semantics.
Chris Lattner
sabre at nondot.org
Wed Jan 2 22:54:09 PST 2008
On Jan 2, 2008, at 2:23 AM, Richard Pennington wrote:
> Ellsif compiles and runs bzip2. During testing I noticed that if I set
> the optimization level to O2 or greater, I'd get an unresolved
> symbol at
> link time.
>
> It turns out that a function is declared in a header file and is
> used by
> two separate source files. In one of the source files, the function is
> defined with __inline__.
>
> If I do function inlining during compilation (i.e. bitcode creation) I
> get the unresolved symbol because the function is discarded after it
> is
> inlined in the file that defines it. If I do function inlining during
> bitcode linking instead, everything works OK and the function is
> inlined
> everywhere it is used.
>
> My question is, what should happen in this case? I don't mind
> deferring
> inlining until the link phase, but I have a feeling that that isn't
> correct behavior. Should a diagnostic be issued in this case?
The semantics of __inline__ are tricky and vary between C89, C99 and C+
+. You should look at the relevant standards to find the meaning of
each one.
Please don't cc the oink and llvmdev lists. The oink list is a closed
list.
-Chris
More information about the llvm-dev
mailing list