The user application must transfer each request to be transmitted on the link to the requester request interface of the core as an independent AXI4-Stream packet. Each packet must start with a descriptor, and can have payload data following the descriptor. The descriptor is always 16 bytes long, and must be sent in the first 16 bytes of the request packet. The descriptor is transferred during the first two beats on a 64-bit interface, and in the first beat on a 128-bit or 256-bit interface. The formats of the descriptor for different request types are illustrated in the following figures.
The format of the following figure applies when the request TLP being transferred is a memory read/write request, an I/O read/write request, or an Atomic Operation request.
The format in the following figure is used for Configuration Requests.
The format of the following figure is used for Vendor-Defined Messages (Type 0 or Type 1) only.
The format of the following figure is used for all ATS messages (Invalid Request, Invalid Completion, Page Request, PRG Response).
For all other messages, the descriptor takes the format of the following figure.
The following tables describe the individual fields of the requester request descriptor.
Bit Index | Field Name | Description |
---|---|---|
1:0 | Address Type |
This field is defined for memory transactions and Atomic Operations only. The core copies this field into the AT of the TL header of the request TLP. 00: Address in the request is un-translated 01: Transaction is a translation request 10: Address in the request is a translated address 11: Reserved |
63:2 | Address |
This field applies to memory, I/O and atomic operation requests. This is the address of the first Dword referenced by the request. The client must also set the First_BE and Last_BE bits in s_axis_rq_tuser to indicate the valid bytes in the first and last Dwords, respectively. When the transaction specifies a 32-bit address, bits [63:32] of this field must be set to 0. When Address Type is 01b (Translation Request), Address [11:2] is Reserved and should be driven to 0. |
74:64 | Dword Count |
These 11 bits indicate the size of the block (in Dwords) to be read or written (for messages, size of the message payload). Its range is 0 – 1024 Dwords. For I/O accesses, the Dword count will always be 1. For memory read requests, Dword count is in the range 1-1024. For a zero length memory read/write request, the Dword count must be 1 with the First_BE bits set to all zeroes. The integrated block does not check the setting of this field against the actual length of the payload supplied (for requests with payload), nor against the maximum payload size or read request size settings of the integrated block. |
78:75 | Request Type | Identifies the transaction type. The transaction types and their encodings are listed in Table 6. |
79 | Poisoned Request | This bit can be used by the client to poison the request TLP being sent. This feature is supported on all request types except - Type 0 or 1 Configuration Write Request. This bit must be set to 0 for all requests, except when the client has detected an error in the block of data following the descriptor and wants to communicate this information using the Data Poisoning feature of PCI Express. |
87:80 |
Requester Function/Device Number or Function ID[7:0] |
Device and/or Function number of the Requester Function. Endpoint mode:
Upstream Port for Switch use case (Endpoint mode is selected within the IP):
Root Port mode (Downstream Port):
|
95:88 |
Requester Bus Number or {{3{Reserved}}, Function ID[12:8]} |
Bus number associated with the Requester Function. Endpoint mode:
Root Port mode (Downstream Port): Must be set to the Requester Bus number. This is used with Requester ID Enable bit in the descriptor. |
103:96 | Tag |
PCIe Tag associated
with the request. For posted transactions, the core always uses the
value from this field as the tag for the request. For
Non-Posted transactions, the core uses the value from this field if
the attribute |
119:104 | Completer ID | This field is applicable only to Configuration requests and messages routed by ID. For these requests, this field specifies the PCI Completer ID associated with the request (these 16 bits are divided into an 8-bit bus number, 5-bit device number, and 3-bit function number in the legacy interpretation mode. In the ARI mode, these 16 bits are treated as an 8-bit bus number and 8-bit Function number). |
120 | Requester ID Enable | The purpose of this field is to enable the user logic to supply the bus and device numbers to be used in the Requester ID. This field is applicable only to Endpoint cores. If this field is 0, the core uses the captured values of the bus and device numbers to form the Requester ID. If this input is 1, the core uses the bus and device numbers supplied by the user logic in the descriptor to form the Requester ID. |
123:121 | Transaction Class (TC) | PCIe Transaction Class (TC) associated with the request. |
126:124 | Attributes |
These bits provide the setting of the attribute bits associated with the request. Bit-124 is the No Snoop bit and bit 125 is the Relaxed Ordering bit. Bit-126 is the ID-Based Ordering bit, it can be set only for memory requests and messages. The core forces the attribute bits to 0 in the request sent on the link if the corresponding attribute is not enabled in the Function’s PCI Express Device Control Register. |
127 | Force ECRC | Force ECRC insertion. Setting this bit to 1 forces the core to append a TLP Digest containing ECRC to the Completion TLP, even when ECRC is not enabled for the Function sending the Completion. |
Bit Index | Field Name | Description |
---|---|---|
1:0 | Reserved | These bits are reserved. |
7:2 | Reg Number | This field specifies the register number targeted by the configuration request. |
11:8 | Extended Reg Number | This field specifies the extended bits for the register number targeted by the configuration request, if applicable. |
63:12 | Reserved | These bits are reserved. |
74:64 | Dword Count |
These 11 bits indicate the size of the block (in Dwords) to be read or written (for messages, size of the message payload). Its range is 0 – 1024 Dwords. For I/O accesses, the Dword count will always be 1. For memory read requests Dword count is in the range 1-1024. For a zero length memory read/write request, the Dword count must be 1, with the First_BE bits set to all zeroes. The integrated block does not check the setting of this field against the actual length of the payload supplied (for requests with payload), nor against the maximum payload size or read request size settings of the integrated block. |
78:75 | Request Type |
Identifies the transaction type. The transactions types and their encodings are listed in Table 6. |
79 | Poisoned Request | This bit can be used by the client to poison the request TLP being sent. This feature is supported in all request types except in Type 0 or 1 Configuration Write Request. This bit must be set to 0 for all requests, except when the client has detected an error in the block of data following the descriptor and wants to communicate this information using the Data Poisoning feature of PCI Express. |
87:80 |
Requester Function/Device Number or Function ID[7:0] |
Device and/or Function number of the Requester Function. Endpoint mode: ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used Upstream Port for Switch use case (Endpoint mode is selected within the IP): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used if the request is originating from the switch itself. These bits must be set to the Requester Device number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used in with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [87:80] must be set to the Requester Function number. Bits [87:83] must be set to the Requester Device number. This is used with Requester ID Enable bit in the descriptor. |
95:88 |
Requester Bus Number or {{3{Reserved}}, Function ID[12:8]} |
Bus number associated with the Requester Function. Endpoint mode: Lower 5 bits of this field are set to the Function ID[12:8]. Remaining 3 bits are reserved for future use. Upstream Port for Switch use case (Endpoint mode is selected within the IP): Not used if the request is originating from the switch itself. These bits must be set to the Requester Bus number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): Must be set to the Requester Bus number. This is used with Requester ID Enable bit in the descriptor. |
103:96 | Tag |
PCIe Tag associated
with the request. For posted transactions, the core always uses the
value from this field as the tag for the request. For
Non-Posted transactions, the core uses the value from this field if
the attribute |
119:104 | Completer ID | This field is applicable only to Configuration requests and messages routed by ID. For these requests, this field specifies the PCI Completer ID associated with the request (these 16 bits are divided into an 8-bit bus number, 5-bit device number, and 3-bit function number in the legacy interpretation mode. In the ARI mode, these 16 bits are treated as an 8-bit bus number and 8-bit Function number). |
120 | Requester ID Enable | The purpose of this field is to enable the user logic to supply the bus and device numbers to be used in the Requester ID. This field is applicable only to Endpoint cores. If this field is 0, the core uses the captured values of the bus and device numbers to form the Requester ID. If this input is 1, the core uses the bus and device numbers supplied by the user logic in the descriptor to form the Requester ID. |
123:121 | Transaction Class (TC) | PCIe Transaction Class (TC) associated with the request. |
126:124 | Attributes |
These bits provide the setting of the Attribute bits associated with the request. Bit 124 is the No Snoop bit and bit 125 is the Relaxed Ordering bit. Bit 126 is the ID-Based Ordering bit, and can be set only for memory requests and messages. The core forces the attribute bits to 0 in the request sent on the link if the corresponding attribute is not enabled in the Function’s PCI Express Device Control Register. |
127 | Force ECRC | Force ECRC insertion. Setting this bit to 1 forces the core to append a TLP Digest containing ECRC to the Completion TLP, even when ECRC is not enabled for the Function sending the Completion. |
Bit Index | Field Name | Description |
---|---|---|
15:0 | Destination ID | This field applies to Vendor-Defined Messages only. When the message is routed by ID (that is, when the Message Routing field is 010 binary), this field must be set to the Destination ID of the message. |
31:16 | Vendor ID | This field applies to Vendor-Defined Messages only. It provides the Vendor ID for the message. |
63:32 | Vendor-Defined Header | This field applies to Vendor-Defined Messages only. It is copied into Dword 3 of the TL header. |
74:64 | Dword Count |
These 11 bits indicate the size of the block (in Dwords) to be read or written (for messages, size of the message payload). Its range is 0 – 1024 Dwords. For I/O accesses, the Dword count will always be 1. For memory read requests Dword count is in the range 1-1024. For a zero length memory read/write request, the Dword count must be 1, with the First_BE bits set to all zeroes. The integrated block does not check the setting of this field against the actual length of the payload supplied (for requests with payload), nor against the maximum payload size or read request size settings of the integrated block. |
78:75 | Request Type | Identifies the transaction type. The transactions types and their encodings are listed in Table 6. |
79 | Poisoned Request | This bit can be used by the client to poison the request TLP being sent. This feature is supported on all request types except - Type 0 or 1 Configuration Write Request. This bit must be set to 0 for all requests, except when the client has detected an error in the block of data following the descriptor and wants to communicate this information using the Data Poisoning feature of PCI Express. |
87:80 |
Requester Function/Device Number or Function ID[7:0] |
Device and/or Function number of the Requester Function. Endpoint mode: ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used. Upstream Port for Switch use case (Endpoint mode is selected within the IP): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used if the request is originating from the switch itself. These bits must be set to the Requester Device number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [87:80] must be set to the Requester Function number. Bits [87:83] must be set to the Requester Device number. This is used with Requester ID Enable bit in the descriptor. |
95:88 |
Requester Bus Number or {{3{Reserved}}, Function ID[12:8]} |
Bus number associated with the Requester Function. Endpoint mode: Lower 5 bits of this field are set to the Function ID[12:8]. Remaining 3 bits are reserved for future use Upstream Port for Switch use case (Endpoint mode is selected within the IP): Not used if the request is originating from the switch itself. These bits must be set to the Requester Bus number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): Must be set to the Requester Bus number. This is used with Requester ID Enable bit in the descriptor. |
103:96 | Tag |
PCIe Tag associated
with the request. For posted transactions, the core always uses the
value from this field as the tag for the request. For
Non-Posted transactions, the core will use the value from this field
if the attribute |
111:104 | Message Code | This field is defined for all messages. It contains the 8-bit Message Code to be set in the TL header. |
114:112 | Message Routing | This field is defined for all messages. The core copies these bits into the 3-bit Routing field r[2:0] of the TL header of the Request TLP. |
119:115 | Reserved | These bits are reserved. |
120 | Requester ID Enable | The purpose of this field is to enable the user logic to supply the bus and device numbers to be used in the Requester ID. This field is applicable only to Endpoint cores. If this field is 0, the core uses the captured values of the bus and device numbers to form the Requester ID. If this input is 1, the core uses the bus and device numbers supplied by the user logic in the descriptor to form the Requester ID. |
123:121 | Transaction Class (TC) | PCIe Transaction Class (TC) associated with the request. |
126:124 | Attributes |
These bits provide the setting of the Attribute bits associated with the request. Bit 124 is the No Snoop bit and bit 125 is the Relaxed Ordering bit. Bit 126 is the ID-Based Ordering bit, and can be set only for memory requests and messages. The core forces the attribute bits to 0 in the request sent on the link if the corresponding attribute is not enabled in the Function’s PCI Express Device Control Register. |
127 | Force ECRC | Force ECRC insertion. Setting this bit to 1 forces the core to append a TLP Digest containing ECRC to the Completion TLP, even when ECRC is not enabled for the Function sending the Completion. |
Bit Index | Field Name | Description |
---|---|---|
63:0 | ATS Header | This field is applicable to ATS messages only. It contains the bytes that the core copies into Dwords 2 and 3 of the TL header. |
74:64 | Dword Count |
These 11 bits indicate the size of the block (in Dwords) to be read or written (for messages, size of the message payload). Its range is 0 – 1024 Dwords. For I/O accesses, the Dword count is always 1. For memory read requests Dword count is in the range 1 - 1024. For a zero length memory read/write request, the Dword count must be 1, with the First_BE bits set to all zeroes. The integrated block does not check the setting of this field against the actual length of the payload supplied (for requests with payload), nor against the maximum payload size or read request size settings of the integrated block. |
78:75 | Request Type | Identifies the transaction type. The transactions types and their encodings are listed in Table 6. |
79 | Poisoned Request | This bit can be used by the client to poison the request TLP being sent. This feature is supported on all request types except - Type 0 or 1 Configuration Write Request. This bit must be set to 0 for all requests, except when the client has detected an error in the block of data following the descriptor and wants to communicate this information using the Data Poisoning feature of PCI Express. |
87:80 |
Requester Function/Device Number or Function ID[7:0] |
Device and/or Function number of the Requester Function. Endpoint mode: ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used. Upstream Port for Switch use case (Endpoint mode is selected within the IP): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used if the request is originating from the switch itself. These bits must be set to the Requester Device number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [87:80] must be set to the Requester Function number. Bits [87:83] must be set to the Requester Device number. This is used with Requester ID Enable bit in the descriptor. |
95:88 |
Requester Bus Number or {{3{Reserved}}, Function ID[12:8]} |
Bus number associated with the Requester Function. Endpoint mode: Lower 5 bits of this field are set to the Function ID[12:8]. Remaining 3 bits are reserved for future use Upstream Port for Switch use case (Endpoint mode is selected within the IP): Not used if the request is originating from the switch itself. These bits must be set to the Requester Bus number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): Must be set to the Requester Bus number. This is used with Requester ID Enable bit in the descriptor. |
103:96 | Tag |
PCIe Tag associated
with the request. For posted transactions, the core always uses the
value from this field as the tag for the request. For
Non-Posted transactions, the core will use the value from this field
if the attribute |
111:104 | Message Code | This field is defined for all messages. It contains the 8-bit Message Code to be set in the TL header. |
114:112 | Message Routing | This field is defined for all messages. The core copies these bits into the 3-bit Routing field r[2:0] of the TL header of the Request TLP. |
119:115 | Reserved | These bits are reserved. |
120 | Requester ID Enable | The purpose of this field is to enable the user logic to supply the bus and device numbers to be used in the Requester ID. This field is applicable only to Endpoint cores. If this field is 0, the core uses the captured values of the bus and device numbers to form the Requester ID. If this input is 1, the core uses the bus and device numbers supplied by the user logic in the descriptor to form the Requester ID. |
123:121 | Transaction Class (TC) | PCIe Transaction Class (TC) associated with the request. |
126:124 | Attributes |
These bits provide the setting of the Attribute bits associated with the request. Bit-124 is the No Snoop bit and bit-125 is the Relaxed Ordering bit. Bit-126 is the ID-Based Ordering bit, and can be set only for memory requests and messages. The core forces the attribute bits to 0 in the request sent on the link if the corresponding attribute is not enabled in the Function’s PCI Express Device Control Register. |
127 | Force ECRC | Force ECRC insertion. Setting this bit to 1 forces the core to append a TLP Digest containing ECRC to the Completion TLP, even when ECRC is not enabled for the Function sending the Completion. |
Bit Index | Field Name | Description |
---|---|---|
15:0 | Snoop Latency | This field is defined for LTR messages only, it is reserved for the others. It provides the value of the 16-bit Snoop Latency field in the TL header of the message. |
31:16 | No-Snoop Latency | This field is defined for LTR messages only, it is reserved for the others. It provides the value of the 16-bit No-Snoop Latency field in the TL header of the message. |
35:32 | OBFF Code | This field is defined for OBFF messages only, it is
reserved for the others. The OBFF Code field is used to distinguish
between various OBFF cases: - 1111b : CPU Active – System fully active for all device actions including bus mastering and interrupts - 0001b : OBFF – System memory path available for device memory read/write bus master activities - 0000b Idle – System in an idle, low power state - All other codes are reserved. |
63:36 | Reserved | These bits are reserved |
74:64 | Dword Count |
These 11 bits indicate the size of the block (in Dwords) to be read or written (for messages, size of the message payload). Its range is 0 – 1024 Dwords. For I/O accesses, the Dword count will always be 1. For memory read requests Dword count is in the range 1 - 1024. For a zero length memory read/write request, the Dword count must be 1, with the First_BE bits set to all zeroes. The integrated block does not check the setting of this field against the actual length of the payload supplied (for requests with payload), nor against the maximum payload size or read request size settings of the integrated block. |
78:75 | Request Type | Identifies the transaction type. The transactions types and their encodings are listed in Table 6. |
79 | Poisoned Request | This bit can be used by the client to poison the request TLP being sent. This feature is supported on all request types except - Type 0 or 1 Configuration Write Request. This bit must be set to 0 for all requests, except when the client has detected an error in the block of data following the descriptor and wants to communicate this information using the Data Poisoning feature of PCI Express. |
87:80 |
Requester Function/Device Number or Function ID[7:0] |
Device and/or Function number of the Requester Function. Endpoint mode: ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used. Upstream Port for Switch use case (Endpoint mode is selected within the IP): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [82:80] must be set to the Requester Function number. Bits [87:83] are not used if the request is originating from the switch itself. These bits must be set to the Requester Device number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): ARI enabled: Bits [87:80] must be set to the Requester Function number. ARI disabled: Bits [87:80] must be set to the Requester Function number. Bits [87:83] must be set to the Requester Device number. This is used with Requester ID Enable bit in the descriptor. |
95:88 |
Requester Bus Number or {{3{Reserved}}, Function ID[12:8]} |
Bus number associated with the Requester Function.
Endpoint mode: Lower 5 bits of this field are set to the Function ID[12:8]. Remaining 3 bits are reserved for future use. Upstream Port for Switch use case (Endpoint mode is selected within the IP): Not used if the request is originating from the switch itself. These bits must be set to the Requester Bus number where the request was originated if the switch is relaying the request (Requester is external to the switch). This is used with Requester ID Enable bit in the descriptor. Root Port mode (Downstream Port): Must be set to the Requester Bus number. This is used with Requester ID Enable bit in the descriptor. |
103:96 | Tag |
PCIe Tag associated
with the request. For posted transactions, the core always uses the
value from this field as the tag for the request. For
Non-Posted transactions, the core uses the value from this field if
the attribute |
111:104 | Message Code | This field is defined for all messages. It contains the 8-bit Message Code to be set in the TL header. |
114:112 | Message Routing | This field is defined for all messages. The core copies these bits into the 3-bit Routing field r[2:0] of the TL header of the Request TLP. |
119:115 | Reserved | These bits are reserved. |
120 | Requester ID Enable | The purpose of this field is to enable the user logic to supply the bus and device numbers to be used in the Requester ID. This field is applicable only to Endpoint cores. If this field is 0, the core uses the captured values of the bus and device numbers to form the Requester ID. If this input is 1, the core uses the bus and device numbers supplied by the user logic in the descriptor to form the Requester ID. |
123:121 | Transaction Class (TC) | PCIe Transaction Class (TC) associated with the request. |
126:124 | Attributes |
These bits provide the setting of the Attribute bits associated with the request. Bit 124 is the No Snoop bit and bit 125 is the Relaxed Ordering bit. Bit 126 is the ID-Based Ordering bit, and can be set only for memory requests and messages. The core forces the attribute bits to 0 in the request sent on the link if the corresponding attribute is not enabled in the Function’s PCI Express Device Control Register. |
127 | Force ECRC | Force ECRC insertion. Setting this bit to 1 forces the core to append a TLP Digest containing ECRC to the Completion TLP, even when ECRC is not enabled for the Function sending the Completion. |