Commit f6af84e7 authored by David Hildenbrand's avatar David Hildenbrand Committed by Christian Borntraeger

KVM: s390: clean up prog irq injection on prog irq icpts

__extract_prog_irq() is used only once for getting the program check data
in one place. Let's combine it with an injection function to avoid a memset
and to prevent misuse on injection by simplifying the interface to only
have the VCPU as parameter.
Reviewed-by: default avatarChristian Borntraeger <borntraeger@de.ibm.com>
Signed-off-by: default avatarDavid Hildenbrand <dahi@linux.vnet.ibm.com>
Signed-off-by: default avatarChristian Borntraeger <borntraeger@de.ibm.com>
parent 65977322
...@@ -136,11 +136,11 @@ static int handle_instruction(struct kvm_vcpu *vcpu) ...@@ -136,11 +136,11 @@ static int handle_instruction(struct kvm_vcpu *vcpu)
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }
static void __extract_prog_irq(struct kvm_vcpu *vcpu, static int inject_prog_on_prog_intercept(struct kvm_vcpu *vcpu)
struct kvm_s390_pgm_info *pgm_info)
{ {
memset(pgm_info, 0, sizeof(struct kvm_s390_pgm_info)); struct kvm_s390_pgm_info pgm_info = {
pgm_info->code = vcpu->arch.sie_block->iprcc; .code = vcpu->arch.sie_block->iprcc,
};
switch (vcpu->arch.sie_block->iprcc & ~PGM_PER) { switch (vcpu->arch.sie_block->iprcc & ~PGM_PER) {
case PGM_AFX_TRANSLATION: case PGM_AFX_TRANSLATION:
...@@ -153,7 +153,7 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu, ...@@ -153,7 +153,7 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu,
case PGM_PRIMARY_AUTHORITY: case PGM_PRIMARY_AUTHORITY:
case PGM_SECONDARY_AUTHORITY: case PGM_SECONDARY_AUTHORITY:
case PGM_SPACE_SWITCH: case PGM_SPACE_SWITCH:
pgm_info->trans_exc_code = vcpu->arch.sie_block->tecmc; pgm_info.trans_exc_code = vcpu->arch.sie_block->tecmc;
break; break;
case PGM_ALEN_TRANSLATION: case PGM_ALEN_TRANSLATION:
case PGM_ALE_SEQUENCE: case PGM_ALE_SEQUENCE:
...@@ -161,7 +161,7 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu, ...@@ -161,7 +161,7 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu,
case PGM_ASTE_SEQUENCE: case PGM_ASTE_SEQUENCE:
case PGM_ASTE_VALIDITY: case PGM_ASTE_VALIDITY:
case PGM_EXTENDED_AUTHORITY: case PGM_EXTENDED_AUTHORITY:
pgm_info->exc_access_id = vcpu->arch.sie_block->eai; pgm_info.exc_access_id = vcpu->arch.sie_block->eai;
break; break;
case PGM_ASCE_TYPE: case PGM_ASCE_TYPE:
case PGM_PAGE_TRANSLATION: case PGM_PAGE_TRANSLATION:
...@@ -169,32 +169,33 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu, ...@@ -169,32 +169,33 @@ static void __extract_prog_irq(struct kvm_vcpu *vcpu,
case PGM_REGION_SECOND_TRANS: case PGM_REGION_SECOND_TRANS:
case PGM_REGION_THIRD_TRANS: case PGM_REGION_THIRD_TRANS:
case PGM_SEGMENT_TRANSLATION: case PGM_SEGMENT_TRANSLATION:
pgm_info->trans_exc_code = vcpu->arch.sie_block->tecmc; pgm_info.trans_exc_code = vcpu->arch.sie_block->tecmc;
pgm_info->exc_access_id = vcpu->arch.sie_block->eai; pgm_info.exc_access_id = vcpu->arch.sie_block->eai;
pgm_info->op_access_id = vcpu->arch.sie_block->oai; pgm_info.op_access_id = vcpu->arch.sie_block->oai;
break; break;
case PGM_MONITOR: case PGM_MONITOR:
pgm_info->mon_class_nr = vcpu->arch.sie_block->mcn; pgm_info.mon_class_nr = vcpu->arch.sie_block->mcn;
pgm_info->mon_code = vcpu->arch.sie_block->tecmc; pgm_info.mon_code = vcpu->arch.sie_block->tecmc;
break; break;
case PGM_VECTOR_PROCESSING: case PGM_VECTOR_PROCESSING:
case PGM_DATA: case PGM_DATA:
pgm_info->data_exc_code = vcpu->arch.sie_block->dxc; pgm_info.data_exc_code = vcpu->arch.sie_block->dxc;
break; break;
case PGM_PROTECTION: case PGM_PROTECTION:
pgm_info->trans_exc_code = vcpu->arch.sie_block->tecmc; pgm_info.trans_exc_code = vcpu->arch.sie_block->tecmc;
pgm_info->exc_access_id = vcpu->arch.sie_block->eai; pgm_info.exc_access_id = vcpu->arch.sie_block->eai;
break; break;
default: default:
break; break;
} }
if (vcpu->arch.sie_block->iprcc & PGM_PER) { if (vcpu->arch.sie_block->iprcc & PGM_PER) {
pgm_info->per_code = vcpu->arch.sie_block->perc; pgm_info.per_code = vcpu->arch.sie_block->perc;
pgm_info->per_atmid = vcpu->arch.sie_block->peratmid; pgm_info.per_atmid = vcpu->arch.sie_block->peratmid;
pgm_info->per_address = vcpu->arch.sie_block->peraddr; pgm_info.per_address = vcpu->arch.sie_block->peraddr;
pgm_info->per_access_id = vcpu->arch.sie_block->peraid; pgm_info.per_access_id = vcpu->arch.sie_block->peraid;
} }
return kvm_s390_inject_prog_irq(vcpu, &pgm_info);
} }
/* /*
...@@ -223,7 +224,6 @@ static int handle_itdb(struct kvm_vcpu *vcpu) ...@@ -223,7 +224,6 @@ static int handle_itdb(struct kvm_vcpu *vcpu)
static int handle_prog(struct kvm_vcpu *vcpu) static int handle_prog(struct kvm_vcpu *vcpu)
{ {
struct kvm_s390_pgm_info pgm_info;
psw_t psw; psw_t psw;
int rc; int rc;
...@@ -249,8 +249,7 @@ static int handle_prog(struct kvm_vcpu *vcpu) ...@@ -249,8 +249,7 @@ static int handle_prog(struct kvm_vcpu *vcpu)
if (rc) if (rc)
return rc; return rc;
__extract_prog_irq(vcpu, &pgm_info); return inject_prog_on_prog_intercept(vcpu);
return kvm_s390_inject_prog_irq(vcpu, &pgm_info);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment