mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 09:43:56 -06:00
390x/css: introduce maximum data address checking
The architecture mandates the addresses to be accessed on the first indirection level (that is, the data addresses without IDA, and the (M)IDAW addresses with (M)IDA) to be checked against an CCW format dependent limit maximum address. If a violation is detected, the storage access is not to be performed and a channel program check needs to be generated. As of today, we fail to do this check. Let us stick even closer to the architecture specification. Signed-off-by: Halil Pasic <pasic@linux.vnet.ibm.com> Message-Id: <20170921180841.24490-5-pasic@linux.vnet.ibm.com> Reviewed-by: Pierre Morel <pmorel@linux.vnet.ibm.com> Reviewed-by: Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
This commit is contained in:
parent
f57ba05823
commit
62a2554ec2
2 changed files with 11 additions and 0 deletions
|
@ -799,6 +799,11 @@ static inline int cds_check_len(CcwDataStream *cds, int len)
|
|||
return cds->flags & CDS_F_STREAM_BROKEN ? -EINVAL : len;
|
||||
}
|
||||
|
||||
static inline bool cds_ccw_addrs_ok(hwaddr addr, int len, bool ccw_fmt1)
|
||||
{
|
||||
return (addr + len) < (ccw_fmt1 ? (1UL << 31) : (1UL << 24));
|
||||
}
|
||||
|
||||
static int ccw_dstream_rw_noflags(CcwDataStream *cds, void *buff, int len,
|
||||
CcwDataStreamOp op)
|
||||
{
|
||||
|
@ -808,6 +813,9 @@ static int ccw_dstream_rw_noflags(CcwDataStream *cds, void *buff, int len,
|
|||
if (ret <= 0) {
|
||||
return ret;
|
||||
}
|
||||
if (!cds_ccw_addrs_ok(cds->cda, len, cds->flags & CDS_F_FMT)) {
|
||||
return -EINVAL; /* channel program check */
|
||||
}
|
||||
if (op == CDS_OP_A) {
|
||||
goto incr;
|
||||
}
|
||||
|
@ -832,7 +840,9 @@ void ccw_dstream_init(CcwDataStream *cds, CCW1 const *ccw, ORB const *orb)
|
|||
g_assert(!(orb->ctrl1 & ORB_CTRL1_MASK_MIDAW));
|
||||
cds->flags = (orb->ctrl0 & ORB_CTRL0_MASK_I2K ? CDS_F_I2K : 0) |
|
||||
(orb->ctrl0 & ORB_CTRL0_MASK_C64 ? CDS_F_C64 : 0) |
|
||||
(orb->ctrl0 & ORB_CTRL0_MASK_FMT ? CDS_F_FMT : 0) |
|
||||
(ccw->flags & CCW_FLAG_IDA ? CDS_F_IDA : 0);
|
||||
|
||||
cds->count = ccw->count;
|
||||
cds->cda_orig = ccw->cda;
|
||||
ccw_dstream_rewind(cds);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue