Each ITARGETSR register is 4-bytes wide and the offset is in bytes.
The current implementation is computing the offset of ICFGR1 and ICFG2
wrongly result to emulate only the first 2 byte of the ICFGR<n> range
read-only. The rest will be treated as read-write.
For convenience introduce ITARGETSR1 and ITARGETSR2.
Signed-off-by: Julien Grall <julien.grall@citrix.com>
Acked-by: Ian Campbell <ian.campbell@citrix.com>
[ ijc -- typoes in commit message ]
case GICD_ICFGR: /* SGIs */
goto write_ignore_32;
- case GICD_ICFGR + 1: /* PPIs */
+
+ case GICD_ICFGR1:
/* It is implementation defined if these are writeable. We chose not */
goto write_ignore_32;
- case GICD_ICFGR + 2 ... GICD_ICFGRN: /* SPIs */
+
+ case GICD_ICFGR2 ... GICD_ICFGRN: /* SPIs */
if ( dabt.size != DABT_WORD ) goto bad_width;
rank = vgic_rank_offset(v, 2, gicd_reg - GICD_ICFGR, DABT_WORD);
if ( rank == NULL) goto write_ignore;
#define GICD_ITARGETSR8 (0x820)
#define GICD_ITARGETSRN (0xBF8)
#define GICD_ICFGR (0xC00)
+#define GICD_ICFGR1 (0xC04)
+#define GICD_ICFGR2 (0xC08)
#define GICD_ICFGRN (0xCFC)
#define GICD_NSACR (0xE00)
#define GICD_NSACRN (0xEFC)