gcc/gcc
Kyrylo Tkachov 1c50eadaae arm.c (const_ok_for_dimode_op): Handle AND case.
2013-04-15  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>

	* config/arm/arm.c (const_ok_for_dimode_op): Handle AND case.
	* config/arm/arm.md (*anddi3_insn): Change to insn_and_split.
	* config/arm/constraints.md (De): New constraint.
	* config/arm/neon.md (anddi3_neon): Delete.
	(neon_vand<mode>): Expand to standard anddi3 pattern.
	* config/arm/predicates.md (imm_for_neon_inv_logic_operand):
	Move earlier in the file.
	(neon_inv_logic_op2): Likewise.
	(arm_anddi_operand_neon): New predicate.

testsuite:
	* gcc.target/arm/anddi3-opt.c: New test.
	* gcc.target/arm/anddi3-opt2.c: Likewise.

From-SVN: r197965
2013-04-15 10:43:43 +00:00
..
ada makeutl.adb, [...]: Minor reformatting. 2013-04-12 15:45:25 +02:00
c re PR c/19449 (__builtin_constant_p cannot resolve to const when optimizing) 2013-04-03 11:17:44 +02:00
c-family opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
common
config arm.c (const_ok_for_dimode_op): Handle AND case. 2013-04-15 10:43:43 +00:00
cp opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
doc Use -z ignore instead of --as-needed on Solaris 2013-04-15 10:31:57 +00:00
fortran class.c (gfc_find_intrinsic_vtab): Removed unused var. 2013-04-15 11:40:28 +02:00
ginclude
go compiler, libgo: Permit testing package when test imports it circularly. 2013-02-10 06:02:38 +00:00
java gcj.texi (Configure-time Options): Refer to GCC, not gcc. 2013-04-14 21:16:58 +00:00
lto re PR middle-end/56231 (warning traces have bogus line information when using LTO) 2013-02-08 12:55:13 +00:00
objc
objcp
po * de.po: Update. 2013-04-02 23:47:43 +01:00
testsuite arm.c (const_ok_for_dimode_op): Handle AND case. 2013-04-15 10:43:43 +00:00
ABOUT-GCC-NLS
acinclude.m4
aclocal.m4
addresses.h
alias.c alias.c (find_base_term): Fix thinko in previous change. 2013-04-08 09:50:48 +00:00
alias.h
alloc-pool.c
alloc-pool.h
asan.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-02 20:25:36 +02:00
asan.h
attribs.c
auto-inc-dec.c
BASE-VER * BASE-VER: Set to 4.9.0. 2013-03-16 08:09:59 +01:00
basic-block.h First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
bb-reorder.c bb-reorder.c (fix_crossing_unconditional_branches): Remove a set-but-unused variable. 2013-04-05 19:23:17 +00:00
bb-reorder.h
bitmap.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
bitmap.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
bt-load.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
builtin-attrs.def
builtin-types.def
builtins.c re PR c/19449 (__builtin_constant_p cannot resolve to const when optimizing) 2013-04-03 11:17:44 +02:00
builtins.def
builtins.h
caller-save.c
calls.c re PR rtl-optimization/56434 (document that __attribute__((__malloc__)) assumes returned pointer has BIGGEST_ALIGNMENT) 2013-03-25 09:39:52 +00:00
cfg-flags.def
cfg.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
cfganal.c sparseset.h (sparseset_bit_p): Use gcc_checking_assert. 2013-01-30 15:42:49 +00:00
cfgbuild.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
cfgcleanup.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
cfgexpand.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
cfghooks.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
cfghooks.h
cfgloop.c cfgloop.c (verify_loop_structure): Streamline and avoid ICEing on corrupt loop tree. 2013-03-20 09:03:06 +00:00
cfgloop.h re PR tree-optimization/53265 (Warn when undefined behavior implies smaller iteration count) 2013-03-14 10:13:36 +01:00
cfgloopanal.c
cfgloopmanip.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
cfgrtl.c emit-rtl.c (remove_insn): Do not call df_insn_delete here. 2013-04-13 10:04:09 +00:00
cgraph.c bb-reorder.c (fix_crossing_unconditional_branches): Remove a set-but-unused variable. 2013-04-05 19:23:17 +00:00
cgraph.h ipa.c (cgraph_externally_visible_p, [...]): Drop aliased parameter. 2013-04-09 22:45:38 +00:00
cgraphbuild.c cgraph.h (cgraph_get_create_real_symbol_node): Declare. 2013-03-17 15:43:13 +00:00
cgraphclones.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
cgraphunit.c
ChangeLog arm.c (const_ok_for_dimode_op): Handle AND case. 2013-04-15 10:43:43 +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 Fix non-ASCII characters in names. 2013-04-09 09:29:32 +02:00
ChangeLog.dataflow
ChangeLog.graphite
ChangeLog.lib
ChangeLog.ptr
ChangeLog.tree-ssa
ChangeLog.tuples
cif-code.def cif-code.def (OVERWRITABLE): Correct the comment for overwritable function. 2013-04-10 09:22:04 +00:00
collect2-aix.c
collect2-aix.h * collect2-aix.h: Define F_LOADONLY. 2013-02-14 20:40:55 +00:00
collect2.c collect2.c (main): Set aix64_flag for -G and -bsvr4 too, disable if -bnortl. 2013-02-06 21:53:13 -05:00
collect2.h
combine-stack-adj.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
combine.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
common.opt opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
compare-elim.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
conditions.h
config.build config.build: Add support for cygwin x64 target. 2013-03-27 22:54:50 +01:00
config.gcc config.gcc (arm*-*-linux-*): Remove duplicate t-linux-android. 2013-04-02 14:32:37 +00:00
config.host config.build: Add support for cygwin x64 target. 2013-03-27 22:54:50 +01:00
config.in Use -z ignore instead of --as-needed on Solaris 2013-04-15 10:31:57 +00:00
configure Use -z ignore instead of --as-needed on Solaris 2013-04-15 10:31:57 +00:00
configure.ac Use -z ignore instead of --as-needed on Solaris 2013-04-15 10:31:57 +00:00
convert.c
convert.h
COPYING
COPYING3
COPYING3.LIB
COPYING.LIB
coretypes.h
coverage.c
coverage.h
cppbuiltin.c
cppbuiltin.h
cppdefault.c
cppdefault.h
cprop.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
cse.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
cselib.c combine.c (try_combine): Removed useless assert. 2013-03-28 14:09:46 +00:00
cselib.h
cstamp-h.in
data-streamer-in.c data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
data-streamer-out.c data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
data-streamer.c
data-streamer.h data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
DATESTAMP Daily bump. 2013-04-15 00:16:53 +00:00
dbgcnt.c
dbgcnt.def
dbgcnt.h
dbxout.c
dbxout.h
dce.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
dce.h
ddg.c
ddg.h
debug.c
debug.h
defaults.h
DEV-PHASE
df-core.c df-core.c (df_find_def): Compare register numbers. 2013-04-12 17:53:55 +00:00
df-problems.c
df-scan.c re PR middle-end/56729 (ICE in df_insn_delete) 2013-04-04 16:40:16 +00:00
df.h df.h (df_insn_delete): Adjust prototype. 2013-03-22 16:37:00 +00:00
dfp.c
dfp.h
diagnostic-color.c opts.c: Include diagnostic-color.h. 2013-04-12 08:20:36 +02:00
diagnostic-color.h opts.c: Include diagnostic-color.h. 2013-04-12 08:20:36 +02:00
diagnostic-core.h opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
diagnostic.c opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
diagnostic.def opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
diagnostic.h re PR middle-end/48087 (-Wall -Werror adds warnings over and above those generated by -Wall) 2013-03-21 18:36:47 +01:00
dojump.c
dominance.c
domwalk.c re PR c/56113 (out of memory when compiling a function with many goto labels (50k > )) 2013-03-18 08:46:44 +00:00
domwalk.h
double-int.c re PR tree-optimization/56064 (Optimize VIEW_CONVERT_EXPR with FIXED_CST) 2013-01-30 11:04:30 +00:00
double-int.h re PR tree-optimization/56064 (Optimize VIEW_CONVERT_EXPR with FIXED_CST) 2013-01-30 11:04:30 +00:00
dse.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
dumpfile.c
dumpfile.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
dwarf2asm.c
dwarf2asm.h
dwarf2cfi.c
dwarf2out.c opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
dwarf2out.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
emit-rtl.c emit-rtl.c (remove_insn): Do not call df_insn_delete here. 2013-04-13 10:04:09 +00:00
emit-rtl.h
errors.c
errors.h
et-forest.c
et-forest.h
except.c re PR c++/55135 (Segfault of gcc on a big file) 2013-03-05 14:45:23 +00:00
except.h re PR c++/55135 (Segfault of gcc on a big file) 2013-03-05 14:45:23 +00:00
exec-tool.in
explow.c
expmed.c Improve cstore code generation on 64-bit sparc. 2013-04-10 12:41:57 -07:00
expmed.h
expr.c re PR middle-end/56548 (ICE in emit_move_insn, at expr.c:3486 with -march=pentium{pro,2,3} -O3) 2013-03-06 18:18:46 +01:00
expr.h re PR target/52555 (ICE unrecognizable insn with -ffast-math and __attribute__((optimize(xx)))) 2013-02-19 00:04:49 +00:00
file-find.c
file-find.h
final.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
fixed-value.c re PR tree-optimization/56064 (Optimize VIEW_CONVERT_EXPR with FIXED_CST) 2013-02-08 13:23:34 +00:00
fixed-value.h re PR tree-optimization/56064 (Optimize VIEW_CONVERT_EXPR with FIXED_CST) 2013-02-08 13:23:34 +00:00
flag-types.h
flags.h
fold-const.c re PR tree-optimization/56918 (incorrect auto-vectorization of array initialization) 2013-04-12 10:18:59 +02:00
fp-test.c
FSFChangeLog
FSFChangeLog.10
FSFChangeLog.11
function.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
function.h re PR middle-end/56524 (Compiler ICE when compiling with -mips16) 2013-03-09 07:54:02 +00:00
fwprop.c re PR rtl-optimization/56178 (Miscompilation of Ada front-end with profiled bootstrap) 2013-02-07 08:07:04 +00:00
gcc-ar.c
gcc-plugin.h
gcc.c Use -z ignore instead of --as-needed on Solaris 2013-04-15 10:31:57 +00:00
gcc.h
gcov-dump.c This patch enables the gcov-dump tool to optionally compute and dump the working set information from the counter histogram... 2013-04-03 20:51:28 +00:00
gcov-io.c This patch enables the gcov-dump tool to optionally compute and dump the working set information from the counter histogram... 2013-04-03 20:51:28 +00:00
gcov-io.h This patch enables the gcov-dump tool to optionally compute and dump the working set information from the counter histogram... 2013-04-03 20:51:28 +00:00
gcov-iov.c
gcov.c
gcse.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
gcse.h
gdbinit.in * gdbinit.in (pbb): Use debug fn. 2013-04-02 17:09:52 -04:00
genattr-common.c
genattr.c
genattrtab.c
genautomata.c
gencheck.c
genchecksum.c
gencodes.c
genconditions.c
genconfig.c
genconstants.c
genemit.c
genenums.c
genextract.c
genflags.c
gengenrtl.c
gengtype-lex.l
gengtype-parse.c
gengtype-state.c
gengtype.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
gengtype.h
genhooks.c
genmddeps.c
genmddump.c
genmodes.c genmodes.c (emit_max_int): New function. 2013-03-28 14:46:31 +00:00
genmultilib t-aarch64-linux (MULTARCH_DIRNAME): Remove. 2013-03-14 09:52:13 +01:00
genopinit.c re PR target/52555 (ICE unrecognizable insn with -ffast-math and __attribute__((optimize(xx)))) 2013-02-19 00:04:49 +00:00
genoutput.c
genpeep.c
genpreds.c genpreds.c (write_lookup_constraint): Do not compare first letter of the constraint again. 2013-02-20 09:04:29 +00:00
genrecog.c
gensupport.c
gensupport.h
ggc-common.c re PR middle-end/56461 (GCC is leaking lots of memory) 2013-03-05 16:51:48 +01:00
ggc-internal.h Remove zone allocator. 2013-01-24 10:13:46 -05:00
ggc-none.c Remove zone allocator. 2013-01-24 10:13:46 -05:00
ggc-page.c re PR bootstrap/56227 (Bootstrap failure on MinGW building ggc-page.c) 2013-02-07 19:01:40 +01:00
ggc.h Remove zone allocator. 2013-01-24 10:13:46 -05:00
gimple-fold.c
gimple-fold.h
gimple-iterator.c
gimple-low.c
gimple-pretty-print.c gimple-pretty-print.c (debug_gimple_stmt): Do not print extra newline. 2013-04-08 12:35:26 +00:00
gimple-pretty-print.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
gimple-ssa-strength-reduction.c
gimple-streamer-in.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
gimple-streamer-out.c data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
gimple-streamer.h
gimple.c gimple.c (is_gimple_constant): Vector CONSTRUCTORs should not be considered a gimple constant. 2013-04-12 07:59:58 +00:00
gimple.def
gimple.h re PR middle-end/56483 (LTO issue with expanding GIMPLE_COND) 2013-03-18 10:29:43 +00:00
gimplify.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-02 20:25:36 +02:00
glimits.h
godump.c
graph.c cfgloop.c (verify_loop_structure): Streamline and avoid ICEing on corrupt loop tree. 2013-03-20 09:03:06 +00:00
graph.h
graphds.c
graphds.h Remove various unused items. 2013-03-29 07:09:33 +00:00
graphite-blocking.c
graphite-clast-to-gimple.c
graphite-clast-to-gimple.h
graphite-dependences.c
graphite-interchange.c
graphite-optimize-isl.c
graphite-poly.c
graphite-poly.h Remove various unused items. 2013-03-29 07:09:33 +00:00
graphite-scop-detection.c
graphite-scop-detection.h
graphite-sese-to-poly.c
graphite-sese-to-poly.h
graphite.c
gsstruct.def
gstab.h
gsyms.h
gsyslimits.h
gtm-builtins.def
haifa-sched.c emit-rtl.c (remove_insn): Do not call df_insn_delete here. 2013-04-13 10:04:09 +00:00
hard-reg-set.h
hash-table.c
hash-table.h
highlev-plugin-common.h
hooks.c
hooks.h
host-default.c
hosthooks-def.h
hosthooks.h
hw-doloop.c avr.c, [...]: Where applicable... 2013-03-23 12:11:10 +00:00
hw-doloop.h
hwint.c hwint.c (sext_hwi, zext_hwi): New functions. 2013-04-03 20:24:07 +00:00
hwint.h hwint.c (sext_hwi, zext_hwi): New functions. 2013-04-03 20:24:07 +00:00
ifcvt.c ifcvt.c (end_ifcvt_sequence): Mark a and b for unsharing as well. 2013-04-12 05:38:27 +00:00
incpath.c incpath.c (add_standard_paths): Use reconcat instead of concat where appropriate and avoid leaking memory. 2013-02-27 08:28:48 +01:00
incpath.h
init-regs.c
input.c
input.h
insn-addr.h
insn-notes.def re PR rtl-optimization/56131 (gcc.dg/pr56035.c ICEs gcc on sparc-linux) 2013-02-25 11:50:25 +00:00
internal-fn.c
internal-fn.def
internal-fn.h
intl.c
intl.h
ipa-cp.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
ipa-inline-analysis.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
ipa-inline-transform.c
ipa-inline.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
ipa-inline.h
ipa-prop.c ipa-prop.c (ipa_write_jump_function): Stream simple and aritmetic pass-through jump functions differently. 2013-03-25 17:50:02 +01:00
ipa-prop.h
ipa-pure-const.c re PR middle-end/56461 (GCC is leaking lots of memory) 2013-02-27 22:35:53 +01:00
ipa-ref-inline.h
ipa-ref.c
ipa-ref.h
ipa-reference.c re PR middle-end/56461 (GCC is leaking lots of memory) 2013-02-27 22:33:20 +01:00
ipa-reference.h
ipa-split.c re PR tree-optimization/56424 (ICE at tree-inline.c:2833 on a-nllcef.ads at -O2) 2013-03-04 17:41:32 +00:00
ipa-utils.c
ipa-utils.h
ipa.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
ira-build.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
ira-color.c
ira-conflicts.c re PR debug/53948 (Assignment line missing for -O0 -g) 2013-02-08 13:03:52 -07:00
ira-costs.c re PR rtl-optimization/56124 (Redundant reload for loading from memory) 2013-04-11 03:55:14 +00:00
ira-emit.c cfgloop.c (verify_loop_structure): Properly handle a loop exiting to another loop header. 2013-02-08 09:09:38 +00:00
ira-int.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
ira-lives.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
ira.c tree-pass.h (TODO_do_not_ggc_collect): New. 2013-04-12 09:50:28 +00:00
ira.h
is-a.h is-a.h (as_a): Use gcc_checking_assert. 2013-03-22 13:01:42 +00:00
jump.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
langhooks-def.h
langhooks.c opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
langhooks.h re PR debug/49090 (provide a way to recognize defaulted template parameters) 2013-03-16 22:33:50 -04:00
LANGUAGES
lcm.c
libfuncs.h
limitx.h
limity.h
lists.c
loop-doloop.c
loop-init.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
loop-invariant.c
loop-iv.c re PR rtl-optimization/56605 (Redundant branch introduced during loop2 phases) 2013-03-20 13:24:12 +00:00
loop-unroll.c re PR rtl-optimization/56466 (ICE in verify_loop_structure, at cfgloop.c:1629 (loop with header n not in loop tree !)) 2013-02-28 10:13:48 +00:00
loop-unswitch.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
lower-subreg.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
lower-subreg.h re PR rtl-optimization/50339 (suboptimal register allocation for abs(__int128_t)) 2013-02-21 22:28:03 +01:00
lra-assigns.c re PR rtl-optimization/56348 (internal compiler error in assign_by_spills with -m32 -fPIC -msse2) 2013-02-15 19:17:02 +00:00
lra-coalesce.c
lra-constraints.c re PR inline-asm/56148 (inline asm matching constraint with different mode) 2013-02-22 16:30:22 +00:00
lra-eliminations.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
lra-int.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
lra-lives.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
lra-spills.c emit-rtl.c (remove_insn): Do not call df_insn_delete here. 2013-04-13 10:04:09 +00:00
lra.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
lra.h
lto-cgraph.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
lto-compress.c
lto-compress.h
lto-opts.c
lto-section-in.c lto-cgraph.c (output_profile_summary, [...]): Use gcov streaming; stream hot bb threshold to ltrans. 2013-03-29 18:07:34 +00:00
lto-section-out.c
lto-streamer-in.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
lto-streamer-out.c data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
lto-streamer.c
lto-streamer.h lto-cgraph.c (output_profile_summary, [...]): Use gcov streaming; stream hot bb threshold to ltrans. 2013-03-29 18:07:34 +00:00
lto-symtab.c re PR lto/56168 (GCC seems to disregard -fno-builtin when compiling with LTO) 2013-02-04 12:19:25 +00:00
lto-wrapper.c opts.h: Include obstack.h. 2013-02-27 08:28:09 +01:00
machmode.def genmodes.c (emit_max_int): New function. 2013-03-28 14:46:31 +00:00
machmode.h
main.c
Makefile.in opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
mcf.c
mkconfig.sh
mode-classes.def
mode-switching.c
modulo-sched.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
omega.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
omega.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
omp-builtins.def
omp-low.c re PR middle-end/56883 (error openmp parallel for order) 2013-04-09 15:25:58 +02:00
ONEWS
opt-functions.awk
opt-gather.awk
opt-include.awk
opt-read.awk
optabs.c re PR middle-end/56524 (Compiler ICE when compiling with -mips16) 2013-03-09 07:54:02 +00:00
optabs.def
optabs.h re PR target/52555 (ICE unrecognizable insn with -ffast-math and __attribute__((optimize(xx)))) 2013-02-19 00:04:49 +00:00
optc-gen.awk
optc-save-gen.awk
opth-gen.awk
opts-common.c re PR bootstrap/56509 (gnattools build failure) 2013-03-05 07:01:13 +01:00
opts-diagnostic.h
opts-global.c
opts.c opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
opts.h opts.h: Include obstack.h. 2013-02-27 08:28:09 +01:00
output.h
params.c
params.def re PR tree-optimization/48184 (ICE: SIGFPE (division by zero) in compute_alignments () at final.c:731 with --param align-threshold=0 on basic code) 2013-04-11 16:20:26 +00:00
params.h
passes.c tree-pass.h (TODO_do_not_ggc_collect): New. 2013-04-12 09:50:28 +00:00
plugin.c
plugin.def
plugin.h
pointer-set.c
pointer-set.h
postreload-gcse.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
postreload.c * postreload.c (reload_combine): Fix code detecting returns. 2013-03-25 11:25:28 +00:00
predict.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
predict.def
predict.h
prefix.c
prefix.h
pretty-print.c opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
pretty-print.h opts.c: Include diagnostic-color.h. 2013-04-12 08:19:58 +02:00
print-rtl.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
print-tree.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
profile.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
profile.h This patch enables the gcov-dump tool to optionally compute and dump the working set information from the counter histogram... 2013-04-03 20:51:28 +00:00
read-md.c
read-md.h
read-rtl.c
README.Portability
real.c
real.h
realmpfr.c
realmpfr.h
recog.c
recog.h
ree.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
reg-notes.def rtl.texi (sequence): Rewrite documentation to match the current use of SEQUENCE rtl objects. 2013-04-08 19:59:57 +00:00
reg-stack.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
regcprop.c
reginfo.c
regmove.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
regrename.c
regrename.h
regs.h re PR debug/53948 (Assignment line missing for -O0 -g) 2013-02-08 13:03:52 -07:00
regset.h
regstat.c
reload1.c cfgrtl.c (fixup_reorder_chain): Do not emit barriers to BB_FOOTER. 2013-03-30 14:26:42 +00:00
reload.c * gcc/reload.c (subst_reloads): Fix DEBUG_RELOAD build issue. 2013-02-04 09:23:38 -07:00
reload.h
reorg.c reorg.c (fill_simple_delay_slots): Reindent block of code. 2013-04-14 09:46:02 +00:00
resource.c reorg.c (fill_simple_delay_slots): Reindent block of code. 2013-04-14 09:46:02 +00:00
resource.h
rtl-error.c
rtl-error.h
rtl.c re PR rtl-optimization/56571 (ICE in copyprop_hardreg_forward_1, at regcprop.c (insn does not satisfy its constraints !)) 2013-03-12 12:13:33 +00:00
rtl.def rtl.texi (sequence): Rewrite documentation to match the current use of SEQUENCE rtl objects. 2013-04-08 19:59:57 +00:00
rtl.h * rtl.h (AUTO_INC_DEC): Fix typo of HAVE_POST_MODIFY_DISP. 2013-04-03 10:25:08 +00:00
rtlanal.c
rtlhooks-def.h
rtlhooks.c
sanitizer.def libsanitizer merge from upstream r175049 2013-02-13 10:46:01 +00:00
sbitmap.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sbitmap.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sched-deps.c sched-deps.c (deps_analyze_insn): Do not check for EH_REGION insn notes, they are emitted only just before final. 2013-04-13 18:08:19 +00:00
sched-ebb.c
sched-int.h sched-deps.c (deps_analyze_insn): Do not check for EH_REGION insn notes, they are emitted only just before final. 2013-04-13 18:08:19 +00:00
sched-rgn.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
sched-vis.c sched-vis.c (print_pattern): Print SEQUENCE of insns as insns. 2013-04-09 15:02:41 +00:00
sdbout.c sdbout.c (sdbout_one_type): Switch to current function's section supporting cold/hot. 2013-03-05 18:59:38 +01:00
sdbout.h
sel-sched-dump.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sel-sched-dump.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sel-sched-ir.c emit-rtl.c (remove_insn): Do not call df_insn_delete here. 2013-04-13 10:04:09 +00:00
sel-sched-ir.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sel-sched.c re PR middle-end/55889 (ICE: in move_op_ascend, at sel-sched.c:6153 with -fschedule-insns -fselective-scheduling) 2013-02-19 17:50:50 +04:00
sel-sched.h
sese.c Remove unused symbols related to ivtype_map. 2013-04-02 20:13:46 +00:00
sese.h Remove unused symbols related to ivtype_map. 2013-04-02 20:13:46 +00:00
simplify-rtx.c simplify-rtx.c (simplify_binary_operation_1): Handle VEC_MERGE. 2013-04-03 09:44:28 +00:00
sparseset.c
sparseset.h sparseset.h (sparseset_bit_p): Use gcc_checking_assert. 2013-01-30 15:42:49 +00:00
sreal.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
sreal.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
ssaexpand.h
stab.def
stack-ptr-mod.c
statistics.c
statistics.h
stmt.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
stor-layout.c stor-layout.c (skip_simple_constant_arithmetic): Move to... 2013-04-11 16:15:25 +00:00
store-motion.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
streamer-hooks.c
streamer-hooks.h
stringpool.c Remove zone allocator. 2013-01-24 10:13:46 -05:00
symtab.c
sync-builtins.def
system.h
target-def.h
target-globals.c re PR target/52555 (ICE unrecognizable insn with -ffast-math and __attribute__((optimize(xx)))) 2013-02-24 19:54:37 +01:00
target-globals.h re PR target/52555 (ICE unrecognizable insn with -ffast-math and __attribute__((optimize(xx)))) 2013-02-19 00:04:49 +00:00
target-hooks-macros.h
target.def Improve cstore code generation on 64-bit sparc. 2013-04-10 12:41:57 -07:00
target.h Improve cstore code generation on 64-bit sparc. 2013-04-10 12:41:57 -07:00
targhooks.c Improve cstore code generation on 64-bit sparc. 2013-04-10 12:41:57 -07:00
targhooks.h Improve cstore code generation on 64-bit sparc. 2013-04-10 12:41:57 -07:00
timevar.c
timevar.def
timevar.h
tlink.c
toplev.c toplev.c (process_options): Do not disable -fomit-frame-pointer on a general basis if... 2013-03-28 08:29:10 +00:00
toplev.h
tracer.c tracer.c (tracer): Mark loops with LOOPS_NEED_FIXUP instead of calling fix_loop_structure. 2013-02-06 13:16:35 +00:00
trans-mem.c trans-mem.c (expand_transaction): Do not set PR_INSTRUMENTEDCODE if GTMA_HAS_NO_INSTRUMENTATION. 2013-03-08 22:26:37 +00:00
trans-mem.h
tree-affine.c
tree-affine.h
tree-browser.c
tree-browser.def
tree-call-cdce.c tree-call-cdce.c (tree_call_cdce): Do not remove unused locals. 2013-02-20 15:19:13 +00:00
tree-cfg.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-02 20:25:36 +02:00
tree-cfgcleanup.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-chrec.c
tree-chrec.h
tree-complex.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-data-ref.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
tree-data-ref.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
tree-dfa.c tree-dfa.c (get_or_create_ssa_default_def): Use parameter fn in all appropriate places. 2013-03-04 19:49:59 +01:00
tree-diagnostic.c tree.h (DECL_DEBUG_EXPR_IS_FROM): Rename to ... 2013-03-21 11:53:39 +00:00
tree-diagnostic.h
tree-dump.c Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
tree-dump.h
tree-eh.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-08 15:46:00 +02:00
tree-emutls.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-flow-inline.h tree-flow-inline.h (get_addr_base_and_unit_offset_1): Handle BIT_FIELD_REF. 2013-04-03 12:54:50 +00:00
tree-flow.h re PR tree-optimization/56878 (Issue with candidate choice in vect_gen_niters_for_prolog_loop.) 2013-04-11 11:21:18 +00:00
tree-if-conv.c
tree-inline.c tree.h (unsave_expr_now): Remove. 2013-04-09 08:26:45 +00:00
tree-inline.h
tree-into-ssa.c re PR tree-optimization/56294 (BOOT_CFLAGS='-O2 -g -fno-ipa-sra' leads to bootstrap comparison failure) 2013-03-06 11:24:07 +00:00
tree-iterator.c
tree-iterator.h
tree-loop-distribution.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-mudflap.c
tree-mudflap.h
tree-nested.c
tree-nomudflap.c
tree-nrv.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-object-size.c
tree-optimize.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
tree-outof-ssa.c
tree-parloops.c
tree-pass.h tree-pass.h (TODO_do_not_ggc_collect): New. 2013-04-12 09:50:28 +00:00
tree-phinodes.c Remove zone allocator. 2013-01-24 10:13:46 -05:00
tree-predcom.c
tree-pretty-print.c
tree-pretty-print.h
tree-profile.c
tree-scalar-evolution.c
tree-scalar-evolution.h
tree-sra.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-address.c
tree-ssa-alias.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-02 20:27:45 +02:00
tree-ssa-alias.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
tree-ssa-ccp.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-coalesce.c
tree-ssa-copy.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-copyrename.c tree-call-cdce.c (tree_call_cdce): Do not remove unused locals. 2013-02-20 15:19:13 +00:00
tree-ssa-dce.c tree-call-cdce.c (tree_call_cdce): Do not remove unused locals. 2013-02-20 15:19:13 +00:00
tree-ssa-dom.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-dse.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-forwprop.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-ifcombine.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-live.c re PR c++/34949 (Dead code in empty destructors.) 2013-04-02 20:25:36 +02:00
tree-ssa-live.h Add uniform debug dump function names. 2013-03-29 03:42:21 +00:00
tree-ssa-loop-ch.c
tree-ssa-loop-im.c tree-ssa-loop-im.c (struct mem_ref): Use bitmap_head instead of bitmap. 2013-03-25 12:53:57 +00:00
tree-ssa-loop-ivcanon.c re PR tree-optimization/56817 (ICE in hide_evolution_in_other_loops_than_loop) 2013-04-03 13:41:13 +00:00
tree-ssa-loop-ivopts.c re PR tree-optimization/56878 (Issue with candidate choice in vect_gen_niters_for_prolog_loop.) 2013-04-11 11:21:18 +00:00
tree-ssa-loop-manip.c expr.c (build_java_binop): Pass a type to build_int_cst. 2013-04-09 10:48:59 +00:00
tree-ssa-loop-niter.c re PR tree-optimization/53265 (Warn when undefined behavior implies smaller iteration count) 2013-03-14 10:13:36 +01:00
tree-ssa-loop-prefetch.c
tree-ssa-loop-unswitch.c
tree-ssa-loop.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-math-opts.c re PR tree-optimization/55524 (If fnma exists but not fms, convert_mult_to_fma should prefer to former over the latter.) 2013-04-10 10:54:25 +01:00
tree-ssa-operands.c
tree-ssa-operands.h
tree-ssa-phiopt.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-phiprop.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-pre.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-propagate.c
tree-ssa-propagate.h
tree-ssa-reassoc.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-sccvn.c re PR tree-optimization/56661 (Incorrect code with -O1 -ftree-pre) 2013-03-20 13:26:19 +00:00
tree-ssa-sccvn.h re PR tree-optimization/56384 (ICE in fold_binary_loc, at fold-const.c:10422) 2013-02-19 12:10:48 +00:00
tree-ssa-sink.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-strlen.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-ssa-structalias.c re PR target/56716 (during gcc 4.8.0 build on Cygwin: bid128_fma.c:4460:1: internal compiler error: Segmentation fault) 2013-03-27 15:10:50 +00:00
tree-ssa-tail-merge.c re PR tree-optimization/56150 (ICE segfault in do_pre / tail_merge_optimize) 2013-01-31 08:52:56 +00:00
tree-ssa-ter.c tree-ssa-ter.c (is_replaceable_p): Do not TER across location or block changes with -Og. 2013-03-08 08:45:29 +00:00
tree-ssa-threadedge.c
tree-ssa-threadupdate.c
tree-ssa-uncprop.c
tree-ssa-uninit.c PR/56490 2013-03-02 18:42:26 +00:00
tree-ssa.c re PR middle-end/56461 (GCC is leaking lots of memory) 2013-02-27 15:01:08 +01:00
tree-ssanames.c tree-call-cdce.c (tree_call_cdce): Do not remove unused locals. 2013-02-20 15:19:13 +00:00
tree-stdarg.c re PR tree-optimization/56205 (stdarg pass confused by jump threading) 2013-02-05 16:54:39 +01:00
tree-stdarg.h
tree-streamer-in.c tree.h (DECL_DEBUG_EXPR_IS_FROM): Rename to ... 2013-03-21 11:53:39 +00:00
tree-streamer-out.c tree.h (DECL_DEBUG_EXPR_IS_FROM): Rename to ... 2013-03-21 11:53:39 +00:00
tree-streamer.c
tree-streamer.h
tree-switch-conversion.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-tailcall.c re PR tree-optimization/56539 (ICE: verify_ssa failed: caused by -foptimize-sibling-calls) 2013-03-07 00:26:42 +01:00
tree-vect-data-refs.c re PR tree-optimization/56878 (Issue with candidate choice in vect_gen_niters_for_prolog_loop.) 2013-04-11 11:21:18 +00:00
tree-vect-generic.c tree-pass.h (PROP_gimple_lvec): New. 2013-03-21 21:11:56 +00:00
tree-vect-loop-manip.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
tree-vect-loop.c tree-vect-loop.c (get_initial_def_for_induction): Properly generate vector constants. 2013-04-11 14:03:09 +00:00
tree-vect-patterns.c
tree-vect-slp.c tree-vectorizer.h (struct _slp_oprnd_info): Remove first_const_oprnd field, rename first_def_type to first_op_type. 2013-04-10 10:40:33 +00:00
tree-vect-stmts.c gimple-pretty-print.c (debug_gimple_stmt): Do not print extra newline. 2013-04-08 12:35:26 +00:00
tree-vectorizer.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree-vectorizer.h tree-vectorizer.h (struct _slp_oprnd_info): Remove first_const_oprnd field, rename first_def_type to first_op_type. 2013-04-10 10:40:33 +00:00
tree-vrp.c passes.c (execute_todo): Do not call ggc_collect conditional here. 2013-04-10 11:33:31 +00:00
tree.c stor-layout.c (skip_simple_constant_arithmetic): Move to... 2013-04-11 16:15:25 +00:00
tree.def
tree.h stor-layout.c (skip_simple_constant_arithmetic): Move to... 2013-04-11 16:15:25 +00:00
treestruct.def
tsan.c re PR sanitizer/55702 (ICE: in instrument_func_exit, at tsan.c:684 with -fsanitize=thread and __builtin_return()) 2013-04-03 16:01:38 +00:00
tsan.h
tsystem.h
typeclass.h
valtrack.c re PR rtl-optimization/56571 (ICE in copyprop_hardreg_forward_1, at regcprop.c (insn does not satisfy its constraints !)) 2013-03-12 12:13:33 +00:00
valtrack.h
value-prof.c First phase of unifying the computation of profile scale factors/probabilities and the actual scaling to use rounding divides... 2013-04-08 17:39:10 +00:00
value-prof.h data-streamer-in.c (streamer_read_gcov_count): New function. 2013-03-28 15:29:40 +00:00
var-tracking.c tree.h (DECL_DEBUG_EXPR_IS_FROM): Rename to ... 2013-03-21 11:53:39 +00:00
varasm.c target.def (TARGET_HAS_IFUNC_P): New target hook. 2013-03-27 09:55:19 +00:00
varpool.c ipa.c (cgraph_externally_visible_p, [...]): Drop aliased parameter. 2013-04-09 22:45:38 +00:00
vec.c
vec.h
version.c
version.h
vmsdbg.h
vmsdbgout.c
web.c
xcoff.h
xcoffout.c
xcoffout.h

Copyright (C) 2000-2013 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 know 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
---------------

Irix6 "cc -n32" and OSF4 "cc" have problems with constant string
initializers with parens around it, e.g.

const char string[] = ("A string");

This is unfortunate since this is what the GNU gettext macro N_
produces.  You need to find a different way to code it.

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.