38#ifndef __ARCH_ARM_SEMIHOSTING_HH__
39#define __ARCH_ARM_SEMIHOSTING_HH__
59struct ArmSemihostingParams;
95 template <
typename Arg>
147 StateBase<uint64_t>(tc, tc->getReg(ArmISA::int_reg::X1))
161 StateBase<uint64_t>(tc, tc->getReg(ArmISA::int_reg::R1))
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;
599std::ostream &operator << (
605template <
typename Arg>
607 typename std::enable_if_t<std::is_integral_v<Arg>>>
612 return state.get(tc);
616template <
typename Arg>
618 typename std::enable_if_t<std::is_integral_v<Arg>>>
623 if (std::is_signed_v<Arg>)
624 return sext<32>(
state.get(tc));
626 return state.get(tc);
630template <
typename Abi>
632 std::is_base_of_v<ArmSemihosting::AbiBase, Abi>>>
638 state.getAddr(),
sizeof(
typename Abi::State::ArgType));
State(const ThreadContext *tc)
State(const ThreadContext *tc)
StateBase(const ThreadContext *tc, Addr arg_pointer)
Arg get(ThreadContext *tc)
Internal state for open files.
FileBase(FileBase &)=delete
virtual bool isTTY() const
Check if a file corresponds to a TTY device.
virtual int64_t seek(uint64_t pos)
Seek to an absolute position in the file.
virtual int64_t write(const uint8_t *buffer, uint64_t size)
Write data to file.
FileBase(ArmSemihosting &_parent, const char *name, const char *_mode)
virtual int64_t read(uint8_t *buffer, uint64_t size)
Read data from file.
virtual int64_t flen()
Get the length of a file in bytes.
virtual int64_t close()
Close the file.
virtual int64_t open()
Open the the file.
void serialize(CheckpointOut &cp) const override
Serialize an object.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
static std::unique_ptr< FileBase > create(ArmSemihosting &parent, const std::string &fname, const char *mode)
const std::string & fileName()
Implementation of the ':semihosting-features' magic file.
int64_t seek(uint64_t pos) override
Seek to an absolute position in the file.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
int64_t read(uint8_t *buffer, uint64_t size) override
Read data from file.
void serialize(CheckpointOut &cp) const override
Serialize an object.
int64_t open() override
Open the the file.
int64_t openImpl(bool unserialize)
int64_t write(const uint8_t *buffer, uint64_t size) override
Write data to file.
int64_t seek(uint64_t pos) override
Seek to an absolute position in the file.
int64_t close() override
Close the file.
void serialize(CheckpointOut &cp) const override
Serialize an object.
bool isTTY() const override
Check if a file corresponds to a TTY device.
int64_t read(uint8_t *buffer, uint64_t size) override
Read data from file.
int64_t flen() override
Get the length of a file in bytes.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Semihosting for AArch32 and AArch64.
std::pair< uint64_t, SemiErrno > RetErrno
void serialize(CheckpointOut &cp) const override
Serialize an object.
RetErrno callSeek(ThreadContext *tc, Handle handle, uint64_t pos)
RetErrno callReadC(ThreadContext *tc)
static const std::map< uint32_t, SemiCall > calls
unsigned calcTickShift() const
RetErrno callSystem(ThreadContext *tc, Addr cmd_addr, size_t cmd_size)
RetErrno callExitExtended(ThreadContext *tc, uint64_t code, uint64_t subcode)
RetErrno callRename(ThreadContext *tc, Addr from_addr, size_t from_size, Addr to_addr, size_t to_size)
RetErrno callClock(ThreadContext *tc)
bool call32(ThreadContext *tc, bool gem5_ops)
Perform an Arm Semihosting call from aarch32 code.
RetErrno callTickFreq(ThreadContext *tc)
RetErrno callWriteC(ThreadContext *tc, InPlaceArg c)
RetErrno callTime(ThreadContext *tc)
static const std::map< const std::string, FILE * > stdioMap
const unsigned tickShift
Number of bits to right shift gem5 ticks to fit in a uint32_t.
static RetErrno retOK(uint64_t r)
RetErrno callGetCmdLine(ThreadContext *tc, Addr addr, InPlaceArg size_arg)
RetErrno callIsError(ThreadContext *tc, int64_t status)
void gatherHeapInfo(ThreadContext *tc, bool aarch64, Addr &heap_base, Addr &heap_limit, Addr &stack_base, Addr &stack_limit)
static PortProxy & portProxy(ThreadContext *tc)
std::string readString(ThreadContext *tc, Addr ptr, size_t len)
RetErrno callWrite0(ThreadContext *tc, InPlaceArg str)
bool call64(ThreadContext *tc, bool gem5_ops)
Perform an Arm Semihosting call from aarch64 code.
RetErrno callElapsed64(ThreadContext *tc, InPlaceArg ticks)
void semiExit(uint64_t code, uint64_t subcode)
const time_t timeBase
Base time when the simulation started.
static FILE * getSTDIO(const char *stream_name, const std::string &name, const char *mode)
void unrecognizedCall(ThreadContext *tc, const char *format, uint64_t op)
static const std::map< uint64_t, const char * > exitCodes
void unserialize(CheckpointIn &cp) override
Unserialize an object.
RetErrno callRemove(ThreadContext *tc, Addr name_base, size_t name_size)
RetErrno callFLen(ThreadContext *tc, Handle handle)
RetErrno callIsTTY(ThreadContext *tc, Handle handle)
RetErrno callClose(ThreadContext *tc, Handle handle)
RetErrno callHeapInfo64(ThreadContext *tc, Addr block_addr)
std::vector< std::unique_ptr< FileBase > > files
RetErrno callExit64(ThreadContext *tc, uint64_t code, uint64_t subcode)
RetErrno callGem5PseudoOp32(ThreadContext *tc, uint32_t encoded_func)
RetErrno callTmpNam(ThreadContext *tc, Addr buffer, uint64_t id, size_t size)
RetErrno callRead(ThreadContext *tc, Handle handle, Addr buffer, size_t size)
static const std::vector< uint8_t > features
RetErrno callHeapInfo32(ThreadContext *tc, Addr block_addr)
uint64_t semiTick(Tick tick) const
static const std::vector< const char * > fmodes
RetErrno callWrite(ThreadContext *tc, Handle handle, Addr buffer, size_t size)
RetErrno callGem5PseudoOp64(ThreadContext *tc, uint64_t encoded_func)
RetErrno callExit32(ThreadContext *tc, InPlaceArg code)
RetErrno callOpen(ThreadContext *tc, const Addr name_base, int fmode, size_t name_size)
static RetErrno retError(SemiErrno e)
RetErrno callElapsed32(ThreadContext *tc, InPlaceArg low, InPlaceArg high)
RetErrno callErrno(ThreadContext *tc)
const std::string cmdLine
virtual std::string name() const
This object is a proxy for a port or other object which implements the functional response protocol,...
T read(Addr address) const
Read sizeof(T) bytes from address and return as object T.
Basic support for object serialization.
Abstract superclass for simulation objects.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual void setReg(const RegId ®, RegVal val)
constexpr int findMsbSet(uint64_t val)
Returns the bit position of the MSB that is set in the input.
#define panic(...)
This implements a cprintf based panic() function.
ByteOrder byteOrder(const ThreadContext *tc)
Bitfield< 31, 29 > format
Tick Frequency
The simulated frequency of curTick(). (In ticks per second)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::string dumpSimcall(std::string name, ThreadContext *tc, std::function< Ret(ThreadContext *, Args...)> target=std::function< Ret(ThreadContext *, Args...)>())
std::ostream CheckpointOut
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
uint64_t Tick
Tick count type.
PortProxy Object Declaration.
uint64_t read(ThreadContext *tc, ByteOrder endian)
InPlaceArg(Addr _addr, size_t _size)
void write(ThreadContext *tc, uint64_t val, ByteOrder endian)
Semihosting call information structure.
SemiCall(const char *_name, Implementation< Args32... > impl32, Implementation< Args64... > impl64)
SemiCall(const char *_name, Implementation< Args... > common)
std::function< RetErrno(ArmSemihosting *sh, ThreadContext *tc)> Dispatcher
std::function< std::string(ThreadContext *tc)> Dumper
static Dispatcher buildDispatcher(Implementation< Args... > impl)
static std::function< RetErrno(ThreadContext *tc, Args... args)> wrapImpl(ArmSemihosting *sh, Implementation< Args... > impl)
const char * name
Call name.
RetErrno(ArmSemihosting::*)(ThreadContext *tc, Args... args) Implementation
static Dumper buildDumper(const char *name, Implementation< Args... > impl)
static ArmSemihosting::InPlaceArg get(ThreadContext *tc, typename Abi::State &state)
static Arg get(ThreadContext *tc, ArmSemihosting::Abi32::State &state)
static Arg get(ThreadContext *tc, ArmSemihosting::Abi64::State &state)
static void store(ThreadContext *tc, const ArmSemihosting::RetErrno &err)
static void store(ThreadContext *tc, const ArmSemihosting::RetErrno &err)