>>> I don't see a better way so I guess this will be a targetinstrinfo >>> bit (true for those with side-effects). >> >> Okay, the tricky thing here is instructions that have "conditional >> side effects". For example, all instructions marked isload/isstore/ >> iscall etc should be considered to have side effects (as would >> anything with implicit definitions), but loads from constant pools >> and other special cases should not be considered to have side >> effects. > > Calls should definitely be marked to have side-effects. To me the > tricky cases are loads / stores. But can't we determine these from > the operands? So, add one more condition: > 3. if memory operation, no external symbol or global address inputs. > > Then we don't need to mark loads / stores as having side effects.
Ah right, even better. So you're saying we don't need a new flag at all? I guess this won't work right now though, because we don't model things that clobber the condcodes. Wouldn't it be nice if we did? :) -Chris _______________________________________________ llvm-commits mailing list llvm-commits@cs.uiuc.edu http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits