aboutsummaryrefslogtreecommitdiff
path: root/target/s390x/tcg_s390x.h
diff options
context:
space:
mode:
authorDavid Hildenbrand <david@redhat.com>2019-02-22 11:19:48 +0100
committerDavid Hildenbrand <david@redhat.com>2019-06-07 14:53:25 +0200
commit9be6fa99d6b1371ced6a9b57c32daec86733cd0a (patch)
treed1922ea6cd6eadd8593e093d51daacbc50fc960e /target/s390x/tcg_s390x.h
parente19a61eb514dbf7c9a725c7539ce3b6166cd6ac4 (diff)
s390x/tcg: Introduce tcg_s390_vector_exception()
Handling is similar to data exceptions, however we can always store the VXC into the lowore and the FPC: z14 PoP, 6-20, "Vector-Exception Code" When a vector-processing exception causes a pro- gram interruption, a vector-exception code (VXC) is stored at location 147, and zeros are stored at loca- tions 144-146. The VXC is also placed in the DXC field of the floating-point-control (FPC) register if bit 45 of control register 0 is one. When bit 45 of control register 0 is zero and bit 46 of control register 0 is one, the DXC field of the FPC register and the con- tents of storage at location 147 are unpredictable. Signed-off-by: David Hildenbrand <david@redhat.com>
Diffstat (limited to 'target/s390x/tcg_s390x.h')
-rw-r--r--target/s390x/tcg_s390x.h2
1 files changed, 2 insertions, 0 deletions
diff --git a/target/s390x/tcg_s390x.h b/target/s390x/tcg_s390x.h
index ab2c4ba703..2813f9d48e 100644
--- a/target/s390x/tcg_s390x.h
+++ b/target/s390x/tcg_s390x.h
@@ -18,5 +18,7 @@ void QEMU_NORETURN tcg_s390_program_interrupt(CPUS390XState *env, uint32_t code,
int ilen, uintptr_t ra);
void QEMU_NORETURN tcg_s390_data_exception(CPUS390XState *env, uint32_t dxc,
uintptr_t ra);
+void QEMU_NORETURN tcg_s390_vector_exception(CPUS390XState *env, uint32_t vxc,
+ uintptr_t ra);
#endif /* TCG_S390X_H */