vfio-ccw: add force unlimited prefetch property
commit9a51c9ee6ca6610e4ab89945e6c75eda3a265ceb
authorHalil Pasic <pasic@linux.ibm.com>
Thu, 24 May 2018 17:58:27 +0000 (24 19:58 +0200)
committerCornelia Huck <cohuck@redhat.com>
Mon, 18 Jun 2018 08:50:32 +0000 (18 10:50 +0200)
treea7ffc640ea034f56611d60fdba8d5e80f1d5b51f
parent7a5342e7ccf2deb5553951024d57ec1327c926dd
vfio-ccw: add force unlimited prefetch property

There is at least one guest (OS) such that although it does not rely on
the guarantees provided by ORB 1 word 9 bit (aka unlimited prefetch, aka
P bit) not being set, it fails to tell this to the machine.

Usually this ain't a big deal, as the original purpose of the P bit is to
allow for performance optimizations. vfio-ccw however can not provide the
guarantees required if the bit is not set.

It is not possible to implement support for the P bit not set without
transitioning to lower level protocols for vfio-ccw.  So let's give the
user the opportunity to force setting the P bit, if the user knows this
is safe.  For self modifying channel programs forcing the P bit is not
safe.  If the P bit is forced for a self modifying channel program things
are expected to break in strange ways.

Let's also avoid warning multiple about P bit not set in the ORB in case
P bit is not told to be forced, and designate the affected vfio-ccw
device.

Signed-off-by: Halil Pasic <pasic@linux.ibm.com>
Suggested-by: Dong Jia Shi <bjsdjshi@linux.ibm.com>
Acked-by: Jason J. Herne <jjherne@linux.ibm.com>
Tested-by: Jason J. Herne <jjherne@linux.ibm.com>
Message-Id: <20180524175828.3143-2-pasic@linux.ibm.com>
Signed-off-by: Cornelia Huck <cohuck@redhat.com>
hw/s390x/css.c
hw/vfio/ccw.c