diff options
author | tschwinge <tschwinge@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-05-25 08:04:28 +0000 |
---|---|---|
committer | tschwinge <tschwinge@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-05-25 08:04:28 +0000 |
commit | 5253ef2bd1fdbfefa5735ecad53f59a76c402c72 (patch) | |
tree | 295b667261e9fb754b42de6d3bcd5a834c7086eb /gcc | |
parent | fa16a29ecc70207b3284d05ab3d8c210fc4c95a6 (diff) | |
download | gcc-5253ef2bd1fdbfefa5735ecad53f59a76c402c72.tar.gz |
gcc/
* fold-const.c (optimize_bit_field_compare): Abort early in the strict
volatile bitfields case.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@187869 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/fold-const.c | 5 |
2 files changed, 11 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d810212dffe..983cd323720 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,4 +1,9 @@ -2012-05-24 Pat Haugen <pthaugen@us.ibm.com> +2012-05-25 Thomas Schwinge <thomas@codesourcery.com> + + * fold-const.c (optimize_bit_field_compare): Abort early in the strict + volatile bitfields case. + +2012-05-24 Pat Haugen <pthaugen@us.ibm.com> * config/rs6000/rs6000.c (rs6000_option_override_internal): Change rs6000_sched_costly_dep default to true_store_to_load_dep_costly. diff --git a/gcc/fold-const.c b/gcc/fold-const.c index 20b07d0ad81..58deca7eb29 100644 --- a/gcc/fold-const.c +++ b/gcc/fold-const.c @@ -3346,6 +3346,11 @@ optimize_bit_field_compare (location_t loc, enum tree_code code, tree mask; tree offset; + /* In the strict volatile bitfields case, doing code changes here may prevent + other optimizations, in particular in a SLOW_BYTE_ACCESS setting. */ + if (flag_strict_volatile_bitfields > 0) + return 0; + /* Get all the information about the extractions being done. If the bit size if the same as the size of the underlying object, we aren't doing an extraction at all and so can do nothing. We also don't want to |