summaryrefslogtreecommitdiff
path: root/src/arch/alpha/pseudo_inst.hh
diff options
context:
space:
mode:
authorGabe Black <gabeblack@google.com>2019-11-25 01:07:41 -0800
committerGabe Black <gabeblack@google.com>2019-12-10 23:58:14 +0000
commitcb3457ccd17a89a4df3e70d35e0254c77a0b5782 (patch)
tree6693c6acb869246269906c5227f1331a78a6262d /src/arch/alpha/pseudo_inst.hh
parentd142a1547cfc7e06964e2cb34905f3e4304c93fd (diff)
downloadgem5-cb3457ccd17a89a4df3e70d35e0254c77a0b5782.tar.xz
arch,cpu,sim: Push syscall number determination up to processes.
The logic that determines which syscall to call was built into the implementation of faults/exceptions or even into the instruction decoder, but that logic can depend on what OS is being used, and sometimes even what version, for example 32bit vs. 64bit. This change pushes that logic up into the Process objects since those already handle a lot of the aspects of emulating the guest OS. Instead, the ISA or fault implementations just notify the rest of the system that a nebulous syscall has happened, and that gets propogated upward until the process does something with it. That's very analogous to how a system call would work on a real machine. When a system call happens, the low level component which detects that should call tc->syscall(&fault), where tc is the relevant thread (or execution) context, and fault is a Fault which can ultimately be set by the system call implementation. The TC implementor (probably a CPU) will then have a chance to do whatever it needs to to handle a system call. Currently only O3 does anything special here. That implementor will end up calling the Process's syscall() method. Once in Process::syscall, the process object will use it's contextual knowledge to determine what system call is being requested. It then calls Process::doSyscall with the right syscall number, where doSyscall centralizes the common mechanism for actually retrieving and calling into the system call implementation. Jira Issue: https://gem5.atlassian.net/browse/GEM5-187 Change-Id: I937ec1ef0576142c2a182ff33ca508d77ad0e7a1 Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/23176 Maintainer: Gabe Black <gabeblack@google.com> Tested-by: kokoro <noreply+kokoro@google.com> Reviewed-by: Brandon Potter <Brandon.Potter@amd.com>
Diffstat (limited to 'src/arch/alpha/pseudo_inst.hh')
0 files changed, 0 insertions, 0 deletions