summaryrefslogtreecommitdiff
path: root/src/dev/arm/gic_v3_its.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/dev/arm/gic_v3_its.cc')
-rw-r--r--src/dev/arm/gic_v3_its.cc45
1 files changed, 41 insertions, 4 deletions
diff --git a/src/dev/arm/gic_v3_its.cc b/src/dev/arm/gic_v3_its.cc
index 26c123c03..de2683c24 100644
--- a/src/dev/arm/gic_v3_its.cc
+++ b/src/dev/arm/gic_v3_its.cc
@@ -826,14 +826,26 @@ Gicv3Its::read(PacketPtr pkt)
value = gitsCbaser;
break;
+ case GITS_CBASER + 4:
+ value = gitsCbaser.high;
+ break;
+
case GITS_CWRITER:
value = gitsCwriter;
break;
+ case GITS_CWRITER + 4:
+ value = gitsCwriter.high;
+ break;
+
case GITS_CREADR:
value = gitsCreadr;
break;
+ case GITS_CREADR + 4:
+ value = gitsCreadr.high;
+ break;
+
case GITS_PIDR2:
value = gic->getDistributor()->gicdPidr2;
break;
@@ -879,16 +891,41 @@ Gicv3Its::write(PacketPtr pkt)
panic("GITS_TYPER is Read Only\n");
case GITS_CBASER:
- assert(pkt->getSize() == sizeof(uint64_t));
- gitsCbaser = pkt->getLE<uint64_t>();
+ if (pkt->getSize() == sizeof(uint32_t)) {
+ gitsCbaser.low = pkt->getLE<uint32_t>();
+ } else {
+ assert(pkt->getSize() == sizeof(uint64_t));
+ gitsCbaser = pkt->getLE<uint64_t>();
+ }
+
+ gitsCreadr = 0; // Cleared when CBASER gets written
+
+ checkCommandQueue();
+ break;
+
+ case GITS_CBASER + 4:
+ assert(pkt->getSize() == sizeof(uint32_t));
+ gitsCbaser.high = pkt->getLE<uint32_t>();
+
gitsCreadr = 0; // Cleared when CBASER gets written
checkCommandQueue();
break;
case GITS_CWRITER:
- assert(pkt->getSize() == sizeof(uint64_t));
- gitsCwriter = pkt->getLE<uint64_t>();
+ if (pkt->getSize() == sizeof(uint32_t)) {
+ gitsCwriter.low = pkt->getLE<uint32_t>();
+ } else {
+ assert(pkt->getSize() == sizeof(uint64_t));
+ gitsCwriter = pkt->getLE<uint64_t>();
+ }
+
+ checkCommandQueue();
+ break;
+
+ case GITS_CWRITER + 4:
+ assert(pkt->getSize() == sizeof(uint32_t));
+ gitsCwriter.high = pkt->getLE<uint32_t>();
checkCommandQueue();
break;