From: christoffer.dall@linaro.org (Christoffer Dall)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v2 7/7] ARM: KVM: MMIO support BE host running LE code
Date: Wed, 19 Mar 2014 18:12:30 -0700 [thread overview]
Message-ID: <20140320011230.GM1297@cbox> (raw)
In-Reply-To: <1392183693-21238-8-git-send-email-victor.kamensky@linaro.org>
On Tue, Feb 11, 2014 at 09:41:33PM -0800, Victor Kamensky wrote:
> In case of status register E bit is not set (LE mode) and host runs in
> BE mode we need byteswap data, so read/write is emulated correctly.
>
> Signed-off-by: Victor Kamensky <victor.kamensky@linaro.org>
> ---
> arch/arm/include/asm/kvm_emulate.h | 22 ++++++++++++++++++----
> 1 file changed, 18 insertions(+), 4 deletions(-)
>
> diff --git a/arch/arm/include/asm/kvm_emulate.h b/arch/arm/include/asm/kvm_emulate.h
> index 0fa90c9..69b7469 100644
> --- a/arch/arm/include/asm/kvm_emulate.h
> +++ b/arch/arm/include/asm/kvm_emulate.h
> @@ -185,9 +185,16 @@ static inline unsigned long vcpu_data_guest_to_host(struct kvm_vcpu *vcpu,
> default:
> return be32_to_cpu(data);
> }
> + } else {
> + switch (len) {
> + case 1:
> + return data & 0xff;
> + case 2:
> + return le16_to_cpu(data & 0xffff);
> + default:
> + return le32_to_cpu(data);
> + }
> }
> -
> - return data; /* Leave LE untouched */
> }
>
> static inline unsigned long vcpu_data_host_to_guest(struct kvm_vcpu *vcpu,
> @@ -203,9 +210,16 @@ static inline unsigned long vcpu_data_host_to_guest(struct kvm_vcpu *vcpu,
> default:
> return cpu_to_be32(data);
> }
> + } else {
> + switch (len) {
> + case 1:
> + return data & 0xff;
> + case 2:
> + return cpu_to_le16(data & 0xffff);
> + default:
> + return cpu_to_le32(data);
> + }
> }
> -
> - return data; /* Leave LE untouched */
> }
>
> #endif /* __ARM_KVM_EMULATE_H__ */
> --
> 1.8.1.4
>
Somehow in my head the way I think about this is
if (guest_be != host_be) {
return swab(data);
}
but it's probably not more clear in terms of the actual code...
Anyway, given that the ABI clarification text gets merged:
Reviewed-by: Christoffer Dall <christoffer.dall@linaro.org>
prev parent reply other threads:[~2014-03-20 1:12 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-02-12 5:41 [PATCH v2 0/7] armv7 BE kvm support Victor Kamensky
2014-02-12 5:41 ` [PATCH v2 1/7] ARM: KVM: switch hypervisor into BE mode in case of BE host Victor Kamensky
2014-03-18 22:23 ` Christoffer Dall
2014-03-19 0:52 ` Victor Kamensky
2014-03-19 3:03 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 2/7] ARM: KVM: fix vgic V7 assembler code to work in BE image Victor Kamensky
2014-03-20 1:10 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 3/7] ARM: KVM: handle 64bit values passed to mrcc or from mcrr instructions in BE case Victor Kamensky
2014-03-20 1:11 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 4/7] ARM: KVM: __kvm_vcpu_run function return result fix " Victor Kamensky
2014-03-20 1:11 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 5/7] ARM: KVM: one_reg coproc set and get BE fixes Victor Kamensky
2014-02-12 7:07 ` Alexander Graf
2014-03-20 1:11 ` Christoffer Dall
2014-03-20 1:48 ` Victor Kamensky
2014-03-20 3:01 ` Christoffer Dall
2014-05-13 20:11 ` Victor Kamensky
2014-05-25 19:09 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 6/7] ARM: KVM: vgic mmio should hold data as LE bytes array in BE case Victor Kamensky
2014-03-20 1:12 ` Christoffer Dall
2014-02-12 5:41 ` [PATCH v2 7/7] ARM: KVM: MMIO support BE host running LE code Victor Kamensky
2014-03-20 1:12 ` Christoffer Dall [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140320011230.GM1297@cbox \
--to=christoffer.dall@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.