gem5  v20.0.0.3
pseudo.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014,2016-2018 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  * Copyright (c) 2007-2008 The Florida State University
15  * All rights reserved.
16  *
17  * Redistribution and use in source and binary forms, with or without
18  * modification, are permitted provided that the following conditions are
19  * met: redistributions of source code must retain the above copyright
20  * notice, this list of conditions and the following disclaimer;
21  * redistributions in binary form must reproduce the above copyright
22  * notice, this list of conditions and the following disclaimer in the
23  * documentation and/or other materials provided with the distribution;
24  * neither the name of the copyright holders nor the names of its
25  * contributors may be used to endorse or promote products derived from
26  * this software without specific prior written permission.
27  *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39  */
40 
41 #include "arch/arm/insts/pseudo.hh"
42 
43 #include "cpu/exec_context.hh"
44 
46  : ArmStaticInst("gem5decoderFault", _machInst, No_OpClass),
47  faultId(static_cast<DecoderFault>(
48  static_cast<uint8_t>(_machInst.decoderFault)))
49 {
50  // Don't call execute() if we're on a speculative path and the
51  // fault is an internal panic fault.
52  flags[IsNonSpeculative] = (faultId == DecoderFault::PANIC);
53 }
54 
55 Fault
57 {
58  const PCState pc_state(xc->pcState());
59  const Addr pc(pc_state.instAddr());
60 
61  switch (faultId) {
63  if (machInst.aarch64) {
64  return std::make_shared<PCAlignmentFault>(pc);
65  } else {
66  // TODO: We should check if we the receiving end is in
67  // aarch64 mode and raise a PCAlignment fault instead.
68  return std::make_shared<PrefetchAbort>(
69  pc, ArmFault::AlignmentFault);
70  }
71 
73  panic("Internal error in instruction decoder\n");
74 
75  case DecoderFault::OK:
76  panic("Decoder fault instruction without decoder fault.\n");
77  }
78 
79  panic("Unhandled fault type");
80 }
81 
82 const char *
84 {
85  switch (faultId) {
86  case DecoderFault::OK:
87  return "OK";
88 
90  return "UnalignedInstruction";
91 
93  return "DecoderPanic";
94  }
95 
96  panic("Unhandled fault type");
97 }
98 
99 std::string
101  Addr pc, const Loader::SymbolTable *symtab) const
102 {
103  return csprintf("gem5fault %s", faultName());
104 }
105 
106 
107 
109  ExtMachInst _machInst)
110  : ArmStaticInst(_mnemonic, _machInst, No_OpClass)
111 {
112  // don't call execute() (which panics) if we're on a
113  // speculative path
114  flags[IsNonSpeculative] = true;
115 }
116 
118  ExtMachInst _machInst,
119  const std::string& _fullMnemonic)
120  : ArmStaticInst(_mnemonic, _machInst, No_OpClass),
121  fullMnemonic(_fullMnemonic)
122 {
123  // don't call execute() (which panics) if we're on a
124  // speculative path
125  flags[IsNonSpeculative] = true;
126 }
127 
128 Fault
130 {
131  return std::make_shared<UndefinedInstruction>(machInst, false, mnemonic);
132 }
133 
134 std::string
136  Addr pc, const Loader::SymbolTable *symtab) const
137 {
138  return csprintf("%-10s (unimplemented)",
139  fullMnemonic.size() ? fullMnemonic.c_str() : mnemonic);
140 }
141 
142 
143 
145  ExtMachInst _machInst)
146  : ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false)
147 {
148  // don't call execute() (which panics) if we're on a
149  // speculative path
150  flags[IsNonSpeculative] = true;
151 }
152 
154  ExtMachInst _machInst,
155  const std::string& _fullMnemonic)
156  : ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false),
157  fullMnemonic(_fullMnemonic)
158 {
159  // don't call execute() (which panics) if we're on a
160  // speculative path
161  flags[IsNonSpeculative] = true;
162 }
163 
164 Fault
166 {
167  if (!warned) {
168  warn("\tinstruction '%s' unimplemented\n",
169  fullMnemonic.size() ? fullMnemonic.c_str() : mnemonic);
170  warned = true;
171  }
172 
173  return NoFault;
174 }
175 
176 std::string
178  Addr pc, const Loader::SymbolTable *symtab) const
179 {
180  return csprintf("%-10s (unimplemented)",
181  fullMnemonic.size() ? fullMnemonic.c_str() : mnemonic);
182 }
183 
185  : ArmStaticInst("Illegal Execution", _machInst, No_OpClass)
186 {}
187 
188 Fault
190 {
191  return std::make_shared<IllegalInstSetStateFault>();
192 }
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:163
DecoderFault faultId
Definition: pseudo.hh:49
decltype(nullptr) constexpr NoFault
Definition: types.hh:243
IllegalExecInst(ExtMachInst _machInst)
Definition: pseudo.cc:184
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
Definition: pseudo.cc:129
WarnUnimplemented(const char *_mnemonic, ExtMachInst _machInst)
Definition: pseudo.cc:144
const char * mnemonic
Base mnemonic (e.g., "add").
Definition: static_inst.hh:246
virtual PCState pcState() const =0
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
Definition: pseudo.cc:56
FailUnimplemented(const char *_mnemonic, ExtMachInst _machInst)
Definition: pseudo.cc:108
No fault.
Definition: types.hh:656
Internal gem5 error.
Definition: types.hh:659
bool warned
Have we warned on this instruction yet?
Definition: pseudo.hh:102
const ExtMachInst machInst
The binary machine instruction.
Definition: static_inst.hh:231
std::bitset< Num_Flags > flags
Flag values for this instruction.
Definition: static_inst.hh:99
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
Definition: exec_context.hh:70
Bitfield< 4 > pc
std::string csprintf(const char *format, const Args &...args)
Definition: cprintf.hh:158
std::string generateDisassembly(Addr pc, const Loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Definition: pseudo.cc:100
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition: types.hh:140
std::string fullMnemonic
Full mnemonic for MRC and MCR instructions including the coproc.
Definition: pseudo.hh:105
std::string generateDisassembly(Addr pc, const Loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Definition: pseudo.cc:135
DecoderFaultInst(ExtMachInst _machInst)
Definition: pseudo.cc:45
const char * faultName() const
Definition: pseudo.cc:83
decoderFault
Definition: types.hh:70
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const
Definition: pseudo.cc:189
std::string generateDisassembly(Addr pc, const Loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Definition: pseudo.cc:177
std::string fullMnemonic
Full mnemonic for MRC and MCR instructions including the coproc.
Definition: pseudo.hh:75
TheISA::ExtMachInst ExtMachInst
Binary extended machine instruction type.
Definition: static_inst.hh:89
#define warn(...)
Definition: logging.hh:208
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
Definition: pseudo.cc:165
Unaligned instruction fault.
Definition: types.hh:657
GenericISA::DelaySlotPCState< MachInst > PCState
Definition: types.hh:41
std::shared_ptr< FaultBase > Fault
Definition: types.hh:238
DecoderFault
Instruction decoder fault codes in ExtMachInst.
Definition: types.hh:655

Generated on Fri Jul 3 2020 15:42:39 for gem5 by doxygen 1.8.13