Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b8e6f8ae authored by Alexander Graf's avatar Alexander Graf Committed by Paul Mackerras
Browse files

KVM: PPC: Book3S: Compile fix for ppc32 in HIOR access code



We were failing to compile on book3s_32 with the following errors:

arch/powerpc/kvm/book3s_pr.c:883:45: error: cast to pointer from integer of different size [-Werror=int-to-pointer-cast]
arch/powerpc/kvm/book3s_pr.c:898:79: error: cast to pointer from integer of different size [-Werror=int-to-pointer-cast]

Fix this by explicity casting the u64 to long before we use it as a pointer.

Also, on PPC32 we can not use get_user/put_user for 64bit wide variables,
as there is no single instruction that could load or store variables that big.

So instead, we have to use copy_from/to_user which works everywhere.

Reported-by: default avatarJörg Sommer <joerg@alea.gnuu.de>
Signed-off-by: default avatarAlexander Graf <agraf@suse.de>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent b1a808ff
Loading
Loading
Loading
Loading
+4 −2
Original line number Original line Diff line number Diff line
@@ -881,7 +881,8 @@ int kvm_vcpu_ioctl_get_one_reg(struct kvm_vcpu *vcpu, struct kvm_one_reg *reg)


	switch (reg->id) {
	switch (reg->id) {
	case KVM_REG_PPC_HIOR:
	case KVM_REG_PPC_HIOR:
		r = put_user(to_book3s(vcpu)->hior, (u64 __user *)reg->addr);
		r = copy_to_user((u64 __user *)(long)reg->addr,
				&to_book3s(vcpu)->hior, sizeof(u64));
		break;
		break;
	default:
	default:
		break;
		break;
@@ -896,7 +897,8 @@ int kvm_vcpu_ioctl_set_one_reg(struct kvm_vcpu *vcpu, struct kvm_one_reg *reg)


	switch (reg->id) {
	switch (reg->id) {
	case KVM_REG_PPC_HIOR:
	case KVM_REG_PPC_HIOR:
		r = get_user(to_book3s(vcpu)->hior, (u64 __user *)reg->addr);
		r = copy_from_user(&to_book3s(vcpu)->hior,
				   (u64 __user *)(long)reg->addr, sizeof(u64));
		if (!r)
		if (!r)
			to_book3s(vcpu)->hior_explicit = true;
			to_book3s(vcpu)->hior_explicit = true;
		break;
		break;