Commit 547f7813 authored by Marc Zyngier's avatar Marc Zyngier

ARM: KVM: fix ordering of 64bit coprocessor accesses

Commit 240e99cb (ARM: KVM: Fix 64-bit coprocessor handling)
added an ordering dependency for the 64bit registers.

The order described is: CRn, CRm, Op1, Op2, 64bit-first.

Unfortunately, the implementation is: CRn, 64bit-first, CRm...

Move the 64bit test to be last in order to match the documentation.
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
Reviewed-by: default avatarChristoffer Dall <christoffer.dall@linaro.org>
Acked-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
parent 46c214dd
...@@ -135,13 +135,13 @@ static inline int cmp_reg(const struct coproc_reg *i1, ...@@ -135,13 +135,13 @@ static inline int cmp_reg(const struct coproc_reg *i1,
return -1; return -1;
if (i1->CRn != i2->CRn) if (i1->CRn != i2->CRn)
return i1->CRn - i2->CRn; return i1->CRn - i2->CRn;
if (i1->is_64 != i2->is_64)
return i2->is_64 - i1->is_64;
if (i1->CRm != i2->CRm) if (i1->CRm != i2->CRm)
return i1->CRm - i2->CRm; return i1->CRm - i2->CRm;
if (i1->Op1 != i2->Op1) if (i1->Op1 != i2->Op1)
return i1->Op1 - i2->Op1; return i1->Op1 - i2->Op1;
if (i1->Op2 != i2->Op2)
return i1->Op2 - i2->Op2; return i1->Op2 - i2->Op2;
return i2->is_64 - i1->is_64;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment