gcc/gcc
Jakub Jelinek a65420e1b5 gimplify: Fix up __builtin_c[lt]zg gimplification [PR122188]
The following testcase ICEs during gimplification.
The problem is that save_expr sometimes doesn't create a SAVE_EXPR but
returns the original complex tree (COND_EXPR) and the code then uses that
tree in 2 different spots without unsharing.  As this is done during
gimplification it wasn't unshared when whole body is unshared and because
gimplification is destructive, the first time we gimplify it we destruct it
and second time we try to gimplify it we ICE on it.
Now, we could replace one a use with unshare_expr (a), but because this
is a gimplification hook, I think easier than trying to create a save_expr
is just gimplify the argument, then we know it is is_gimple_val and so
something without side-effects and can safely use it twice.  That argument
would be the first thing to gimplify after return GS_OK anyway, so it
doesn't change argument sequencing etc.

2025-10-08  Jakub Jelinek  <jakub@redhat.com>

	PR c/122188
	* c-gimplify.cc (c_gimplify_expr): Gimplify CALL_EXPR_ARG (*expr_p, 0)
	instead of calling save_expr on it.

	* c-c++-common/pr122188.c: New test.

(cherry picked from commit bb22f7d4d6)
2025-10-14 20:05:17 +02:00
..
ada Daily bump. 2025-10-05 16:56:15 +00:00
analyzer Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
c Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
c-family gimplify: Fix up __builtin_c[lt]zg gimplification [PR122188] 2025-10-14 20:05:17 +02:00
cobol Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
common AVR: Disable tree-switch-conversion per default. 2025-09-10 21:22:01 +02:00
config i386: Remove AMX-TRANSPOSE from Diamond Rapids 2025-10-14 15:04:16 +08:00
cp Daily bump. 2025-09-26 00:25:10 +00:00
d Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
doc i386: Remove AMX-TRANSPOSE from Diamond Rapids 2025-10-14 15:04:16 +08:00
fortran Daily bump. 2025-09-29 00:25:02 +00:00
ginclude
go Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
jit Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
lto Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
m2 Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
objc Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
objcp Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
po Daily bump. 2025-08-25 00:26:32 +00:00
rtl-ssa rtl-ssa: Maintain clobber_group invariant [PR121757] 2025-09-11 17:32:38 +01:00
rust Update ChangeLog and version files for release 2025-08-08 06:52:36 +00:00
sym-exec
testsuite gimplify: Fix up __builtin_c[lt]zg gimplification [PR122188] 2025-10-14 20:05:17 +02:00
text-art
ABOUT-GCC-NLS
BASE-VER Bump BASE-VER 2025-08-08 09:32:56 +02:00
COPYING
COPYING.LIB
COPYING3
COPYING3.LIB
ChangeLog Daily bump. 2025-10-14 00:27:12 +00:00
ChangeLog-1997
ChangeLog-1998
ChangeLog-1999
ChangeLog-2000
ChangeLog-2001
ChangeLog-2002
ChangeLog-2003
ChangeLog-2004
ChangeLog-2005
ChangeLog-2006
ChangeLog-2007
ChangeLog-2008
ChangeLog-2009
ChangeLog-2010
ChangeLog-2011
ChangeLog-2012
ChangeLog-2013
ChangeLog-2014
ChangeLog-2015
ChangeLog-2016
ChangeLog-2017
ChangeLog-2018
ChangeLog-2019
ChangeLog-2020
ChangeLog-2021
ChangeLog-2022
ChangeLog-2023
ChangeLog-2024
ChangeLog.dataflow
ChangeLog.gimple-classes
ChangeLog.graphite
ChangeLog.jit
ChangeLog.lib
ChangeLog.ptr
ChangeLog.tree-ssa
ChangeLog.tuples
DATESTAMP Daily bump. 2025-10-14 00:27:12 +00:00
DEV-PHASE
FSFChangeLog
FSFChangeLog.10
FSFChangeLog.11
LANGUAGES
Makefile.in
ONEWS
README.Portability
acinclude.m4
aclocal.m4
addresses.h
adjust-alignment.cc
alias.cc
alias.h
align.h
alloc-pool.cc
alloc-pool.h
array-traits.h
asan.cc
asan.h
attr-fnspec.h
attr-urls.def
attribs.cc
attribs.h
auto-inc-dec.cc
auto-profile.cc
auto-profile.h
avoid-store-forwarding.cc
avoid-store-forwarding.h
backend.h
basic-block.h
bb-reorder.cc
bb-reorder.h
bbitmap.h
bitmap.cc
bitmap.h
btfout.cc
builtin-attrs.def
builtin-types.def
builtins.cc crc: Error out on non-constant poly arguments for the crc builtins [PR120709] 2025-07-14 22:04:39 -07:00
builtins.def
builtins.h
caller-save.cc
calls.cc calls: Allow musttail calls to noreturn [PR121159] 2025-07-29 10:15:15 +02:00
calls.h
ccmp.cc
ccmp.h
cfg-flags.def
cfg.cc
cfg.h
cfganal.cc
cfganal.h
cfgbuild.cc
cfgbuild.h
cfgcleanup.cc
cfgcleanup.h
cfgexpand.cc expand: Allow musttail tail calls with -fsanitize=address [PR120608] 2025-06-23 16:18:03 +02:00
cfgexpand.h
cfghooks.cc
cfghooks.h
cfgloop.cc
cfgloop.h
cfgloopanal.cc
cfgloopmanip.cc
cfgloopmanip.h
cfgrtl.cc
cfgrtl.h
cgraph.cc Fix ICE in speculative devirtualization 2025-07-31 09:43:30 +02:00
cgraph.h ipa: Dump cgraph_node UID instead of order into ipa-clones dump file 2025-05-20 16:49:22 +02:00
cgraphbuild.cc
cgraphclones.cc ipa: Dump cgraph_node UID instead of order into ipa-clones dump file 2025-05-20 16:49:22 +02:00
cgraphunit.cc
cif-code.def
collect-utils.cc
collect-utils.h
collect2-aix.cc
collect2-aix.h
collect2.cc
collect2.h
color-macros.h
combine-stack-adj.cc
combine.cc
common.md
common.opt
common.opt.urls
compare-elim.cc
conditions.h
config.build
config.gcc nvptx: Support '-march=sm_61' 2025-07-22 11:11:49 +02:00
config.host
config.in
configure
configure.ac
context.cc
context.h
convert.cc
convert.h
coretypes.h
coroutine-builtins.def
coroutine-passes.cc
coverage.cc
coverage.h
cppbuiltin.cc
cppbuiltin.h
cppdefault.cc
cppdefault.h
cprop.cc
crc-verification.cc
crc-verification.h
cse.cc
cselib.cc
cselib.h
cstamp-h.in
ctfc.cc
ctfc.h
ctfout.cc
data-streamer-in.cc
data-streamer-out.cc
data-streamer.cc
data-streamer.h
dbgcnt.cc
dbgcnt.def
dbgcnt.h
dce.cc
dce.h
ddg.cc
ddg.h
debug.cc
debug.h
defaults.h
df-core.cc
df-problems.cc
df-scan.cc
df.h
dfp.cc dfp: Further decimal_real_to_integer fixes [PR120631] 2025-06-19 09:00:58 +02:00
dfp.h
diagnostic-buffer.h
diagnostic-client-data-hooks.h
diagnostic-color.cc
diagnostic-color.h
diagnostic-core.h
diagnostic-diagram.h
diagnostic-event-id.h
diagnostic-format-json.cc
diagnostic-format-sarif.cc
diagnostic-format-sarif.h
diagnostic-format-text.cc
diagnostic-format-text.h
diagnostic-format.h
diagnostic-global-context.cc
diagnostic-highlight-colors.h
diagnostic-label-effects.h
diagnostic-macro-unwinding.cc
diagnostic-macro-unwinding.h
diagnostic-metadata.h
diagnostic-output-file.h
diagnostic-path.cc
diagnostic-path.h
diagnostic-show-locus.cc
diagnostic-spec.cc
diagnostic-spec.h
diagnostic-url.h
diagnostic.cc
diagnostic.def
diagnostic.h
digraph.cc
digraph.h
dojump.cc
dojump.h
dominance.cc
dominance.h
domwalk.cc
domwalk.h
double-int.cc
double-int.h
dse.cc rtl-optimization/120182 - wrong-code with RTL DSE and constant addresses 2025-06-06 09:52:55 +02:00
dump-context.h
dumpfile.cc
dumpfile.h
dwarf2asm.cc
dwarf2asm.h
dwarf2cfi.cc
dwarf2codeview.cc Fix assertion when trying to represent Ada arrays in CodeView 2025-09-01 21:44:44 +01:00
dwarf2codeview.h
dwarf2ctf.cc
dwarf2ctf.h
dwarf2out.cc dwarf2out: Propagate dtprel into the .debug_addr table in resolve_addr_in_expr 2025-05-14 17:09:40 +02:00
dwarf2out.h
early-remat.cc
edit-context.cc
edit-context.h
emit-rtl.cc
emit-rtl.h
errors.cc
errors.h
escaped_string.h
et-forest.cc
et-forest.h
except.cc
except.h
exec-tool.in
explow.cc
explow.h
expmed.cc
expmed.h
expr.cc expr: Handle RAW_DATA_CST in store_constructor [PR121831] 2025-09-24 17:32:15 +02:00
expr.h
ext-dce.cc ext-dce: Fix subreg_lsb is_constant assumption (2) 2025-07-21 15:41:01 +01:00
fibonacci_heap.cc
fibonacci_heap.h
file-find.cc
file-find.h
file-prefix-map.cc
file-prefix-map.h
final.cc
fixed-value.cc
fixed-value.h
flag-types.h
flags.h
fold-const-call.cc
fold-const-call.h
fold-const.cc
fold-const.h
fold-mem-offsets.cc
fp-test.cc
function-abi.cc
function-abi.h
function-tests.cc
function.cc
function.h
fwprop.cc fwprop: Don't propagate asms [PR121253] 2025-08-18 12:15:21 +01:00
gcc-ar.cc
gcc-attribute-urlifier.cc
gcc-main.cc
gcc-plugin.h
gcc-rich-location.cc
gcc-rich-location.h
gcc-symtab.h
gcc-urlifier.cc
gcc-urlifier.def
gcc-urlifier.h
gcc.cc
gcc.h
gcov-counter.def
gcov-dump.cc
gcov-io.cc
gcov-io.h
gcov-tool.cc
gcov.cc
gcse-common.cc
gcse-common.h
gcse.cc gcse: Skip hardreg pre when the hardreg is never live [PR121095] 2025-07-26 11:21:35 -07:00
gcse.h
gdbasan.in
gdbhooks.py
gdbinit.in
gen-pass-instances.awk
genattr-common.cc
genattr.cc
genattrtab.cc
genautomata.cc
gencfn-macros.cc
gencheck.cc
genchecksum.cc
gencodes.cc
genconditions.cc
genconfig.cc
genconstants.cc
genemit.cc
genenums.cc
generic-match-head.cc
generic-match.h
genextract.cc
genflags.cc
gengenrtl.cc
gengtype-lex.l
gengtype-parse.cc
gengtype-state.cc
gengtype.cc
gengtype.h
genhooks.cc
genmatch.cc
genmddeps.cc
genmddump.cc
genmodes.cc
genmultilib
genopinit.cc
genoutput.cc
genpeep.cc
genpreds.cc
genrecog.cc
gensupport.cc
gensupport.h
gentarget-def.cc
genversion.cc
ggc-common.cc
ggc-internal.h
ggc-none.cc
ggc-page.cc
ggc-tests.cc
ggc.h
gimple-array-bounds.cc
gimple-array-bounds.h
gimple-builder.cc
gimple-builder.h
gimple-crc-optimization.cc crc: Fix up ICE from optimize_crc_loop [PR120677] 2025-06-17 13:25:54 +02:00
gimple-expr.cc
gimple-expr.h
gimple-fold.cc gimple-fold: Fix up big endian _BitInt adjustment [PR121131] 2025-07-18 09:30:46 +02:00
gimple-fold.h
gimple-harden-conditionals.cc
gimple-harden-control-flow.cc
gimple-if-to-switch.cc
gimple-isel.cc
gimple-iterator.cc
gimple-iterator.h
gimple-laddress.cc
gimple-loop-interchange.cc
gimple-loop-jam.cc
gimple-loop-versioning.cc
gimple-low.cc
gimple-low.h
gimple-lower-bitint.cc bitint: Fix up lowering optimization of .*_OVERFLOW ifns [PR121828] 2025-09-24 17:33:51 +02:00
gimple-lower-bitint.h
gimple-match-exports.cc
gimple-match-head.cc
gimple-match.h
gimple-predicate-analysis.cc tree-optimization/120729 - limit compile time in uninit_analysis::prune_phi_opnds 2025-06-26 08:51:52 +02:00
gimple-predicate-analysis.h tree-optimization/120729 - limit compile time in uninit_analysis::prune_phi_opnds 2025-06-26 08:51:52 +02:00
gimple-predict.h
gimple-pretty-print.cc
gimple-pretty-print.h
gimple-range-cache.cc
gimple-range-cache.h
gimple-range-edge.cc
gimple-range-edge.h
gimple-range-fold.cc
gimple-range-fold.h
gimple-range-gori.cc
gimple-range-gori.h
gimple-range-infer.cc
gimple-range-infer.h
gimple-range-op.cc
gimple-range-op.h
gimple-range-path.cc
gimple-range-path.h
gimple-range-phi.cc
gimple-range-phi.h
gimple-range-tests.cc
gimple-range-trace.cc
gimple-range-trace.h
gimple-range.cc
gimple-range.h
gimple-ssa-backprop.cc
gimple-ssa-isolate-paths.cc
gimple-ssa-nonnull-compare.cc
gimple-ssa-sccopy.cc
gimple-ssa-split-paths.cc
gimple-ssa-sprintf.cc
gimple-ssa-store-merging.cc bswap: Fix up ubsan detected UB in find_bswap_or_nop [PR121322] 2025-08-01 09:11:25 +02:00
gimple-ssa-strength-reduction.cc
gimple-ssa-warn-access.cc
gimple-ssa-warn-access.h
gimple-ssa-warn-alloca.cc
gimple-ssa-warn-restrict.cc
gimple-ssa-warn-restrict.h
gimple-ssa.h
gimple-streamer-in.cc
gimple-streamer-out.cc
gimple-streamer.h
gimple-walk.cc
gimple-walk.h
gimple-warn-recursion.cc
gimple.cc
gimple.def
gimple.h middle-end: Fix typo in gimple.h 2025-08-31 10:19:21 +01:00
gimplify-me.cc
gimplify-me.h
gimplify.cc
gimplify.h
glimits.h
godump.cc
graph.cc
graph.h
graphds.cc
graphds.h
graphite-dependences.cc
graphite-isl-ast-to-gimple.cc
graphite-optimize-isl.cc
graphite-poly.cc
graphite-scop-detection.cc
graphite-sese-to-poly.cc
graphite.cc
graphite.h
graphviz.cc
graphviz.h
gsstruct.def
gsyms.h
gsyslimits.h
gtm-builtins.def
haifa-sched.cc
hard-reg-set.h
hash-map-tests.cc
hash-map-traits.h
hash-map.h
hash-set-tests.cc
hash-set.h
hash-table.cc
hash-table.h
hash-traits.h
highlev-plugin-common.h
hooks.cc
hooks.h
host-default.cc
hosthooks-def.h
hosthooks.h
hw-doloop.cc
hw-doloop.h
hwint.cc
hwint.h
ifcvt.cc
ifcvt.h
inchash.cc
inchash.h
incpath.cc
incpath.h
init-regs.cc
input.cc
input.h
insn-addr.h
insn-notes.def
int-vector-builder.h
internal-fn.cc tree-optimization/121049 - avoid loop masking with even/odd reduction 2025-07-18 10:39:43 +02:00
internal-fn.def
internal-fn.h tree-optimization/121049 - avoid loop masking with even/odd reduction 2025-07-18 10:39:43 +02:00
intl.cc
intl.h
ipa-comdats.cc
ipa-cp.cc ipa: Dump cgraph_node UID instead of order into ipa-clones dump file 2025-05-20 16:49:22 +02:00
ipa-cp.h
ipa-devirt.cc
ipa-fnsummary.cc ipa: Disallow signature changes in fun->has_musttail functions [PR121023] 2025-07-11 12:54:28 +02:00
ipa-fnsummary.h
ipa-free-lang-data.cc
ipa-icf-gimple.cc
ipa-icf-gimple.h
ipa-icf.cc
ipa-icf.h
ipa-inline-analysis.cc
ipa-inline-transform.cc
ipa-inline.cc
ipa-inline.h
ipa-locality-cloning.cc
ipa-locality-cloning.h
ipa-modref-tree.cc
ipa-modref-tree.h
ipa-modref.cc
ipa-modref.h
ipa-param-manipulation.cc
ipa-param-manipulation.h
ipa-polymorphic-call.cc
ipa-predicate.cc
ipa-predicate.h
ipa-profile.cc
ipa-prop.cc ipa: When inlining, don't combine PT JFs changing signedness (PR120295) 2025-06-12 14:07:48 +02:00
ipa-prop.h
ipa-pure-const.cc
ipa-ref.cc
ipa-ref.h
ipa-reference.cc
ipa-reference.h
ipa-split.cc
ipa-sra.cc Fix IPA-SRA issue with reverse SSO on specific pattern 2025-05-27 21:33:16 +02:00
ipa-strub.cc
ipa-strub.h
ipa-utils.cc
ipa-utils.h
ipa-visibility.cc
ipa.cc
ira-build.cc
ira-color.cc
ira-conflicts.cc
ira-costs.cc
ira-emit.cc
ira-int.h
ira-lives.cc
ira.cc
ira.h
is-a.h
iterator-utils.h
json-parsing.cc
json-parsing.h
json.cc
json.h
jump.cc
langhooks-def.h
langhooks.cc
langhooks.h
late-combine.cc
lazy-diagnostic-path.cc
lazy-diagnostic-path.h
lcm.cc
lcm.h
libfuncs.h
libgdiagnostics++.h
libgdiagnostics.cc
libgdiagnostics.h
libgdiagnostics.map
libsarifreplay.cc
libsarifreplay.h
limitx.h
limity.h
lists.cc
lock-and-run.sh
lockfile.cc
lockfile.h
logical-location.h
loop-doloop.cc
loop-init.cc
loop-invariant.cc
loop-iv.cc
loop-unroll.cc
loop-unroll.h
lower-subreg.cc
lower-subreg.h
lra-assigns.cc
lra-coalesce.cc
lra-constraints.cc Fix latent LRA bug 2025-09-16 11:47:48 -06:00
lra-eliminations.cc
lra-int.h
lra-lives.cc
lra-remat.cc
lra-spills.cc
lra.cc
lra.h
lto-cgraph.cc
lto-compress.cc
lto-compress.h
lto-ltrans-cache.cc
lto-ltrans-cache.h
lto-opts.cc
lto-section-in.cc
lto-section-names.h
lto-section-out.cc
lto-streamer-in.cc
lto-streamer-out.cc 'TYPE_EMPTY_P' vs. code offloading [PR120308] 2025-07-22 11:11:50 +02:00
lto-streamer.cc
lto-streamer.h Bump LTO_minor_version 2025-06-26 08:53:01 +02:00
lto-wrapper.cc
machmode.def
machmode.h change get_best_mode args int -> HOST_WIDE_INT [PR121264] 2025-07-31 12:26:48 +02:00
main.cc
make-unique.h
match.pd match.pd: Do not canonicalize division by power 2 for {ROUND, CEIL}_DIV 2025-10-13 15:24:00 +05:30
mcf.cc
mem-stats-traits.h
mem-stats.h
memmodel.h
memory-block.cc
memory-block.h
mkconfig.sh
mode-classes.def
mode-switching.cc
modulo-sched.cc
multiple_target.cc
mux-utils.h
obstack-utils.h
omp-api.h
omp-builtins.def
omp-expand.cc omp-expand: Initialize fd->loop.n2 if needed for the zero iter case [PR121453] 2025-09-24 17:03:59 +02:00
omp-expand.h
omp-general.cc OpenMP: Unshare expr in context-selector condition [PR121922] 2025-09-25 12:09:00 +02:00
omp-general.h
omp-low.cc openmp: Fix up ICE in lower_omp_regimplify_operands_p [PR121977] 2025-09-24 17:43:53 +02:00
omp-low.h
omp-oacc-kernels-decompose.cc
omp-oacc-neuter-broadcast.cc
omp-offload.cc OpenMP: Fix implicit 'declare target' for <ostream> 2025-07-22 11:11:51 +02:00
omp-offload.h
omp-selectors.h
omp-simd-clone.cc
omp-simd-clone.h
opt-functions.awk
opt-gather.awk
opt-include.awk
opt-problem.cc
opt-problem.h
opt-read.awk
opt-suggestions.cc
opt-suggestions.h
optabs-libfuncs.cc
optabs-libfuncs.h
optabs-query.cc
optabs-query.h
optabs-tree.cc
optabs-tree.h
optabs.cc
optabs.def
optabs.h
optc-gen.awk
optc-save-gen.awk
opth-gen.awk
optinfo-emit-json.cc
optinfo-emit-json.h
optinfo.cc
optinfo.h
options-urls-cc-gen.awk
opts-common.cc
opts-diagnostic.cc
opts-diagnostic.h
opts-global.cc
opts-jobserver.h
opts.cc
opts.h
ordered-hash-map-tests.cc
ordered-hash-map.h
output.h
pair-fusion.cc
pair-fusion.h
params.opt tree-optimization/120924 - up --param uninit-max-chain-len 2025-07-18 11:46:15 +02:00
params.opt.urls
pass_manager.h
passes.cc
passes.def tailc: Handle musttail in case of non-cleaned-up cleanups, especially ASan related [PR120608] 2025-07-01 12:09:18 +02:00
path-coverage.cc
plugin.cc
plugin.def
plugin.h
pointer-query.cc
pointer-query.h
poly-int-types.h
poly-int.h
postreload-gcse.cc
postreload.cc
predict.cc
predict.def
predict.h
prefix.cc
prefix.h
pretty-print-format-impl.h
pretty-print-markup.h
pretty-print-urlifier.h
pretty-print.cc
pretty-print.h
prime-paths.cc
print-rtl-function.cc
print-rtl.cc
print-rtl.h
print-tree.cc
print-tree.h
profile-count.cc
profile-count.h
profile.cc
profile.h
range-op-float.cc
range-op-mixed.h
range-op-ptr.cc
range-op.cc
range-op.h
range.cc
range.h
read-md.cc
read-md.h
read-rtl-function.cc Make the RTL frontend set REG_NREGS correctly 2025-07-21 15:41:02 +01:00
read-rtl-function.h
read-rtl.cc
real.cc dfp, real: Fix up FLOAT_EXPR/FIX_TRUNC_EXPR constant folding between dfp and large _BitInt [PR120631] 2025-06-19 09:00:42 +02:00
real.h
realmpfr.cc
realmpfr.h
recog.cc
recog.h
ree.cc
reg-notes.def
reg-stack.cc
regcprop.cc
regcprop.h
regenerate-attr-urls.py
regenerate-opt-urls.py
reginfo.cc
regrename.cc
regrename.h
regs.h
regset.h
regstat.cc
reload.cc
reload.h
reload1.cc
reorg.cc
resource.cc
resource.h
rtl-error.cc
rtl-error.h
rtl-iter.h
rtl-ssa.h
rtl-tests.cc
rtl.cc
rtl.def
rtl.h
rtlanal.cc rtl-ssa: Reject non-address uses of autoinc regs [PR120347] 2025-06-25 17:28:42 +01:00
rtlanal.h
rtlhash.cc
rtlhash.h
rtlhooks-def.h
rtlhooks.cc
rtx-vector-builder.cc
rtx-vector-builder.h
run-rtl-passes.cc
run-rtl-passes.h
sancov.cc
sanitizer.def
sanopt.cc
sarif-replay.cc
sarif-spec-urls.def
sbitmap.cc
sbitmap.h
sched-deps.cc
sched-ebb.cc
sched-int.h
sched-rgn.cc
sel-sched-dump.cc
sel-sched-dump.h
sel-sched-ir.cc
sel-sched-ir.h
sel-sched.cc
sel-sched.h
selftest-diagnostic-path.cc
selftest-diagnostic-path.h
selftest-diagnostic-show-locus.h
selftest-diagnostic.cc
selftest-diagnostic.h
selftest-json.cc
selftest-json.h
selftest-logical-location.cc
selftest-logical-location.h
selftest-rtl.cc
selftest-rtl.h
selftest-run-tests.cc
selftest-tree.h
selftest.cc
selftest.h
sese.cc
sese.h
shortest-paths.h
shrink-wrap.cc
shrink-wrap.h
signop.h
simple-diagnostic-path.cc
simple-diagnostic-path.h
simplify-rtx.cc Remove MODE_COMPOSITE_P test from simplify_gen_subreg [PR120718] 2025-08-14 17:56:50 +01:00
sort.cc
sparseset.cc
sparseset.h
spellcheck-tree.cc
spellcheck-tree.h
spellcheck.cc
spellcheck.h
splay-tree-utils.cc
splay-tree-utils.h
splay-tree-utils.tcc
sreal.cc
sreal.h
ssa-iterators.h
ssa.h
stack-ptr-mod.cc
statistics.cc
statistics.h
stmt.cc stmt: Handle %cc[name] in resolve_asm_operand_names [PR122133] 2025-10-14 20:04:23 +02:00
stmt.h
stor-layout.cc change get_best_mode args int -> HOST_WIDE_INT [PR121264] 2025-07-31 12:26:48 +02:00
stor-layout.h
store-motion.cc
streamer-hooks.cc
streamer-hooks.h
stringpool.cc
stringpool.h
substring-locations.cc
substring-locations.h
symbol-summary.h
symtab-clones.cc
symtab-clones.h
symtab-thunks.cc
symtab-thunks.h
symtab.cc ipa: Dump cgraph_node UID instead of order into ipa-clones dump file 2025-05-20 16:49:22 +02:00
sync-builtins.def
system.h
target-def.h
target-globals.cc
target-globals.h
target-hooks-macros.h
target-insns.def
target.def
target.h
targhooks.cc
targhooks.h
text-range-label.h
timevar.cc
timevar.def
timevar.h
toplev.cc
toplev.h
tracer.cc
tracer.h
trans-mem.cc
trans-mem.h
tree-affine.cc
tree-affine.h
tree-assume.cc
tree-call-cdce.cc
tree-cfg.cc
tree-cfg.h
tree-cfgcleanup.cc
tree-cfgcleanup.h
tree-chrec.cc tree-chrec: Use signed_type_for in convert_affine_scev 2025-06-13 09:58:17 +02:00
tree-chrec.h
tree-complex.cc middle-end: Fix complex lowering of cabs with no LHS [PR120369] 2025-07-03 10:32:43 -07:00
tree-core.h
tree-data-ref.cc
tree-data-ref.h
tree-dfa.cc
tree-dfa.h
tree-diagnostic-client-data-hooks.cc
tree-diagnostic.cc
tree-diagnostic.h
tree-dump.cc
tree-dump.h
tree-eh.cc
tree-eh.h
tree-emutls.cc
tree-hash-traits.h
tree-hasher.h
tree-if-conv.cc
tree-if-conv.h
tree-inline.cc
tree-inline.h
tree-into-ssa.cc
tree-into-ssa.h
tree-iterator.cc
tree-iterator.h
tree-logical-location.cc
tree-logical-location.h
tree-loop-distribution.cc
tree-nested.cc
tree-nested.h
tree-nrv.cc Defuse 'RESULT_DECL' check in 'pass_nrv' (for offloading compilation) [PR119835] 2025-07-22 11:11:50 +02:00
tree-object-size.cc tree-optimization/120780: Support object size for containing objects 2025-07-10 06:07:33 -05:00
tree-object-size.h
tree-outof-ssa.cc
tree-outof-ssa.h
tree-parloops.cc
tree-parloops.h
tree-pass.h
tree-phinodes.cc
tree-phinodes.h
tree-predcom.cc
tree-pretty-print-markup.h
tree-pretty-print.cc
tree-pretty-print.h
tree-profile.cc
tree-scalar-evolution.cc tree-optimization/121370 - avoid UB in building a CHREC 2025-09-24 10:29:48 +02:00
tree-scalar-evolution.h
tree-sra.cc tree-optimization/121527 - wrong SRA with aggregate copy 2025-09-24 10:36:18 +02:00
tree-sra.h
tree-ssa-address.cc
tree-ssa-address.h
tree-ssa-alias-compare.h
tree-ssa-alias.cc tree-optimization/121323 - UBSAN error in ao_ref_init_from_ptr_and_range 2025-08-01 09:20:03 +02:00
tree-ssa-alias.h
tree-ssa-ccp.cc
tree-ssa-ccp.h
tree-ssa-coalesce.cc
tree-ssa-coalesce.h
tree-ssa-copy.cc
tree-ssa-dce.cc
tree-ssa-dce.h
tree-ssa-dom.cc
tree-ssa-dom.h
tree-ssa-dse.cc tree-optimization/120817 - bogus DSE of .MASK_STORE 2025-07-09 08:29:35 +02:00
tree-ssa-dse.h
tree-ssa-forwprop.cc
tree-ssa-ifcombine.cc
tree-ssa-live.cc
tree-ssa-live.h
tree-ssa-loop-ch.cc
tree-ssa-loop-im.cc tree-optimization/120341 - stores into STRING_CSTs can trap 2025-06-06 09:53:11 +02:00
tree-ssa-loop-ivcanon.cc
tree-ssa-loop-ivopts.cc tree-optimization/121844 - IVOPTs and asm goto in latch 2025-09-24 10:36:18 +02:00
tree-ssa-loop-ivopts.h
tree-ssa-loop-manip.cc
tree-ssa-loop-manip.h
tree-ssa-loop-niter.cc
tree-ssa-loop-niter.h
tree-ssa-loop-prefetch.cc
tree-ssa-loop-split.cc
tree-ssa-loop-unswitch.cc
tree-ssa-loop.cc
tree-ssa-loop.h
tree-ssa-math-opts.cc widening_mul: Reset flow sensitive info in maybe_optimize_guarding_check [PR122104] 2025-10-14 20:00:08 +02:00
tree-ssa-math-opts.h
tree-ssa-operands.cc
tree-ssa-operands.h
tree-ssa-phiopt.cc tree-optimization/120341 - stores into STRING_CSTs can trap 2025-06-06 09:53:11 +02:00
tree-ssa-phiprop.cc
tree-ssa-pre.cc tree-optimization/121035 - handle stray VN values without expression 2025-07-18 10:39:43 +02:00
tree-ssa-propagate.cc Deal with prior EH/abormal cleanup when fixing up noreturn calls 2025-09-24 10:36:18 +02:00
tree-ssa-propagate.h
tree-ssa-reassoc.cc
tree-ssa-reassoc.h
tree-ssa-sccvn.cc tree-optimization/122016 - PRE insertion breaks abnormal coalescing 2025-09-24 10:36:18 +02:00
tree-ssa-sccvn.h
tree-ssa-scopedtables.cc
tree-ssa-scopedtables.h
tree-ssa-sink.cc
tree-ssa-strlen.cc
tree-ssa-strlen.h
tree-ssa-structalias.cc tree-optimization/120358 - bogus PTA with structure access 2025-07-09 08:29:35 +02:00
tree-ssa-tail-merge.cc
tree-ssa-ter.cc
tree-ssa-ter.h
tree-ssa-threadbackward.cc tree-optimization/120003 - missed jump threading 2025-06-06 09:52:37 +02:00
tree-ssa-threadedge.cc
tree-ssa-threadedge.h
tree-ssa-threadupdate.cc
tree-ssa-threadupdate.h
tree-ssa-uncprop.cc
tree-ssa-uninit.cc
tree-ssa.cc
tree-ssa.h
tree-ssanames.cc
tree-ssanames.h
tree-stdarg.cc
tree-stdarg.h
tree-streamer-in.cc 'TYPE_EMPTY_P' vs. code offloading [PR120308] 2025-07-22 11:11:50 +02:00
tree-streamer-out.cc 'TYPE_EMPTY_P' vs. code offloading [PR120308] 2025-07-22 11:11:50 +02:00
tree-streamer.cc
tree-streamer.h
tree-switch-conversion.cc
tree-switch-conversion.h
tree-tailcall.cc tailc: Handle other forms of finally_tmp.N conditional cleanups after musttail [PR121389] 2025-08-08 10:35:00 +02:00
tree-vect-data-refs.cc vect: Fix insufficient alignment requirement for speculative loads [PR121190] 2025-07-31 06:01:42 +01:00
tree-vect-generic.cc
tree-vect-loop-manip.cc
tree-vect-loop.cc tree-optimization/121256 - re-instantiate check on SLP node 2025-07-31 13:47:39 +02:00
tree-vect-patterns.cc
tree-vect-slp-patterns.cc
tree-vect-slp.cc tree-optimization/121659 - bogus swap of reduction operands 2025-09-24 10:36:18 +02:00
tree-vect-stmts.cc tree-optimization/121130 - vectorizable_call cannot handle .MASK_CALL 2025-07-31 08:26:36 +02:00
tree-vector-builder.cc
tree-vector-builder.h
tree-vectorizer.cc
tree-vectorizer.h vectorizer: Fix riscv build [PR120042] 2025-06-10 11:21:14 +02:00
tree-vrp.cc
tree-vrp.h
tree.cc
tree.def
tree.h Fix IPA-SRA issue with reverse SSO on specific pattern 2025-05-27 21:33:16 +02:00
treestruct.def
tristate.cc
tristate.h
tsan.cc
tsan.h
tsystem.h
typeclass.h
typed-splay-tree.cc
typed-splay-tree.h
ubsan.cc
ubsan.h
unique-argv.h
valtrack.cc
valtrack.h
value-pointer-equiv.cc
value-pointer-equiv.h
value-prof.cc
value-prof.h
value-query.cc
value-query.h
value-range-pretty-print.cc
value-range-pretty-print.h
value-range-storage.cc
value-range-storage.h
value-range.cc
value-range.h
value-relation.cc
value-relation.h
var-tracking.cc
varasm.cc
varasm.h
varpool.cc
vec-perm-indices.cc
vec-perm-indices.h
vec.cc
vec.h
vector-builder.h
vmsdbg.h
vmsdbgout.cc
vr-values.cc tree-optimization/120654 - ICE with range query from IVOPTs 2025-06-26 08:51:44 +02:00
vr-values.h
vtable-verify.cc
vtable-verify.h
warning-control.cc
web.cc
wide-int-bitmask.h
wide-int-print.cc
wide-int-print.h
wide-int.cc
wide-int.h
xcoff.h

README.Portability

Copyright (C) 2000-2025 Free Software Foundation, Inc.

This file is intended to contain a few notes about writing C code
within GCC so that it compiles without error on the full range of
compilers GCC needs to be able to compile on.

The problem is that many ISO-standard constructs are not accepted by
either old or buggy compilers, and we keep getting bitten by them.
This knowledge until now has been sparsely spread around, so I
thought I'd collect it in one useful place.  Please add and correct
any problems as you come across them.

I'm going to start from a base of the ISO C90 standard, since that is
probably what most people code to naturally.  Obviously using
constructs introduced after that is not a good idea.

For the complete coding style conventions used in GCC, please read
http://gcc.gnu.org/codingconventions.html


String literals
---------------

Some compilers like MSVC++ have fairly low limits on the maximum
length of a string literal; 509 is the lowest we've come across.  You
may need to break up a long printf statement into many smaller ones.


Empty macro arguments
---------------------

ISO C (6.8.3 in the 1990 standard) specifies the following:

If (before argument substitution) any argument consists of no
preprocessing tokens, the behavior is undefined.

This was relaxed by ISO C99, but some older compilers emit an error,
so code like

#define foo(x, y) x y
foo (bar, )

needs to be coded in some other way.


Avoid unnecessary test before free
----------------------------------

Since SunOS 4 stopped being a reasonable portability target,
(which happened around 2007) there has been no need to guard
against "free (NULL)".  Thus, any guard like the following
constitutes a redundant test:

  if (P)
    free (P);

It is better to avoid the test.[*]
Instead, simply free P, regardless of whether it is NULL.

[*] However, if your profiling exposes a test like this in a
performance-critical loop, say where P is nearly always NULL, and
the cost of calling free on a NULL pointer would be prohibitively
high, consider using __builtin_expect, e.g., like this:

  if (__builtin_expect (ptr != NULL, 0))
    free (ptr);



Trigraphs
---------

You weren't going to use them anyway, but some otherwise ISO C
compliant compilers do not accept trigraphs.


Suffixes on Integer Constants
-----------------------------

You should never use a 'l' suffix on integer constants ('L' is fine),
since it can easily be confused with the number '1'.


			Common Coding Pitfalls
			======================

errno
-----

errno might be declared as a macro.


Implicit int
------------

In C, the 'int' keyword can often be omitted from type declarations.
For instance, you can write

  unsigned variable;

as shorthand for

  unsigned int variable;

There are several places where this can cause trouble.  First, suppose
'variable' is a long; then you might think

  (unsigned) variable

would convert it to unsigned long.  It does not.  It converts to
unsigned int.  This mostly causes problems on 64-bit platforms, where
long and int are not the same size.

Second, if you write a function definition with no return type at
all:

  operate (int a, int b)
  {
    ...
  }

that function is expected to return int, *not* void.  GCC will warn
about this.

Implicit function declarations always have return type int.  So if you
correct the above definition to

  void
  operate (int a, int b)
  ...

but operate() is called above its definition, you will get an error
about a "type mismatch with previous implicit declaration".  The cure
is to prototype all functions at the top of the file, or in an
appropriate header.

Char vs unsigned char vs int
----------------------------

In C, unqualified 'char' may be either signed or unsigned; it is the
implementation's choice.  When you are processing 7-bit ASCII, it does
not matter.  But when your program must handle arbitrary binary data,
or fully 8-bit character sets, you have a problem.  The most obvious
issue is if you have a look-up table indexed by characters.

For instance, the character '\341' in ISO Latin 1 is SMALL LETTER A
WITH ACUTE ACCENT.  In the proper locale, isalpha('\341') will be
true.  But if you read '\341' from a file and store it in a plain
char, isalpha(c) may look up character 225, or it may look up
character -31.  And the ctype table has no entry at offset -31, so
your program will crash.  (If you're lucky.)

It is wise to use unsigned char everywhere you possibly can.  This
avoids all these problems.  Unfortunately, the routines in <string.h>
take plain char arguments, so you have to remember to cast them back
and forth - or avoid the use of strxxx() functions, which is probably
a good idea anyway.

Another common mistake is to use either char or unsigned char to
receive the result of getc() or related stdio functions.  They may
return EOF, which is outside the range of values representable by
char.  If you use char, some legal character value may be confused
with EOF, such as '\377' (SMALL LETTER Y WITH UMLAUT, in Latin-1).
The correct choice is int.

A more subtle version of the same mistake might look like this:

  unsigned char pushback[NPUSHBACK];
  int pbidx;
  #define unget(c) (assert(pbidx < NPUSHBACK), pushback[pbidx++] = (c))
  #define get(c) (pbidx ? pushback[--pbidx] : getchar())
  ...
  unget(EOF);

which will mysteriously turn a pushed-back EOF into a SMALL LETTER Y
WITH UMLAUT.


Other common pitfalls
---------------------

o Expecting 'plain' char to be either sign or unsigned extending.

o Shifting an item by a negative amount or by greater than or equal to
  the number of bits in a type (expecting shifts by 32 to be sensible
  has caused quite a number of bugs at least in the early days).

o Expecting ints shifted right to be sign extended.

o Modifying the same value twice within one sequence point.

o Host vs. target floating point representation, including emitting NaNs
  and Infinities in a form that the assembler handles.

o qsort being an unstable sort function (unstable in the sense that
  multiple items that sort the same may be sorted in different orders
  by different qsort functions).

o Passing incorrect types to fprintf and friends.

o Adding a function declaration for a module declared in another file to
  a .c file instead of to a .h file.