* [Qemu-devel] [PATCH v1 1/1] target-arm: helper.c: RAZ REVIDR cp register
[not found] <cover.1366682426.git.peter.crosthwaite@xilinx.com>
@ 2013-04-23 2:08 ` peter.crosthwaite
2013-04-23 10:55 ` Peter Maydell
0 siblings, 1 reply; 2+ messages in thread
From: peter.crosthwaite @ 2013-04-23 2:08 UTC (permalink / raw)
To: qemu-devel; +Cc: peter.maydell
From: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
Guests should be able to read REVIDR without suffering an abort. Just
RAZ the REVIDR register.
Signed-off-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
---
target-arm/helper.c | 4 ++++
1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/target-arm/helper.c b/target-arm/helper.c
index fd055e8..e655c74 100644
--- a/target-arm/helper.c
+++ b/target-arm/helper.c
@@ -1187,6 +1187,10 @@ void register_cp_regs_for_features(ARMCPU *cpu)
{ .name = "TLBTR",
.cp = 15, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 3,
.access = PL1_R, .type = ARM_CP_CONST, .resetvalue = 0 },
+ /* RAZ the REVIDR register */
+ { .name = "REVIDR",
+ .cp = 15, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 6,
+ .access = PL1_R, .type = ARM_CP_CONST, .resetvalue = 0 },
/* crn = 0 op1 = 0 crm = 3..7 : currently unassigned; we RAZ. */
{ .name = "DUMMY",
.cp = 15, .crn = 0, .crm = 3, .opc1 = 0, .opc2 = CP_ANY,
--
1.7.0.4
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [Qemu-devel] [PATCH v1 1/1] target-arm: helper.c: RAZ REVIDR cp register
2013-04-23 2:08 ` [Qemu-devel] [PATCH v1 1/1] target-arm: helper.c: RAZ REVIDR cp register peter.crosthwaite
@ 2013-04-23 10:55 ` Peter Maydell
0 siblings, 0 replies; 2+ messages in thread
From: Peter Maydell @ 2013-04-23 10:55 UTC (permalink / raw)
To: peter.crosthwaite; +Cc: qemu-devel
On 23 April 2013 03:08, <peter.crosthwaite@xilinx.com> wrote:
> From: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
>
> Guests should be able to read REVIDR without suffering an abort. Just
> RAZ the REVIDR register.
>
> Signed-off-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
> ---
>
> target-arm/helper.c | 4 ++++
> 1 files changed, 4 insertions(+), 0 deletions(-)
>
> diff --git a/target-arm/helper.c b/target-arm/helper.c
> index fd055e8..e655c74 100644
> --- a/target-arm/helper.c
> +++ b/target-arm/helper.c
> @@ -1187,6 +1187,10 @@ void register_cp_regs_for_features(ARMCPU *cpu)
> { .name = "TLBTR",
> .cp = 15, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 3,
> .access = PL1_R, .type = ARM_CP_CONST, .resetvalue = 0 },
> + /* RAZ the REVIDR register */
> + { .name = "REVIDR",
> + .cp = 15, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 6,
> + .access = PL1_R, .type = ARM_CP_CONST, .resetvalue = 0 },
> /* crn = 0 op1 = 0 crm = 3..7 : currently unassigned; we RAZ. */
> { .name = "DUMMY",
> .cp = 15, .crn = 0, .crm = 3, .opc1 = 0, .opc2 = CP_ANY,
REVIDR is v7 only, so I don't think this is the right place to define it.
(It's also IMPDEF whether it exists or whether it's an alias for MIDR;
A7, A9 and A15 have a REVIDR, A5 and A8 don't.)
I suggest doing what we do for the MPIDR: define a feature bit
and a one-entry cp_reginfo for it.
(We don't implement the documented behaviour that unallocated
entries in c0,c0,0,X should read the MIDR, so I wouldn't worry
about that.)
thanks
-- PMM
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2013-04-23 10:55 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <cover.1366682426.git.peter.crosthwaite@xilinx.com>
2013-04-23 2:08 ` [Qemu-devel] [PATCH v1 1/1] target-arm: helper.c: RAZ REVIDR cp register peter.crosthwaite
2013-04-23 10:55 ` Peter Maydell
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).