* [Qemu-devel] [PATCH v4] s390/css: handle CCW_FLAG_SKIP
@ 2019-05-16 13:33 Cornelia Huck
2019-05-17 6:16 ` Cornelia Huck
0 siblings, 1 reply; 2+ messages in thread
From: Cornelia Huck @ 2019-05-16 13:33 UTC (permalink / raw)
To: Halil Pasic, Christian Borntraeger
Cc: Eric Farman, qemu-s390x, Cornelia Huck, qemu-devel, Pierre Morel
If a ccw has CCW_FLAG_SKIP set, and the command is of type
read, read backwards, or sense, no data should be written
to the guest for that command.
Reviewed-by: Eric Farman <farman@linux.ibm.com>
Signed-off-by: Cornelia Huck <cohuck@redhat.com>
---
Will queue this unless someone complains.
v3 -> v4: use MEMTX_OK [Eric]
v2 -> v3: fixed checks even more [Pierre]
v1 -> v2: fixed checks for command type [Eric]
---
hw/s390x/css.c | 22 ++++++++++++++++++----
include/hw/s390x/css.h | 1 +
2 files changed, 19 insertions(+), 4 deletions(-)
diff --git a/hw/s390x/css.c b/hw/s390x/css.c
index 8fc9e35ba5d3..ad310b9f94bc 100644
--- a/hw/s390x/css.c
+++ b/hw/s390x/css.c
@@ -830,8 +830,12 @@ static int ccw_dstream_rw_noflags(CcwDataStream *cds, void *buff, int len,
if (op == CDS_OP_A) {
goto incr;
}
- ret = address_space_rw(&address_space_memory, cds->cda,
- MEMTXATTRS_UNSPECIFIED, buff, len, op);
+ if (!cds->do_skip) {
+ ret = address_space_rw(&address_space_memory, cds->cda,
+ MEMTXATTRS_UNSPECIFIED, buff, len, op);
+ } else {
+ ret = MEMTX_OK;
+ }
if (ret != MEMTX_OK) {
cds->flags |= CDS_F_STREAM_BROKEN;
return -EINVAL;
@@ -928,8 +932,13 @@ static int ccw_dstream_rw_ida(CcwDataStream *cds, void *buff, int len,
do {
iter_len = MIN(len, cont_left);
if (op != CDS_OP_A) {
- ret = address_space_rw(&address_space_memory, cds->cda,
- MEMTXATTRS_UNSPECIFIED, buff, iter_len, op);
+ if (!cds->do_skip) {
+ ret = address_space_rw(&address_space_memory, cds->cda,
+ MEMTXATTRS_UNSPECIFIED, buff, iter_len,
+ op);
+ } else {
+ ret = MEMTX_OK;
+ }
if (ret != MEMTX_OK) {
/* assume inaccessible address */
ret = -EINVAL; /* channel program check */
@@ -968,6 +977,11 @@ void ccw_dstream_init(CcwDataStream *cds, CCW1 const *ccw, ORB const *orb)
cds->count = ccw->count;
cds->cda_orig = ccw->cda;
+ /* skip is only effective for read, read backwards, or sense commands */
+ cds->do_skip = (ccw->flags & CCW_FLAG_SKIP) &&
+ ((ccw->cmd_code & 0x0f) == CCW_CMD_BASIC_SENSE ||
+ (ccw->cmd_code & 0x03) == 0x02 /* read */ ||
+ (ccw->cmd_code & 0x0f) == 0x0c /* read backwards */);
ccw_dstream_rewind(cds);
if (!(cds->flags & CDS_F_IDA)) {
cds->op_handler = ccw_dstream_rw_noflags;
diff --git a/include/hw/s390x/css.h b/include/hw/s390x/css.h
index aae19c427229..7cc183ef4366 100644
--- a/include/hw/s390x/css.h
+++ b/include/hw/s390x/css.h
@@ -97,6 +97,7 @@ typedef struct CcwDataStream {
int (*op_handler)(struct CcwDataStream *cds, void *buff, int len,
CcwDataStreamOp op);
hwaddr cda;
+ bool do_skip;
} CcwDataStream;
/*
--
2.20.1
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [Qemu-devel] [PATCH v4] s390/css: handle CCW_FLAG_SKIP
2019-05-16 13:33 [Qemu-devel] [PATCH v4] s390/css: handle CCW_FLAG_SKIP Cornelia Huck
@ 2019-05-17 6:16 ` Cornelia Huck
0 siblings, 0 replies; 2+ messages in thread
From: Cornelia Huck @ 2019-05-17 6:16 UTC (permalink / raw)
To: Halil Pasic, Christian Borntraeger
Cc: Eric Farman, qemu-s390x, qemu-devel, Pierre Morel
On Thu, 16 May 2019 15:33:27 +0200
Cornelia Huck <cohuck@redhat.com> wrote:
> If a ccw has CCW_FLAG_SKIP set, and the command is of type
> read, read backwards, or sense, no data should be written
> to the guest for that command.
>
> Reviewed-by: Eric Farman <farman@linux.ibm.com>
> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
> ---
>
> Will queue this unless someone complains.
>
> v3 -> v4: use MEMTX_OK [Eric]
> v2 -> v3: fixed checks even more [Pierre]
> v1 -> v2: fixed checks for command type [Eric]
>
> ---
> hw/s390x/css.c | 22 ++++++++++++++++++----
> include/hw/s390x/css.h | 1 +
> 2 files changed, 19 insertions(+), 4 deletions(-)
Queued to s390-next.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2019-05-17 6:18 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-05-16 13:33 [Qemu-devel] [PATCH v4] s390/css: handle CCW_FLAG_SKIP Cornelia Huck
2019-05-17 6:16 ` Cornelia Huck
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).