8602 – [3.2/3.3/3.4 regression] incorrect line numbers in warning messages when using inline functions (original) (raw)
| [ Reported to the Debian BTS as report #153965. Please CC 153965@bugs.debian.org on replies. Log of report can be found at http://bugs.debian.org/153965 ] ----- static inline int foo(int x) { if (!x) return 0; } int main(void) { foo(1); return 1; } ----- $ gcc-2.95 -Wall -c !$ gcc-2.95 -Wall -c bug-153965.c bug-153965.c: In function `foo': bug-153965.c:6: warning: control reaches end of non-void function ^^^ $ gcc-3.2 -Wall -c bug-153965.c bug-153965.c: In function `foo': bug-153965.c:13: warning: control reaches end of non-void function ^^^^ $ gcc-3.3 -Wall -c bug-153965.c bug-153965.c: In function `foo': bug-153965.c:13: warning: control reaches end of non-void function ^^^^^ gcc 3.[23] also produces correct line numbers if either "static" or "inline" is removed from foo. Removing the body of function foo() causes a secondary warning to be generated in the right place, but the original warning still has the wrong line number. [gcc-3.2 is gcc-3.2.1 20021111, gcc-3.3 is HEAD 20021103] Release: 3.2.1 (Debian) (Debian unstable) Environment: System: Debian GNU/Linux (unstable) Architecture: i686 host: i386-linux Configured with: /home/packages/gcc/3.2/gcc-3.2-3.2.1ds5/src/configure -v --enable-languages=c,c++,java,f77,proto,objc,ada --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-gxx-include-dir=/usr/include/c++/3.2 --enable-shared --with-system-zlib --enable-nls --without-included-gettext --enable-__cxa_atexit --enable-clocale=gnu --enable-java-gc=boehm --enable-objc-gc i386-linux Comment 1 Neil Booth 2002-11-16 03:23:59 UTC State-Changed-From-To: open->analyzed State-Changed-Why: Confirmed. Change category to C as it clearly has nothing to do with preprocessor. Comment 2 janis187 2003-01-15 09:08:29 UTC From: Janis Johnson <janis187@us.ibm.com> To: gcc-gnats@gcc.gnu.org, gcc-prs@gcc.gnu.org, asuffield@debian.org, 153965@bugs.debian.org, gcc-bugs@gcc.gnu.org, nobody@gcc.gnu.org Cc: Subject: Re: c/8602: [3.2/3.3 regression] incorrect line numbers in warning messages when using inline functions Date: Wed, 15 Jan 2003 09:08:29 -0800 The regression was introduced with this patch: --- gcc/ChangeLog --- 2000-10-05 Richard Henderson <rth@cygnus.com> * c-decl.c (warn_missing_noreturn): Remove. (c_expand_body): Don't set or check can_reach_end. * c-tree.h (warn_missing_noreturn): Move ... * flags.h: ... here. (can_reach_end): Remove. * flow.c (check_function_return_warnings): New. (make_edges): No edge to exit for noreturn sibcalls. * function.c (expand_function_end): Save the return value clobber instruction. (mark_function_status): Mark it. * function.h (struct function): Add x_clobber_return_insn. * jump.c (can_reach_end): Remove. (calculate_can_reach_end): Remove. (jump_optimize_1): Don't call it. * output.h (check_function_return_warnings): Declare. * toplev.c (warn_missing_noreturn): Move from c-decl.c (rest_of_compilation): Call check_function_return_warnings. http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=8602 Comment 3 Richard Henderson 2003-02-06 00:39:25 UTC Responsible-Changed-From-To: unassigned->rth Responsible-Changed-Why: . | | | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | |