gem5 v24.0.0.0
Loading...
Searching...
No Matches
external_slave.hh File Reference

ExternalSlave is a memory object representing a binding from a gem5 requestor to a response port in a system external to gem5. More...

#include "mem/port.hh"
#include "params/ExternalSlave.hh"
#include "sim/sim_object.hh"

Go to the source code of this file.

Classes

class  gem5::ExternalSlave
 
class  gem5::ExternalSlave::ExternalPort
 Derive from this class to create an external port interface. More...
 
class  gem5::ExternalSlave::Handler
 

Namespaces

namespace  gem5
 Copyright (c) 2024 - Pranith Kumar Copyright (c) 2020 Inria All rights reserved.
 

Detailed Description

ExternalSlave is a memory object representing a binding from a gem5 requestor to a response port in a system external to gem5.

During initialisation, a ‘handler’ for the port type specified in the port's port_type parameter is found from the registered port handlers provided with registerHandler. Once a handler is found, it is passed the port_data parameter of the port which can be used to identify the external port which is to be bound to. A port handler will usually construct a bridge object in the external system to accomodate the port-to-port mapping but this bridge is not exposed to gem5 other than be the presentation of the SlavePort which can be bound.

The external port must provide a gem5 SlavePort interface (with the exception of getAddrRanges which is provided by the ExternalSlave object).

Definition in file external_slave.hh.


Generated on Tue Jun 18 2024 16:24:08 for gem5 by doxygen 1.11.0