gem5 v24.1.0.1
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
isa.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2010-2024 Arm Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions are
16 * met: redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer;
18 * redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution;
21 * neither the name of the copyright holders nor the names of its
22 * contributors may be used to endorse or promote products derived from
23 * this software without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 */
37
38#include "arch/arm/isa.hh"
39
40#include "arch/arm/decoder.hh"
41#include "arch/arm/faults.hh"
42#include "arch/arm/htm.hh"
44#include "arch/arm/mmu.hh"
45#include "arch/arm/pmu.hh"
46#include "arch/arm/regs/misc.hh"
49#include "arch/arm/system.hh"
50#include "arch/arm/utility.hh"
52#include "base/cprintf.hh"
53#include "base/random.hh"
54#include "cpu/base.hh"
55#include "cpu/checker/cpu.hh"
56#include "cpu/reg_class.hh"
57#include "debug/Arm.hh"
58#include "debug/LLSC.hh"
59#include "debug/MatRegs.hh"
60#include "debug/VecPredRegs.hh"
61#include "debug/VecRegs.hh"
63#include "dev/arm/gic_v3.hh"
65#include "params/ArmISA.hh"
66#include "sim/faults.hh"
67#include "sim/stat_control.hh"
68#include "sim/system.hh"
69
70namespace gem5
71{
72
73namespace ArmISA
74{
75
76using namespace misc_regs;
77
78namespace
79{
80
81/* Not applicable to ARM */
82RegClass floatRegClass(FloatRegClass, FloatRegClassName, 0, debug::FloatRegs);
83
84} // anonymous namespace
85
86ISA::ISA(const Params &p) : BaseISA(p, "arm"), system(NULL),
87 _decoderFlavor(p.decoderFlavor), pmu(p.pmu), impdefAsNop(p.impdef_nop)
88{
89 _regClasses.push_back(&flatIntRegClass);
90 _regClasses.push_back(&floatRegClass);
91 _regClasses.push_back(&vecRegClass);
92 _regClasses.push_back(&vecElemClass);
93 _regClasses.push_back(&vecPredRegClass);
94 _regClasses.push_back(&matRegClass);
95 _regClasses.push_back(&ccRegClass);
96 _regClasses.push_back(&miscRegClass);
97
98 // Hook up a dummy device if we haven't been configured with a
99 // real PMU. By using a dummy device, we don't need to check that
100 // the PMU exist every time we try to access a PMU register.
101 if (!pmu)
102 pmu = &dummyDevice;
103
104 // Give all ISA devices a pointer to this ISA
105 pmu->setISA(this);
106
107 system = dynamic_cast<ArmSystem *>(p.system);
108
109 // Cache system-level properties
110 if (FullSystem && system) {
115 sveVL = system->sveVL();
116 smeVL = system->smeVL();
117
119 } else {
120 highestELIs64 = true; // ArmSystem::highestELIs64 does the same
121 highestEL = EL1; // ArmSystem::highestEL does the same
122 haveLargeAsid64 = false;
123 physAddrRange = 32; // dummy value
124 sveVL = p.sve_vl_se;
125 smeVL = p.sme_vl_se;
126
127 release = p.release_se;
128 }
129
130 selfDebug = new SelfDebug();
133
134 clear();
135}
136
137void
139{
140 // Invalidate cached copies of miscregs in the TLBs
141 if (tc) {
143 }
144
145 for (auto idx = 0; idx < NUM_MISCREGS; idx++) {
146 miscRegs[idx] = lookUpMiscReg[idx].reset();
147 }
148
150}
151
152void
154{
156
157 if (tc) {
159
160 if (release->has(ArmExtension::TME)) {
161 std::unique_ptr<BaseHTMCheckpoint> cpt(new HTMCheckpoint());
162 tc->setHtmCheckpointPtr(std::move(cpt));
163 }
164 }
165}
166
167void
169{
171
172 if (!system)
173 return;
174
175 selfDebug->init(tc);
176
177 if (auto gicv3_ifc = getGICv3CPUInterface(tc); gicv3_ifc) {
178 gicv3_ifc->setISA(this);
179 gicv3_ifc->setThreadContext(tc);
180 }
181}
182
183void
185{
186 tc = new_tc;
188}
189
190void
192{
193 for (auto &id: flatIntRegClass)
194 tc->setReg(id, src->getReg(id));
195
196 for (auto &id: ccRegClass)
197 tc->setReg(id, src->getReg(id));
198
199 for (int i = 0; i < NUM_MISCREGS; i++)
201
203 for (auto &id: vecRegClass) {
204 src->getReg(id, &vc);
205 tc->setReg(id, &vc);
206 }
207
208 for (auto &id: vecElemClass)
209 tc->setReg(id, src->getReg(id));
210
212 for (auto &id: matRegClass) {
213 src->getReg(id, &mc);
214 tc->setReg(id, &mc);
215 }
216
217 // setMiscReg "with effect" will set the misc register mapping correctly.
218 // e.g. updateRegMap(val)
220
221 // Copy over the PC State
222 tc->pcState(src->pcState());
223
224 // Invalidate the tlb misc register cache
225 static_cast<MMU *>(tc->getMMUPtr())->invalidateMiscReg();
226}
227
232int
234{
235 const HCR hcr = readMiscRegNoEffect(MISCREG_HCR_EL2);
236 if (hcr.e2h == 0x0)
237 return misc_reg;
239 bool sec_el2 = scr.eel2 && release->has(ArmExtension::FEAT_SEL2);
240 switch(misc_reg) {
241 case MISCREG_SPSR_EL1:
242 return currEL() == EL2 ? MISCREG_SPSR_EL2 : misc_reg;
243 case MISCREG_ELR_EL1:
244 return currEL() == EL2 ? MISCREG_ELR_EL2 : misc_reg;
246 return currEL() == EL2 ? MISCREG_SCTLR_EL2 : misc_reg;
248 return currEL() == EL2 ? MISCREG_CPTR_EL2 : misc_reg;
249// case MISCREG_TRFCR_EL1:
250// return currEL() == EL2 ? MISCREG_TRFCR_EL2 : misc_reg;
252 return currEL() == EL2 ? MISCREG_TTBR0_EL2 : misc_reg;
254 return currEL() == EL2 ? MISCREG_TTBR1_EL2 : misc_reg;
255 case MISCREG_TCR_EL1:
256 return currEL() == EL2 ? MISCREG_TCR_EL2 : misc_reg;
258 return currEL() == EL2 ? MISCREG_AFSR0_EL2 : misc_reg;
260 return currEL() == EL2 ? MISCREG_AFSR1_EL2 : misc_reg;
261 case MISCREG_ESR_EL1:
262 return currEL() == EL2 ? MISCREG_ESR_EL2 : misc_reg;
263 case MISCREG_FAR_EL1:
264 return currEL() == EL2 ? MISCREG_FAR_EL2 : misc_reg;
265 case MISCREG_MAIR_EL1:
266 return currEL() == EL2 ? MISCREG_MAIR_EL2 : misc_reg;
268 return currEL() == EL2 ? MISCREG_AMAIR_EL2 : misc_reg;
269 case MISCREG_VBAR_EL1:
270 return currEL() == EL2 ? MISCREG_VBAR_EL2 : misc_reg;
272 return currEL() == EL2 ? MISCREG_CONTEXTIDR_EL2 : misc_reg;
274 return currEL() == EL2 ? MISCREG_CNTHCTL_EL2 : misc_reg;
276 return currEL() == EL2 ? MISCREG_MPAM2_EL2 : misc_reg;
277 case MISCREG_ZCR_EL1:
278 return currEL() == EL2 ? MISCREG_ZCR_EL2 : misc_reg;
281 if (ELIsInHost(tc, currEL())) {
282 return sec_el2 && !scr.ns ? MISCREG_CNTHPS_TVAL_EL2:
284 } else {
285 return misc_reg;
286 }
287 case MISCREG_CNTP_CTL:
289 if (ELIsInHost(tc, currEL())) {
290 return sec_el2 && !scr.ns ? MISCREG_CNTHPS_CTL_EL2:
292 } else {
293 return misc_reg;
294 }
297 if (ELIsInHost(tc, currEL())) {
298 return sec_el2 && !scr.ns ? MISCREG_CNTHPS_CVAL_EL2:
300 } else {
301 return misc_reg;
302 }
305 if (ELIsInHost(tc, currEL())) {
306 return sec_el2 && !scr.ns ? MISCREG_CNTHVS_TVAL_EL2:
308 } else {
309 return misc_reg;
310 }
311 case MISCREG_CNTV_CTL:
313 if (ELIsInHost(tc, currEL())) {
314 return sec_el2 && !scr.ns ? MISCREG_CNTHVS_CTL_EL2:
316 } else {
317 return misc_reg;
318 }
321 if (ELIsInHost(tc, currEL())) {
322 return sec_el2 && !scr.ns ? MISCREG_CNTHVS_CVAL_EL2:
324 } else {
325 return misc_reg;
326 }
327 case MISCREG_CNTVCT:
329 return ELIsInHost(tc, currEL()) ? MISCREG_CNTPCT_EL0 : misc_reg;
331 return MISCREG_SCTLR_EL1;
333 return MISCREG_SCTLR2_EL1;
335 return MISCREG_CPACR_EL1;
336 case MISCREG_ZCR_EL12:
337 return MISCREG_ZCR_EL1;
339 return MISCREG_TTBR0_EL1;
341 return MISCREG_TTBR1_EL1;
342 case MISCREG_TCR_EL12:
343 return MISCREG_TCR_EL1;
345 return MISCREG_TCR2_EL1;
347 return MISCREG_SPSR_EL1;
348 case MISCREG_ELR_EL12:
349 return MISCREG_ELR_EL1;
351 return MISCREG_AFSR0_EL1;
353 return MISCREG_AFSR1_EL1;
354 case MISCREG_ESR_EL12:
355 return MISCREG_ESR_EL1;
356 case MISCREG_FAR_EL12:
357 return MISCREG_FAR_EL1;
359 return MISCREG_MAIR_EL1;
361 return MISCREG_AMAIR_EL1;
363 return MISCREG_VBAR_EL1;
367 return MISCREG_CNTKCTL_EL1;
369 return MISCREG_MPAM1_EL1;
370 // _EL02 registers
383 default:
384 return misc_reg;
385 }
386}
387
388RegVal
390{
391 assert(idx < NUM_MISCREGS);
392
393 const auto &reg = lookUpMiscReg[idx]; // bit masks
394 const auto &map = getMiscIndices(idx);
395 int lower = map.first, upper = map.second;
396 // NB!: apply architectural masks according to desired register,
397 // despite possibly getting value from different (mapped) register.
398 auto val = !upper ? miscRegs[lower] : ((miscRegs[lower] & mask(32))
399 |(miscRegs[upper] << 32));
400 if (val & reg.res0()) {
401 DPRINTF(MiscRegs, "Reading MiscReg %s with set res0 bits: %#x\n",
402 miscRegName[idx], val & reg.res0());
403 }
404 if ((val & reg.res1()) != reg.res1()) {
405 DPRINTF(MiscRegs, "Reading MiscReg %s with clear res1 bits: %#x\n",
406 miscRegName[idx], (val & reg.res1()) ^ reg.res1());
407 }
408 return (val & ~reg.raz()) | reg.rao(); // enforce raz/rao
409}
410
411
412RegVal
414{
415 CPSR cpsr = 0;
416 SCR scr = 0;
417
418 if (idx == MISCREG_CPSR) {
419 cpsr = miscRegs[idx];
420 auto pc = tc->pcState().as<PCState>();
421 cpsr.t = pc.thumb() ? 1 : 0;
422 return cpsr;
423 }
424
425#ifndef NDEBUG
426 auto& miscreg_info = lookUpMiscReg[idx].info;
427 if (!miscreg_info[MISCREG_IMPLEMENTED]) {
428 if (miscreg_info[MISCREG_WARN_NOT_FAIL])
429 warn("Unimplemented system register %s read.\n",
430 miscRegName[idx]);
431 else
432 panic("Unimplemented system register %s read.\n",
433 miscRegName[idx]);
434 }
435#endif
436 idx = redirectRegVHE(idx);
437
438 switch (unflattenMiscReg(idx)) {
439 case MISCREG_CPACR:
440 {
441 const uint32_t ones = (uint32_t)(-1);
442 CPACR cpacrMask = 0;
443 // Only cp10, cp11, and ase are implemented, nothing else should
444 // be readable? (straight copy from the write code)
445 cpacrMask.cp10 = ones;
446 cpacrMask.cp11 = ones;
447 cpacrMask.asedis = ones;
448
449 // Security Extensions may limit the readability of CPACR
450 if (release->has(ArmExtension::SECURITY)) {
453 if (scr.ns && (cpsr.mode != MODE_MON) && ELIs32(tc, EL3)) {
454 NSACR nsacr = readMiscRegNoEffect(MISCREG_NSACR);
455 // NB: Skipping the full loop, here
456 if (!nsacr.cp10) cpacrMask.cp10 = 0;
457 if (!nsacr.cp11) cpacrMask.cp11 = 0;
458 }
459 }
461 val &= cpacrMask;
462 DPRINTF(MiscRegs, "Reading misc reg %s: %#x\n",
463 miscRegName[idx], val);
464 return val;
465 }
466 case MISCREG_MPIDR:
468 return readMPIDR(system, tc);
469 case MISCREG_ID_AFR0: // not implemented, so alias MIDR
470 case MISCREG_REVIDR: // not implemented, so alias MIDR
471 case MISCREG_MIDR:
472 case MISCREG_MIDR_EL1:
473 if (currEL() == EL1 && EL2Enabled(tc)) {
475 } else {
476 return readMiscRegNoEffect(idx);
477 }
478 break;
479
480 case MISCREG_CLIDR:
481 warn_once("The clidr register always reports 0 caches.\n");
482 warn_once("clidr LoUIS field of 0b001 to match current "
483 "ARM implementations.\n");
484 return 0x00200000;
485 case MISCREG_CCSIDR:
486 warn_once("The ccsidr register isn't implemented and "
487 "always reads as 0.\n");
488 break;
489 case MISCREG_ACTLR:
490 warn("Not doing anything for miscreg ACTLR\n");
491 break;
492
497 return pmu->readMiscReg(idx);
498
499 case MISCREG_CPSR_Q:
500 panic("shouldn't be reading this register seperately\n");
501 case MISCREG_FPSCR_QC:
502 return readMiscRegNoEffect(MISCREG_FPSCR) & ~FpscrQcMask;
504 return readMiscRegNoEffect(MISCREG_FPSCR) & ~FpscrExcMask;
505 case MISCREG_FPSR:
506 {
507 const uint32_t ones = (uint32_t)(-1);
508 FPSCR fpscrMask = 0;
509 fpscrMask.ioc = ones;
510 fpscrMask.dzc = ones;
511 fpscrMask.ofc = ones;
512 fpscrMask.ufc = ones;
513 fpscrMask.ixc = ones;
514 fpscrMask.idc = ones;
515 fpscrMask.qc = ones;
516 fpscrMask.v = ones;
517 fpscrMask.c = ones;
518 fpscrMask.z = ones;
519 fpscrMask.n = ones;
520 return readMiscRegNoEffect(MISCREG_FPSCR) & (uint32_t)fpscrMask;
521 }
522 case MISCREG_FPCR:
523 {
524 const uint32_t ones = (uint32_t)(-1);
525 FPSCR fpscrMask = 0;
526 fpscrMask.len = ones;
527 fpscrMask.fz16 = ones;
528 fpscrMask.stride = ones;
529 fpscrMask.rMode = ones;
530 fpscrMask.fz = ones;
531 fpscrMask.dn = ones;
532 fpscrMask.ahp = ones;
533 return readMiscRegNoEffect(MISCREG_FPSCR) & (uint32_t)fpscrMask;
534 }
535 case MISCREG_NZCV:
536 {
537 CPSR cpsr = 0;
538 cpsr.nz = tc->getReg(cc_reg::Nz);
539 cpsr.c = tc->getReg(cc_reg::C);
540 cpsr.v = tc->getReg(cc_reg::V);
541 return cpsr;
542 }
543 case MISCREG_DAIF:
544 {
545 CPSR cpsr = 0;
546 cpsr.daif = (uint8_t) ((CPSR) miscRegs[MISCREG_CPSR]).daif;
547 return cpsr;
548 }
549 case MISCREG_SP_EL0:
550 {
551 return tc->getReg(int_reg::Sp0);
552 }
553 case MISCREG_SP_EL1:
554 {
555 return tc->getReg(int_reg::Sp1);
556 }
557 case MISCREG_SP_EL2:
558 {
559 return tc->getReg(int_reg::Sp2);
560 }
561 case MISCREG_SPSEL:
562 {
563 return miscRegs[MISCREG_CPSR] & 0x1;
564 }
566 {
567 return miscRegs[MISCREG_CPSR] & 0xc;
568 }
569 case MISCREG_PAN:
570 {
571 return miscRegs[MISCREG_CPSR] & 0x400000;
572 }
573 case MISCREG_UAO:
574 {
575 return miscRegs[MISCREG_CPSR] & 0x800000;
576 }
577 case MISCREG_L2CTLR:
578 {
579 // mostly unimplemented, just set NumCPUs field from sim and return
580 L2CTLR l2ctlr = 0;
581 // b00:1CPU to b11:4CPUs
582 l2ctlr.numCPUs = tc->getSystemPtr()->threads.size() - 1;
583 return l2ctlr;
584 }
585 case MISCREG_ISR:
586 case MISCREG_ISR_EL1:
587 {
588 auto ic = dynamic_cast<ArmISA::Interrupts *>(
590 return ic->getISR(
594 }
595 case MISCREG_HCPTR:
596 {
597 HCPTR val = readMiscRegNoEffect(idx);
598 bool secure_lookup = release->has(ArmExtension::SECURITY) &&
599 isSecure(tc);
600 if (!secure_lookup) {
601 NSACR nsacr = readMiscRegNoEffect(MISCREG_NSACR);
602 if (!nsacr.cp10) {
603 val.tcp10 = 1;
604 val.tcp11 = 1;
605 }
606 }
607 return val;
608 }
609 case MISCREG_HDFAR: // alias for secure DFAR
611 case MISCREG_HIFAR: // alias for secure IFAR
613
615 {
617 mpam1.mpamEn = readRegisterNoEffect<MpamAccessor>(
618 tc, highestEL).mpamEn;
619 mpam1.el1.forcedNs = isSecure(tc) ?
620 readRegisterNoEffect<MpamAccessor>(tc, EL3).el3.forceNs : 0;
621 return mpam1;
622 }
624 {
626 mpam2.mpamEn = readRegisterNoEffect<MpamAccessor>(
627 tc, highestEL).mpamEn;
628 return mpam2;
629 }
630
631 case MISCREG_RNDR:
635 return rng->random<RegVal>();
636 case MISCREG_RNDRRS:
640 // Note: we are not reseeding
641 // The random number generator already has an hardcoded
642 // seed for the sake of determinism. There is no point
643 // in simulating non-determinism here
644 return rng->random<RegVal>();
645
646 // Generic Timer registers
649 return getGenericTimer().readMiscReg(idx);
650
654 return getGICv3CPUInterface().readMiscReg(idx);
655
656 default:
657 break;
658
659 }
660 return readMiscRegNoEffect(idx);
661}
662
663void
665{
666 assert(idx < NUM_MISCREGS);
667
668 const auto &reg = lookUpMiscReg[idx]; // bit masks
669 const auto &map = getMiscIndices(idx);
670 int lower = map.first, upper = map.second;
671
672 auto v = (val & ~reg.wi()) | reg.rao();
673 if (upper > 0) {
674 miscRegs[lower] = bits(v, 31, 0);
675 miscRegs[upper] = bits(v, 63, 32);
676 DPRINTF(MiscRegs, "Writing MiscReg %s (%d %d:%d) : %#x\n",
677 miscRegName[idx], idx, lower, upper, v);
678 } else {
679 miscRegs[lower] = v;
680 DPRINTF(MiscRegs, "Writing MiscReg %s (%d %d) : %#x\n",
681 miscRegName[idx], idx, lower, v);
682 }
683}
684
685void
687{
688
689 RegVal newVal = val;
690 bool secure_lookup;
691 SCR scr;
692
693 if (idx == MISCREG_CPSR) {
695
696
697 CPSR old_cpsr = miscRegs[MISCREG_CPSR];
698 int old_mode = old_cpsr.mode;
699 CPSR cpsr = val;
700 if (cpsr.pan != old_cpsr.pan || cpsr.il != old_cpsr.il) {
702 }
703
704 DPRINTF(Arm, "Updating CPSR from %#x to %#x f:%d i:%d a:%d mode:%#x\n",
705 miscRegs[idx], cpsr, cpsr.f, cpsr.i, cpsr.a, cpsr.mode);
706 PCState pc = tc->pcState().as<PCState>();
707 pc.nextThumb(cpsr.t);
708 pc.illegalExec(cpsr.il == 1);
709 selfDebug->setDebugMask(cpsr.d == 1);
710
711 tc->getDecoderPtr()->as<Decoder>().setSveLen(
712 (getCurSveVecLenInBits() >> 7) - 1);
713 tc->getDecoderPtr()->as<Decoder>().setSmeLen(
714 (getCurSmeVecLenInBits() >> 7) - 1);
715
716 // Follow slightly different semantics if a CheckerCPU object
717 // is connected
718 CheckerCPU *checker = tc->getCheckerCpuPtr();
719 if (checker) {
721 } else {
722 tc->pcState(pc);
723 }
724
725 setMiscRegNoEffect(idx, newVal);
726
727 if (old_mode != cpsr.mode) {
729 if (gicv3CpuInterface) {
730 // The assertion and de-assertion of IRQs and FIQs are
731 // affected by the current Exception level and Security
732 // state of the PE. As part of the Context
733 // Synchronization that occurs as the result of taking
734 // or returning from an exception, the CPU interface
735 // ensures that IRQ and FIQ are both appropriately
736 // asserted or deasserted for the Exception level and
737 // Security state that the PE is entering.
738 static_cast<Gicv3CPUInterface&>(
739 getGICv3CPUInterface()).update();
740 }
741 }
742 } else {
743#ifndef NDEBUG
744 auto& miscreg_info = lookUpMiscReg[idx].info;
745 if (!miscreg_info[MISCREG_IMPLEMENTED]) {
746 if (miscreg_info[MISCREG_WARN_NOT_FAIL])
747 warn("Unimplemented system register %s write with %#x.\n",
748 miscRegName[idx], val);
749 else
750 panic("Unimplemented system register %s write with %#x.\n",
751 miscRegName[idx], val);
752 }
753#endif
754 idx = redirectRegVHE(idx);
755
756 switch (unflattenMiscReg(idx)) {
757 case MISCREG_CPACR:
758 {
759
760 const uint32_t ones = (uint32_t)(-1);
761 CPACR cpacrMask = 0;
762 // Only cp10, cp11, and ase are implemented
763 // nothing else should be writable
764 cpacrMask.cp10 = ones;
765 cpacrMask.cp11 = ones;
766 cpacrMask.asedis = ones;
767
768 // Security Extensions may limit the writability of CPACR
769 if (release->has(ArmExtension::SECURITY)) {
772 if (scr.ns && (cpsr.mode != MODE_MON) && ELIs32(tc, EL3)) {
773 NSACR nsacr = readMiscRegNoEffect(MISCREG_NSACR);
774 // NB: Skipping the full loop, here
775 if (!nsacr.cp10) cpacrMask.cp10 = 0;
776 if (!nsacr.cp11) cpacrMask.cp11 = 0;
777 }
778 }
779
781 newVal &= cpacrMask;
782 newVal |= old_val & ~cpacrMask;
783 DPRINTF(MiscRegs, "Writing misc reg %s: %#x\n",
784 miscRegName[idx], newVal);
785 }
786 break;
788 {
789 const uint32_t ones = (uint32_t)(-1);
790 CPACR cpacrMask = 0;
791 cpacrMask.tta = ones;
792 cpacrMask.fpen = ones;
793 if (release->has(ArmExtension::FEAT_SVE)) {
794 cpacrMask.zen = ones;
795 }
796 if (release->has(ArmExtension::FEAT_SME)) {
797 cpacrMask.smen = ones;
798 }
799 newVal &= cpacrMask;
800 DPRINTF(MiscRegs, "Writing misc reg %s: %#x\n",
801 miscRegName[idx], newVal);
802 }
803 break;
804 case MISCREG_CPTR_EL2:
805 {
806 const HCR hcr = readMiscRegNoEffect(MISCREG_HCR_EL2);
807 const uint32_t ones = (uint32_t)(-1);
808 CPTR cptrMask = 0;
809 cptrMask.tcpac = ones;
810 cptrMask.tta = ones;
811 cptrMask.tfp = ones;
812 if (release->has(ArmExtension::FEAT_SVE)) {
813 cptrMask.tz = ones;
814 cptrMask.zen = hcr.e2h ? ones : 0;
815 }
816 if (release->has(ArmExtension::FEAT_SME)) {
817 cptrMask.tsm = ones;
818 cptrMask.smen = hcr.e2h ? ones : 0;
819 }
820 cptrMask.fpen = hcr.e2h ? ones : 0;
821 newVal &= cptrMask;
822 cptrMask = 0;
823 cptrMask.res1_13_el2 = ones;
824 cptrMask.res1_7_0_el2 = ones;
825 if (!release->has(ArmExtension::FEAT_SVE)) {
826 cptrMask.res1_8_el2 = ones;
827 }
828 if (!release->has(ArmExtension::FEAT_SME)) {
829 cptrMask.res1_12_el2 = ones;
830 }
831 cptrMask.res1_9_el2 = ones;
832 newVal |= cptrMask;
833 DPRINTF(MiscRegs, "Writing misc reg %s: %#x\n",
834 miscRegName[idx], newVal);
835 }
836 break;
837 case MISCREG_CPTR_EL3:
838 {
839 const uint32_t ones = (uint32_t)(-1);
840 CPTR cptrMask = 0;
841 cptrMask.tcpac = ones;
842 cptrMask.tta = ones;
843 cptrMask.tfp = ones;
844 if (release->has(ArmExtension::FEAT_SVE)) {
845 cptrMask.ez = ones;
846 }
847 if (release->has(ArmExtension::FEAT_SME)) {
848 cptrMask.esm = ones;
849 }
850 newVal &= cptrMask;
851 DPRINTF(MiscRegs, "Writing misc reg %s: %#x\n",
852 miscRegName[idx], newVal);
853 }
854 break;
855 case MISCREG_CSSELR:
856 warn_once("The csselr register isn't implemented.\n");
857 return;
858
860 warn("Calling DC ZVA! Not Implemeted! Expect WEIRD results\n");
861 return;
862
863 case MISCREG_FPSCR:
864 tc->getDecoderPtr()->as<Decoder>().setContext(newVal);
865 break;
866 case MISCREG_FPSR:
867 {
868 const uint32_t ones = (uint32_t)(-1);
869 FPSCR fpscrMask = 0;
870 fpscrMask.ioc = ones;
871 fpscrMask.dzc = ones;
872 fpscrMask.ofc = ones;
873 fpscrMask.ufc = ones;
874 fpscrMask.ixc = ones;
875 fpscrMask.idc = ones;
876 fpscrMask.qc = ones;
877 fpscrMask.v = ones;
878 fpscrMask.c = ones;
879 fpscrMask.z = ones;
880 fpscrMask.n = ones;
881 newVal = (newVal & (uint32_t)fpscrMask) |
883 ~(uint32_t)fpscrMask);
884 idx = MISCREG_FPSCR;
885 }
886 break;
887 case MISCREG_FPCR:
888 {
889 const uint32_t ones = (uint32_t)(-1);
890 FPSCR fpscrMask = 0;
891 fpscrMask.len = ones;
892 fpscrMask.fz16 = ones;
893 fpscrMask.stride = ones;
894 fpscrMask.rMode = ones;
895 fpscrMask.fz = ones;
896 fpscrMask.dn = ones;
897 fpscrMask.ahp = ones;
898 newVal = (newVal & (uint32_t)fpscrMask) |
900 ~(uint32_t)fpscrMask);
901 idx = MISCREG_FPSCR;
902 }
903 break;
904 case MISCREG_CPSR_Q:
905 {
906 assert(!(newVal & ~CpsrMaskQ));
907 newVal = readMiscRegNoEffect(MISCREG_CPSR) | newVal;
908 idx = MISCREG_CPSR;
909 }
910 break;
911 case MISCREG_FPSCR_QC:
912 {
914 (newVal & FpscrQcMask);
915 idx = MISCREG_FPSCR;
916 }
917 break;
919 {
921 (newVal & FpscrExcMask);
922 idx = MISCREG_FPSCR;
923 }
924 break;
925 case MISCREG_FPEXC:
926 {
927 // vfpv3 architecture, section B.6.1 of DDI04068
928 // bit 29 - valid only if fpexc[31] is 0
929 const uint32_t fpexcMask = 0x60000000;
930 newVal = (newVal & fpexcMask) |
931 (readMiscRegNoEffect(MISCREG_FPEXC) & ~fpexcMask);
932 }
933 break;
934 case MISCREG_HCR:
935 {
936 const HDCR mdcr = tc->readMiscRegNoEffect(MISCREG_MDCR_EL2);
937 selfDebug->setenableTDETGE((HCR)val, mdcr);
938 }
939 break;
940
941 case MISCREG_HDCR:
942 {
943 const HCR hcr = tc->readMiscReg(MISCREG_HCR_EL2);
944 selfDebug->setenableTDETGE(hcr, (HDCR)val);
945 }
946 break;
947 case MISCREG_DBGOSLAR:
948 {
950 const uint32_t temp = (val == 0xC5ACCE55)? 0x1 : 0x0;
952 r.oslk = bits(temp,0);
954 }
955 break;
958 break;
961 break;
962
963 case MISCREG_MDCR_EL2:
964 {
965 const HCR hcr = tc->readMiscReg(MISCREG_HCR_EL2);
966 selfDebug->setenableTDETGE(hcr, (HDCR)val);
967 }
968 break;
969 case MISCREG_SDCR:
970 case MISCREG_MDCR_EL3:
971 {
973 }
974 break;
976 {
979 DBGDS32 v = val;
980 r.moe = v.moe;
981 r.udccdis = v.udccdis;
982 r.mdbgen = v.mdbgen;
985 }
986
987 break;
989 {
991 }
992 break;
993
995 {
998 r.oslk = bits(val, 0);
999 r.oslm_3 = 1;
1001 }
1002 break;
1003
1006 break;
1009 break;
1010 case MISCREG_SCR:
1012 break;
1013 case MISCREG_SCTLR:
1014 {
1015 DPRINTF(MiscRegs, "Writing SCTLR: %#x\n", newVal);
1017
1018 MiscRegIndex sctlr_idx;
1019 if (release->has(ArmExtension::SECURITY) &&
1020 !highestELIs64 && !scr.ns) {
1021 sctlr_idx = MISCREG_SCTLR_S;
1022 } else {
1023 sctlr_idx = MISCREG_SCTLR_NS;
1024 }
1025
1026 SCTLR sctlr = miscRegs[sctlr_idx];
1027 SCTLR new_sctlr = newVal;
1028 new_sctlr.nmfi = ((bool)sctlr.nmfi) &&
1029 !release->has(ArmExtension::VIRTUALIZATION);
1030 miscRegs[sctlr_idx] = (RegVal)new_sctlr;
1032 }
1033 case MISCREG_MIDR:
1034 case MISCREG_ID_PFR0:
1035 case MISCREG_ID_PFR1:
1036 case MISCREG_ID_DFR0:
1037 case MISCREG_ID_MMFR0:
1038 case MISCREG_ID_MMFR1:
1039 case MISCREG_ID_MMFR2:
1040 case MISCREG_ID_MMFR3:
1041 case MISCREG_ID_MMFR4:
1042 case MISCREG_ID_ISAR0:
1043 case MISCREG_ID_ISAR1:
1044 case MISCREG_ID_ISAR2:
1045 case MISCREG_ID_ISAR3:
1046 case MISCREG_ID_ISAR4:
1047 case MISCREG_ID_ISAR5:
1048
1049 case MISCREG_MPIDR:
1050 case MISCREG_FPSID:
1051 case MISCREG_TLBTR:
1052 case MISCREG_MVFR0:
1053 case MISCREG_MVFR1:
1054
1066 // ID registers are constants.
1067 return;
1068
1069 // TLB Invalidate All
1070 case MISCREG_ACTLR:
1071 warn("Not doing anything for write of miscreg ACTLR\n");
1072 break;
1073
1078 pmu->setMiscReg(idx, newVal);
1079 break;
1080
1081
1082 case MISCREG_HSTR: // TJDBX, now redifined to be RES0
1083 {
1084 HSTR hstrMask = 0;
1085 hstrMask.tjdbx = 1;
1086 newVal &= ~((uint32_t) hstrMask);
1087 break;
1088 }
1089 case MISCREG_HCPTR:
1090 {
1091 // If a CP bit in NSACR is 0 then the corresponding bit in
1092 // HCPTR is RAO/WI. Same applies to NSASEDIS
1093 secure_lookup = release->has(ArmExtension::SECURITY) &&
1094 isSecure(tc);
1095 if (!secure_lookup) {
1097 RegVal mask =
1098 (readMiscRegNoEffect(MISCREG_NSACR) ^ 0x7FFF) & 0xBFFF;
1099 newVal = (newVal & ~mask) | (oldValue & mask);
1100 }
1101 break;
1102 }
1103 case MISCREG_HDFAR: // alias for secure DFAR
1104 idx = MISCREG_DFAR_S;
1105 break;
1106 case MISCREG_HIFAR: // alias for secure IFAR
1107 idx = MISCREG_IFAR_S;
1108 break;
1109 case MISCREG_ATS1CPR:
1111 return;
1112 case MISCREG_ATS1CPW:
1114 return;
1115 case MISCREG_ATS1CUR:
1118 return;
1119 case MISCREG_ATS1CUW:
1122 return;
1123 case MISCREG_ATS12NSOPR:
1124 if (!release->has(ArmExtension::SECURITY))
1125 panic("Security Extensions required for ATS12NSOPR");
1127 return;
1128 case MISCREG_ATS12NSOPW:
1129 if (!release->has(ArmExtension::SECURITY))
1130 panic("Security Extensions required for ATS12NSOPW");
1132 return;
1133 case MISCREG_ATS12NSOUR:
1134 if (!release->has(ArmExtension::SECURITY))
1135 panic("Security Extensions required for ATS12NSOUR");
1138 return;
1139 case MISCREG_ATS12NSOUW:
1140 if (!release->has(ArmExtension::SECURITY))
1141 panic("Security Extensions required for ATS12NSOUW");
1144 return;
1145 case MISCREG_ATS1HR:
1147 return;
1148 case MISCREG_ATS1HW:
1150 return;
1151 case MISCREG_TTBCR:
1152 {
1153 TTBCR ttbcr = readMiscRegNoEffect(MISCREG_TTBCR);
1154 const uint32_t ones = (uint32_t)(-1);
1155 TTBCR ttbcrMask = 0;
1156 TTBCR ttbcrNew = newVal;
1157
1158 // ARM DDI 0406C.b, ARMv7-32
1159 ttbcrMask.n = ones; // T0SZ
1160 if (release->has(ArmExtension::SECURITY)) {
1161 ttbcrMask.pd0 = ones;
1162 ttbcrMask.pd1 = ones;
1163 }
1164 ttbcrMask.epd0 = ones;
1165 ttbcrMask.irgn0 = ones;
1166 ttbcrMask.orgn0 = ones;
1167 ttbcrMask.sh0 = ones;
1168 ttbcrMask.ps = ones; // T1SZ
1169 ttbcrMask.a1 = ones;
1170 ttbcrMask.epd1 = ones;
1171 ttbcrMask.irgn1 = ones;
1172 ttbcrMask.orgn1 = ones;
1173 ttbcrMask.sh1 = ones;
1174 if (release->has(ArmExtension::LPAE))
1175 ttbcrMask.eae = ones;
1176
1177 if (release->has(ArmExtension::LPAE) && ttbcrNew.eae) {
1178 newVal = newVal & ttbcrMask;
1179 } else {
1180 newVal = (newVal & ttbcrMask) | (ttbcr & (~ttbcrMask));
1181 }
1182 // Invalidate TLB MiscReg
1184 break;
1185 }
1186 case MISCREG_TTBR0:
1187 case MISCREG_TTBR1:
1188 {
1189 TTBCR ttbcr = readMiscRegNoEffect(MISCREG_TTBCR);
1190 if (release->has(ArmExtension::LPAE)) {
1191 if (ttbcr.eae) {
1192 // ARMv7 bit 63-56, 47-40 reserved, UNK/SBZP
1193 // ARMv8 AArch32 bit 63-56 only
1194 uint64_t ttbrMask = mask(63,56) | mask(47,40);
1195 newVal = (newVal & (~ttbrMask));
1196 }
1197 }
1198 // Invalidate TLB MiscReg
1200 break;
1201 }
1202 case MISCREG_SCTLR_EL1:
1203 case MISCREG_CONTEXTIDR:
1204 case MISCREG_PRRR:
1205 case MISCREG_NMRR:
1206 case MISCREG_MAIR0:
1207 case MISCREG_MAIR1:
1208 case MISCREG_DACR:
1209 case MISCREG_VTTBR:
1210 case MISCREG_SCR_EL3:
1211 case MISCREG_TCR_EL1:
1212 case MISCREG_TCR_EL2:
1213 case MISCREG_TCR_EL3:
1214 case MISCREG_VTCR_EL2:
1215 case MISCREG_SCTLR_EL2:
1216 case MISCREG_SCTLR_EL3:
1217 case MISCREG_HSCTLR:
1218 case MISCREG_TTBR0_EL1:
1219 case MISCREG_TTBR1_EL1:
1220 case MISCREG_TTBR0_EL2:
1221 case MISCREG_TTBR1_EL2:
1222 case MISCREG_TTBR0_EL3:
1224 break;
1225 case MISCREG_HCR_EL2:
1226 {
1227 const HDCR mdcr = tc->readMiscRegNoEffect(MISCREG_MDCR_EL2);
1228 selfDebug->setenableTDETGE((HCR)val, mdcr);
1230 }
1231 break;
1232 case MISCREG_NZCV:
1233 {
1234 CPSR cpsr = val;
1235
1236 tc->setReg(cc_reg::Nz, cpsr.nz);
1237 tc->setReg(cc_reg::C, cpsr.c);
1238 tc->setReg(cc_reg::V, cpsr.v);
1239 }
1240 break;
1241 case MISCREG_DAIF:
1242 {
1243 CPSR cpsr = miscRegs[MISCREG_CPSR];
1244 cpsr.daif = (uint8_t) ((CPSR) newVal).daif;
1245 newVal = cpsr;
1246 idx = MISCREG_CPSR;
1247 }
1248 break;
1249 case MISCREG_SP_EL0:
1250 tc->setReg(int_reg::Sp0, newVal);
1251 break;
1252 case MISCREG_SP_EL1:
1253 tc->setReg(int_reg::Sp1, newVal);
1254 break;
1255 case MISCREG_SP_EL2:
1256 tc->setReg(int_reg::Sp2, newVal);
1257 break;
1258 case MISCREG_SPSEL:
1259 {
1260 CPSR cpsr = miscRegs[MISCREG_CPSR];
1261 cpsr.sp = (uint8_t) ((CPSR) newVal).sp;
1262 newVal = cpsr;
1263 idx = MISCREG_CPSR;
1264 }
1265 break;
1266 case MISCREG_CURRENTEL:
1267 {
1268 CPSR cpsr = miscRegs[MISCREG_CPSR];
1269 cpsr.el = (uint8_t) ((CPSR) newVal).el;
1270 newVal = cpsr;
1271 idx = MISCREG_CPSR;
1272 }
1273 break;
1274 case MISCREG_PAN:
1275 {
1276 // PAN is affecting data accesses
1278
1279 CPSR cpsr = miscRegs[MISCREG_CPSR];
1280 cpsr.pan = (uint8_t) ((CPSR) newVal).pan;
1281 newVal = cpsr;
1282 idx = MISCREG_CPSR;
1283 }
1284 break;
1285 case MISCREG_UAO:
1286 {
1287 // UAO is affecting data accesses
1289
1290 CPSR cpsr = miscRegs[MISCREG_CPSR];
1291 cpsr.uao = (uint8_t) ((CPSR) newVal).uao;
1292 newVal = cpsr;
1293 idx = MISCREG_CPSR;
1294 }
1295 break;
1296 case MISCREG_L2CTLR:
1297 warn("miscreg L2CTLR (%s) written with %#x. ignored...\n",
1298 miscRegName[idx], uint32_t(val));
1299 break;
1300
1301 // Generic Timer registers
1304 getGenericTimer().setMiscReg(idx, newVal);
1305 break;
1309 getGICv3CPUInterface().setMiscReg(idx, newVal);
1310 return;
1311 case MISCREG_ZCR_EL3:
1312 case MISCREG_ZCR_EL2:
1313 case MISCREG_ZCR_EL1:
1314 // Set the value here as we need to update the regs before
1315 // reading them back in getCurSveVecLenInBits to avoid
1316 // setting stale vector lengths in the decoder.
1317 setMiscRegNoEffect(idx, newVal);
1318 tc->getDecoderPtr()->as<Decoder>().setSveLen(
1319 (getCurSveVecLenInBits() >> 7) - 1);
1320 return;
1321 case MISCREG_SMCR_EL3:
1322 case MISCREG_SMCR_EL2:
1323 case MISCREG_SMCR_EL1:
1324 // Set the value here as we need to update the regs before
1325 // reading them back in getCurSmeVecLenInBits to avoid
1326 // setting stale vector lengths in the decoder.
1327 setMiscRegNoEffect(idx, newVal);
1328 tc->getDecoderPtr()->as<Decoder>().setSmeLen(
1329 (getCurSmeVecLenInBits() >> 7) - 1);
1330 return;
1331 }
1332 setMiscRegNoEffect(idx, newVal);
1333 }
1334}
1335
1336RegVal
1338{
1339 int flat_idx = flattenMiscIndex(idx);
1340 return lookUpMiscReg[flat_idx].reset();
1341}
1342
1343void
1345{
1346 int flat_idx = flattenMiscIndex(idx);
1347 InitReg(flat_idx).reset(val);
1348}
1349
1352{
1353 // We only need to create an ISA interface the first time we try
1354 // to access the timer.
1355 if (timer)
1356 return *timer.get();
1357
1358 assert(system);
1359 GenericTimer *generic_timer(system->getGenericTimer());
1360 if (!generic_timer) {
1361 panic("Trying to get a generic timer from a system that hasn't "
1362 "been configured to use a generic timer.\n");
1363 }
1364
1365 timer.reset(new GenericTimerISA(*generic_timer, tc->contextId()));
1366 timer->setThreadContext(tc);
1367
1368 return *timer.get();
1369}
1370
1373{
1375 return *gicv3CpuInterface.get();
1376
1377 auto gicv3_ifc = getGICv3CPUInterface(tc);
1378 panic_if(!gicv3_ifc, "The system does not have a GICv3 irq controller\n");
1379 gicv3CpuInterface.reset(gicv3_ifc);
1380
1381 return *gicv3CpuInterface.get();
1382}
1383
1386{
1387 assert(system);
1388 Gicv3 *gicv3 = dynamic_cast<Gicv3 *>(system->getGIC());
1389 if (gicv3) {
1390 return gicv3->getCPUInterface(tc->contextId());
1391 } else {
1392 return nullptr;
1393 }
1394}
1395
1396bool
1398{
1399 if (!release->has(ArmExtension::SECURITY)) {
1400 return false;
1401 }
1402
1403 SCR scr = miscRegs[MISCREG_SCR];
1404 CPSR cpsr = miscRegs[MISCREG_CPSR];
1405
1406 switch ((OperatingMode) (uint8_t) cpsr.mode) {
1407 case MODE_MON:
1408 case MODE_EL3T:
1409 case MODE_EL3H:
1410 return true;
1411 case MODE_HYP:
1412 case MODE_EL2T:
1413 case MODE_EL2H:
1414 return false;
1415 default:
1416 return !scr.ns;
1417 }
1418}
1419
1422{
1423 CPSR cpsr = readMiscRegNoEffect(MISCREG_CPSR);
1424
1425 return opModeToEL((OperatingMode)(uint8_t)cpsr.mode);
1426}
1427
1428unsigned
1430{
1431 SVCR svcr = miscRegs[MISCREG_SVCR];
1432 // If we are in Streaming Mode, we should return the Streaming Mode vector
1433 // length instead.
1434 if (svcr.sm) {
1435 return getCurSmeVecLenInBits();
1436 }
1437
1438 if (!FullSystem) {
1439 return sveVL * 128;
1440 }
1441
1442 panic_if(!tc,
1443 "A ThreadContext is needed to determine the SVE vector length "
1444 "in full-system mode");
1445
1446 CPSR cpsr = miscRegs[MISCREG_CPSR];
1447 ExceptionLevel el = (ExceptionLevel) (uint8_t) cpsr.el;
1448
1449 unsigned len = 0;
1450
1451 if (el == EL1 || (el == EL0 && !ELIsInHost(tc, el))) {
1452 len = static_cast<ZCR>(miscRegs[MISCREG_ZCR_EL1]).len;
1453 }
1454
1455 if (el == EL2 || (el == EL0 && ELIsInHost(tc, el))) {
1456 len = static_cast<ZCR>(miscRegs[MISCREG_ZCR_EL2]).len;
1457 } else if (release->has(ArmExtension::VIRTUALIZATION) && !isSecure(tc) &&
1458 (el == EL0 || el == EL1)) {
1459 len = std::min(
1460 len,
1461 static_cast<unsigned>(
1462 static_cast<ZCR>(miscRegs[MISCREG_ZCR_EL2]).len));
1463 }
1464
1465 if (el == EL3) {
1466 len = static_cast<ZCR>(miscRegs[MISCREG_ZCR_EL3]).len;
1467 } else if (release->has(ArmExtension::SECURITY)) {
1468 len = std::min(
1469 len,
1470 static_cast<unsigned>(
1471 static_cast<ZCR>(miscRegs[MISCREG_ZCR_EL3]).len));
1472 }
1473
1474 len = std::min(len, sveVL - 1);
1475
1476 return (len + 1) * 128;
1477}
1478
1479unsigned
1481{
1482 if (!FullSystem) {
1483 return smeVL * 128;
1484 }
1485
1486 panic_if(!tc,
1487 "A ThreadContext is needed to determine the SME vector length "
1488 "in full-system mode");
1489
1490 CPSR cpsr = miscRegs[MISCREG_CPSR];
1491 ExceptionLevel el = (ExceptionLevel) (uint8_t) cpsr.el;
1492
1493 unsigned len = 0;
1494
1495 if (el == EL1 || (el == EL0 && !ELIsInHost(tc, el))) {
1496 len = static_cast<SMCR>(miscRegs[MISCREG_SMCR_EL1]).len;
1497 }
1498
1499 if (el == EL2 || (el == EL0 && ELIsInHost(tc, el))) {
1500 len = static_cast<SMCR>(miscRegs[MISCREG_SMCR_EL2]).len;
1501 } else if (release->has(ArmExtension::VIRTUALIZATION) && !isSecure(tc) &&
1502 (el == EL0 || el == EL1)) {
1503 len = std::min(
1504 len,
1505 static_cast<unsigned>(
1506 static_cast<SMCR>(miscRegs[MISCREG_SMCR_EL2]).len));
1507 }
1508
1509 if (el == EL3) {
1510 len = static_cast<SMCR>(miscRegs[MISCREG_SMCR_EL3]).len;
1511 } else if (release->has(ArmExtension::SECURITY)) {
1512 len = std::min(
1513 len,
1514 static_cast<unsigned>(
1515 static_cast<SMCR>(miscRegs[MISCREG_SMCR_EL3]).len));
1516 }
1517
1518 len = std::min(len, smeVL - 1);
1519
1520 // len + 1 must be a power of 2! Round down to the nearest whole power of
1521 // two.
1522 static const unsigned LUT[16] = {0, 1, 1, 3, 3, 3, 3, 7,
1523 7, 7, 7, 7, 7, 7, 7, 15};
1524 len = LUT[len];
1525
1526 return (len + 1) * 128;
1527}
1528
1529void
1531{
1533
1534 DPRINTF(Checkpoint, "Serializing Arm Misc Registers\n");
1536}
1537
1538void
1540{
1541 DPRINTF(Checkpoint, "Unserializing Arm Misc Registers\n");
1543
1544 for (auto idx = 0; idx < NUM_MISCREGS; idx++) {
1545 if (!lookUpMiscReg[idx].info[MISCREG_UNSERIALIZE] &&
1546 miscRegs[idx] != lookUpMiscReg[idx].reset()) {
1547 warn("Checkpoint value for register %s does not match "
1548 "current configuration (checkpointed: %#x, current: %#x)",
1549 miscRegName[idx], miscRegs[idx],
1550 lookUpMiscReg[idx].reset());
1551 miscRegs[idx] = lookUpMiscReg[idx].reset();
1552 }
1553 }
1554
1555 CPSR tmp_cpsr = miscRegs[MISCREG_CPSR];
1556 updateRegMap(tmp_cpsr);
1557}
1558
1559void
1562{
1563 // If we're in timing mode then doing the translation in
1564 // functional mode then we're slightly distorting performance
1565 // results obtained from simulations. The translation should be
1566 // done in the same mode the core is running in. NOTE: This
1567 // can't be an atomic translation because that causes problems
1568 // with unexpected atomic snoop requests.
1569 warn_once("Doing AT (address translation) in functional mode! Fix Me!\n");
1570
1571 auto req = std::make_shared<Request>(
1573 tc->pcState().instAddr(), tc->contextId());
1574
1576 req, tc, mode, tran_type);
1577
1578 PAR par = 0;
1579 if (fault == NoFault) {
1580 Addr paddr = req->getPaddr();
1581 TTBCR ttbcr = readMiscRegNoEffect(MISCREG_TTBCR);
1583
1584 uint8_t max_paddr_bit = 0;
1585 if (release->has(ArmExtension::LPAE) &&
1586 (ttbcr.eae || tran_type & MMU::HypMode ||
1587 ((tran_type & MMU::S1S2NsTran) && hcr.vm) )) {
1588
1589 max_paddr_bit = 39;
1590 } else {
1591 max_paddr_bit = 31;
1592 }
1593
1594 par = (paddr & mask(max_paddr_bit, 12)) |
1595 (getMMUPtr(tc)->getAttr());
1596
1597 DPRINTF(MiscRegs,
1598 "MISCREG: Translated addr 0x%08x: PAR: 0x%08x\n",
1599 val, par);
1600 } else {
1601 ArmFault *arm_fault = static_cast<ArmFault *>(fault.get());
1602 arm_fault->update(tc);
1603 // Set fault bit and FSR
1604 FSR fsr = arm_fault->getFsr(tc);
1605
1606 par.f = 0x1; // F bit
1607 par.lpae = fsr.lpae;
1608 par.ptw = (arm_fault->iss() >> 7) & 0x1;
1609 par.s = arm_fault->isStage2() ? 1 : 0;
1610
1611 if (par.lpae) {
1612 // LPAE - rearange fault status
1613 par.fst = fsr.status;
1614 } else {
1615 // VMSA - rearange fault status
1616 par.fs4_0 = fsr.fsLow | (fsr.fsHigh << 5);
1617 par.fs5 = fsr.ext;
1618 }
1619 DPRINTF(MiscRegs,
1620 "MISCREG: Translated addr 0x%08x fault fsr %#x: PAR: 0x%08x\n",
1621 val, fsr, par);
1622 }
1624 return;
1625}
1626
1627template <class XC>
1628static inline void
1630 Addr cacheBlockMask)
1631{
1632 // Should only every see invalidations / direct writes
1633 assert(pkt->isInvalidate() || pkt->isWrite());
1634
1635 DPRINTF(LLSC, "%s: handling snoop for address: %#x locked: %d\n",
1636 tc->getCpuPtr()->name(), pkt->getAddr(),
1637 xc->readMiscReg(MISCREG_LOCKFLAG));
1638 if (!xc->readMiscReg(MISCREG_LOCKFLAG))
1639 return;
1640
1641 Addr locked_addr = xc->readMiscReg(MISCREG_LOCKADDR) & cacheBlockMask;
1642 // If no caches are attached, the snoop address always needs to be masked
1643 Addr snoop_addr = pkt->getAddr() & cacheBlockMask;
1644
1645 DPRINTF(LLSC, "%s: handling snoop for address: %#x locked addr: %#x\n",
1646 tc->getCpuPtr()->name(), snoop_addr, locked_addr);
1647 if (locked_addr == snoop_addr) {
1648 DPRINTF(LLSC, "%s: address match, clearing lock and signaling sev\n",
1649 tc->getCpuPtr()->name());
1650 xc->setMiscReg(MISCREG_LOCKFLAG, false);
1651 // Implement ARMv8 WFE/SEV semantics
1652 sendEvent(tc);
1653 xc->setMiscReg(MISCREG_SEV_MAILBOX, true);
1654 }
1655}
1656
1657void
1659{
1660 lockedSnoopHandler(tc, tc, pkt, cacheBlockMask);
1661}
1662
1663void
1665{
1666 lockedSnoopHandler(xc->tcBase(), xc, pkt, cacheBlockMask);
1667}
1668
1669void
1671{
1672 tc->setMiscReg(MISCREG_LOCKADDR, req->getPaddr());
1674 DPRINTF(LLSC, "%s: Placing address %#x in monitor\n",
1675 tc->getCpuPtr()->name(), req->getPaddr());
1676}
1677
1678void
1680{
1681 xc->setMiscReg(MISCREG_LOCKADDR, req->getPaddr());
1682 xc->setMiscReg(MISCREG_LOCKFLAG, true);
1683 DPRINTF(LLSC, "%s: Placing address %#x in monitor\n",
1684 xc->tcBase()->getCpuPtr()->name(), req->getPaddr());
1685}
1686
1687void
1689{
1690 DPRINTF(LLSC, "%s: handling snoop lock hit address: %#x\n",
1694}
1695
1696void
1698{
1699 DPRINTF(LLSC, "%s: handling snoop lock hit address: %#x\n",
1700 xc->tcBase()->getCpuPtr()->name(),
1702 xc->setMiscReg(MISCREG_LOCKFLAG, false);
1704}
1705
1706template <class XC>
1707static inline bool
1709 Addr cacheBlockMask)
1710{
1711 if (req->isSwap())
1712 return true;
1713
1714 DPRINTF(LLSC, "Handling locked write for address %#x in monitor.\n",
1715 req->getPaddr());
1716 // Verify that the lock flag is still set and the address
1717 // is correct
1718 bool lock_flag = xc->readMiscReg(MISCREG_LOCKFLAG);
1719 Addr lock_addr = xc->readMiscReg(MISCREG_LOCKADDR) & cacheBlockMask;
1720 if (!lock_flag || (req->getPaddr() & cacheBlockMask) != lock_addr) {
1721 // Lock flag not set or addr mismatch in CPU;
1722 // don't even bother sending to memory system
1723 req->setExtraData(0);
1724 xc->setMiscReg(MISCREG_LOCKFLAG, false);
1725 DPRINTF(LLSC, "clearing lock flag in handle locked write\n",
1726 tc->getCpuPtr()->name());
1727 // the rest of this code is not architectural;
1728 // it's just a debugging aid to help detect
1729 // livelock by warning on long sequences of failed
1730 // store conditionals
1731 int stCondFailures = xc->readStCondFailures();
1732 stCondFailures++;
1733 xc->setStCondFailures(stCondFailures);
1734 if (stCondFailures % 100000 == 0) {
1735 warn("context %d: %d consecutive "
1736 "store conditional failures\n",
1737 tc->contextId(), stCondFailures);
1738 }
1739
1740 // store conditional failed already, so don't issue it to mem
1741 return false;
1742 }
1743 return true;
1744}
1745
1746bool
1747ISA::handleLockedWrite(const RequestPtr &req, Addr cacheBlockMask)
1748{
1749 return lockedWriteHandler(tc, tc, req, cacheBlockMask);
1750}
1751
1752bool
1754 Addr cacheBlockMask)
1755{
1756 return lockedWriteHandler(xc->tcBase(), xc, req, cacheBlockMask);
1757}
1758
1759void
1761{
1762 // A spinlock would typically include a Wait For Event (WFE) to
1763 // conserve energy. The ARMv8 architecture specifies that an event
1764 // is automatically generated when clearing the exclusive monitor
1765 // to wake up the processor in WFE.
1766 DPRINTF(LLSC, "Clearing lock and signaling sev\n");
1768 // Implement ARMv8 WFE/SEV semantics
1769 sendEvent(tc);
1771}
1772
1773void
1775{
1776 // A spinlock would typically include a Wait For Event (WFE) to
1777 // conserve energy. The ARMv8 architecture specifies that an event
1778 // is automatically generated when clearing the exclusive monitor
1779 // to wake up the processor in WFE.
1780 DPRINTF(LLSC, "Clearing lock and signaling sev\n");
1781 xc->setMiscReg(MISCREG_LOCKFLAG, false);
1782 // Implement ARMv8 WFE/SEV semantics
1783 sendEvent(xc->tcBase());
1785}
1786
1787} // namespace ArmISA
1788} // namespace gem5
ISA-specific types for hardware transactional memory.
#define DPRINTF(x,...)
Definition trace.hh:209
virtual FSR getFsr(ThreadContext *tc) const
Definition faults.hh:248
virtual uint32_t iss() const =0
virtual void update(ThreadContext *tc)
Definition faults.cc:413
virtual bool isStage2() const
Definition faults.hh:247
Base class for devices that use the MiscReg interfaces.
Definition isa_device.hh:62
virtual void setMiscReg(int misc_reg, RegVal val)=0
Write to a system register belonging to this device.
virtual void setISA(ISA *isa)
Definition isa_device.cc:55
virtual void setThreadContext(ThreadContext *tc)
Definition isa_device.hh:68
virtual RegVal readMiscReg(int misc_reg)=0
Read a system register belonging to this device.
bool inSecureState() const
Return true if the PE is in Secure state.
Definition isa.cc:1397
void setMiscRegReset(RegIndex, RegVal val)
Definition isa.cc:1344
unsigned getCurSveVecLenInBits() const
Definition isa.cc:1429
ExceptionLevel currEL() const
Returns the current Exception Level (EL) of the ISA object.
Definition isa.cc:1421
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
Definition isa.cc:184
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition isa.cc:1530
void copyRegsFrom(ThreadContext *src) override
Definition isa.cc:191
Random::RandomPtr rng
Definition isa.hh:115
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
Definition isa.hh:81
RegVal readMiscRegReset(RegIndex) const
Definition isa.cc:1337
void setupThreadContext()
Definition isa.cc:168
void setMiscRegNoEffect(RegIndex idx, RegVal val) override
Definition isa.cc:664
uint8_t physAddrRange
Definition isa.hh:96
bool haveLargeAsid64
Definition isa.hh:95
void handleLockedSnoop(PacketPtr pkt, Addr cacheBlockMask) override
Definition isa.cc:1658
void clear() override
Definition isa.cc:138
int flattenMiscIndex(int reg) const
Definition isa.hh:205
std::pair< int, int > getMiscIndices(int misc_reg) const
Definition isa.hh:338
RegVal miscRegs[NUM_MISCREGS]
Definition isa.hh:129
unsigned smeVL
SME vector length in quadwords.
Definition isa.hh:102
BaseISADevice * pmu
Definition isa.hh:84
std::unique_ptr< BaseISADevice > timer
Definition isa.hh:87
bool handleLockedWrite(const RequestPtr &req, Addr cacheBlockMask) override
Definition isa.cc:1747
SelfDebug * selfDebug
Definition isa.hh:113
void globalClearExclusive() override
Definition isa.cc:1760
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition isa.cc:1539
void updateRegMap(CPSR cpsr)
Definition isa.hh:133
void startup() override
startup() is the final initialization call before simulation.
Definition isa.cc:153
int redirectRegVHE(int misc_reg)
Returns the enconcing equivalent when VHE is implemented and HCR_EL2.E2H is enabled and executing at ...
Definition isa.cc:233
BaseISADevice & getGICv3CPUInterface()
Definition isa.cc:1372
ArmSystem * system
Definition isa.hh:75
BaseISADevice & getGenericTimer()
Definition isa.cc:1351
RegVal readMiscRegNoEffect(RegIndex idx) const override
Definition isa.cc:389
void setMiscReg(RegIndex, RegVal val) override
Definition isa.cc:686
unsigned sveVL
SVE vector length in quadwords.
Definition isa.hh:99
const MiscRegLUTEntryInitializer InitReg(uint32_t reg)
Definition isa.hh:118
void handleLockedRead(const RequestPtr &req) override
Definition isa.cc:1670
void addressTranslation(MMU::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
Definition isa.cc:1560
void initializeMiscRegMetadata()
Definition misc.cc:3057
const ArmRelease * release
This could be either a FS or a SE release.
Definition isa.hh:105
bool highestELIs64
Definition isa.hh:93
RegVal readMiscReg(RegIndex idx) override
Definition isa.cc:413
void handleLockedSnoopHit() override
Definition isa.cc:1688
ISA(const Params &p)
Definition isa.cc:86
std::unique_ptr< BaseISADevice > gicv3CpuInterface
Definition isa.hh:90
ExceptionLevel highestEL
Definition isa.hh:94
unsigned getCurSmeVecLenInBits() const
Definition isa.cc:1480
void invalidateMiscReg()
Definition mmu.cc:208
uint64_t getAttr() const
Definition mmu.hh:306
TranslationGenPtr translateFunctional(Addr start, Addr size, ThreadContext *tc, Mode mode, Request::Flags flags) override
Returns a translation generator for a region of virtual addresses, instead of directly translating a ...
Definition mmu.hh:86
chain reset(uint64_t res_val) const
Definition misc.hh:1337
void setenableTDETGE(HCR hcr, HDCR mdcr)
void init(ThreadContext *tc)
void updateOSLock(RegVal val)
void setMDSCRvals(RegVal val)
void updateDBGBCR(int index, DBGBCR val)
void setbSDD(RegVal val)
void updateDBGWCR(int index, DBGWCR val)
void setMDBGen(RegVal val)
void setDebugMask(bool mask)
bool has(ArmExtension ext) const
Definition system.hh:76
GenericTimer * getGenericTimer() const
Get a pointer to the system's generic timer model.
Definition system.hh:177
bool highestELIs64() const
Returns true if the register width of the highest implemented exception level is 64 bits (ARMv8)
Definition system.hh:187
ArmISA::ExceptionLevel highestEL() const
Returns the highest implemented exception level.
Definition system.hh:191
unsigned smeVL() const
Returns the SME vector length at reset, in quadwords.
Definition system.hh:212
BaseGic * getGIC() const
Get a pointer to the system's GIC.
Definition system.hh:180
uint8_t physAddrRange() const
Returns the supported physical address range in bits.
Definition system.hh:220
bool haveLargeAsid64() const
Returns true if ASID is 16 bits in AArch64 (ARMv8)
Definition system.hh:206
const ArmRelease * releaseFS() const
Definition system.hh:156
unsigned sveVL() const
Returns the SVE vector length at reset, in quadwords.
Definition system.hh:209
BaseInterrupts * getInterruptController(ThreadID tid)
Definition base.hh:253
ThreadContext * tc
Definition isa.hh:68
RegClasses _regClasses
Definition isa.hh:70
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition isa.hh:136
CheckerCPU class.
Definition cpu.hh:85
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
virtual ThreadContext * tcBase() const =0
Returns a pointer to the ThreadContext.
virtual RegVal readMiscReg(int misc_reg)=0
Reads a miscellaneous register, handling any architectural side effects due to reading that register.
virtual void setMiscReg(int misc_reg, RegVal val)=0
Sets a miscellaneous register, handling any architectural side effects due to writing that register.
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
Definition gic_v3.hh:189
Backing store for matrices.
Definition matrix.hh:381
virtual std::string name() const
Definition named.hh:47
Target & as()
Definition pcstate.hh:73
Addr instAddr() const
Returns the memory address of the instruction this PC points to.
Definition pcstate.hh:108
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
Addr getAddr() const
Definition packet.hh:807
bool isWrite() const
Definition packet.hh:594
bool isInvalidate() const
Definition packet.hh:609
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
Definition request.hh:282
SimObjectParams Params
int size() const
Definition system.hh:210
Threads threads
Definition system.hh:310
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual RegVal readMiscReg(RegIndex misc_reg)=0
virtual void setHtmCheckpointPtr(BaseHTMCheckpointPtr cpt)=0
virtual void pcStateNoRecord(const PCStateBase &val)=0
virtual void setMiscReg(RegIndex misc_reg, RegVal val)=0
virtual RegVal getReg(const RegId &reg) const
virtual void setMiscRegNoEffect(RegIndex misc_reg, RegVal val)=0
virtual System * getSystemPtr()=0
virtual BaseCPU * getCpuPtr()=0
virtual void setReg(const RegId &reg, RegVal val)
virtual CheckerCPU * getCheckerCpuPtr()=0
virtual InstDecoder * getDecoderPtr()=0
virtual const PCStateBase & pcState() const =0
virtual int threadId() const =0
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
virtual BaseMMU * getMMUPtr()=0
virtual ContextID contextId() const =0
Vector Register Abstraction This generic class is the model in a particularization of MVC,...
Definition vec_reg.hh:126
This module implements the global system counter and the local per-CPU architected timers as specifie...
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Definition bitfield.hh:79
#define panic(...)
This implements a cprintf based panic() function.
Definition logging.hh:188
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Definition logging.hh:214
virtual void startup()
startup() is the final initialization call before simulation.
Definition sim_object.cc:96
uint8_t flags
Definition helpers.cc:87
#define warn(...)
Definition logging.hh:256
#define warn_once(...)
Definition logging.hh:260
constexpr RegId V
Definition cc.hh:96
constexpr RegId C
Definition cc.hh:95
constexpr RegId Nz
Definition cc.hh:94
constexpr RegId Sp2
Definition int.hh:235
constexpr RegId Sp0
Definition int.hh:233
constexpr RegId Sp1
Definition int.hh:234
bool ELIs32(ThreadContext *tc, ExceptionLevel el)
Definition utility.cc:283
Bitfield< 28 > v
Definition misc_types.hh:54
constexpr RegClass flatIntRegClass
Definition int.hh:178
static const uint32_t FpscrQcMask
Definition misc.hh:3000
bool ELIsInHost(ThreadContext *tc, ExceptionLevel el)
Returns true if the current exception level el is executing a Host OS or an application of a Host OS ...
Definition utility.cc:291
Bitfield< 3, 0 > mask
Definition pcstate.hh:63
Bitfield< 18, 16 > len
Bitfield< 4, 0 > mode
Definition misc_types.hh:74
bool isSecure(ThreadContext *tc)
Definition utility.cc:74
Bitfield< 22 > pan
Definition misc_types.hh:59
static const uint32_t FpscrExcMask
Definition misc.hh:3004
Bitfield< 7 > i
Definition misc_types.hh:67
void sendEvent(ThreadContext *tc)
Send an event (SEV) to a specific PE if there isn't already a pending event.
Definition utility.cc:65
constexpr RegClass matRegClass
Definition mat.hh:92
MMU * getMMUPtr(T *tc)
Definition mmu.hh:449
constexpr RegClass vecElemClass
Definition vec.hh:105
static const uint32_t CpsrMaskQ
Definition misc.hh:2983
bool EL2Enabled(ThreadContext *tc)
Definition utility.cc:268
void preUnflattenMiscReg()
Definition misc.cc:722
constexpr RegClass vecPredRegClass
Definition vec.hh:109
constexpr RegClass ccRegClass
Definition cc.hh:87
@ MISCREG_NSACR
Definition misc.hh:263
@ MISCREG_ID_AA64PFR0_EL1
Definition misc.hh:591
@ MISCREG_DBGBCR15
Definition misc.hh:155
@ MISCREG_DBGOSLSR
Definition misc.hh:206
@ MISCREG_TTBR1_EL12
Definition misc.hh:635
@ MISCREG_CNTV_CTL_EL0
Definition misc.hh:843
@ MISCREG_HCR
Definition misc.hh:266
@ MISCREG_HDFAR
Definition misc.hh:307
@ MISCREG_MPIDR_EL1
Definition misc.hh:570
@ MISCREG_ATS1HR
Definition misc.hh:337
@ MISCREG_SCTLR_EL2
Definition misc.hh:616
@ MISCREG_CNTV_CVAL_EL02
Definition misc.hh:850
@ MISCREG_CNTP_CTL_EL0
Definition misc.hh:840
@ MISCREG_PMOVSSET
Definition misc.hh:396
@ MISCREG_FPEXC
Definition misc.hh:93
@ MISCREG_CNTP_CTL_EL02
Definition misc.hh:846
@ MISCREG_SPSEL
Definition misc.hh:655
@ MISCREG_TCR_EL2
Definition misc.hh:641
@ MISCREG_RNDRRS
Definition misc.hh:1160
@ MISCREG_DBGDSCRint
Definition misc.hh:114
@ MISCREG_MVFR1
Definition misc.hh:91
@ MISCREG_MIDR_EL1
Definition misc.hh:569
@ MISCREG_ZCR_EL2
Definition misc.hh:1141
@ MISCREG_ICC_IGRPEN1_EL3
Definition misc.hh:967
@ MISCREG_CNTFRQ
Definition misc.hh:443
@ MISCREG_AFSR1_EL12
Definition misc.hh:676
@ MISCREG_CPSR_Q
Definition misc.hh:97
@ MISCREG_MAIR_EL1
Definition misc.hh:810
@ MISCREG_ICC_PMR_EL1
Definition misc.hh:922
@ MISCREG_CONTEXTIDR_EL1
Definition misc.hh:829
@ MISCREG_CNTV_TVAL
Definition misc.hh:457
@ MISCREG_HCPTR
Definition misc.hh:269
@ MISCREG_SPSR_EL2
Definition misc.hh:663
@ MISCREG_ID_MMFR1
Definition misc.hh:234
@ MISCREG_LOCKFLAG
Definition misc.hh:101
@ MISCREG_ICH_LR15_EL2
Definition misc.hh:999
@ MISCREG_FPSID
Definition misc.hh:89
@ MISCREG_MAIR_EL12
Definition misc.hh:811
@ MISCREG_SCTLR
Definition misc.hh:253
@ MISCREG_TTBCR
Definition misc.hh:278
@ MISCREG_ATS12NSOUW
Definition misc.hh:329
@ MISCREG_MAIR_EL2
Definition misc.hh:814
@ MISCREG_CNTV_CVAL
Definition misc.hh:456
@ MISCREG_CSSELR
Definition misc.hh:248
@ MISCREG_CPACR
Definition misc.hh:259
@ MISCREG_SCR_EL3
Definition misc.hh:628
@ MISCREG_CNTKCTL_EL12
Definition misc.hh:853
@ MISCREG_ID_AA64DFR0_EL1
Definition misc.hh:593
@ MISCREG_DBGOSLAR
Definition misc.hh:205
@ MISCREG_DBGDSCRext
Definition misc.hh:121
@ MISCREG_SCTLR2_EL12
Definition misc.hh:612
@ MISCREG_SCTLR2_EL1
Definition misc.hh:611
@ MISCREG_TCR_EL3
Definition misc.hh:648
@ MISCREG_SMCR_EL1
Definition misc.hh:1154
@ MISCREG_FPSR
Definition misc.hh:660
@ MISCREG_CPACR_EL12
Definition misc.hh:615
@ MISCREG_HDCR
Definition misc.hh:268
@ MISCREG_ESR_EL1
Definition misc.hh:677
@ MISCREG_CNTP_TVAL
Definition misc.hh:452
@ MISCREG_TCR_EL1
Definition misc.hh:636
@ MISCREG_CNTVCT
Definition misc.hh:445
@ MISCREG_ESR_EL12
Definition misc.hh:678
@ MISCREG_AFSR0_EL1
Definition misc.hh:673
@ MISCREG_ID_ISAR5
Definition misc.hh:243
@ MISCREG_ATS1CUR
Definition misc.hh:324
@ MISCREG_OSLAR_EL1
Definition misc.hh:558
@ MISCREG_CNTPCT_EL0
Definition misc.hh:838
@ MISCREG_MPAM1_EL1
Definition misc.hh:1173
@ MISCREG_AFSR1_EL2
Definition misc.hh:681
@ MISCREG_CNTV_CTL_EL02
Definition misc.hh:849
@ MISCREG_DBGBCR0_EL1
Definition misc.hh:504
@ MISCREG_ID_ISAR4
Definition misc.hh:242
@ MISCREG_SCTLR_EL1
Definition misc.hh:609
@ MISCREG_CNTP_TVAL_EL02
Definition misc.hh:848
@ MISCREG_PRRR
Definition misc.hh:399
@ MISCREG_CPTR_EL2
Definition misc.hh:622
@ MISCREG_CCSIDR
Definition misc.hh:245
@ MISCREG_FAR_EL1
Definition misc.hh:687
@ MISCREG_DBGWCR0
Definition misc.hh:172
@ MISCREG_PMCR
Definition misc.hh:369
@ MISCREG_CNTHV_CTL_EL2
Definition misc.hh:865
@ MISCREG_CNTV_CTL
Definition misc.hh:455
@ MISCREG_ID_AA64DFR1_EL1
Definition misc.hh:594
@ MISCREG_ID_AA64ISAR1_EL1
Definition misc.hh:598
@ MISCREG_SMCR_EL3
Definition misc.hh:1151
@ MISCREG_ELR_EL12
Definition misc.hh:653
@ MISCREG_PMEVCNTR0_EL0
Definition misc.hh:874
@ MISCREG_VBAR_EL12
Definition misc.hh:821
@ MISCREG_ID_AA64MMFR1_EL1
Definition misc.hh:600
@ MISCREG_TTBR0_EL12
Definition misc.hh:633
@ MISCREG_ATS12NSOUR
Definition misc.hh:328
@ MISCREG_CNTVCT_EL0
Definition misc.hh:839
@ MISCREG_SP_EL0
Definition misc.hh:654
@ MISCREG_DFAR_S
Definition misc.hh:303
@ MISCREG_CPSR
Definition misc.hh:79
@ MISCREG_FPCR
Definition misc.hh:659
@ MISCREG_SDCR
Definition misc.hh:260
@ MISCREG_CPACR_EL1
Definition misc.hh:614
@ MISCREG_ID_MMFR0
Definition misc.hh:233
@ MISCREG_PMEVTYPER5_EL0
Definition misc.hh:885
@ MISCREG_CNTP_CVAL
Definition misc.hh:449
@ MISCREG_ID_ISAR0
Definition misc.hh:238
@ MISCREG_CNTKCTL_EL1
Definition misc.hh:852
@ MISCREG_SP_EL2
Definition misc.hh:672
@ MISCREG_NMRR
Definition misc.hh:405
@ MISCREG_SCTLR_EL12
Definition misc.hh:610
@ MISCREG_TTBR1_EL1
Definition misc.hh:634
@ MISCREG_MAIR1
Definition misc.hh:408
@ MISCREG_DAIF
Definition misc.hh:658
@ MISCREG_SEV_MAILBOX
Definition misc.hh:109
@ MISCREG_SPSR_EL12
Definition misc.hh:651
@ MISCREG_CNTP_CVAL_EL02
Definition misc.hh:847
@ MISCREG_PMINTENSET_EL1
Definition misc.hh:794
@ MISCREG_CNTHPS_CVAL_EL2
Definition misc.hh:862
@ MISCREG_REVIDR
Definition misc.hh:228
@ MISCREG_ID_MMFR3
Definition misc.hh:236
@ MISCREG_ICH_LRC15
Definition misc.hh:1136
@ MISCREG_TCR2_EL12
Definition misc.hh:639
@ MISCREG_ISR
Definition misc.hh:426
@ MISCREG_CONTEXTIDR
Definition misc.hh:429
@ MISCREG_CNTHPS_TVAL_EL2
Definition misc.hh:863
@ MISCREG_SCR
Definition misc.hh:261
@ MISCREG_ELR_EL2
Definition misc.hh:664
@ MISCREG_CONTEXTIDR_EL2
Definition misc.hh:901
@ MISCREG_TCR_EL12
Definition misc.hh:637
@ MISCREG_CNTHCTL_EL2
Definition misc.hh:857
@ MISCREG_MDSCR_EL1
Definition misc.hh:485
@ MISCREG_ID_DFR0
Definition misc.hh:231
@ MISCREG_TTBR1_EL2
Definition misc.hh:904
@ MISCREG_ID_AA64MMFR0_EL1
Definition misc.hh:599
@ MISCREG_AMAIR_EL1
Definition misc.hh:812
@ MISCREG_ATS1HW
Definition misc.hh:338
@ MISCREG_DC_ZVA_Xt
Definition misc.hh:703
@ MISCREG_CNTHVS_TVAL_EL2
Definition misc.hh:870
@ MISCREG_ATS1CPR
Definition misc.hh:322
@ MISCREG_NZCV
Definition misc.hh:657
@ MISCREG_SPSR_EL1
Definition misc.hh:650
@ MISCREG_FAR_EL12
Definition misc.hh:688
@ MISCREG_CNTP_CVAL_EL0
Definition misc.hh:841
@ MISCREG_HCR_EL2
Definition misc.hh:619
@ MISCREG_CNTHVS_CVAL_EL2
Definition misc.hh:869
@ MISCREG_SMCR_EL2
Definition misc.hh:1152
@ MISCREG_ATS1CPW
Definition misc.hh:323
@ MISCREG_TTBR1
Definition misc.hh:275
@ MISCREG_MPIDR
Definition misc.hh:227
@ MISCREG_ZCR_EL1
Definition misc.hh:1143
@ MISCREG_ID_AA64MMFR2_EL1
Definition misc.hh:906
@ MISCREG_VTCR_EL2
Definition misc.hh:644
@ MISCREG_VTTBR
Definition misc.hh:478
@ MISCREG_CNTVOFF_EL2
Definition misc.hh:872
@ MISCREG_VPIDR
Definition misc.hh:251
@ MISCREG_DBGWCR15
Definition misc.hh:187
@ MISCREG_CNTHPS_CTL_EL2
Definition misc.hh:861
@ MISCREG_VBAR_EL2
Definition misc.hh:824
@ MISCREG_CLIDR
Definition misc.hh:246
@ MISCREG_SCTLR_S
Definition misc.hh:255
@ MISCREG_MDCR_EL2
Definition misc.hh:621
@ MISCREG_CNTHV_TVAL_EL2
Definition misc.hh:867
@ MISCREG_VBAR_EL1
Definition misc.hh:820
@ MISCREG_MIDR
Definition misc.hh:223
@ MISCREG_AMAIR_EL2
Definition misc.hh:815
@ MISCREG_L2CTLR
Definition misc.hh:397
@ MISCREG_CNTP_CTL
Definition misc.hh:446
@ MISCREG_TTBR0_EL3
Definition misc.hh:647
@ MISCREG_DBGWCR0_EL1
Definition misc.hh:536
@ MISCREG_ATS12NSOPW
Definition misc.hh:327
@ MISCREG_ISR_EL1
Definition misc.hh:823
@ MISCREG_CNTVOFF
Definition misc.hh:463
@ MISCREG_TLBTR
Definition misc.hh:226
@ MISCREG_ID_AA64AFR1_EL1
Definition misc.hh:596
@ MISCREG_AFSR0_EL12
Definition misc.hh:674
@ MISCREG_ELR_EL1
Definition misc.hh:652
@ MISCREG_AMAIR_EL12
Definition misc.hh:813
@ NUM_PHYS_MISCREGS
Definition misc.hh:1193
@ MISCREG_DBGWCR15_EL1
Definition misc.hh:551
@ MISCREG_TCR2_EL1
Definition misc.hh:638
@ MISCREG_ID_PFR1
Definition misc.hh:230
@ MISCREG_CNTHP_CVAL_EL2
Definition misc.hh:859
@ MISCREG_CNTV_TVAL_EL0
Definition misc.hh:845
@ MISCREG_MPAM2_EL2
Definition misc.hh:1174
@ MISCREG_ZCR_EL3
Definition misc.hh:1140
@ MISCREG_FPSCR
Definition misc.hh:90
@ MISCREG_TTBR0
Definition misc.hh:272
@ MISCREG_DACR
Definition misc.hh:283
@ MISCREG_TTBR0_EL2
Definition misc.hh:640
@ MISCREG_HSCTLR
Definition misc.hh:264
@ MISCREG_SCTLR_NS
Definition misc.hh:254
@ MISCREG_ICC_AP0R0
Definition misc.hh:1044
@ MISCREG_TTBR0_EL1
Definition misc.hh:632
@ MISCREG_SCTLR_EL3
Definition misc.hh:625
@ MISCREG_CNTP_TVAL_EL0
Definition misc.hh:842
@ MISCREG_FPSCR_QC
Definition misc.hh:99
@ MISCREG_CURRENTEL
Definition misc.hh:656
@ MISCREG_ICH_AP0R0_EL2
Definition misc.hh:970
@ MISCREG_ID_ISAR1
Definition misc.hh:239
@ MISCREG_DBGBCR0
Definition misc.hh:140
@ MISCREG_ID_AA64AFR0_EL1
Definition misc.hh:595
@ MISCREG_ATS12NSOPR
Definition misc.hh:326
@ MISCREG_OSLSR_EL1
Definition misc.hh:559
@ MISCREG_DBGBCR15_EL1
Definition misc.hh:519
@ MISCREG_MVFR0
Definition misc.hh:92
@ MISCREG_ID_AA64ISAR0_EL1
Definition misc.hh:597
@ MISCREG_HIFAR
Definition misc.hh:308
@ MISCREG_CNTHP_TVAL_EL2
Definition misc.hh:860
@ MISCREG_ID_MMFR2
Definition misc.hh:235
@ MISCREG_FAR_EL2
Definition misc.hh:689
@ MISCREG_CNTHVS_CTL_EL2
Definition misc.hh:868
@ MISCREG_FPSCR_EXC
Definition misc.hh:98
@ MISCREG_CNTV_TVAL_EL02
Definition misc.hh:851
@ MISCREG_MPAM1_EL12
Definition misc.hh:1176
@ MISCREG_ID_ISAR3
Definition misc.hh:241
@ MISCREG_CNTHP_CTL_EL2
Definition misc.hh:858
@ MISCREG_PAR
Definition misc.hh:312
@ MISCREG_CONTEXTIDR_EL12
Definition misc.hh:830
@ MISCREG_CPTR_EL3
Definition misc.hh:630
@ MISCREG_ESR_EL2
Definition misc.hh:682
@ MISCREG_ID_PFR0
Definition misc.hh:229
@ MISCREG_IFAR_S
Definition misc.hh:306
@ MISCREG_ID_MMFR4
Definition misc.hh:237
@ MISCREG_AFSR1_EL1
Definition misc.hh:675
@ MISCREG_CNTHV_CVAL_EL2
Definition misc.hh:866
@ MISCREG_LOCKADDR
Definition misc.hh:100
@ MISCREG_CNTFRQ_EL0
Definition misc.hh:837
@ MISCREG_ID_AFR0
Definition misc.hh:232
@ MISCREG_ACTLR
Definition misc.hh:256
@ MISCREG_PMXEVTYPER_PMCCFILTR
Definition misc.hh:108
@ MISCREG_ID_AA64PFR1_EL1
Definition misc.hh:592
@ MISCREG_HSTR
Definition misc.hh:270
@ MISCREG_MDCR_EL3
Definition misc.hh:631
@ MISCREG_AFSR0_EL2
Definition misc.hh:680
@ MISCREG_ID_ISAR2
Definition misc.hh:240
@ MISCREG_CNTV_CVAL_EL0
Definition misc.hh:844
@ MISCREG_ZCR_EL12
Definition misc.hh:1142
@ MISCREG_SP_EL1
Definition misc.hh:665
@ MISCREG_ATS1CUW
Definition misc.hh:325
@ MISCREG_MAIR0
Definition misc.hh:402
@ MISCREG_PMOVSSET_EL0
Definition misc.hh:809
Bitfield< 9, 6 > daif
Definition misc_types.hh:70
Bitfield< 3, 2 > el
Definition misc_types.hh:73
@ MISCREG_WARN_NOT_FAIL
Definition misc.hh:1232
@ MISCREG_UNSERIALIZE
Definition misc.hh:1231
@ MISCREG_IMPLEMENTED
Definition misc.hh:1228
int unflattenMiscReg(int reg)
Definition misc.cc:738
Bitfield< 0 > sp
Definition misc_types.hh:75
static bool lockedWriteHandler(ThreadContext *tc, XC *xc, const RequestPtr &req, Addr cacheBlockMask)
Definition isa.cc:1708
static ExceptionLevel opModeToEL(OperatingMode mode)
Definition types.hh:429
constexpr RegClass miscRegClass
Definition misc.hh:2975
const char *const miscRegName[]
Definition misc.hh:1840
RegVal readMPIDR(ArmSystem *arm_sys, ThreadContext *tc)
This helper function is either returing the value of MPIDR_EL1 (by calling getMPIDR),...
Definition utility.cc:148
static void lockedSnoopHandler(ThreadContext *tc, XC *xc, PacketPtr pkt, Addr cacheBlockMask)
Definition isa.cc:1629
std::vector< struct MiscRegLUTEntry > lookUpMiscReg(NUM_MISCREGS)
Definition misc.hh:1719
Bitfield< 23 > uao
Definition misc_types.hh:58
constexpr RegClass vecRegClass
Definition vec.hh:101
Bitfield< 4 > pc
Bitfield< 0 > p
Bitfield< 5, 3 > reg
Definition types.hh:92
Bitfield< 15 > system
Definition misc.hh:1032
Bitfield< 63 > val
Definition misc.hh:804
constexpr RegClass floatRegClass
Definition float.hh:143
Copyright (c) 2024 Arm Limited All rights reserved.
Definition binary32.hh:36
std::shared_ptr< FaultBase > Fault
Definition types.hh:249
std::shared_ptr< Request > RequestPtr
Definition request.hh:94
uint16_t RegIndex
Definition types.hh:176
std::ostream CheckpointOut
Definition serialize.hh:66
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
Definition root.cc:220
uint64_t RegVal
Definition types.hh:173
constexpr decltype(nullptr) NoFault
Definition types.hh:253
@ FloatRegClass
Floating-point register.
Definition reg_class.hh:62
constexpr char FloatRegClassName[]
Definition reg_class.hh:76
#define UNSERIALIZE_MAPPING(member, names, size)
Definition serialize.hh:666
#define SERIALIZE_MAPPING(member, names, size)
Definition serialize.hh:660

Generated on Mon Jan 13 2025 04:28:22 for gem5 by doxygen 1.9.8