HV: instr_emul: Make vie_read/write_bytereg as non-failed function

vie_read/write_bytereg call vm_get/set_register to get/set byteregs.

We have make vm_get/set_register as non-failed function in previous patch.
So, this patch make the vie_read/write_bytereg as non-failed function too.

Signed-off-by: Kaige Fu <kaige.fu@intel.com>
Acked-by: Eddie Dong <eddie.dong@intel.com>
This commit is contained in:
Kaige Fu 2018-08-06 12:00:04 +08:00 committed by lijinxia
parent 59c0f355c8
commit 12726dbfc9

View File

@ -597,11 +597,11 @@ static void vie_calc_bytereg(struct instr_emul_vie *vie,
}
}
static int vie_read_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie,
uint8_t *rval)
static uint8_t vie_read_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie)
{
int lhbr;
uint64_t val;
int error = 0, lhbr;
uint8_t reg_val;
enum cpu_reg_name reg;
vie_calc_bytereg(vie, &reg, &lhbr);
@ -612,23 +612,24 @@ static int vie_read_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie,
* base register right by 8 bits (%ah = %rax >> 8).
*/
if (lhbr != 0) {
*rval = (uint8_t)(val >> 8);
reg_val = (uint8_t)(val >> 8);
} else {
*rval = (uint8_t)val;
}
return error;
reg_val = (uint8_t)val;
}
static int vie_write_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie,
return reg_val;
}
static void vie_write_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie,
uint8_t byte)
{
uint64_t origval, val, mask;
int error = 0, lhbr;
enum cpu_reg_name reg;
int lhbr;
vie_calc_bytereg(vie, &reg, &lhbr);
origval = vm_get_register(vcpu, reg);
if (error == 0) {
val = byte;
mask = 0xffU;
if (lhbr != 0) {
@ -642,8 +643,6 @@ static int vie_write_bytereg(struct vcpu *vcpu, struct instr_emul_vie *vie,
val |= origval & ~mask;
vm_set_register(vcpu, reg, val);
}
return error;
}
static int vie_update_register(struct vcpu *vcpu, enum cpu_reg_name reg,
uint64_t val_arg, uint8_t size)
@ -744,10 +743,8 @@ static int emulate_mov(struct vcpu *vcpu, struct instr_emul_vie *vie)
* REX + 88/r: mov r/m8, r8 (%ah, %ch, %dh, %bh not available)
*/
size = 1U; /* override for byte operation */
error = vie_read_bytereg(vcpu, vie, &byte);
if (error == 0) {
byte = vie_read_bytereg(vcpu, vie);
error = mmio_write(vcpu, byte);
}
break;
case 0x89U:
/*
@ -771,7 +768,7 @@ static int emulate_mov(struct vcpu *vcpu, struct instr_emul_vie *vie)
size = 1U; /* override for byte operation */
error = mmio_read(vcpu, &val);
if (error == 0) {
error = vie_write_bytereg(vcpu, vie, (uint8_t)val);
vie_write_bytereg(vcpu, vie, (uint8_t)val);
}
break;
case 0x8BU: