Go to the documentation of this file.
   38 #ifndef __ARCH_ARM_SEMIHOSTING_HH__ 
   39 #define __ARCH_ARM_SEMIHOSTING_HH__ 
   59 struct ArmSemihostingParams;
 
   95         template <
typename Arg>
 
  183                 return proxy.read<uint64_t>(
addr, endian);
 
  185                 return proxy.read<uint32_t>(
addr, endian);
 
  187                 panic(
"Unexpected semihosting argument size %d.", 
size);
 
  196                 proxy.write<uint64_t>(
addr, 
val, endian);
 
  198                 proxy.write<uint32_t>(
addr, 
val, endian);
 
  200                 panic(
"Unexpected semihosting argument size %d.", 
size);
 
  289         static std::unique_ptr<FileBase> 
create(
 
  292         static std::unique_ptr<FileBase> 
create(
 
  316         virtual int64_t 
open() { 
return 0; }
 
  323         virtual int64_t 
close() { 
return 0; }
 
  330         virtual bool isTTY()
 const { 
return false; }
 
  337         virtual int64_t 
read(uint8_t *buffer, uint64_t size);
 
  344         virtual int64_t 
write(
const uint8_t *buffer, uint64_t size);
 
  352         virtual int64_t 
seek(uint64_t pos);
 
  359         virtual int64_t 
flen();
 
  374                      const char *
name, 
const char *
mode);
 
  379         int64_t 
read(uint8_t *buffer, uint64_t size) 
override;
 
  380         int64_t 
seek(uint64_t 
pos) 
override;
 
  396         int64_t 
close() 
override;
 
  397         bool isTTY() 
const override;
 
  398         int64_t 
read(uint8_t *buffer, uint64_t size) 
override;
 
  399         int64_t 
write(
const uint8_t *buffer, uint64_t size) 
override;
 
  400         int64_t 
seek(uint64_t pos) 
override;
 
  401         int64_t 
flen() 
override;
 
  422         return msb > 31 ? msb - 31 : 0;
 
  429     void semiExit(uint64_t code, uint64_t subcode);
 
  461         template <
typename ...Args>
 
  467         template <
typename ...Args>
 
  472                 return (
sh->*
impl)(tc, args...);
 
  491         template <
typename Abi, 
typename ...Args>
 
  498                 return invokeSimcall<Abi>(tc, wrapper);
 
  503         template <
typename Abi, 
typename ...Args>
 
  514         template <
typename ...Args>
 
  523         template <
typename ...Args32, 
typename ...Args64>
 
  534                       int fmode, 
size_t name_size);
 
  539                        Addr buffer, 
size_t size);
 
  541                       Addr buffer, 
size_t size);
 
  548                         uint64_t 
id, 
size_t size);
 
  551                         Addr to_addr, 
size_t to_size);
 
  560                         Addr &stack_base, 
Addr &stack_limit);
 
  575     template <
typename Abi>
 
  582         invokeSimcall<Abi>(tc, retErr);
 
  585     static FILE *
getSTDIO(
const char *stream_name,
 
  586                           const std::string &
name, 
const char *
mode);
 
  588     static const std::map<uint32_t, SemiCall> 
calls;
 
  590     static const std::map<uint64_t, const char *> 
exitCodes;
 
  592     static const std::map<const std::string, FILE *> 
stdioMap;
 
  606 template <
typename Arg>
 
  608     typename std::enable_if_t<std::is_integral_v<Arg>>>
 
  613         return state.get(tc);
 
  617 template <
typename Arg>
 
  619     typename std::enable_if_t<std::is_integral_v<Arg>>>
 
  624         if (std::is_signed_v<Arg>)
 
  625             return sext<32>(
state.get(tc));
 
  627             return state.get(tc);
 
  631 template <
typename Abi>
 
  633     std::is_base_of_v<ArmSemihosting::AbiBase, Abi>>>
 
  639                 state.getAddr(), 
sizeof(
typename Abi::State::ArgType));
 
  659         tc->
setReg(ArmISA::int_reg::X0, 
err.first);
 
  666 #endif // __ARCH_ARM_SEMIHOSTING_HH__ 
  
const std::string & fileName()
std::ostream & operator<<(std::ostream &os, const ArmSemihosting::InPlaceArg &ipa)
RetErrno callFLen(ThreadContext *tc, Handle handle)
RetErrno callReadC(ThreadContext *tc)
RetErrno callExitExtended(ThreadContext *tc, uint64_t code, uint64_t subcode)
const time_t timeBase
Base time when the simulation started.
RetErrno callExit64(ThreadContext *tc, uint64_t code, uint64_t subcode)
static Arg get(ThreadContext *tc, ArmSemihosting::Abi64::State &state)
RetErrno callClose(ThreadContext *tc, Handle handle)
constexpr RegId R1(IntRegClass, _R1Idx)
Bitfield< 31, 29 > format
int64_t write(const uint8_t *buffer, uint64_t size) override
Write data to file.
SemiCall(const char *_name, Implementation< Args32... > impl32, Implementation< Args64... > impl64)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
ArmSemihosting(const ArmSemihostingParams &p)
const char * name
Call name.
void serialize(CheckpointOut &cp) const override
Serialize an object.
void write(ThreadContext *tc, uint64_t val, ByteOrder endian)
RetErrno callRemove(ThreadContext *tc, Addr name_base, size_t name_size)
Internal state for open files.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
std::function< std::string(ThreadContext *tc)> Dumper
uint64_t semiTick(Tick tick) const
static const std::map< uint64_t, const char * > exitCodes
RetErrno callIsTTY(ThreadContext *tc, Handle handle)
Tick Frequency
The simulated frequency of curTick(). (In ticks per second)
int64_t close() override
Close the file.
std::pair< uint64_t, SemiErrno > RetErrno
static PortProxy & portProxy(ThreadContext *tc)
ByteOrder byteOrder(const ThreadContext *tc)
RetErrno callHeapInfo32(ThreadContext *tc, Addr block_addr)
SemiCall(const char *_name, Implementation< Args... > common)
Implementation of the ':semihosting-features' magic file.
RetErrno callErrno(ThreadContext *tc)
File(ArmSemihosting &_parent, const char *name, const char *mode)
void semiExit(uint64_t code, uint64_t subcode)
bool isTTY() const override
Check if a file corresponds to a TTY device.
void serialize(CheckpointOut &cp) const override
Serialize an object.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool call32(ThreadContext *tc, bool gem5_ops)
Perform an Arm Semihosting call from aarch32 code.
FileFeatures(ArmSemihosting &_parent, const char *name, const char *mode)
virtual int64_t close()
Close the file.
static void store(ThreadContext *tc, const ArmSemihosting::RetErrno &err)
RetErrno callIsError(ThreadContext *tc, int64_t status)
int64_t read(uint8_t *buffer, uint64_t size) override
Read data from file.
RetErrno callSystem(ThreadContext *tc, Addr cmd_addr, size_t cmd_size)
RetErrno callGem5PseudoOp64(ThreadContext *tc, uint64_t encoded_func)
Basic support for object serialization.
RetErrno callGetCmdLine(ThreadContext *tc, Addr addr, InPlaceArg size_arg)
std::function< RetErrno(ArmSemihosting *sh, ThreadContext *tc)> Dispatcher
RetErrno callExit32(ThreadContext *tc, InPlaceArg code)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
RetErrno callWrite(ThreadContext *tc, Handle handle, Addr buffer, size_t size)
static Dispatcher buildDispatcher(Implementation< Args... > impl)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual std::string name() const
static const std::vector< const char * > fmodes
int64_t seek(uint64_t pos) override
Seek to an absolute position in the file.
static RetErrno retError(SemiErrno e)
uint64_t Tick
Tick count type.
const unsigned tickShift
Number of bits to right shift gem5 ticks to fit in a uint32_t.
static ArmSemihosting::InPlaceArg get(ThreadContext *tc, typename Abi::State &state)
T read(Addr address) const
Read sizeof(T) bytes from address and return as object T.
std::string dumpSimcall(std::string name, ThreadContext *tc, std::function< Ret(ThreadContext *, Args...)> target=std::function< Ret(ThreadContext *, Args...)>())
static RetErrno retOK(uint64_t r)
void serialize(CheckpointOut &cp) const override
Serialize an object.
RetErrno(ArmSemihosting::*)(ThreadContext *tc, Args... args) Implementation
InPlaceArg(Addr _addr, size_t _size)
RetErrno callRead(ThreadContext *tc, Handle handle, Addr buffer, size_t size)
FileBase(ArmSemihosting &_parent, const char *name, const char *_mode)
static void store(ThreadContext *tc, const ArmSemihosting::RetErrno &err)
This object is a proxy for a port or other object which implements the functional response protocol,...
void unrecognizedCall(ThreadContext *tc, const char *format, uint64_t op)
int64_t flen() override
Get the length of a file in bytes.
State(const ThreadContext *tc)
uint64_t read(ThreadContext *tc, ByteOrder endian)
StateBase(const ThreadContext *tc, Addr arg_pointer)
constexpr RegId R0(IntRegClass, _R0Idx)
RetErrno callGem5PseudoOp32(ThreadContext *tc, uint32_t encoded_func)
RetErrno callElapsed32(ThreadContext *tc, InPlaceArg low, InPlaceArg high)
Abstract superclass for simulation objects.
State(const ThreadContext *tc)
bool call64(ThreadContext *tc, bool gem5_ops)
Perform an Arm Semihosting call from aarch64 code.
RetErrno callWrite0(ThreadContext *tc, InPlaceArg str)
void serialize(CheckpointOut &cp) const override
Serialize an object.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
int64_t read(uint8_t *buffer, uint64_t size) override
Read data from file.
RetErrno callTime(ThreadContext *tc)
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
RetErrno callSeek(ThreadContext *tc, Handle handle, uint64_t pos)
const std::string cmdLine
Semihosting for AArch32 and AArch64.
virtual int64_t flen()
Get the length of a file in bytes.
static std::unique_ptr< FileBase > create(ArmSemihosting &parent, const std::string &fname, const char *mode)
static FILE * getSTDIO(const char *stream_name, const std::string &name, const char *mode)
virtual int64_t read(uint8_t *buffer, uint64_t size)
Read data from file.
RetErrno callElapsed64(ThreadContext *tc, InPlaceArg ticks)
RetErrno callTickFreq(ThreadContext *tc)
virtual int64_t seek(uint64_t pos)
Seek to an absolute position in the file.
static Arg get(ThreadContext *tc, ArmSemihosting::Abi32::State &state)
std::string readString(ThreadContext *tc, Addr ptr, size_t len)
virtual bool isTTY() const
Check if a file corresponds to a TTY device.
RetErrno callWriteC(ThreadContext *tc, InPlaceArg c)
void gatherHeapInfo(ThreadContext *tc, bool aarch64, Addr &heap_base, Addr &heap_limit, Addr &stack_base, Addr &stack_limit)
unsigned calcTickShift() const
static const std::map< const std::string, FILE * > stdioMap
Arg get(ThreadContext *tc)
static Dumper buildDumper(const char *name, Implementation< Args... > impl)
static const std::map< uint32_t, SemiCall > calls
int64_t seek(uint64_t pos) override
Seek to an absolute position in the file.
virtual int64_t write(const uint8_t *buffer, uint64_t size)
Write data to file.
RetErrno callHeapInfo64(ThreadContext *tc, Addr block_addr)
constexpr int findMsbSet(uint64_t val)
Returns the bit position of the MSB that is set in the input.
std::ostream CheckpointOut
int64_t open() override
Open the the file.
static const std::vector< uint8_t > features
static std::function< RetErrno(ThreadContext *tc, Args... args)> wrapImpl(ArmSemihosting *sh, Implementation< Args... > impl)
RetErrno callClock(ThreadContext *tc)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
RetErrno callRename(ThreadContext *tc, Addr from_addr, size_t from_size, Addr to_addr, size_t to_size)
int64_t openImpl(bool unserialize)
Semihosting call information structure.
RetErrno callTmpNam(ThreadContext *tc, Addr buffer, uint64_t id, size_t size)
RetErrno callOpen(ThreadContext *tc, const Addr name_base, int fmode, size_t name_size)
virtual int64_t open()
Open the the file.
struct IsAapcs64Hfa< E[N], typename std::enable_if_t< std::is_floating_point_v< E > &&N<=4 > > :public std::true_type{};template< typename T >constexpr bool IsAapcs64HfaV=IsAapcs64Hfa< T >::value;template< typename T, typename Enabled=void >struct IsAapcs64Hva :public std::false_type {};template< typename E, size_t N >struct IsAapcs64Hva< E[N], typename std::enable_if_t< IsAapcs64ShortVectorV< E > &&N<=4 > > :public std::true_type{};template< typename T >constexpr bool IsAapcs64HvaV=IsAapcs64Hva< T >::value;template< typename T, typename Enabled=void >struct IsAapcs64Hxa :public std::false_type {};template< typename T >struct IsAapcs64Hxa< T, typename std::enable_if_t< IsAapcs64HfaV< T >||IsAapcs64HvaV< T > > > :public std::true_type{};template< typename T >constexpr bool IsAapcs64HxaV=IsAapcs64Hxa< T >::value;struct Aapcs64ArgumentBase{ template< typename T > static T loadFromStack(ThreadContext *tc, Aapcs64::State &state) { size_t align=std::max< size_t >(8, alignof(T));size_t size=roundUp(sizeof(T), 8);state.nsaa=roundUp(state.nsaa, align);ConstVPtr< T > val(state.nsaa, tc);state.nsaa+=size;return gtoh(*val, ArmISA::byteOrder(tc));}};template< typename Float >struct Argument< Aapcs64, Float, typename std::enable_if_t< std::is_floating_point_v< Float >||IsAapcs64ShortVectorV< Float > > > :public Aapcs64ArgumentBase{ static Float get(ThreadContext *tc, Aapcs64::State &state) { if(state.nsrn<=state.MAX_SRN) { RegId id(VecRegClass, state.nsrn++);ArmISA::VecRegContainer vc;tc->getReg(id, &vc);return vc.as< Float >()[0];} return loadFromStack< Float >(tc, state);}};template< typename Float >struct Result< Aapcs64, Float, typename std::enable_if_t< std::is_floating_point_v< Float >||IsAapcs64ShortVectorV< Float > > >{ static void store(ThreadContext *tc, const Float &f) { RegId id(VecRegClass, 0);ArmISA::VecRegContainer reg;tc-> getReg(id, ®)
#define panic(...)
This implements a cprintf based panic() function.
virtual void setReg(const RegId ®, RegVal val)
std::vector< std::unique_ptr< FileBase > > files
Generated on Thu Jul 28 2022 13:32:24 for gem5 by  doxygen 1.8.17