diff options
Diffstat (limited to 'src/arch/arm/isa/templates/misc64.isa')
-rw-r--r-- | src/arch/arm/isa/templates/misc64.isa | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/src/arch/arm/isa/templates/misc64.isa b/src/arch/arm/isa/templates/misc64.isa index 3c830c858..ed9b4a3ae 100644 --- a/src/arch/arm/isa/templates/misc64.isa +++ b/src/arch/arm/isa/templates/misc64.isa @@ -1,6 +1,6 @@ // -*- mode:c++ -*- -// Copyright (c) 2011,2017-2018 ARM Limited +// Copyright (c) 2011,2017-2019 ARM Limited // All rights reserved // // The license below extends only to copyright in the software and shall @@ -109,6 +109,29 @@ def template RegRegRegImmOp64Constructor {{ } }}; +def template MiscRegOp64Declare {{ +class %(class_name)s : public %(base_class)s +{ + public: + // Constructor + %(class_name)s(ExtMachInst machInst, MiscRegIndex _dest, + uint64_t _imm); + + Fault execute(ExecContext *, Trace::InstRecord *) const override; +}; +}}; + +def template MiscRegOp64Constructor {{ + %(class_name)s::%(class_name)s(ExtMachInst machInst, + MiscRegIndex _dest, + uint64_t _imm) + : %(base_class)s("%(mnemonic)s", machInst, %(op_class)s, + _dest, _imm) + { + %(constructor)s; + } +}}; + def template MiscRegRegOp64Declare {{ class %(class_name)s : public %(base_class)s { |