Merge branch 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6
* 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6: [S390] KVM: Read buffer overflow [S390] kernel: Storing machine flags early in lowcore
This commit is contained in:
Коммит
9cf9d28e9b
|
@ -208,6 +208,9 @@ static noinline __init void detect_machine_type(void)
|
||||||
machine_flags |= MACHINE_FLAG_KVM;
|
machine_flags |= MACHINE_FLAG_KVM;
|
||||||
else
|
else
|
||||||
machine_flags |= MACHINE_FLAG_VM;
|
machine_flags |= MACHINE_FLAG_VM;
|
||||||
|
|
||||||
|
/* Store machine flags for setting up lowcore early */
|
||||||
|
S390_lowcore.machine_flags = machine_flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __init void early_pgm_check_handler(void)
|
static __init void early_pgm_check_handler(void)
|
||||||
|
|
|
@ -169,7 +169,7 @@ static int __sigp_set_prefix(struct kvm_vcpu *vcpu, u16 cpu_addr, u32 address,
|
||||||
unsigned long *reg)
|
unsigned long *reg)
|
||||||
{
|
{
|
||||||
struct kvm_s390_float_interrupt *fi = &vcpu->kvm->arch.float_int;
|
struct kvm_s390_float_interrupt *fi = &vcpu->kvm->arch.float_int;
|
||||||
struct kvm_s390_local_interrupt *li;
|
struct kvm_s390_local_interrupt *li = NULL;
|
||||||
struct kvm_s390_interrupt_info *inti;
|
struct kvm_s390_interrupt_info *inti;
|
||||||
int rc;
|
int rc;
|
||||||
u8 tmp;
|
u8 tmp;
|
||||||
|
@ -189,9 +189,10 @@ static int __sigp_set_prefix(struct kvm_vcpu *vcpu, u16 cpu_addr, u32 address,
|
||||||
return 2; /* busy */
|
return 2; /* busy */
|
||||||
|
|
||||||
spin_lock(&fi->lock);
|
spin_lock(&fi->lock);
|
||||||
li = fi->local_int[cpu_addr];
|
if (cpu_addr < KVM_MAX_VCPUS)
|
||||||
|
li = fi->local_int[cpu_addr];
|
||||||
|
|
||||||
if ((cpu_addr >= KVM_MAX_VCPUS) || (li == NULL)) {
|
if (li == NULL) {
|
||||||
rc = 1; /* incorrect state */
|
rc = 1; /* incorrect state */
|
||||||
*reg &= SIGP_STAT_INCORRECT_STATE;
|
*reg &= SIGP_STAT_INCORRECT_STATE;
|
||||||
kfree(inti);
|
kfree(inti);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче