On Fri, 8 Jun 2018 17:51:27 +0200
Pierre Morel <pmorel@xxxxxxxxxxxxx> wrote:
On 08/06/2018 16:45, Cornelia Huck wrote:Looking at Documentation/s390/vfio-ccw.txt, it states that "scsw_area
On Fri, 8 Jun 2018 15:13:28 +0200I do not think we need to change the interface radically but
Halil Pasic <pasic@xxxxxxxxxxxxx> wrote:
On 06/08/2018 02:20 PM, Cornelia Huck wrote:It might make sense to keep this for ssch, maybe reuse it for hsch/csch,
The status of what? Kind of a target status?Hm, I rather consider that "we write a status, and the backend figuresMy proposal is to do the sameThis I do not agree scsw(r) is part of the driver.
copying to scsw(r) again, which would mean we get a request with both
the halt and the start bit set. The vfio code now needs to do a hsch
(instead of a ssch). The real channel subsystem should figure this out,
as we can't reliably check whether the start function has concluded
already (there's always a race window).
The interface here is not a device interface anymore but a driver
interface.
SCSW is a status, it is at its place in QEMU device interface with the
guest
but here pwrite() sends a command.
out what to do based on that status".
I think this approach is the source of lots of complications. For instance
take xsch. How are we supposed to react to a guest xsch (in QEMU and
in the kernel module)? My guess is that the right thing to do is to issue
an xsch in the vfio-ccw kernel module on the passed through subchannel.
But there is no bit in fctl for cancel.
Bottom line is: I'm not happy with the current design but I'm not sure
if it's practical to do something about it (i.e. change it radically).
I also do not thing we should extend it by using multiple commands
in a single syscall.
Currently:
 - only SSCH bit is used
 - only the SSCH instruction is implemented
 - all other bits, CSCH,HSCH produce an error when used alone
ÂÂÂ or are ignored in conjonction with SSCH
ÂÂ - there is no implementation using the other bits
ÂÂ - It is not specified in the documentation that multiple commands
ÂÂÂÂ can be used.
should be filled with the SCSW of the Virtual Subchannel". This seems
to indicate that this is really intended to be a scsw... but I agree,
it does lack details.
Looking at these, I think there is no trouble to modify the wayYes, we're currently still free to go in different directions; adding
the Kernel interface is implemented without impact on current QEMU.
But if we begin to allow ssch/hsch/csch in a single command
in a new implementation we will be stuck with it.
support for hsch/csch to the interface in the way I did would fix it.
In any case, we need better documentation :/
Not a problem, I agree (and yes, the patch did that).and think about something else for other things we want to handleYes we will need to have another interface, ioctl, or new region,
all possible, but really more complex.
(xsch, channel monitoring, the path handling stuff for which we alreadyWe can use another region for getting up information on path handling
or monitoring, as does the patch IIRC.
This is not a problem.
For xsch, I like Halil's suggestion of simply always setting cc 2.
Channel monitoring is a difficult beast (need to pass through msch, mix
of virtual and passthrough devices on the machine which have different
semantics etc.) I put some of my concerns into
https://wiki.qemu.org/ToDo/Channel_I/O_Passthrough; please add to that
if you have further thoughts.
We should keep those requirements in mind, even if we won't implement
support for it right now.
OK, I think I see your concern now.had a prototype etc.) It's probably not practical to do radical surgeryThere is no need for radical surgery, no change is required to older or
on the existing code.
current QEMU code.
My concern is to avoid a future implementation merging multiple commands
in a single syscall.
It is not only a problem of beauty of the interface,
using a status is for the up-stream, from device to program.
Using the same construct, same name and same location, to produce commands
for the down stream is misleading and source of incoherence.
What happens on the real hardware is that we do a ssch etc. and this
triggers a change that is visible in the scsw when we do a stsch.
What happens here is that the guest doing a ssch triggers a change in
our virtual scsw in QEMU (so far, so good); then we send this scsw to
the vfio module, which looks at the scsw to figure out that it should
do a ssch on the host. This works fine to figure out that a ssch needs
to be done, and would also work for hsch and csch, but it is really a
bit of reverse engineering, and it would probably fail for rsch
(haven't thought about that yet). To parse the intention of doing a
halt or clear out of the scsw_area, we need to rely (a) on user space
doing the right thing, and (b) on us implementing the rules for which
function can be initiated when correctly. If we treat fctl as a simple
command field, we'll just do what user space asks of us directly.
So, what are you proposing? Being more specific and stating that the
scsw is not necessarily a real scsw, but merely a vehicle for sending a
command? Or keeping it as it is now for ssch, and adding a second
interface for hsch/csch (and maybe rsch, msch, ...)?