On 25 September 2015 at 15:27, Andre Przywara <andre.przywara@xxxxxxx> wrote: > On 24/09/15 13:08, Pavel Fedin wrote: >> Hello! >> >>> The only thing that is pure 64-bit is the MRS/MSR _instruction_ in >>> Aarch64, which always takes a x<nn> register. >>> So can you model the register size according to the spec and allow >>> 32-bit accesses from userland? >> >> I would like to complete the rework and respin v4, but this is, i guess, the only major issue left. >> Additionally, it impacts the API. So... >> In order to allow 32-bit accesses we would have to drop using ARM64_SYS_REG() for building >> attribute ID and introduce something own, like KVM_DEV_ARM_VGIC_REG(). It will have different bits >> layout (actually it will be missing 'arch' and 'size' field, and instead i will use >> KVM_DEV_ARM_VGIC_64BIT flag for length specification, the same as for redistributor. >> Will this be OK ? > > No, instead you should go with your original approach ;-) > Thinking about that again I see that this interface is of course modeled > after the architectured GICv3 system registers, where AArch32 has its > own, separate encoding. So it's perfectly fine to use that 64-bit > interface between userland and KVM now. If we later get Aarch32 support > for the GICv3, we can add the appropriate Aarch32 sysregs to that > interface and have a natural match. Christoffer, Marc and I had a discussion about how best to handle GICv3 state save and restore here at Linaro Connect this week, and one of the conclusions there was that all of it should be done via the device fd's save/restore interface, not via the SET/GET_ONE_REG CPU register interface. (Because it's much less confusing to have all of the GICv3's state be dealt with via the same interface, rather than splitting it; it's also more convenient for QEMU.) More details to follow from one of us next week when we aren't all on aeroplanes, I expect. thanks -- PMM -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html