Documentation ¶
Overview ¶
Package cp defines the Command Processor component of a GCN3 GPU
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Builder ¶
type Builder struct {
// contains filtered or unexported fields
}
Builder can build Command Processors
func MakeBuilder ¶
func MakeBuilder() Builder
MakeBuilder creates a new builder with default configuration values.
func (Builder) Build ¶
func (b Builder) Build(name string) *CommandProcessor
Build builds a new Command Processor
func (Builder) WithEngine ¶
WithEngine sets the even-driven simulation engine to use.
func (Builder) WithMonitor ¶
func (b Builder) WithMonitor(monitor *monitoring.Monitor) Builder
WithMonitor sets the monitor used to show progress bars.
type CUInterfaceForCP ¶
type CUInterfaceForCP interface { resource.DispatchableCU // ControlPort returns a port on the CU that the CP can send controlling // messages to. ControlPort() sim.Port }
CUInterfaceForCP defines the interface that a CP requires from CU.
type CommandProcessor ¶
type CommandProcessor struct { *sim.TickingComponent Dispatchers []dispatching.Dispatcher DMAEngine sim.Port Driver sim.Port TLBs []sim.Port CUs []sim.Port AddressTranslators []sim.Port RDMA sim.Port PMC sim.Port L1VCaches []sim.Port L1SCaches []sim.Port L1ICaches []sim.Port L2Caches []sim.Port DRAMControllers []*idealmemcontroller.Comp ToDriver sim.Port ToDMA sim.Port ToCUs sim.Port ToTLBs sim.Port ToAddressTranslators sim.Port ToCaches sim.Port ToRDMA sim.Port ToPMC sim.Port // contains filtered or unexported fields }
CommandProcessor is an Akita component that is responsible for receiving requests from the driver and dispatch the requests to other parts of the GPU.
func (*CommandProcessor) RegisterCU ¶
func (p *CommandProcessor) RegisterCU(cu CUInterfaceForCP)
RegisterCU allows the Command Processor to control the CU.
type DMAEngine ¶
type DMAEngine struct { *sim.TickingComponent Log2AccessSize uint64 ToCP sim.Port ToMem sim.Port // contains filtered or unexported fields }
A DMAEngine is responsible for accessing data that does not belongs to the GPU that the DMAEngine works in.
func NewDMAEngine ¶
func NewDMAEngine( name string, engine sim.Engine, localDataSource mem.LowModuleFinder, ) *DMAEngine
NewDMAEngine creates a DMAEngine, injecting a engine and a "LowModuleFinder" that helps with locating the module that holds the data.
func (*DMAEngine) SetLocalDataSource ¶
func (dma *DMAEngine) SetLocalDataSource(s mem.LowModuleFinder)
SetLocalDataSource sets the table that maps from addresses to port that can provide the data.
Directories ¶
Path | Synopsis |
---|---|
internal
|
|
dispatching
Package dispatching defines how work-groups and wavefronts are dispatched to compute units.
|
Package dispatching defines how work-groups and wavefronts are dispatched to compute units. |
resource
Package resource manages the Compute Unit resources
|
Package resource manages the Compute Unit resources |