[Bug tree-optimization/22000] [4.0/4.1 Regression] Read from volatile member of struct is optimized away
joseph at codesourcery dot com
gcc-bugzilla@gcc.gnu.org
Thu Jun 23 16:59:00 GMT 2005
------- Additional Comments From joseph at codesourcery dot com 2005-06-23 16:59 -------
Subject: Re: [4.0/4.1 Regression] Read from
volatile member of struct is optimized away
On Thu, 23 Jun 2005, mmitchel at gcc dot gnu dot org wrote:
> I somewhat suspect this hunk of code in c-typeck.c:build_component_ref:
>
> if (TREE_THIS_VOLATILE (datum) || TREE_THIS_VOLATILE (subdatum))
> TREE_THIS_VOLATILE (ref) = 1;
>
> I don't see anything that sets TREE_SIDE_EFFECTS.
In general TREE_SIDE_EFFECTS is set by the low-level tree-building code in
tree.c (if set for the operands of a tree) so front ends need only change
it if the defaults are wrong.
> If this bit is set in an expression, so is TREE_SIDE_EFFECTS. */
> #define TREE_THIS_VOLATILE(NODE) ((NODE)->common.volatile_flag)
This does seem like something tree checking could usefully be added for.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=22000
More information about the Gcc-bugs
mailing list