KVM: s390: prepare to read random guest instructions

We will have to read instructions not residing at the current PSW
address.

Reviewed-by: Eric Farman <farman@linux.vnet.ibm.com>
Signed-off-by: David Hildenbrand <dahi@linux.vnet.ibm.com>
Cc: David Hildenbrand <david@redhat.com>
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
This commit is contained in:
David Hildenbrand 2016-05-24 12:00:49 +02:00 коммит произвёл Christian Borntraeger
Родитель f41711788c
Коммит 3fa8cad740
2 изменённых файлов: 6 добавлений и 5 удалений

Просмотреть файл

@ -247,10 +247,11 @@ int read_guest(struct kvm_vcpu *vcpu, unsigned long ga, u8 ar, void *data,
/** /**
* read_guest_instr - copy instruction data from guest space to kernel space * read_guest_instr - copy instruction data from guest space to kernel space
* @vcpu: virtual cpu * @vcpu: virtual cpu
* @ga: guest address
* @data: destination address in kernel space * @data: destination address in kernel space
* @len: number of bytes to copy * @len: number of bytes to copy
* *
* Copy @len bytes from the current psw address (guest space) to @data (kernel * Copy @len bytes from the given address (guest space) to @data (kernel
* space). * space).
* *
* The behaviour of read_guest_instr is identical to read_guest, except that * The behaviour of read_guest_instr is identical to read_guest, except that
@ -258,10 +259,10 @@ int read_guest(struct kvm_vcpu *vcpu, unsigned long ga, u8 ar, void *data,
* address-space mode. * address-space mode.
*/ */
static inline __must_check static inline __must_check
int read_guest_instr(struct kvm_vcpu *vcpu, void *data, unsigned long len) int read_guest_instr(struct kvm_vcpu *vcpu, unsigned long ga, void *data,
unsigned long len)
{ {
return access_guest(vcpu, vcpu->arch.sie_block->gpsw.addr, 0, data, len, return access_guest(vcpu, ga, 0, data, len, GACC_IFETCH);
GACC_IFETCH);
} }
/** /**

Просмотреть файл

@ -2588,7 +2588,7 @@ static int vcpu_post_run_fault_in_sie(struct kvm_vcpu *vcpu)
* to look up the current opcode to get the length of the instruction * to look up the current opcode to get the length of the instruction
* to be able to forward the PSW. * to be able to forward the PSW.
*/ */
rc = read_guest_instr(vcpu, &opcode, 1); rc = read_guest_instr(vcpu, vcpu->arch.sie_block->gpsw.addr, &opcode, 1);
ilen = insn_length(opcode); ilen = insn_length(opcode);
if (rc < 0) { if (rc < 0) {
return rc; return rc;