diff options
| author | Ulrich Weigand <ulrich.weigand@de.ibm.com> | 2016-10-25 15:39:15 +0000 | 
|---|---|---|
| committer | Ulrich Weigand <ulrich.weigand@de.ibm.com> | 2016-10-25 15:39:15 +0000 | 
| commit | 7bdb485e1841ceb8421a1d9e62cf120b9b77f527 (patch) | |
| tree | 60a86aa69b26ef9080229743749ccb7d37cde977 /llvm/lib/CodeGen/MachineScheduler.cpp | |
| parent | 91cc4a6503fee173c303e510ebc2183b4e7bc29b (diff) | |
| download | llvm-7bdb485e1841ceb8421a1d9e62cf120b9b77f527.zip llvm-7bdb485e1841ceb8421a1d9e62cf120b9b77f527.tar.gz llvm-7bdb485e1841ceb8421a1d9e62cf120b9b77f527.tar.bz2 | |
[SystemZ] Do not use LOC(G) for volatile loads
It is not safe to use LOAD ON CONDITION to implement access to a memory
location marked "volatile", since the architecture leaves it unspecified
whether or not an access happens if the condition is false.
The current code already appears to care about that:
  def LOC  : CondUnaryRSY<"loc",  0xEBF2, nonvolatile_load, GR32, 4>;
Unfortunately, that "nonvolatile_load" operator is simply ignored
by the CondUnaryRSY class, and there was no test to catch it.
llvm-svn: 285077
Diffstat (limited to 'llvm/lib/CodeGen/MachineScheduler.cpp')
0 files changed, 0 insertions, 0 deletions
