On 12/19/2013 03:38 PM, Peter Maydell wrote:
On 19 December 2013 07:27, Fedorov Sergey <s.fedo...@samsung.com> wrote:
Yes, this banking scheme makes state changing events quite heavy. But
maintaining the active copies allows to keep translation table walking code
untouched. I think there is a trade-off between state changing and
translation table walking overheads.
We shouldn't be doing tlb walks that often that it makes a
difference whether we do env->ttbr0 or env->ttbr0[env->ns] ...
I think the CP banking is the most fragile thing in this patch series and
this should become much better after review :)
It would probably be a good idea to look at the v8 ARM ARM and
figure out how banked-for-NS/S registers should fit in with the
AArch64 vs AArch32 split.
[if you don't have a copy, it's on the ARM website:
http://infocenter.arm.com/help/topic/com.arm.doc.ddi0487a.a_errata2/index.html
you'll need to register an account on the website if you don't already
have one but it's a fairly simple "fill in the form" automated process]
Note in particular that:
* many of the current uint32_t fields in our CPU state struct are
likely to widen to uint64_t, so the AArch64 representation is
canonical, and the AArch32 register accessors access a part
of that state (typically the lower 32 bits)
* registers which are banked S/NS in AArch32 are not necessarily
banked in AArch64
AArch64 support is likely to land before your TrustZone stuff
does so we need to make the two features work together cleanly.
thanks
-- PMM
I've briefly looked at the v8 ARM ARM. As I can see there is no banked
system control registers in AArch64. Seems the concept is changed to
provide separate registers for each meaningful execution level. Please,
correct me if I am wrong.
So I think there shouldn't be "active" and "banked" fields for banked
AArch32 CP15 registers as in my patch. Seems it is worth to use AArch64
view of system control registers as a basis. That means there would be
separate S and NS register fields in CPU state structure that will me
mapped to separate AArch64 registers. ARMCPRegInfo structure would have
additional field holding NS register state filed offset for AArch32
banked registers.
Which branch in https://git.linaro.org/people/peter.maydell/qemu-arm.git
repository holds the most actual A64 support?
Thanks!
Best regards,
Sergey Fedorov