This constrains the location of system memory (stack and heap) for a kernel to a specific address on a specific tile. The address can be specified in one of two different ways:
- Column, row, bankId and offset, where the tile is specified by column, row, bankId and the offset address is relative to the bankId, starting at zero with a maximum value of 8192 bytes of a bank.
- Column, row, and bankId, where the
bankId
is relative to the tile and can take values 0, 1, 2, 3.Note: The hardware view is 8 banks of 128-bit width. The software view is 4 banks of 256 width.
Syntax
"reserved_memory": <bank_address>
<bank_address> ::= {
"column": integer,
"row": integer,
"bankId": integer,
"offset": integer
}
<bank_address> ::= {
"column": integer,
"row": integer,
"bankId": integer
}
Example
{
"NodeConstraints": {
"mygraph.k1": {
"reserved_memory": {
"column": 2,
"row": 1,
"bankId": 3,
"offset": 4128
}
},
"mygraph.k2": {
"reserved_memory": {
"column": 1,
"row": 1,
"bankId": 3
}
}
}
}