gcc/gcc
Iain Sandoe 448c89d590 coroutines: Fix handling of artificial vars [PR94886]
The testcase ICEs because the range-based for generates three
artificial variables that need to be allocated to the coroutine
frame but, when walking the BIND_EXR that contains these, the
DECL_INITIAL for one of them refers to an entry appearing later,
which means that the frame entry hasn't been allocated when that
INITIAL is walked.

The solution is to defer walking the DECL_INITIAL/SIZE etc. until
all the BIND_EXPR vars have been processed.

gcc/cp/ChangeLog:

2020-04-30  Iain Sandoe  <iain@sandoe.co.uk>

	PR c++/94886
	* coroutines.cc (transform_local_var_uses): Defer walking
	the DECL_INITIALs of BIND_EXPR vars until all the frame
	allocations have been made.

gcc/testsuite/ChangeLog:

2020-04-30  Iain Sandoe  <iain@sandoe.co.uk>

	PR c++/94886
	* g++.dg/coroutines/pr94886-folly-3.C: New test.
2020-04-30 16:00:39 +01:00
..
ada Fix GIMPLE verification failure in LTO mode on Ada code 2020-03-11 11:34:25 +01:00
analyzer analyzer: fix ICE copying struct [PR 94816] 2020-04-28 13:26:22 -04:00
brig
c c, objc: Fix up c_parser_objc_selector_arg after CPP_SCOPE changes [PR94637] 2020-04-19 12:13:33 +02:00
c-family diagnostics: Add %{...%} pretty-format support for URLs and use it in -Wpsabi diagnostics 2020-04-29 22:41:47 +02:00
common [gcn] Set 'UI_NONE' for 'TARGET_EXCEPT_UNWIND_INFO' [PR94282] 2020-04-29 09:39:03 +02:00
config [AArch64] Make -moutline-atomics on by default 2020-04-30 13:12:13 +01:00
cp coroutines: Fix handling of artificial vars [PR94886] 2020-04-30 16:00:39 +01:00
d d: Fix documentation of -defaultlib= and -debuglib= 2020-04-30 12:27:05 +02:00
doc [AArch64] Make -moutline-atomics on by default 2020-04-30 13:12:13 +01:00
fortran fortran/io.c: Fix use of uninitialized variable num [PR94769] 2020-04-29 16:37:18 +02:00
ginclude
go gotest: increase the test timeout 2020-04-23 20:16:32 -07:00
jit libgccjit: add new version entry point 2020-03-31 20:57:15 +02:00
lto c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02:00
objc
objcp
po Regenerate gcc.pot. 2020-04-27 21:20:49 +00:00
testsuite coroutines: Fix handling of artificial vars [PR94886] 2020-04-30 16:00:39 +01:00
ABOUT-GCC-NLS
acinclude.m4
aclocal.m4
addresses.h
alias.c Fix some comment typos in alias.c. 2020-04-02 15:29:10 -07:00
alias.h tree-optimization/93946 - fix bogus redundant store removal in FRE, DSE and DOM 2020-03-03 11:02:28 +01:00
align.h
alloc-pool.c
alloc-pool.h
array-traits.h
asan.c ubsan: Avoid -Wpadded warnings [PR94641] 2020-04-21 17:06:31 +02:00
asan.h
attribs.c attribs: Don't diagnose attribute exclusions during error recovery [PR94705] 2020-04-23 09:54:14 +02:00
attribs.h
auto-inc-dec.c auto-inc-dec: Don't add incs/decs to bare CLOBBERs [PR93124] 2020-01-23 09:19:15 +00:00
auto-profile.c
auto-profile.h
backend.h
BASE-VER Bump gcc/BASE-VER to 10.0.1 now that we are in stage4. 2020-01-15 14:48:55 +01:00
basic-block.h
bb-reorder.c typo fix: Fix probablity, becuse, sucessor and destinarion typos [PR93912] 2020-02-25 22:10:48 +01:00
bb-reorder.h
bitmap.c
bitmap.h
brig-builtins.def
builtin-attrs.def
builtin-types.def [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
builtins.c expand: Don't depend on warning flags in code generation of strnlen [PR94189] 2020-03-17 10:42:35 +01:00
builtins.def Improve DSE which in turn eliminates the need for jump threading and block duplication for the original testcase in pr89689 which in turn eliminates the false positive -Warray-bounds warning for the original testcase. 2020-01-29 12:26:35 -07:00
builtins.h
caller-save.c
calls.c calls: Remove FIXME for cxx17_empty_base_field_p 2020-04-29 13:47:21 +01:00
calls.h calls: Remove FIXME for cxx17_empty_base_field_p 2020-04-29 13:47:21 +01:00
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 Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
cfgexpand.h
cfghooks.c typo fix: Fix probablity, becuse, sucessor and destinarion typos [PR93912] 2020-02-25 22:10:48 +01:00
cfghooks.h
cfgloop.c
cfgloop.h c/94392 - only enable -ffinite-loops for C++ 2020-04-02 16:53:21 +02:00
cfgloopanal.c
cfgloopmanip.c c/94392 - only enable -ffinite-loops for C++ 2020-04-02 16:53:21 +02:00
cfgloopmanip.h
cfgrtl.c Fix -fcompare-debug issue in delete_insn_and_edges [PR94618] 2020-04-17 10:33:27 +02:00
cfgrtl.h
cgraph.c ipa: Make call redirection detect already adjusted calls (PR 93621) 2020-04-16 19:21:02 +02:00
cgraph.h Do not remove ifunc_resolver in LTO. 2020-04-27 06:44:29 +02:00
cgraphbuild.c
cgraphclones.c fix PVS studio reported bugs 2020-04-17 10:38:45 +02:00
cgraphunit.c ipa: Make call redirection detect already adjusted calls (PR 93621) 2020-04-16 19:21:02 +02:00
ChangeLog diagnostics: Fix spelling in comment 2020-04-30 14:43:30 +01: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 Fix up comment typo. 2020-02-05 11:36:25 +01:00
ChangeLog-2010
ChangeLog-2011
ChangeLog-2012
ChangeLog-2013
ChangeLog-2014
ChangeLog-2015
ChangeLog-2016
ChangeLog-2017
ChangeLog-2018
ChangeLog-2019
ChangeLog.dataflow
ChangeLog.gimple-classes
ChangeLog.graphite
ChangeLog.jit
ChangeLog.lib
ChangeLog.ptr
ChangeLog.tree-ssa
ChangeLog.tuples
cif-code.def
collect-utils.c
collect-utils.h
collect2-aix.c
collect2-aix.h
collect2.c Fix a typo in comment. 2020-02-19 18:49:16 +01:00
collect2.h Fix -save-temp leaking files in /tmp 2020-02-19 12:48:54 +01:00
color-macros.h
combine-stack-adj.c
combine.c rtl combine should consider NaNs when generate fp min/max [PR94708] 2020-04-24 11:25:38 +02:00
common.md
common.opt PR driver/90983 - manual documents -Wno-stack-usage flag but it is unrecognized 2020-04-23 17:49:01 -06:00
compare-elim.c
conditions.h
config.build
config.gcc [Arm] Implement CDE intrinsics for MVE registers. 2020-04-08 16:06:47 +01:00
config.host
config.in --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
configure --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
configure.ac --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
context.c
context.h
convert.c
convert.h
COPYING
COPYING.LIB
COPYING3
COPYING3.LIB
coretypes.h Introduce -fprofile-reproducibility and support it with TOP N. 2020-02-18 14:28:22 +01:00
coroutine-builtins.def [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
coroutine-passes.cc [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
coverage.c Do not use HAVE_DOS_BASED_FILE_SYSTEM for Cygwin. 2020-04-17 09:22:51 +02:00
coverage.h
cppbuiltin.c
cppbuiltin.h
cppdefault.c
cppdefault.h
cprop.c
cse.c [committed] [PR rtl-optimization/90275] Another 90275 related cse.c fix 2020-04-17 15:40:43 -06:00
cselib.c cselib: Mark the cselib_record_sp_cfa_base_equiv VALUE as preserved [PR94551] 2020-04-11 07:34:38 +02:00
cselib.h cselib, var-tracking: Improve debug info after the cselib sp tracking changes [PR94495] 2020-04-09 21:21:24 +02:00
cstamp-h.in
data-streamer-in.c
data-streamer-out.c
data-streamer.c
data-streamer.h
DATESTAMP Daily bump. 2020-04-30 00:16:16 +00:00
dbgcnt.c
dbgcnt.def
dbgcnt.h
dbxout.c
dbxout.h
dce.c
dce.h
ddg.c modulo-sched: fix bootstrap compare-debug issue 2020-03-27 08:02:56 +03:00
ddg.h modulo-sched: fix bootstrap compare-debug issue 2020-03-27 08:02:56 +03:00
debug.c
debug.h
defaults.h
DEV-PHASE
df-core.c df: Don't abuse bb->aux (PR94148, PR94042) 2020-03-13 15:15:26 +00:00
df-problems.c
df-scan.c
df.h
dfp.c dfp: Fix decimal_to_binary [PR94111] 2020-03-11 09:33:52 +01:00
dfp.h
diagnostic-color.c PR 87488: Add --with-diagnostics-urls configuration option 2020-02-15 08:32:57 +01:00
diagnostic-color.h
diagnostic-core.h diagnostic_metadata: unbreak xgettext (v2) 2020-01-28 13:47:14 -05:00
diagnostic-event-id.h
diagnostic-format-json.cc
diagnostic-metadata.h
diagnostic-path.h
diagnostic-show-locus.c
diagnostic-url.h PR 87488: Add --with-diagnostics-urls configuration option 2020-02-15 08:32:57 +01:00
diagnostic.c diagnostics: don't generate URLs that won't be used 2020-02-17 20:40:00 -05:00
diagnostic.def
diagnostic.h
digraph.cc analyzer: fix build with gcc 4.4 (PR 93276) 2020-01-27 09:43:23 -05:00
digraph.h
dojump.c dojump: Fix gcc.dg/torture/pr91323.c for aarch64 targets 2020-01-27 10:53:33 +00:00
dojump.h
dominance.c
dominance.h
domwalk.c
domwalk.h
double-int.c
double-int.h
dse.c cselib: Reuse VALUEs on sp adjustments [PR92264] 2020-04-02 14:28:14 +02:00
dump-context.h
dumpfile.c selftest: Work around GCC 4.2 PR33916 bug by optimizing the ctor [PR89494] 2020-04-15 15:14:45 +02:00
dumpfile.h
dwarf2asm.c
dwarf2asm.h
dwarf2cfi.c aarch64: Fix .cfi_window_save with pac-ret [PR94515] 2020-04-27 09:10:05 +01:00
dwarf2out.c fix PVS studio reported bugs 2020-04-17 10:38:45 +02:00
dwarf2out.h
early-remat.c early-remat: Handle sets of multiple candidate regs [PR94605] 2020-04-16 13:06:10 +01:00
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: Fix ICE caused by plus_constant [PR94002] 2020-03-03 10:42:34 +01:00
explow.h
expmed.c Fix unaligned load with small memcpy on the ARM 2020-03-13 09:21:42 +01:00
expmed.h
expr.c middle-end/94614 - avoid multiword moves to nothing 2020-04-16 12:54:38 +02: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 division folding with vector operands [PR94412] 2020-03-31 11:06:43 +02:00
fold-const.h sccvn: Handle bitfields in vn_reference_lookup_3 [PR93582] 2020-02-13 10:04:11 +01:00
fp-test.c
FSFChangeLog
FSFChangeLog.10
FSFChangeLog.11
function-abi.cc
function-abi.h
function-tests.c
function.c bootstrap: Fix building with GCC 4.2 [PR89494] 2020-04-16 10:15:18 +02:00
function.h [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
fwprop.c
gcc-ar.c
gcc-main.c
gcc-plugin.h
gcc-rich-location.c
gcc-rich-location.h
gcc-symtab.h
gcc.c PR47785: Add support for handling Xassembler/Wa options with LTO. 2020-02-24 11:55:45 +05:30
gcc.h
gcov-counter.def
gcov-dump.c
gcov-io.c
gcov-io.h
gcov-iov.c
gcov-tool.c
gcov.c
gcse-common.c
gcse-common.h
gcse.c
gcse.h
gdbasan.in
gdbhooks.py pretty-print SSA names 2020-04-16 09:56:31 +02:00
gdbinit.in gdbinit.in: Fix typo. 2020-03-09 20:18:39 -04:00
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
genflags.c
gengenrtl.c
gengtype-lex.l
gengtype-parse.c
gengtype-state.c
gengtype.c
gengtype.h
genhooks.c
genmatch.c middle-end/90648 fend off builtin calls with not enough arguments from match 2020-02-05 14:06:40 +01:00
genmddeps.c
genmddump.c
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-builder.c
gimple-builder.h
gimple-expr.c
gimple-expr.h
gimple-fold.c PR tree-optimization/94131 - ICE on printf with a VLA string and -fno-tree-ccp 2020-03-25 09:39:50 -06:00
gimple-fold.h
gimple-iterator.c
gimple-iterator.h
gimple-laddress.c
gimple-loop-interchange.cc
gimple-loop-jam.c
gimple-loop-versioning.cc Fix up duplicated duplicated words in comments 2020-03-18 12:56:26 +01:00
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-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 tree-optimization: Fix use of uninitialized variable [PR94774] 2020-04-29 15:51:47 +02:00
gimple-ssa-store-merging.c Fix segfault with -O2 -fnon-call-exceptions -ftracer 2020-04-23 22:28:02 +02:00
gimple-ssa-strength-reduction.c
gimple-ssa-warn-alloca.c PR middle-end/94004 - missing -Walloca on calls to alloca due to -Wno-system-headers 2020-03-25 10:48:13 -06:00
gimple-ssa-warn-restrict.c PR middle-end/94647 - bogus -Warray-bounds on strncpy into a larger member array from a smaller array 2020-04-21 11:11:06 -06:00
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 Allow new/delete operator deletion only for replaceable. 2020-04-08 17:16:55 +02:00
gimple.def
gimple.h Allow new/delete operator deletion only for replaceable. 2020-04-08 17:16:55 +02:00
gimplify-me.c
gimplify-me.h
gimplify.c [OpenMP] Fix 'omp exit data' for Fortran arrays (PR 94635) 2020-04-17 19:08:55 +02:00
gimplify.h
glimits.h
godump.c
graph.c
graph.h
graphds.c
graphds.h
graphite-dependences.c
graphite-isl-ast-to-gimple.c tree-optimization/93964 - adjust ISL code generation for pointer params 2020-03-04 11:37:27 +01:00
graphite-optimize-isl.c
graphite-poly.c
graphite-scop-detection.c tree-optimization/93964 - adjust ISL code generation for pointer params 2020-03-04 11:37:27 +01:00
graphite-sese-to-poly.c
graphite.c
graphite.h
graphviz.cc analyzer: add new supergraph visualization 2020-03-27 10:02:39 -04:00
graphviz.h analyzer: add new supergraph visualization 2020-03-27 10:02:39 -04:00
gsstruct.def
gstab.h
gsyms.h
gsyslimits.h
gtm-builtins.def
haifa-sched.c Avoid putting a REG_NOTE on anything other than an INSN in haifa-sched.c 2020-03-06 08:35:18 -07:00
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
hsa-brig-format.h
hsa-brig.c
hsa-builtins.def
hsa-common.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
hsa-common.h Fix doubled indefinite articles, mostly in comments. 2020-03-14 08:15:08 +01:00
hsa-dump.c
hsa-gen.c
hsa-regalloc.c
hw-doloop.c
hw-doloop.h
hwint.c
hwint.h
ifcvt.c
ifcvt.h
inchash.c
inchash.h
incpath.c
incpath.h
init-regs.c
input.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
input.h
insn-addr.h
insn-notes.def
int-vector-builder.h
internal-fn.c [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
internal-fn.def [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
internal-fn.h
intl.c
intl.h
ipa-comdats.c Fix ICE on invalid calls_comdat_local flag [pr94582] 2020-04-20 15:25:50 +02:00
ipa-cp.c Fix correct offset in ipa_get_jf_ancestor_result. 2020-03-20 11:01:13 +01:00
ipa-devirt.c Fix grammar in error message. 2020-02-17 13:21:34 +01:00
ipa-fnsummary.c Fix previous commit. 2020-04-04 17:55:04 +02:00
ipa-fnsummary.h
ipa-hsa.c
ipa-icf-gimple.c ICF: compare type attributes for gimple_call_fntypes. 2020-04-03 09:05:06 +02:00
ipa-icf-gimple.h
ipa-icf.c Allow new/delete operator deletion only for replaceable. 2020-04-08 17:16:55 +02:00
ipa-icf.h
ipa-inline-analysis.c
ipa-inline-transform.c ipa: Make call redirection detect already adjusted calls (PR 93621) 2020-04-16 19:21:02 +02:00
ipa-inline.c ipa: Fix wrong code with failed propagation to builtin_constant_p [PR93940] 2020-04-04 11:45:13 +02:00
ipa-inline.h ipa: Make call redirection detect already adjusted calls (PR 93621) 2020-04-16 19:21:02 +02:00
ipa-param-manipulation.c Drop MALLOC attribute for void functions. 2020-02-18 14:39:41 +01:00
ipa-param-manipulation.h Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
ipa-polymorphic-call.c
ipa-predicate.c Fix up duplicated duplicated words in comments 2020-03-18 12:56:26 +01:00
ipa-predicate.h
ipa-profile.c ipa: fix handling of multiple speculations (PR93318) 2020-01-28 20:38:09 +01:00
ipa-prop.c ipa/94245 - avoid folding when we want an ADDR_EXPR 2020-03-23 11:23:29 +01:00
ipa-prop.h Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
ipa-pure-const.c Drop MALLOC attribute for void functions. 2020-02-18 14:39:41 +01:00
ipa-ref.c
ipa-ref.h
ipa-reference.c
ipa-reference.h
ipa-split.c Fix verifier ICE on wrong comdat local flag [PR93347] 2020-03-20 22:06:24 +01:00
ipa-sra.c ipa-sra: Fix treatment of internal functions (PR 94434) 2020-04-14 19:26:39 +02:00
ipa-utils.c ipa: fix handling of multiple speculations (PR93318) 2020-01-28 20:38:09 +01:00
ipa-utils.h
ipa-visibility.c Typo fixes - functoin -> function [PR93796] 2020-02-18 08:54:52 +01:00
ipa.c Fix updating of call_stmt_site_hash 2020-01-21 16:33:43 +01:00
ira-build.c
ira-color.c Revert: One more patch for PR93564: Prefer smaller hard regno when we do not honor reg alloc order. 2020-03-09 14:05:09 -04:00
ira-conflicts.c regalloc/debug: fix buggy print_hard_reg_set 2020-02-11 18:16:40 +01:00
ira-costs.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
ira-emit.c
ira-int.h
ira-lives.c Fix for PR93272 - LRA: EH reg allocated to hold local variable 2020-01-28 15:47:35 -05:00
ira.c [IRA] Fix PR91052 by skipping multiple_sets insn in combine_and_move_insns 2020-02-11 23:22:02 -06:00
ira.h
is-a.h
json.cc
json.h
jump.c
langhooks-def.h
langhooks.c middle-end: Avoid using DECL_UID in ASM_FORMAT_PRIVATE_NAME [PR94223] 2020-03-25 09:18:33 +01:00
langhooks.h Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
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-iv: make find_simple_exit static 2020-03-10 19:54:50 +03:00
loop-unroll.c
loop-unroll.h
lower-subreg.c middle-end/94614 - avoid multiword moves to nothing 2020-04-16 12:54:38 +02:00
lower-subreg.h
lra-assigns.c PR93561 -- [bounds checking] memory overflow for spill_for 2020-02-06 17:10:58 -05:00
lra-coalesce.c
lra-constraints.c lra: Tighten check for reloading paradoxical subregs [PR94052] 2020-03-21 08:53:30 +00:00
lra-eliminations.c
lra-int.h
lra-lives.c lra: Stop eh_return data regs being incorrectly marked live [PR92989] 2020-04-06 19:00:14 +01:00
lra-remat.c
lra-spills.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
lra.c lra: set insn_code_data to NULL when freeing 2020-03-30 21:03:00 -04:00
lra.h
lto-cgraph.c Fix ICE in speculative_call_info 2020-01-19 13:49:38 +01:00
lto-compress.c
lto-compress.h
lto-opts.c fix -fdebug-prefix-map without gas .file support 2020-02-27 11:43:52 +01:00
lto-section-in.c API extension for binutils (type of symbols). 2020-03-19 16:56:27 +01:00
lto-section-names.h
lto-section-out.c
lto-streamer-in.c c/94392 - only enable -ffinite-loops for C++ 2020-04-02 16:53:21 +02:00
lto-streamer-out.c c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02:00
lto-streamer.c
lto-streamer.h API extension for binutils (type of symbols). 2020-03-19 16:56:27 +01:00
lto-wrapper.c Do not strcat to result of getenv. 2020-03-13 13:50:01 +01:00
machmode.def
machmode.h
main.c
Makefile.in --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
match.pd fold undefined pointer offsetting 2020-03-11 15:35:51 +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 modulo-sched: fix bootstrap compare-debug issue 2020-03-27 08:02:56 +03:00
multiple_target.c Make target_clones resolver fn static if possible. 2020-03-25 11:03:39 +01:00
omp-builtins.def
omp-expand.c OpenACC: Avoid ICE in type-cast 'async', 'wait' clauses 2020-04-23 15:58:09 +01:00
omp-expand.h
omp-general.c Handle 'omp declare target' attribute set for both OpenACC and OpenMP 'target' [PR89433, PR93465] 2020-04-10 15:34:22 +02:00
omp-general.h
omp-grid.c HSA: omp-grid.c – access proper clause code 2020-04-08 11:54:29 +02:00
omp-grid.h
omp-low.c Remove fishy self-assignment in omp-low.c [PR94629] 2020-04-21 15:12:05 +02:00
omp-low.h
omp-offload.c Fix OpenMP offload handling for target-link variables for nvptx (PR81689) 2020-03-24 15:13:56 +01:00
omp-offload.h
omp-simd-clone.c openmp: Avoid ICEs with declare simd; declare simd inbranch [PR93555] 2020-02-05 11:32:37 +01:00
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 optabs: Don't use scalar conversions for vectors [PR93843] 2020-02-26 12:46:59 +00:00
optabs-tree.h
optabs.c Shortcut identity VEC_PERM expansion [PR94710] 2020-04-23 21:59:01 +02:00
optabs.def
optabs.h Fix uninitialized field in expand_operand. 2020-01-16 12:25:31 +00:00
optc-gen.awk
optc-save-gen.awk
opth-gen.awk
optinfo-emit-json.cc Fix up duplicated duplicated words in comments 2020-03-18 12:56:26 +01:00
optinfo-emit-json.h
optinfo.cc
optinfo.h
opts-common.c PR47785: Add support for handling Xassembler/Wa options with LTO. 2020-02-24 11:55:45 +05:30
opts-diagnostic.h
opts-global.c c/86134 avoid errors for unrecognized -Wno- options 2020-02-17 09:32:44 +01:00
opts.c --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
opts.h --with-{documentation,changes}-root-url tweaks 2020-04-30 11:49:40 +02:00
ordered-hash-map-tests.cc
ordered-hash-map.h
output.h i386: Fix up -fdollars-in-identifiers with identifiers starting with $ in -masm=att [PR91298] 2020-01-22 10:22:16 +01:00
params.opt params: Decrease -param=max-find-base-term-values= default [PR92264] 2020-04-02 14:34:42 +02:00
pass_manager.h
passes.c pass_manager: Fix ICE with -fdump-passes -fdisable-tree-* [PR93874] 2020-02-25 10:21:34 +01:00
passes.def [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
plugin.c
plugin.def
plugin.h
poly-int-types.h
poly-int.h
postreload-gcse.c
postreload.c postreload: Fix autoinc handling in reload_cse_move2add [PR94516] 2020-04-08 12:04:46 +02:00
predict.c typo fix: Fix probablity, becuse, sucessor and destinarion typos [PR93912] 2020-02-25 22:10:48 +01:00
predict.def
predict.h
prefix.c
prefix.h
pretty-print.c diagnostics: Fix spelling in comment 2020-04-30 14:43:30 +01:00
pretty-print.h PR 87488: Add --with-diagnostics-urls configuration option 2020-02-15 08:32:57 +01:00
print-rtl-function.c
print-rtl.c print-rtl: Fix printing of CONST_STRING in DEBUG_INSNs [PR93399] 2020-03-05 09:12:44 +01:00
print-rtl.h
print-tree.c
print-tree.h
profile-count.c * profile-count.c (profile_quality_display_names): Fix ordering. 2020-01-28 21:31:26 +01:00
profile-count.h ipa: fix handling of multiple speculations (PR93318) 2020-01-28 20:38:09 +01:00
profile.c Smart relaxation of TOP N counter. 2020-01-22 12:08:11 +01:00
profile.h
range-op.cc
range-op.h
range.cc
range.h
read-md.c
read-md.h
read-rtl-function.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
read-rtl-function.h
read-rtl.c
README.Portability
real.c real: Fix roundeven on inf/nan [PR93663] 2020-02-12 22:15:40 +01:00
real.h
realmpfr.c
realmpfr.h
recog.c Improve splitX passes management 2020-02-09 17:56:38 +01:00
recog.h
ree.c
reg-notes.def
reg-stack.c
regcprop.c
regcprop.h
reginfo.c
regrename.c Don't let DEBUG_INSNSs change register renaming decisions 2020-04-18 09:39:18 -06:00
regrename.h
regs.h
regset.h
regstat.c
reload.c
reload.h
reload1.c cselib, reload: Fix cselib ICE on m68k/microblaze [PR94526] 2020-04-08 21:23:58 +02:00
reorg.c Fix incorrect filling of delay slots in branchy code at -O2 2020-03-13 10:03:30 +01:00
resource.c Fix incorrect filling of delay slots in branchy code at -O2 2020-03-13 10:03:30 +01:00
resource.h Fix incorrect filling of delay slots in branchy code at -O2 2020-03-13 10:03:30 +01:00
rtl-error.c
rtl-error.h
rtl-iter.h
rtl-tests.c
rtl.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
rtl.def
rtl.h cselib: Reuse VALUEs on sp adjustments [PR92264] 2020-04-02 14:28:14 +02:00
rtlanal.c [rtl] Harden 'set_noop_p' for non-constant selectors [PR94279] 2020-04-29 09:44:36 +02:00
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 sanopt: Avoid crash on anonymous parameter [PR93436] 2020-01-26 16:28:10 -05:00
sbitmap.c
sbitmap.h
sched-deps.c Uninitialized padding in struct _dep. 2020-01-16 12:30:22 +00:00
sched-ebb.c
sched-int.h Uninitialized padding in struct _dep. 2020-01-16 12:30:22 +00:00
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 Fix warning URLs for Fortran and analyzer [PR 92830] 2020-04-27 15:02:57 -04:00
selftest.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
selftest.h Fix warning URLs for Fortran and analyzer [PR 92830] 2020-04-27 15:02:57 -04:00
sese.c
sese.h
shortest-paths.h
shrink-wrap.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
shrink-wrap.h
signop.h
simplify-rtx.c Verify the code used for the optimized comparison is valid for the comparison's mode. 2020-03-23 17:59:34 -06:00
sort.cc
sparseset.c
sparseset.h
spellcheck-tree.c
spellcheck-tree.h
spellcheck.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
spellcheck.h
sreal.c
sreal.h
ssa-iterators.h
ssa.h
stab.def
stack-ptr-mod.c
statistics.c
statistics.h
stmt.c
stmt.h
stor-layout.c ubsan: Avoid -Wpadded warnings [PR94641] 2020-04-21 17:06:31 +02:00
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.c Fix spacing in symtab_node::dump_references. 2020-04-20 14:09:41 +02:00
sync-builtins.def
system.h
target-def.h
target-globals.c
target-globals.h
target-hooks-macros.h
target-insns.def
target.def Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
target.h
targhooks.c Fix PR 93242: patchable-function-entry broken on MIPS 2020-01-20 14:22:42 +00:00
targhooks.h
timevar.c
timevar.def
timevar.h
toplev.c toplev.c: Check for null argument to fprintf 2020-04-30 07:53:02 +02:00
toplev.h
tracer.c
tracer.h
trans-mem.c
trans-mem.h
tree-affine.c
tree-affine.h
tree-call-cdce.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
tree-cfg.c c/94392 - only enable -ffinite-loops for C++ 2020-04-02 16:53:21 +02:00
tree-cfg.h
tree-cfgcleanup.c
tree-cfgcleanup.h
tree-chrec.c
tree-chrec.h
tree-complex.c
tree-core.h c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02:00
tree-data-ref.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
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 Record outer non-cleanup region in TREE EH. 2020-01-20 11:10:30 +01:00
tree-eh.h
tree-emutls.c Do not call null register_common in emutls 2020-02-17 17:08:11 -03:00
tree-hash-traits.h
tree-hasher.h
tree-if-conv.c if-conv: Delete dead stmts backwards in ifcvt_local_dce [PR94283] 2020-03-25 08:08:04 +01:00
tree-if-conv.h
tree-inline.c Fix ICE on invalid calls_comdat_local flag [pr94582] 2020-04-20 15:25:50 +02:00
tree-inline.h
tree-into-ssa.c Change recursive prepare_block_for_update to use a worklist 2020-01-21 11:17:26 +00:00
tree-into-ssa.h
tree-iterator.c c++: Fix further protected_set_expr_location related -fcompare-debug issues [PR94441] 2020-04-04 09:16:07 +02:00
tree-iterator.h c++: Fix further protected_set_expr_location related -fcompare-debug issues [PR94441] 2020-04-04 09:16:07 +02:00
tree-loop-distribution.c Update post order number for merged SCC. 2020-03-16 11:11:42 +08:00
tree-nested.c tree-nested: Fix handling of *reduction clauses with C array sections [PR93566] 2020-03-15 01:27:40 +01:00
tree-nested.h
tree-nrv.c
tree-object-size.c objsz: Don't call replace_uses_by on SSA_NAME_OCCURS_IN_ABNORMAL_PHI [PR94423] 2020-04-01 09:44:59 +02:00
tree-object-size.h
tree-outof-ssa.c
tree-outof-ssa.h
tree-parloops.c tree-optimization/93439 move clique bookkeeping to OMP expansion 2020-01-28 14:10:16 +01:00
tree-parloops.h
tree-pass.h [C++ coroutines] Initial implementation. 2020-01-18 11:55:56 +00:00
tree-phinodes.c
tree-phinodes.h
tree-predcom.c predcom: Fix invalid store-store commoning [PR93434] 2020-01-28 10:47:43 +00:00
tree-pretty-print.c print-rtl: Fix printing of CONST_STRING in DEBUG_INSNs [PR93399] 2020-03-05 09:12:44 +01:00
tree-pretty-print.h print-rtl: Fix printing of CONST_STRING in DEBUG_INSNs [PR93399] 2020-03-05 09:12:44 +01:00
tree-profile.c Add __gcov_indirect_call_profiler_v4_atomic. 2020-01-27 16:20:10 +01:00
tree-scalar-evolution.c
tree-scalar-evolution.h
tree-sra.c sra: Fix access verification (PR 94598) 2020-04-16 11:05:17 +02:00
tree-sra.h
tree-ssa-address.c
tree-ssa-address.h
tree-ssa-alias.c middle-end/94539 - void * aliases every other pointer 2020-04-15 09:19:26 +02: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 List valid pairs for new and delete operators. 2020-04-16 15:39:22 +02:00
tree-ssa-dce.h
tree-ssa-dom.c middle-end/94188 fix fold of addr expression generation 2020-03-18 09:14:48 +01:00
tree-ssa-dom.h
tree-ssa-dse.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
tree-ssa-dse.h
tree-ssa-forwprop.c forwprop: Fix ICE when building an identity constructor [PR94784] 2020-04-27 11:08:04 +01:00
tree-ssa-ifcombine.c
tree-ssa-live.c
tree-ssa-live.h
tree-ssa-loop-ch.c typo fix: Fix probablity, becuse, sucessor and destinarion typos [PR93912] 2020-02-25 22:10:48 +01:00
tree-ssa-loop-im.c fix regression with MEM commoning 2020-04-29 08:23:37 +02:00
tree-ssa-loop-ivcanon.c
tree-ssa-loop-ivopts.c Add unsigned type iv_cand for iv_use with non mode-precision type 2020-04-09 16:42:48 +08:00
tree-ssa-loop-ivopts.h
tree-ssa-loop-manip.c loop-manip: Avoid -fcompare-debug issues in create_iv [PR94285] 2020-03-24 09:36:32 +01:00
tree-ssa-loop-manip.h
tree-ssa-loop-niter.c c/94392 - only enable -ffinite-loops for C++ 2020-04-02 16:53:21 +02:00
tree-ssa-loop-niter.h PR tree-optimization/92429 do not fold when updating epilogue statements 2020-01-16 10:28:02 +00:00
tree-ssa-loop-prefetch.c
tree-ssa-loop-split.c Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
tree-ssa-loop-unswitch.c
tree-ssa-loop.c
tree-ssa-loop.h
tree-ssa-math-opts.c widening_mul: restrict ops to be defined in the same basic-block when convert plusminus to widen 2020-03-26 08:36:42 +01:00
tree-ssa-operands.c
tree-ssa-operands.h
tree-ssa-phiopt.c cselim: Don't assume it is safe to cstore replace a store to a local variable with unknown offset [PR94734] 2020-04-25 00:10:01 +02:00
tree-ssa-phiprop.c
tree-ssa-pre.c tree-optimization/94163 constrain alignment set by PRE 2020-03-13 13:57:41 +01:00
tree-ssa-propagate.c tree-optimization/94352 - fix uninitialized use of curr_order 2020-03-27 13:55:22 +01:00
tree-ssa-propagate.h
tree-ssa-reassoc.c reassoc: Fix -fcompare-debug bug in reassociate_bb [PR94329] 2020-03-28 10:21:52 +01:00
tree-ssa-sccvn.c fix PVS studio reported bugs 2020-04-17 10:38:45 +02:00
tree-ssa-sccvn.h sccvn: Improve handling of load masked with integer constant [PR93582] 2020-03-03 11:24:33 +01:00
tree-ssa-scopedtables.c tree-optimization/93946 - fix bogus redundant store removal in FRE, DSE and DOM 2020-03-03 11:02:28 +01:00
tree-ssa-scopedtables.h tree-optimization/93946 - fix bogus redundant store removal in FRE, DSE and DOM 2020-03-03 11:02:28 +01:00
tree-ssa-sink.c
tree-ssa-strlen.c PR tree-optimization/94131 - ICE on printf with a VLA string and -fno-tree-ccp 2020-03-25 09:39:50 -06:00
tree-ssa-strlen.h Fix up duplicated duplicated words in comments 2020-03-18 12:56:26 +01:00
tree-ssa-structalias.c tree-optimization/93381 fix integer offsetting in points-to analysis 2020-01-22 12:38:12 +01:00
tree-ssa-tail-merge.c
tree-ssa-ter.c
tree-ssa-ter.h
tree-ssa-threadbackward.c
tree-ssa-threadedge.c Fix ICE due to invalid jump threading request 2020-01-24 17:51:19 -05:00
tree-ssa-threadedge.h
tree-ssa-threadupdate.c
tree-ssa-threadupdate.h
tree-ssa-uncprop.c
tree-ssa-uninit.c
tree-ssa.c PR tree-optimization/94574 - aarch64: ICE during GIMPLE pass:ccp 2020-04-14 16:02:31 +02:00
tree-ssa.h
tree-ssanames.c
tree-ssanames.h
tree-stdarg.c
tree-stdarg.h
tree-streamer-in.c c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02:00
tree-streamer-out.c c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02:00
tree-streamer.c
tree-streamer.h
tree-switch-conversion.c
tree-switch-conversion.h
tree-tailcall.c tailcall: Fix up process_assignment [PR94001] 2020-03-04 09:01:59 +01:00
tree-vect-data-refs.c vect: Fix offset calculation for -ve strides [PR93767] 2020-02-19 13:12:22 +00:00
tree-vect-generic.c vect: Fix up lowering of TRUNC_MOD_EXPR by negative constant [PR94524] 2020-04-08 21:22:05 +02:00
tree-vect-loop-manip.c tree-optimization/93094 pass down VECTORIZED_CALL to versioning 2020-01-20 09:48:42 +01:00
tree-vect-loop.c vect: Tweak vect_better_loop_vinfo_p handling of variable VFs 2020-04-20 17:13:29 +01:00
tree-vect-patterns.c vect: Fix up lowering of TRUNC_MOD_EXPR by negative constant [PR94524] 2020-04-08 21:22:05 +02:00
tree-vect-slp.c tree-optimization/94261 - avoid IL adjustments in SLP analysis 2020-03-23 16:48:37 +01:00
tree-vect-stmts.c vect: Fix COND_EXPRs involving variant booleans [PR94727] 2020-04-28 08:04:29 +01:00
tree-vector-builder.c
tree-vector-builder.h
tree-vectorizer.c tree-optimization/93094 pass down VECTORIZED_CALL to versioning 2020-01-20 09:48:42 +01:00
tree-vectorizer.h tree-optimization/93094 pass down VECTORIZED_CALL to versioning 2020-01-20 09:48:42 +01:00
tree-vrp.c
tree-vrp.h
tree.c tree: Don't reuse types if TYPE_USER_ALIGN differ [PR94775] 2020-04-30 08:34:40 -04:00
tree.def Fix up duplicated duplicated words mostly in comments 2020-03-17 13:52:19 +01:00
tree.h c++, middle-end, rs6000: Fix C++17 ABI incompatibilities during class layout and [[no_unique_address]] handling [PR94707] 2020-04-29 09:01:49 +02: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: Avoid -Wpadded warnings [PR94641] 2020-04-21 17:06:31 +02:00
ubsan.h
unique-ptr-tests.cc
valtrack.c
valtrack.h
value-prof.c value-prof: Fix abs uses in value-prof.c [PR93962] 2020-03-11 09:34:59 +01:00
value-prof.h
value-range.cc
value-range.h
var-tracking.c var-tracking.c: Fix possible use of uninitialized variable pre 2020-04-30 08:12:42 +02:00
varasm.c varasm: Fix output_constructor where a RANGE_EXPR index needs to skip some elts [PR94303] 2020-03-25 09:21:05 +01:00
varasm.h
varpool.c Reword a comment in varpool_node::ctor_useable_for_folding_p. 2020-01-18 13:49:05 +01:00
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
wide-int-print.cc
wide-int-print.h
wide-int.cc
wide-int.h
xcoff.h
xcoffout.c
xcoffout.h

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