1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
<!---======================= begin_copyright_notice ============================
Copyright (C) 2020-2021 Intel Corporation
SPDX-License-Identifier: MIT
============================= end_copyright_notice ==========================-->
## Opcode
URB_WRITE = 0x72
## Format
| | | | | | | |
| --- | --- | --- | --- | --- | --- | --- |
| 0x72(URB_WRITE) | Exec_size | Pred | Num_out | Channel_mask | Global_offset | URB_handle |
| | Per_slot_offset | Vertex_data | | | | |
## Semantics
Write to the Unified Resource Buffer (URB)
## Description
- **Exec_size(ub):** Execution size
- Bit[2..0]: size of the region for source and destination operands
- 0b011: 8 elements
- Bit[7..4]: execution mask (explicit control over the enabled channels)
- 0b0000: M1
- 0b0001: M2
- 0b0010: M3
- 0b0011: M4
- 0b0100: M5
- 0b0101: M6
- 0b0110: M7
- 0b0111: M8
- 0b1000: M1_NM
- 0b1001: M2_NM
- 0b1010: M3_NM
- 0b1011: M4_NM
- 0b1100: M5_NM
- 0b1101: M6_NM
- 0b1110: M7_NM
- 0b1111: M8_NM
- **Pred(uw):** Predication control
- **Num_out(ub):**
- Bit[2..0]: specifies the number of output parameters. Valid values are [1-8]
- **Channel_mask(raw_operand):** First 8 elements represent the 8-bit channel mask for each vertex. 1 means the corresponding channel will be written, 0 means not. Should be set to V0 if all channels are on. Must have type UD
- **Global_offset(uw):** global offset to each URB handle in 128-bit units. Valid values are [0-2047]
- **URB_handle(raw_operand):** First 8 elements represent the URB handles where each channel's results are written to. Must have type UD
- **Per_slot_offset(raw_operand):** First 8 elements represent the per-slot offset to each URB handle, in 128-bit units. Must be set to V0 if per-slot offset is not used. Must have type UD. Valid values are [0-2047]
- **Vertex_data(raw_operand):** num_out GRFs from the operands are written to the URB subject to the channel mask. Each GRF represents an output parameter, and each dword in the GRF stores the value of the corresponding vertex. Must have type UD,D,F
#### Properties
## Text
```
[(<P>)] URB_WRITE (M1, 8) <num_out> <global_offset> <channel_mask> <URB_handle> <per_slot_offset> <vertex_data>
//<channel_mask> is an integer representing the bit mask value
```
## Notes
|