public inbox for openembedded-core@lists.openembedded.org
 help / color / mirror / Atom feed
From: Richard Purdie <richard.purdie@linuxfoundation.org>
To: jdmason@kudzu.us, openembedded-core@lists.openembedded.org
Subject: Re: [OE-core] [PATCH] gn: remove gcc override
Date: Sat, 04 Oct 2025 15:17:18 +0100	[thread overview]
Message-ID: <f66ecf89fde642336b3d454f38acab28ebe8ad11.camel@linuxfoundation.org> (raw)
In-Reply-To: <20251003200206.1201180-1-jon.mason@arm.com>

On Fri, 2025-10-03 at 16:02 -0400, Jon Mason via lists.openembedded.org
wrote:
> When compiling gn with clang, the following errors are being seen
> (with
> qemuarm64-secureboot machine, possibly others):
> 
> In file included from /usr/include/c++/12/string:40,
>                  from ../sources/gn-
> 0+git/src/base/strings/string_number_conversions.h:11,
>                  from ../sources/gn-0+git/src/gn/operators.cc:10:
> In static member function ‘static constexpr void
> std::char_traits<char>::assign(char_type&, const char_type&)’,
>     inlined from ‘static constexpr void
> std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::_S_copy(_CharT*,
> const _CharT*, size_type) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:421:23,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Allocator>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::_M_replace(size_type, size_type, const _CharT*, size_type)
> [with _CharT = char; _Traits = std::char_traits<char>; _Alloc =
> std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.tcc:532:22,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Alloc>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::assign(const _CharT*) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:1647:19,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Alloc>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::operator=(const _CharT*) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:815:28,
>     inlined from ‘Err {anonymous}::MakeOverwriteError(const
> BinaryOpNode*, const Value&)’ at ../sources/gn-
> 0+git/src/gn/operators.cc:202:17:
> /usr/include/c++/12/bits/char_traits.h:354:16: error: ‘((const
> std::char_traits<char>::char_type*)((char*)&empty_def +
> offsetof(std::__cxx11::string, std::__cxx11::basic_string<char,
> std::char_traits<char>, std::allocator<char> >::<unnamed>)))[2]’ may
> be used uninitialized [-Werror=maybe-uninitialized]
>   354 |         __c1 = __c2;
>       |                ^~~~
> ../sources/gn-0+git/src/gn/operators.cc: In function ‘Err
> {anonymous}::MakeOverwriteError(const BinaryOpNode*, const Value&)’:
> ../sources/gn-0+git/src/gn/operators.cc:198:15: note: ‘empty_def’
> declared here
>   198 |   std::string empty_def;
>       |               ^~~~~~~~~
> In static member function ‘static constexpr void
> std::char_traits<char>::assign(char_type&, const char_type&)’,
>     inlined from ‘static constexpr void
> std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::_S_copy(_CharT*,
> const _CharT*, size_type) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:421:23,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Allocator>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::_M_replace(size_type, size_type, const _CharT*, size_type)
> [with _CharT = char; _Traits = std::char_traits<char>; _Alloc =
> std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.tcc:532:22,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Alloc>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::assign(const _CharT*) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:1647:19,
>     inlined from ‘constexpr std::__cxx11::basic_string<_CharT,
> _Traits, _Alloc>& std::__cxx11::basic_string<_CharT, _Traits,
> _Alloc>::operator=(const _CharT*) [with _CharT = char; _Traits =
> std::char_traits<char>; _Alloc = std::allocator<char>]’ at
> /usr/include/c++/12/bits/basic_string.h:815:28,
>     inlined from ‘Err {anonymous}::MakeOverwriteError(const
> BinaryOpNode*, const Value&)’ at ../sources/gn-
> 0+git/src/gn/operators.cc:205:17:
> /usr/include/c++/12/bits/char_traits.h:354:16: error: ‘((const
> std::char_traits<char>::char_type*)((char*)&empty_def +
> offsetof(std::__cxx11::string, std::__cxx11::basic_string<char,
> std::char_traits<char>, std::allocator<char> >::<unnamed>)))[2]’ may
> be used uninitialized [-Werror=maybe-uninitialized]
>   354 |         __c1 = __c2;
>       |                ^~~~
> ../sources/gn-0+git/src/gn/operators.cc: In function ‘Err
> {anonymous}::MakeOverwriteError(const BinaryOpNode*, const Value&)’:
> ../sources/gn-0+git/src/gn/operators.cc:198:15: note: ‘empty_def’
> declared here
>   198 |   std::string empty_def;
>       |               ^~~~~~~~~
> cc1plus: all warnings being treated as errors
> 
> Remove the toolchain-gcc override to allow the cflag
> -Wno-error=maybe-uninitialized to be applied.
> 
> Signed-off-by: Jon Mason <jon.mason@arm.com>
> ---
>  meta/recipes-devtools/gn/gn_git.bb | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/meta/recipes-devtools/gn/gn_git.bb b/meta/recipes-
> devtools/gn/gn_git.bb
> index d8896609b193..2443ea7139f4 100644
> --- a/meta/recipes-devtools/gn/gn_git.bb
> +++ b/meta/recipes-devtools/gn/gn_git.bb
> @@ -49,4 +49,4 @@ BBCLASSEXTEND = "native"
>  
>  COMPATIBLE_HOST = "^(?!riscv32).*"
>  
> -CFLAGS:append:toolchain-gcc = " -Wno-error=maybe-uninitialized"
> +CFLAGS:append = " -Wno-error=maybe-uninitialized"

In that case can you drop the append and just make it a += please?

Cheers,

Richard


      reply	other threads:[~2025-10-04 14:17 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-10-03 20:02 [PATCH] gn: remove gcc override Jon Mason
2025-10-04 14:17 ` Richard Purdie [this message]

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=f66ecf89fde642336b3d454f38acab28ebe8ad11.camel@linuxfoundation.org \
    --to=richard.purdie@linuxfoundation.org \
    --cc=jdmason@kudzu.us \
    --cc=openembedded-core@lists.openembedded.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: link
Be 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