Go to the documentation of this file.
37 #include "debug/HSADriver.hh"
42 #include "params/HSADriver.hh"
60 auto device_fd_entry = std::make_shared<DeviceFDEntry>(
this,
filename);
61 int tgt_fd = process->fds->allocFD(device_fd_entry);
71 int tgt_flags,
int tgt_fd, off_t
offset)
74 bool is_event_mmap =
false;
76 bool should_mmap = (start == 0);
84 "offset: 0x%x, )\n", start, length,
offset);
86 "Start address should be provided by KFD\n");
88 "Requested length %d, expected length %d; length mismatch\n",
94 "offset: 0x%x)\n", start, length,
offset);
100 start = mem_state->getMmapEnd() - length;
101 mem_state->setMmapEnd(start);
133 fatal(
"%s: Exceeded maximum number of HSA queues allowed\n",
name());
146 return "DriverWakeupEvent";
153 driver->schedule(
this,
curTick() + wakeup_delay);
160 "Trying wakeup on an event that is not yet created\n");
161 if (
ETable[event_id].threadWaiting) {
163 "No thread context to wake up\n");
166 "Signal event: Waking up CPU %d\n", tc->
cpuId());
179 ETable[event_id].setEvent =
true;
187 "Timer event: Waking up CPU %d\n", tc->cpuId());
191 driver->TCEvents[tc].clearEvents();
#define fatal(...)
This implements a cprintf based fatal() function.
#define KFD_SIGNAL_EVENT_LIMIT
uint64_t read_pointer_address
virtual void activate()=0
Set the status to Active.
const std::string & filename
filename for opening this driver (under /dev)
uint64_t Tick
Tick count type.
void scheduleWakeup(Tick wakeup_delay)
virtual Process * getProcessPtr()=0
HSADriver(const HSADriverParams &p)
void setDeviceQueueDesc(uint64_t hostReadIndexPointer, uint64_t basePointer, uint64_t queue_id, uint32_t size)
#define KFD_MMAP_TYPE_MASK
std::unordered_map< ThreadContext *, EventList > TCEvents
EmulatedDriver is an abstract base class for fake SE-mode device drivers.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
uint64_t ring_base_address
const char * description() const override
Return a C string describing the event.
virtual int cpuId() const =0
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
#define KFD_MMAP_TYPE_EVENTS
virtual const std::string name() const
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
HSAPacketProcessor & hsaPacketProc()
virtual void signalWakeupEvent(uint32_t event_id)
Tick curTick()
The universal simulation clock.
std::unordered_map< uint32_t, ETEntry > ETable
HSADevice * device
HSA agent (device) that is controled by this driver.
void allocateQueue(ThreadContext *tc, Addr ioc_buf)
Forward relevant parameters to packet processor; queueID is used to link doorbell.
Addr mmap(ThreadContext *tc, Addr start, uint64_t length, int prot, int tgt_flags, int tgt_fd, off_t offset)
Currently, mmap() will simply setup a mapping for the associated device's packet processor's doorbell...
std::shared_ptr< MemState > memState
int open(ThreadContext *tc, int mode, int flags)
Create an FD entry for the KFD inside of the owning process.
Generated on Tue Mar 23 2021 19:41:26 for gem5 by doxygen 1.8.17