This is an archive of the discontinued LLVM Phabricator instance.

[OpenMP] Fix detecting warning options for GCC
ClosedPublic

Authored by mstorsjo on Dec 13 2022, 1:53 AM.

Details

Summary

If testing for a warning option like -Wno-<foo> with GCC, GCC won't
print any diagnostic at all, leading to the options being accepted
incorrectly. However later, if compiling a file that actually prints
another warning, GCC will also print warnings about these -Wno-<foo>
options being unrecognized.

This avoids warning spam like this, for every OpenMP source file that
produces build warnings with GCC:

cc1plus: warning: unrecognized command line option ‘-Wno-int-to-void-pointer-cast’
cc1plus: warning: unrecognized command line option ‘-Wno-return-type-c-linkage’
cc1plus: warning: unrecognized command line option ‘-Wno-covered-switch-default’
cc1plus: warning: unrecognized command line option ‘-Wno-enum-constexpr-conversion’

This matches how such warning options are detected and added in
llvm/cmake/modules/HandleLLVMOptions.cmake, e.g. like this:

check_cxx_compiler_flag("-Wclass-memaccess" CXX_SUPPORTS_CLASS_MEMACCESS_FLAG)
append_if(CXX_SUPPORTS_CLASS_MEMACCESS_FLAG "-Wno-class-memaccess" CMAKE_CXX_FLAGS)

This also matches how LLDB warning options were restructured for
GCC compatibility in e546bbfda0ab91cf78c096d8c035851cc7c3b9f3.

Diff Detail

Event Timeline

mstorsjo created this revision.Dec 13 2022, 1:53 AM
Herald added a project: Restricted Project. · View Herald TranscriptDec 13 2022, 1:53 AM
mstorsjo requested review of this revision.Dec 13 2022, 1:53 AM
Herald added a project: Restricted Project. · View Herald TranscriptDec 13 2022, 1:53 AM
Herald added a subscriber: sstefan1. · View Herald Transcript
JonChesterfield accepted this revision.Dec 13 2022, 3:37 AM

The duplication in our cmake files makes me sad. Thanks for the fix

This revision is now accepted and ready to land.Dec 13 2022, 3:37 AM
This revision was automatically updated to reflect the committed changes.