On Sun, Mar 30, 2014 at 1:21 PM, Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> wrote: > On Sun, Mar 30, 2014 at 12:22 PM, Christopher Li <sparse@xxxxxxxxxxx> wrote: >> >> Possible. If I comment out that check, I will get this error in the >> extern-inline.c >> test case: >> >> $ ./sparse validation/extern-inline.c validation/extern-inline.c >> validation/extern-inline.c:12:1: warning: multiple definitions for function 'g' >> validation/extern-inline.c:12:1: the previous one is here > > Ok, I think that is just us being too anal. We should allow multiple > definitions for functions that are identical otherwise, but differ in > the "inline". The difference is not only in "inline", but also the different function body declared in two different files. The better example should be ./sparse validations/extern-inlineA.c validations/extern-inlineB.c where inlineA.c and inlineB.c has different implementation of function 'g'. Same function prototype of 'g', just different function body in different files. In other words, we should treat extern inline has the same file visibility as static inline. The only difference is that, when compiler can't inline the function, extern inline assume the function has external copy and don't generate the local copy. Static inline turn the function into a static function. > > So the correct thing to do is (I think) to remove that check, and then > make the parse_function_body() warning go away by accepting the fact > that we can have both an inline version and an out-of-line version of > the same function. I agree we should remove that MOD_INLINE check and fix the warning else where. The warning is actually not about inline version vs out-of-line version. It is about two files have two different implementation of the inline version. Let me take a stab on that. My guess is that, I can fix it by treating extern inline like static inline, remove the symbol when the file scope ends. Then the second file will not see it and complain the duplicate symbol. Haven't verify that works or not yet. Chris -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html