gcc/gcc
Martin Jambor b8188b7d73 ipa: Fix resolving speculations through cgraph_edge::set_call_stmt
In the PR 98078 testcase, speculative call-graph edges which were
created by IPA-CP are confirmed during inlining but
cgraph_edge::set_call_stmt does not take it very well.

The function enters the update_speculative branch and updates the
edges in the speculation bundle separately (by a recursive call), but
when it processes the first direct edge, most of the bundle actually
ceases to exist because it is devirtualized.  It nevertheless goes on
to attempt to update the indirect edge (that has just been removed),
which surprisingly gets as far as adding the edge to the
call_site_hash, the same devirtualized edge for the second time, and
that triggers an assert.

Fixed by this patch which makes the function aware that it is about to
resolve a speculation and do so instead of updating components of
speculation.  Also, it does so before dealing with the hash because
the speculation resolution code needs the hash to point to the first
speculative direct edge and also cleans the hash up by calling
update_call_stmt_hash_for_removing_direct_edge.

Bootstrapped and tested on x86_64-linux, also profile-LTO-bootstrapped
on the same system.

gcc/ChangeLog:

2021-01-20  Martin Jambor  <mjambor@suse.cz>

	PR ipa/98078
	* cgraph.c (cgraph_edge::set_call_stmt): Do not update all
	corresponding speculative edges if we are about to resolve
	sepculation.  Make edge direct (and so resolve speculations) before
	removing it from call_site_hash.
	(cgraph_edge::make_direct): Relax the initial assert to allow calling
	the function on speculative direct edges.
2021-03-05 17:25:20 +01:00
..
ada Fix build breakage with latest glibc release 2021-03-05 12:47:28 +01:00
analyzer Daily bump. 2021-03-03 00:16:48 +00:00
brig
c OpenACC: C/C++ - fix async parsing [PR99137] 2021-03-05 11:41:44 +01:00
c-family Fix oversight in support for forward declarations 2021-03-05 12:47:28 +01:00
common arm: Ignore --with-mode when CPU only supports one instruction set. 2021-03-03 13:53:37 +00:00
config aarch64: Add missing error_mark_node check [PR99381] 2021-03-04 14:36:39 +00:00
cp c++: instantiating imported specializations [PR 99389] 2021-03-05 05:30:30 -08:00
d Daily bump. 2021-03-04 00:16:48 +00:00
doc Add input_modes parameter to TARGET_MD_ASM_ADJUST hook 2021-03-04 14:33:41 +01:00
fortran Fortran: Follow fixes to -freal-{4,8}-real* handling [PR99355,PR57871] 2021-03-05 10:43:11 +01:00
ginclude
go compiler: allow //go:embed in files underscore-importing embed 2021-03-02 14:03:26 -08:00
jit Daily bump. 2021-02-20 00:16:26 +00:00
lto Daily bump. 2021-03-01 00:16:29 +00:00
objc
objcp
po Daily bump. 2021-03-01 00:16:29 +00:00
rtl-ssa rtl-ssa: Reduce the amount of temporary memory needed [PR98863] 2021-02-15 15:05:22 +00:00
testsuite c++: instantiating imported specializations [PR 99389] 2021-03-05 05:30:30 -08:00
ABOUT-GCC-NLS
acinclude.m4
aclocal.m4
addresses.h
adjust-alignment.c
alias.c
alias.h
align.h
alloc-pool.c
alloc-pool.h
array-traits.h
asan.c
asan.h
attr-fnspec.h
attribs.c PR middle-end/97172 - ICE: tree code 'ssa_name' is not supported in LTO streams 2021-02-24 08:57:59 -07:00
attribs.h
auto-inc-dec.c
auto-profile.c
auto-profile.h
backend.h
BASE-VER Bump gcc/BASE-VER to 11.0.1 now that we are in stage4. 2021-02-25 11:16:29 +01:00
basic-block.h
bb-reorder.c
bb-reorder.h
bitmap.c
bitmap.h
brig-builtins.def
builtin-attrs.def
builtin-types.def
builtins.c Correct a workaround for vectorized stores. 2021-03-03 17:04:48 -07:00
builtins.def
builtins.h
caller-save.c
calls.c calls: Fix a memory leak in maybe_warn_rdwr_sizes [PR99004] 2021-02-09 12:29:32 +01:00
calls.h
ccmp.c
ccmp.h
cfg-flags.def
cfg.c
cfg.h
cfganal.c
cfganal.h
cfgbuild.c
cfgbuild.h
cfgcleanup.c
cfgcleanup.h
cfgexpand.c Add input_modes parameter to TARGET_MD_ASM_ADJUST hook 2021-03-04 14:33:41 +01:00
cfgexpand.h
cfghooks.c
cfghooks.h
cfgloop.c
cfgloop.h
cfgloopanal.c
cfgloopmanip.c
cfgloopmanip.h
cfgrtl.c cfgrtl: Fix up fixup_partitions caused ICE [PR99085] 2021-03-03 09:51:54 +01:00
cfgrtl.h
cgraph.c ipa: Fix resolving speculations through cgraph_edge::set_call_stmt 2021-03-05 17:25:20 +01:00
cgraph.h cgraph: flatten and same_body aliases [PR96078] 2021-03-02 23:20:43 -05:00
cgraphbuild.c
cgraphclones.c
cgraphunit.c cgraph: flatten and same_body aliases [PR96078] 2021-03-02 23:20:43 -05:00
ChangeLog Daily bump. 2021-03-05 00:16:21 +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.dataflow
ChangeLog.gimple-classes
ChangeLog.graphite
ChangeLog.jit
ChangeLog.lib
ChangeLog.ptr
ChangeLog.tree-ssa
ChangeLog.tuples
cif-code.def
collect2-aix.c
collect2-aix.h
collect2.c
collect2.h
collect-utils.c
collect-utils.h
color-macros.h
combine-stack-adj.c
combine.c
common.md
common.opt opts: fix handling of -fpatchable-function-entries option 2021-02-08 12:31:24 +01:00
compare-elim.c
conditions.h
config.build
config.gcc IBM Z: arch14: Add command line options 2021-03-02 11:58:31 +01:00
config.host
config.in
configure
configure.ac
context.c
context.h
convert.c
convert.h
COPYING
COPYING3
COPYING3.LIB
COPYING.LIB
coretypes.h
coroutine-builtins.def
coroutine-passes.cc
coverage.c
coverage.h
cppbuiltin.c
cppbuiltin.h
cppdefault.c
cppdefault.h
cprop.c
cse.c
cselib.c
cselib.h
cstamp-h.in
data-streamer-in.c
data-streamer-out.c
data-streamer.c
data-streamer.h
DATESTAMP Daily bump. 2021-03-05 00:16:21 +00:00
dbgcnt.c
dbgcnt.def
dbgcnt.h
dbxout.c
dbxout.h
dce.c
dce.h
ddg.c
ddg.h
debug.c
debug.h
defaults.h
DEV-PHASE
df-core.c Fix cast in df_worklist_dataflow_doublequeue 2021-02-15 10:43:30 +01:00
df-problems.c df: Record all definitions in DF_LR_BB_INFO->def [PR98863] 2021-02-12 15:54:48 +00:00
df-scan.c
df.h
dfp.c
dfp.h
diagnostic-color.c
diagnostic-color.h
diagnostic-core.h
diagnostic-event-id.h
diagnostic-format-json.cc
diagnostic-metadata.h
diagnostic-path.h
diagnostic-show-locus.c diagnostics: fix ICE on fix-it hints on very long lines [PR99323] 2021-03-02 15:46:06 -05:00
diagnostic-url.h
diagnostic.c
diagnostic.def
diagnostic.h
digraph.cc
digraph.h
dojump.c
dojump.h
dominance.c
dominance.h
domwalk.c
domwalk.h
double-int.c
double-int.h
dse.c
dump-context.h
dumpfile.c
dumpfile.h
dwarf2asm.c
dwarf2asm.h
dwarf2cfi.c dwarf2unwind : Force the CFA after remember/restore pairs [44107/48097]. 2021-03-01 19:37:09 +00:00
dwarf2out.c dwarf2out: Fix -gsplit-dwarf on riscv or other non-.uleb128 targets [PR99090] 2021-03-03 09:53:58 +01:00
dwarf2out.h
early-remat.c
edit-context.c
edit-context.h
emit-rtl.c
emit-rtl.h
errors.c
errors.h
escaped_string.h
et-forest.c
et-forest.h
except.c
except.h
exec-tool.in
explow.c
explow.h
expmed.c expand: Fix ICE in store_bit_field_using_insv [PR93235] 2021-03-04 19:38:08 +01:00
expmed.h
expr.c middle-end/99281 - avoid bitfield stores into addressable types 2021-02-26 12:34:27 +01:00
expr.h
fibonacci_heap.c
fibonacci_heap.h
file-find.c
file-find.h
file-prefix-map.c
file-prefix-map.h
final.c
fixed-value.c
fixed-value.h
flag-types.h
flags.h
fold-const-call.c
fold-const-call.h
fold-const.c fold-const: Fix up ((1 << x) & y) != 0 folding for vectors [PR99225] 2021-02-24 12:10:25 +01:00
fold-const.h
fp-test.c
FSFChangeLog
FSFChangeLog.10
FSFChangeLog.11
function-abi.cc
function-abi.h
function-tests.c
function.c
function.h
fwprop.c reduce sparseset memory requirement 2021-02-11 12:46:34 +01:00
gcc-ar.c
gcc-main.c
gcc-plugin.h
gcc-rich-location.c
gcc-rich-location.h
gcc-symtab.h
gcc.c driver: error for nonexistent linker inputs [PR 98943] 2021-02-05 05:32:34 -08:00
gcc.h
gcov-counter.def
gcov-dump.c
gcov-io.c
gcov-io.h gcov: use mmap pools for KVP. 2021-03-03 14:21:45 +01:00
gcov-iov.c
gcov-tool.c
gcov.c
gcse-common.c
gcse-common.h
gcse.c gcse, ipa-devirt: Use %wd/%wu instead of HOST_WIDE_INT_PRINT* in diagnostics [PR99288] 2021-02-27 10:43:28 +01:00
gcse.h
gdbasan.in
gdbhooks.py
gdbinit.in
gen-pass-instances.awk
genattr-common.c
genattr.c
genattrtab.c
genautomata.c
gencfn-macros.c
gencheck.c
genchecksum.c
gencodes.c
genconditions.c
genconfig.c
genconstants.c
genemit.c
genenums.c
generic-match-head.c
generic-match.h
genextract.c Revert: "Don't build insn-extract.o with rtl checking" 2021-02-24 09:39:11 +00:00
genflags.c
gengenrtl.c
gengtype-lex.l
gengtype-parse.c
gengtype-state.c
gengtype.c
gengtype.h
genhooks.c
genmatch.c
genmddeps.c
genmddump.c Update copyright years. 2021-01-04 10:26:59 +01:00
genmodes.c
genmultilib
genopinit.c
genoutput.c
genpeep.c
genpreds.c
genrecog.c
gensupport.c
gensupport.h
gentarget-def.c
ggc-common.c
ggc-internal.h
ggc-none.c
ggc-page.c
ggc-tests.c
ggc.h
gimple-array-bounds.cc array-bounds: Fix up ICE on overaligned variables [PR99109] 2021-02-18 09:45:19 +01:00
gimple-array-bounds.h
gimple-builder.c
gimple-builder.h
gimple-expr.c
gimple-expr.h
gimple-fold.c
gimple-fold.h
gimple-if-to-switch.cc if-to-switch: fix memory leak in case merging 2021-02-10 13:20:51 +01:00
gimple-isel.cc
gimple-iterator.c
gimple-iterator.h
gimple-laddress.c
gimple-loop-interchange.cc fix memory leaks 2021-02-02 20:07:30 +01:00
gimple-loop-jam.c fix memory leaks 2021-02-02 20:07:30 +01:00
gimple-loop-versioning.cc
gimple-low.c
gimple-low.h
gimple-match-head.c
gimple-match.h
gimple-predict.h
gimple-pretty-print.c
gimple-pretty-print.h
gimple-range-cache.cc
gimple-range-cache.h
gimple-range-edge.cc
gimple-range-edge.h
gimple-range-gori.cc
gimple-range-gori.h
gimple-range.cc
gimple-range.h
gimple-ssa-backprop.c
gimple-ssa-evrp-analyze.c
gimple-ssa-evrp-analyze.h
gimple-ssa-evrp.c
gimple-ssa-isolate-paths.c
gimple-ssa-nonnull-compare.c
gimple-ssa-split-paths.c
gimple-ssa-sprintf.c
gimple-ssa-store-merging.c tree-optimization/99165 - fix ICE in store-merging w/ non-call EH 2021-02-22 08:38:14 +01:00
gimple-ssa-strength-reduction.c
gimple-ssa-warn-alloca.c
gimple-ssa-warn-restrict.c
gimple-ssa-warn-restrict.h
gimple-ssa.h
gimple-streamer-in.c
gimple-streamer-out.c
gimple-streamer.h
gimple-walk.c
gimple-walk.h
gimple.c
gimple.def
gimple.h
gimplify-me.c
gimplify-me.h
gimplify.c openacc: Fix lowering for derived-type mappings through array elements 2021-02-17 06:13:55 -08:00
gimplify.h
glimits.h
godump.c
graph.c
graph.h
graphds.c
graphds.h
graphite-dependences.c
graphite-isl-ast-to-gimple.c
graphite-optimize-isl.c
graphite-poly.c
graphite-scop-detection.c
graphite-sese-to-poly.c
graphite.c
graphite.h
graphviz.cc
graphviz.h
gsstruct.def
gstab.h
gsyms.h
gsyslimits.h
gtm-builtins.def
haifa-sched.c
hard-reg-set.h
hash-map-tests.c
hash-map-traits.h
hash-map.h
hash-set-tests.c
hash-set.h
hash-table.c
hash-table.h
hash-traits.h
highlev-plugin-common.h
hooks.c
hooks.h
host-default.c
hosthooks-def.h
hosthooks.h
hw-doloop.c
hw-doloop.h
hwint.c
hwint.h
ifcvt.c ifcvt: Avoid ICEs trying to force_operand random RTL [PR97487] 2021-02-03 09:10:29 +01:00
ifcvt.h
inchash.c
inchash.h
incpath.c
incpath.h
init-regs.c rtl-optimization: Fix uninitialized use of opaque mode variable ICE [PR98872] 2021-02-15 10:39:24 -06:00
input.c
input.h
insn-addr.h
insn-notes.def
int-vector-builder.h
internal-fn.c
internal-fn.def
internal-fn.h
intl.c
intl.h
ipa-comdats.c
ipa-cp.c
ipa-devirt.c gcse, ipa-devirt: Use %wd/%wu instead of HOST_WIDE_INT_PRINT* in diagnostics [PR99288] 2021-02-27 10:43:28 +01:00
ipa-fnsummary.c Fix ICE in compute_fn_summary 2021-03-01 14:36:11 +01:00
ipa-fnsummary.h
ipa-icf-gimple.c
ipa-icf-gimple.h
ipa-icf.c IPA ICF + ASAN: do not merge vars with different alignment 2021-02-23 16:03:09 +01:00
ipa-icf.h
ipa-inline-analysis.c
ipa-inline-transform.c
ipa-inline.c
ipa-inline.h
ipa-modref-tree.c
ipa-modref-tree.h
ipa-modref.c
ipa-modref.h
ipa-param-manipulation.c
ipa-param-manipulation.h
ipa-polymorphic-call.c
ipa-predicate.c
ipa-predicate.h
ipa-profile.c
ipa-prop.c middle-end/38474 - fix alias walk budget accounting in IPA analysis 2021-02-12 12:34:28 +01:00
ipa-prop.h
ipa-pure-const.c ipa/99029 - fix memory leak in propagate_malloc 2021-02-10 10:09:33 +01:00
ipa-ref.c
ipa-ref.h
ipa-reference.c Fix memory leak in ipa-refernece 2021-02-14 23:24:44 +01:00
ipa-reference.h
ipa-split.c
ipa-sra.c
ipa-utils.c
ipa-utils.h
ipa-visibility.c
ipa.c typos: Fix various typos - mainly misspelled reference* [PR99304] 2021-02-28 11:12:57 +01:00
ira-build.c
ira-color.c
ira-conflicts.c ira: Make sure allocno copies are ordered [PR98791] 2021-02-22 13:46:29 +00:00
ira-costs.c
ira-emit.c
ira-int.h
ira-lives.c
ira.c
ira.h
is-a.h
iterator-utils.h
json.cc
json.h
jump.c
langhooks-def.h
langhooks.c
langhooks.h
LANGUAGES
lcm.c
lcm.h
libfuncs.h
limitx.h
limity.h
lists.c
lock-and-run.sh
loop-doloop.c
loop-init.c
loop-invariant.c
loop-iv.c
loop-unroll.c
loop-unroll.h
lower-subreg.c
lower-subreg.h
lra-assigns.c
lra-coalesce.c
lra-constraints.c [PR99123] inline-asm: Don't use decompose_mem_address to find used hard regs 2021-02-24 13:57:45 -05:00
lra-eliminations.c
lra-int.h
lra-lives.c
lra-remat.c [PR96264] LRA: Check output insn hard regs when updating available rematerialization after the insn 2021-02-18 17:51:03 -05:00
lra-spills.c lra: clear lra_insn_recog_data after simplifying a mem subreg 2021-02-03 13:40:19 +01:00
lra.c
lra.h
lto-cgraph.c
lto-compress.c
lto-compress.h
lto-opts.c
lto-section-in.c
lto-section-names.h
lto-section-out.c
lto-streamer-in.c
lto-streamer-out.c Fill up padding in lto_section struct. 2021-02-03 13:18:52 +01:00
lto-streamer.c more memory leak fixes 2021-02-03 10:04:13 +01:00
lto-streamer.h Fill up padding in lto_section struct. 2021-02-03 13:18:52 +01:00
lto-wrapper.c
machmode.def
machmode.h
main.c
Makefile.in
match.pd match.pd: Use :s for (T)(A) + CST -> (T)(A + CST) [PR95798] 2021-02-25 10:22:53 +01:00
mcf.c
mem-stats-traits.h
mem-stats.h
memmodel.h
memory-block.cc
memory-block.h
mkconfig.sh
mode-classes.def
mode-switching.c
modulo-sched.c
multiple_target.c
mux-utils.h
obstack-utils.h
omp-builtins.def
omp-expand.c
omp-expand.h
omp-general.c
omp-general.h
omp-low.c openmp: Diagnose invalid teams nested in target construct [PR99226] 2021-02-24 20:11:11 +01:00
omp-low.h
omp-oacc-kernels-decompose.cc
omp-offload.c
omp-offload.h
omp-simd-clone.c
omp-simd-clone.h
ONEWS
opt-functions.awk
opt-gather.awk
opt-include.awk
opt-problem.cc
opt-problem.h
opt-read.awk
opt-suggestions.c
opt-suggestions.h
optabs-libfuncs.c
optabs-libfuncs.h
optabs-query.c
optabs-query.h
optabs-tree.c [aarch64][vect] Support V8QI->V8HI WIDEN_ patterns 2021-02-11 15:04:59 +00:00
optabs-tree.h [aarch64][vect] Support V8QI->V8HI WIDEN_ patterns 2021-02-11 15:04:59 +00:00
optabs.c
optabs.def
optabs.h
optc-gen.awk
optc-save-gen.awk s390: add exceptions for param modified by target pragma 2021-03-01 15:42:35 +01:00
opth-gen.awk
optinfo-emit-json.cc
optinfo-emit-json.h
optinfo.cc
optinfo.h
opts-common.c Fix producer string memory leaks 2021-02-12 10:25:06 +01:00
opts-diagnostic.h
opts-global.c
opts.c Fix producer string memory leaks 2021-02-12 10:25:06 +01:00
opts.h opts: fix handling of -fpatchable-function-entries option 2021-02-08 12:31:24 +01:00
ordered-hash-map-tests.cc
ordered-hash-map.h
output.h
params.opt Fix typo in param description. 2021-02-19 17:29:23 +01:00
pass_manager.h
passes.c
passes.def
plugin.c
plugin.def
plugin.h
poly-int-types.h
poly-int.h
postreload-gcse.c
postreload.c
predict.c
predict.def
predict.h
prefix.c
prefix.h
pretty-print.c
pretty-print.h
print-rtl-function.c
print-rtl.c
print-rtl.h
print-tree.c
print-tree.h
profile-count.c
profile-count.h
profile.c
profile.h
range-op.cc
range-op.h
range.cc
range.h
read-md.c
read-md.h
read-rtl-function.c
read-rtl-function.h
read-rtl.c
README.Portability
real.c
real.h
realmpfr.c
realmpfr.h
recog.c passes: Enable split4 with selective scheduling 2 [PR98439] 2021-02-13 16:08:29 +01:00
recog.h
ree.c
reg-notes.def
reg-stack.c
regcprop.c
regcprop.h
reginfo.c
regrename.c
regrename.h
regs.h
regset.h
regstat.c
reload1.c
reload.c
reload.h
reorg.c Fix miscompilation of Python on HP-PA/Linux 2021-02-09 19:54:52 +01:00
resource.c
resource.h
rtl-error.c
rtl-error.h
rtl-iter.h
rtl-ssa.h
rtl-tests.c
rtl.c
rtl.def
rtl.h
rtlanal.c Fix undefined behavior spotted by the sanitizer 2021-03-05 12:47:28 +01:00
rtlanal.h
rtlhash.c
rtlhash.h
rtlhooks-def.h
rtlhooks.c
rtx-vector-builder.c
rtx-vector-builder.h
run-rtl-passes.c
run-rtl-passes.h
sancov.c
sanitizer.def
sanopt.c
sbitmap.c
sbitmap.h
sched-deps.c
sched-ebb.c
sched-int.h
sched-rgn.c
sel-sched-dump.c
sel-sched-dump.h
sel-sched-ir.c
sel-sched-ir.h
sel-sched.c
sel-sched.h
selftest-diagnostic.c
selftest-diagnostic.h
selftest-rtl.c
selftest-rtl.h
selftest-run-tests.c
selftest.c
selftest.h
sese.c
sese.h
shortest-paths.h
shrink-wrap.c
shrink-wrap.h
signop.h
simplify-rtx.c
sort.cc
sparseset.c
sparseset.h reduce sparseset memory requirement 2021-02-11 12:46:34 +01:00
spellcheck-tree.c
spellcheck-tree.h
spellcheck.c
spellcheck.h
splay-tree-utils.cc
splay-tree-utils.h
splay-tree-utils.tcc
sreal.c
sreal.h
ssa-iterators.h
ssa.h
stab.def
stack-ptr-mod.c
statistics.c
statistics.h
stmt.c [PR98096] inline-asm: Take inout operands into account for access to labels by names. 2021-02-16 10:30:10 -05:00
stmt.h
stor-layout.c
stor-layout.h
store-motion.c
streamer-hooks.c
streamer-hooks.h
stringpool.c
stringpool.h
substring-locations.c
substring-locations.h
symbol-summary.h
symtab-clones.cc
symtab-clones.h
symtab-thunks.cc
symtab-thunks.h
symtab.c
sync-builtins.def
system.h
target-def.h
target-globals.c
target-globals.h
target-hooks-macros.h
target-insns.def
target.def Add input_modes parameter to TARGET_MD_ASM_ADJUST hook 2021-03-04 14:33:41 +01:00
target.h
targhooks.c
targhooks.h
timevar.c
timevar.def
timevar.h
toplev.c Fix 2 more leaks related to gen_command_line_string. 2021-02-15 16:01:58 +01:00
toplev.h
tracer.c
tracer.h
trans-mem.c
trans-mem.h
tree-affine.c
tree-affine.h
tree-call-cdce.c
tree-cfg.c tree-cfg: Fix up gimple_merge_blocks FORCED_LABEL handling [PR99034] 2021-02-19 12:14:39 +01:00
tree-cfg.h
tree-cfgcleanup.c
tree-cfgcleanup.h
tree-chrec.c
tree-chrec.h
tree-complex.c
tree-core.h
tree-data-ref.c
tree-data-ref.h
tree-dfa.c
tree-dfa.h
tree-diagnostic-path.cc
tree-diagnostic.c
tree-diagnostic.h
tree-dump.c
tree-dump.h
tree-eh.c
tree-eh.h
tree-emutls.c
tree-hash-traits.h
tree-hasher.h
tree-if-conv.c
tree-if-conv.h
tree-inline.c Fix ICE in tree_inlinable_function_p. 2021-02-22 10:42:52 +01:00
tree-inline.h
tree-into-ssa.c
tree-into-ssa.h
tree-iterator.c
tree-iterator.h
tree-loop-distribution.c more memory leak fixes 2021-02-03 10:04:13 +01:00
tree-nested.c
tree-nested.h
tree-nrv.c
tree-object-size.c
tree-object-size.h
tree-outof-ssa.c
tree-outof-ssa.h
tree-parloops.c
tree-parloops.h
tree-pass.h
tree-phinodes.c
tree-phinodes.h
tree-predcom.c
tree-pretty-print.c middle-end/97855 - avoid recursing into pp_printf 2021-03-04 11:32:34 +01:00
tree-pretty-print.h
tree-profile.c
tree-scalar-evolution.c
tree-scalar-evolution.h
tree-sra.c
tree-sra.h
tree-ssa-address.c
tree-ssa-address.h
tree-ssa-alias-compare.h
tree-ssa-alias.c typos: Fix various typos - mainly misspelled reference* [PR99304] 2021-02-28 11:12:57 +01:00
tree-ssa-alias.h
tree-ssa-ccp.c
tree-ssa-ccp.h
tree-ssa-coalesce.c
tree-ssa-coalesce.h
tree-ssa-copy.c
tree-ssa-dce.c
tree-ssa-dce.h
tree-ssa-dom.c
tree-ssa-dom.h
tree-ssa-dse.c
tree-ssa-dse.h
tree-ssa-forwprop.c
tree-ssa-ifcombine.c
tree-ssa-live.c
tree-ssa-live.h
tree-ssa-loop-ch.c
tree-ssa-loop-im.c fix memory leaks 2021-02-02 20:07:30 +01:00
tree-ssa-loop-ivcanon.c
tree-ssa-loop-ivopts.c
tree-ssa-loop-ivopts.h
tree-ssa-loop-manip.c
tree-ssa-loop-manip.h
tree-ssa-loop-niter.c
tree-ssa-loop-niter.h
tree-ssa-loop-prefetch.c
tree-ssa-loop-split.c
tree-ssa-loop-unswitch.c
tree-ssa-loop.c
tree-ssa-loop.h
tree-ssa-math-opts.c
tree-ssa-math-opts.h
tree-ssa-operands.c
tree-ssa-operands.h
tree-ssa-phiopt.c
tree-ssa-phiprop.c
tree-ssa-pre.c
tree-ssa-propagate.c
tree-ssa-propagate.h
tree-ssa-reassoc.c
tree-ssa-reassoc.h
tree-ssa-sccvn.c Fix O(region-size) unwind in VN 2021-02-09 13:06:55 +01:00
tree-ssa-sccvn.h Fix O(region-size) unwind in VN 2021-02-09 13:06:55 +01:00
tree-ssa-scopedtables.c
tree-ssa-scopedtables.h
tree-ssa-sink.c
tree-ssa-strlen.c PR tree-optimization/98937 - pointer_query cache leaks 2021-02-03 10:23:53 -07:00
tree-ssa-strlen.h
tree-ssa-structalias.c tree-optimization/38474 - improve PTA varinfo sorting 2021-02-16 12:48:07 +01:00
tree-ssa-tail-merge.c
tree-ssa-ter.c
tree-ssa-ter.h
tree-ssa-threadbackward.c
tree-ssa-threadedge.c
tree-ssa-threadedge.h
tree-ssa-threadupdate.c
tree-ssa-threadupdate.h
tree-ssa-uncprop.c
tree-ssa-uninit.c
tree-ssa.c
tree-ssa.h
tree-ssanames.c
tree-ssanames.h
tree-stdarg.c
tree-stdarg.h
tree-streamer-in.c
tree-streamer-out.c
tree-streamer.c
tree-streamer.h
tree-switch-conversion.c if-to-switch: fix memory leak in case merging 2021-02-10 13:20:51 +01:00
tree-switch-conversion.h if-to-switch: fix memory leak in case merging 2021-02-10 13:20:51 +01:00
tree-tailcall.c
tree-vect-data-refs.c
tree-vect-generic.c
tree-vect-loop-manip.c
tree-vect-loop.c tree-optimization/99253 - fix reduction path check 2021-02-25 10:28:49 +01:00
tree-vect-patterns.c
tree-vect-slp-patterns.c slp: fix sharing of SLP only patterns. 2021-02-24 09:43:22 +00:00
tree-vect-slp.c slp: Don't traverse tree on (nil) nodes. 2021-02-25 16:27:50 +00:00
tree-vect-stmts.c openmp: Fix up vectorization simd call badness computation [PR99100] 2021-02-16 08:59:03 +01:00
tree-vector-builder.c
tree-vector-builder.h
tree-vectorizer.c slp: fix sharing of SLP only patterns. 2021-02-24 09:43:22 +00:00
tree-vectorizer.h tree-optimization/98855 - redo BB vectorization costing 2021-02-05 14:03:00 +01:00
tree-vrp.c vrp: Improve register_edge_assert_for [PR95757] 2021-03-02 11:49:12 +01:00
tree-vrp.h
tree.c typos: Fix various typos - mainly misspelled reference* [PR99304] 2021-02-28 11:12:57 +01:00
tree.def
tree.h c++: Completeness of typedef structs [PR 99294] 2021-03-01 05:57:53 -08:00
treestruct.def
tristate.cc
tristate.h
tsan.c
tsan.h
tsystem.h
typeclass.h
typed-splay-tree.c
typed-splay-tree.h
ubsan.c
ubsan.h
unique-ptr-tests.cc
valtrack.c
valtrack.h
value-prof.c
value-prof.h
value-query.cc
value-query.h
value-range-equiv.cc
value-range-equiv.h
value-range.cc
value-range.h
var-tracking.c
varasm.c Add retain attribute to place symbols in SHF_GNU_RETAIN section 2021-02-18 13:27:38 -08:00
varasm.h
varpool.c
vec-perm-indices.c
vec-perm-indices.h
vec.c
vec.h
vector-builder.h
version.c
version.h
vmsdbg.h
vmsdbgout.c
vr-values.c
vr-values.h
vtable-verify.c
vtable-verify.h
web.c
wide-int-bitmask.h i386: Avoid C++ global constructors in every object that includes i386.h 2021-02-18 10:32:57 +01:00
wide-int-print.cc
wide-int-print.h
wide-int.cc
wide-int.h
xcoff.h
xcoffout.c
xcoffout.h

Copyright (C) 2000-2021 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.