diff options
author | Steve Reinhardt <steve.reinhardt@amd.com> | 2016-03-17 10:29:32 -0700 |
---|---|---|
committer | Steve Reinhardt <steve.reinhardt@amd.com> | 2016-03-17 10:29:32 -0700 |
commit | f6cd7a4bb7ee66b58f88fbdc6bdc4faa6a559952 (patch) | |
tree | 7d579b1d984c0b3d7497780ff8ff1b96ab1f7aae /src/arch/arm | |
parent | 7eaa5952f994c07a801fbef81f8097a5e9a5828f (diff) | |
download | gem5-f6cd7a4bb7ee66b58f88fbdc6bdc4faa6a559952.tar.xz |
syscall_emul: move mmapGrowsDown() to LiveProcess
The mmapGrowsDown() method was a static method on the OperatingSystem
class (and derived classes), which worked OK for the templated syscall
emulation methods, but made it hard to access elsewhere. This patch
moves the method to be a virtual function on the LiveProcess method,
where it can be overridden for specific platforms (for now, Alpha).
This patch also changes the value of mmapGrowsDown() from being false
by default and true only on X86Linux32 to being true by default and
false only on Alpha, which seems closer to reality (though in reality
most people use ASLR and this doesn't really matter anymore).
In the process, also got rid of the unused mmap_start field on
LiveProcess and OperatingSystem mmapGrowsUp variable.
Diffstat (limited to 'src/arch/arm')
-rw-r--r-- | src/arch/arm/process.cc | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/arch/arm/process.cc b/src/arch/arm/process.cc index ba56f0cdc..0c6f48fb5 100644 --- a/src/arch/arm/process.cc +++ b/src/arch/arm/process.cc @@ -77,7 +77,7 @@ ArmLiveProcess32::ArmLiveProcess32(LiveProcessParams *params, brk_point = roundUp(brk_point, PageBytes); // Set up region for mmaps. For now, start at bottom of kuseg space. - mmap_start = mmap_end = 0x40000000L; + mmap_end = 0x40000000L; } ArmLiveProcess64::ArmLiveProcess64(LiveProcessParams *params, @@ -94,7 +94,7 @@ ArmLiveProcess64::ArmLiveProcess64(LiveProcessParams *params, brk_point = roundUp(brk_point, PageBytes); // Set up region for mmaps. For now, start at bottom of kuseg space. - mmap_start = mmap_end = 0x4000000000L; + mmap_end = 0x4000000000L; } void |