mem-ruby: Fix fast-forward when using the backing store.
authorYuan Yao <yuanyao@seas.harvard.edu>
Sun, 23 Feb 2020 22:16:03 +0000 (17:16 -0500)
committerYuan Yao <yaoyuannnn@gmail.com>
Fri, 13 Mar 2020 00:30:11 +0000 (00:30 +0000)
commitf5e1e1b854499aa11ec1aba1b8fd60a32be0ea50
tree6b72ba24dc09efbef95a3cb96fce1171375d8cdf
parent75430bfe6bba6169c7083f817ce9a74cd9089975
mem-ruby: Fix fast-forward when using the backing store.

While the up-to-date data may reside in any agent of Ruby's memory
hierarchy, there's an optional backing store in Ruby that provides
a 'correct' view of the physical memory. When it is enabled by the
user, every Ruby memory access will update this global memory view
as well upon finishing.

The issue is that Ruby's atomic access, used in fast-forward, does
not currently access the backing store, leading to data
incorrectness. More specifically, at the very beginning stage of the
simulation, a loader loads the program into the backing store using
functional accesses. Then the program starts execution with
fast-forward enabled, using atomic accesses for faster simulation. But
because atomic access only accesses the real memory hierarchy, the CPU
fetches incorrect instructions.

The fix is simple. Just make Ruby's atomic access update the backing
store as well as the real physical memory.

Change-Id: I2541d923e18ea488d383097ca7abd4124e47e59b
Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/26343
Reviewed-by: Jason Lowe-Power <jason@lowepower.com>
Reviewed-by: Onur Kayıran <onur.kayiran@amd.com>
Maintainer: Jason Lowe-Power <jason@lowepower.com>
Tested-by: kokoro <noreply+kokoro@google.com>
src/mem/ruby/system/RubyPort.cc