public inbox for gcc-bugs@sourceware.org help / color / mirror / Atom feed
From: "msebor at gcc dot gnu.org" <gcc-bugzilla@gcc.gnu.org> To: gcc-bugs@gcc.gnu.org Subject: [Bug middle-end/98465] Bogus warning stringop-overread wuth -std=gnu++20 -O2 and std::string::insert Date: Wed, 30 Dec 2020 21:25:06 +0000 [thread overview] Message-ID: <bug-98465-4-yN0cEo1PqY@http.gcc.gnu.org/bugzilla/> (raw) In-Reply-To: <bug-98465-4@http.gcc.gnu.org/bugzilla/> https://gcc.gnu.org/bugzilla/show_bug.cgi?id=98465 --- Comment #4 from Martin Sebor <msebor at gcc dot gnu.org> --- (In reply to Romain Geissler from comment #2) > There seems to be a strange interaction between -Wsystem-headers and -g in > gcc 11 which I don't understand. Thanks for the -g hint; with it I can see it on my end as well. The difference seems to be in how the inlining information is encoded with -g vs without. With -g, the algorithm that looks for the location into which the call to s.insert() has been inlined manages to uncover it. Without -g, the algorithm fails and falls back on the traditional approach that only considers macro expansion but not inlining. So without -g, the warning is not issued because of a bug or limitation in the new algorithm. (The algorithm was introduced in r11-6028 to enable -Wfree-nonheap-object and other similar middle-end warnings for invalid uses of C++ standard library functions. The goal is to avoid issuing warnings for deliberate abuses by system headers, but we want to issue those for incidental misuses of system functions by user code.) (In reply to Romain Geissler from comment #3) > Why does having a function f2 affects warnings in function f1 ? Because s.insert() is a trivial wrapper around replace(), calls to it end up expanded inline into those to s._M_replace(). When there's just one caller of s1.insert(), the latter is inlined into it as well. But with two or more callers, because _M_replace() is big, the inliner decides it's better not to expand it inline. That in turn prevents constant propagation from substituting the constant array's address into the code, which then defeats the warning. The inlining limit is controlled by -finline-limit=n so suitably increasing it will trigger the warning.
next prev parent reply other threads:[~2020-12-30 21:25 UTC|newest] Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-12-28 18:36 [Bug middle-end/98465] New: " romain.geissler at amadeus dot com 2020-12-28 20:54 ` [Bug middle-end/98465] " msebor at gcc dot gnu.org 2020-12-30 12:49 ` romain.geissler at amadeus dot com 2020-12-30 13:22 ` romain.geissler at amadeus dot com 2020-12-30 21:25 ` msebor at gcc dot gnu.org [this message] 2021-01-06 22:38 ` msebor at gcc dot gnu.org 2021-01-06 22:59 ` msebor at gcc dot gnu.org 2021-01-06 23:14 ` msebor at gcc dot gnu.org 2021-01-07 20:26 ` msebor at gcc dot gnu.org 2021-01-13 18:19 ` msebor at gcc dot gnu.org 2021-01-13 18:41 ` law at redhat dot com 2021-01-13 18:52 ` jakub at gcc dot gnu.org 2021-01-13 19:02 ` msebor at gcc dot gnu.org 2021-01-13 19:14 ` jakub at gcc dot gnu.org 2021-01-13 19:30 ` msebor at gcc dot gnu.org 2021-01-14 2:21 ` msebor at gcc dot gnu.org 2021-01-19 19:00 ` msebor at gcc dot gnu.org 2021-01-20 23:20 ` [Bug middle-end/98465] [11 Regression] Bogus -Wstringop-overread with " msebor at gcc dot gnu.org 2021-02-04 14:03 ` jakub at gcc dot gnu.org 2021-02-04 14:39 ` redi at gcc dot gnu.org 2021-02-04 15:25 ` jakub at gcc dot gnu.org 2021-02-04 15:53 ` redi at gcc dot gnu.org 2021-02-04 15:54 ` redi at gcc dot gnu.org 2021-02-04 16:02 ` msebor at gcc dot gnu.org 2021-02-04 16:58 ` jakub at gcc dot gnu.org 2021-02-04 17:12 ` jakub at gcc dot gnu.org 2021-02-04 20:57 ` msebor at gcc dot gnu.org 2021-02-04 21:09 ` jakub at gcc dot gnu.org 2021-02-05 10:15 ` jakub at gcc dot gnu.org 2021-02-08 18:51 ` jakub at gcc dot gnu.org 2021-02-09 11:33 ` cvs-commit at gcc dot gnu.org 2021-02-09 11:35 ` [Bug middle-end/98465] " jakub at gcc dot gnu.org 2021-02-19 23:41 ` msebor at gcc dot gnu.org 2021-11-12 19:53 ` msebor at gcc dot gnu.org 2022-02-15 3:55 ` Randy at miningrigrentals dot com 2022-02-15 9:47 ` redi at gcc dot gnu.org 2022-02-15 9:55 ` Randy at miningrigrentals dot com 2022-02-15 10:02 ` redi at gcc dot gnu.org 2022-02-15 10:50 ` Randy at miningrigrentals dot com 2022-02-15 12:29 ` redi at gcc dot gnu.org 2022-02-15 12:40 ` Randy at miningrigrentals dot com 2022-02-15 12:52 ` redi at gcc dot gnu.org 2022-02-15 19:23 ` Randy at miningrigrentals dot com 2022-02-17 10:37 ` redi at gcc dot gnu.org
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=bug-98465-4-yN0cEo1PqY@http.gcc.gnu.org/bugzilla/ \ --to=gcc-bugzilla@gcc.gnu.org \ --cc=gcc-bugs@gcc.gnu.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).