Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1 | +---------------------------------------------------------------------+ |
| 2 | | Log file: mau.log | |
| 3 | | Compiler version: 5.1.0 (fca32d1) | |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 4 | | Created on: Wed Sep 13 12:56:57 2017 | |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 5 | +---------------------------------------------------------------------+ |
| 6 | |
| 7 | Match Table table0 did not specify the number of entries required. A default value (512) will be used. |
| 8 | Match Entry Table table0 has already been associated with stat Table table0_counter. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 9 | Cannot implement table0 in phase 0 resources because table uses side effect tables. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 10 | Match Table table0 did not specify the number of entries required. A default value (512) will be used. |
| 11 | Match Entry Table table0 has already been associated with stat Table table0_counter. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 12 | Cannot implement table0 in phase 0 resources because table uses side effect tables. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 13 | Match Table table0 did not specify the number of entries required. A default value (512) will be used. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 14 | POV/metadata bridge containers added between ingress/egress: [0] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 15 | Metadata bridge_ingress_intrinsic containers added between ingress/egress: [128] |
| 16 | Match Entry Table table0 has already been associated with stat Table table0_counter. |
| 17 | Match table ingress_port_count_table has no match key fields |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 18 | Match table egress_port_count_table has no match key fields |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 19 | |
| 20 | ########################################## |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 21 | Call to decide_action_data_placement(stage=0, table=process_packet_out_table) |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 22 | ########################################## |
| 23 | |
| 24 | |
| 25 | Max immediate bits used in any action is 0 bits. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 26 | Overhead bit width for table process_packet_out_table is 0 bits. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 27 | Bits available in overhead for non-essential immediate data is 32 bits. |
| 28 | ~~~~~~~~~~~~~~~~~~~~~ |
| 29 | Examining placing 0 bits in match overhead |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 30 | Overhead bit width for table process_packet_out_table is 0 bits. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 31 | Overhead SRAMs to use = 97 |
| 32 | Entries requested = 1024 and match entries get = 0 |
| 33 | ram_size_matrix = |
| 34 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 35 | 0 0 0 0 0 0 0 0 # 0 |
| 36 | |
| 37 | immediate_size_matrix = |
| 38 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 39 | 0 0 0 0 0 0 0 0 # 0 |
| 40 | |
| 41 | hash_to_phv_matrix = |
| 42 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 43 | 0 0 0 0 0 0 0 0 # 0 |
| 44 | |
| 45 | total action ram packing size = [0, 0, 0] |
| 46 | action_ram_packing: |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 47 | action _process_packet_out has [] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 48 | total action ram packing size = [0, 0, 0] |
| 49 | action_ram_packing: |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 50 | action _process_packet_out has [] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 51 | total action ram packing size = [0, 0, 0] |
| 52 | action_ram_packing: |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 53 | action _process_packet_out has [] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 54 | byte_enables = [] |
| 55 | After allocation of 32s, available_slots is [] |
| 56 | final packing is [] |
| 57 | byte_enables = [] |
| 58 | After allocation of 32s, available_slots is [] |
| 59 | final packing is [] |
| 60 | byte_enables = [] |
| 61 | After allocation of 32s, available_slots is [] |
| 62 | final packing is [] |
| 63 | Action Data SRAMs to use = 0 |
| 64 | TODO: Total RAMs use when put 0 bits in match overhead: 97 |
| 65 | TODO: Total RAMs use when put 0 bits in match overhead: 97 |
| 66 | ~~~~~~~~~~~~~~~~~~~~~ |
| 67 | Examining placing 8 bits in match overhead |
| 68 | ~~~~~~~~~~~~~~~~~~~~~ |
| 69 | Examining placing 16 bits in match overhead |
| 70 | ~~~~~~~~~~~~~~~~~~~~~ |
| 71 | Examining placing 24 bits in match overhead |
| 72 | ~~~~~~~~~~~~~~~~~~~~~ |
| 73 | Examining placing 32 bits in match overhead |
| 74 | |
| 75 | ########################################## |
| 76 | |
| 77 | Best Ram Usage is 97 rams |
| 78 | Best Immediate placement is 0 bits |
| 79 | |
| 80 | ########################################## |
| 81 | Call to decide_action_data_placement(stage=0, table=table0) |
| 82 | ########################################## |
| 83 | |
| 84 | |
| 85 | Max immediate bits used in any action is 0 bits. |
| 86 | Overhead bit width for table table0 is 3 bits. |
| 87 | Bits available in overhead for non-essential immediate data is 32 bits. |
| 88 | ~~~~~~~~~~~~~~~~~~~~~ |
| 89 | Examining placing 0 bits in match overhead |
| 90 | Overhead bit width for table table0 is 3 bits. |
| 91 | Overhead SRAMs to use = 1 |
| 92 | Entries requested = 512 and match entries get = 512 |
| 93 | ram_size_matrix = |
| 94 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 95 | 0 0 0 1 0 0 0 0 # 0 |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 96 | 0 0 0 1 0 0 0 0 # 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 97 | 0 0 0 0 0 0 0 0 # 2 |
| 98 | |
| 99 | immediate_size_matrix = |
| 100 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 101 | 0 0 0 0 0 0 0 0 # 0 |
| 102 | 0 0 0 0 0 0 0 0 # 1 |
| 103 | 0 0 0 0 0 0 0 0 # 2 |
| 104 | |
| 105 | hash_to_phv_matrix = |
| 106 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 107 | 0 0 0 0 0 0 0 0 # 0 |
| 108 | 0 0 0 0 0 0 0 0 # 1 |
| 109 | 0 0 0 0 0 0 0 0 # 2 |
| 110 | |
| 111 | total action ram packing size = [16, 0, 0] |
| 112 | action_ram_packing: |
| 113 | action set_egress_port has [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 114 | action send_to_cpu has [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 115 | action _drop has [] |
| 116 | total action ram packing size = [16, 0, 0] |
| 117 | action_ram_packing: |
| 118 | action set_egress_port has [] |
| 119 | action send_to_cpu has [] |
| 120 | action _drop has [] |
| 121 | total action ram packing size = [16, 0, 0] |
| 122 | action_ram_packing: |
| 123 | action set_egress_port has [] |
| 124 | action send_to_cpu has [] |
| 125 | action _drop has [] |
| 126 | byte_enables = [1, 1] |
| 127 | Allocating Action Parameter Bus Byte 32 in stage 0 for Byte 0 of 16-bit constant |
| 128 | Allocating Action Parameter Bus Byte 33 in stage 0 for Byte 1 of 16-bit constant |
| 129 | Allocating Action Parameter Bus Byte 34 in stage 0 for Byte 0 of 16-bit constant |
| 130 | Allocating Action Parameter Bus Byte 35 in stage 0 for Byte 1 of 16-bit constant |
| 131 | After allocation of 32s, available_slots is [(16, 0, 0), (32, 8, 0), (16, 1, 16)] |
| 132 | final packing is [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 133 | final packing is [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 134 | final packing is [] |
| 135 | byte_enables = [] |
| 136 | After allocation of 32s, available_slots is [] |
| 137 | final packing is [] |
| 138 | final packing is [] |
| 139 | final packing is [] |
| 140 | byte_enables = [] |
| 141 | After allocation of 32s, available_slots is [] |
| 142 | final packing is [] |
| 143 | final packing is [] |
| 144 | final packing is [] |
| 145 | Action Data SRAMs to use = 1 |
| 146 | TODO: Total RAMs use when put 0 bits in match overhead: 2 |
| 147 | TODO: Total RAMs use when put 0 bits in match overhead: 2 |
| 148 | ~~~~~~~~~~~~~~~~~~~~~ |
| 149 | Examining placing 8 bits in match overhead |
| 150 | ~~~~~~~~~~~~~~~~~~~~~ |
| 151 | Examining placing 16 bits in match overhead |
| 152 | Overhead bit width for table table0 is 3 bits. |
| 153 | Overhead SRAMs to use = 1 |
| 154 | Entries requested = 512 and match entries get = 512 |
| 155 | ram_size_matrix = |
| 156 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 157 | 0 0 0 0 0 0 0 0 # 0 |
| 158 | 0 0 0 0 0 0 0 0 # 1 |
| 159 | 0 0 0 0 0 0 0 0 # 2 |
| 160 | |
| 161 | immediate_size_matrix = |
| 162 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 163 | 0 0 0 1 0 0 0 0 # 0 |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 164 | 0 0 0 1 0 0 0 0 # 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 165 | 0 0 0 0 0 0 0 0 # 2 |
| 166 | |
| 167 | hash_to_phv_matrix = |
| 168 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 169 | 0 0 0 0 0 0 0 0 # 0 |
| 170 | 0 0 0 0 0 0 0 0 # 1 |
| 171 | 0 0 0 0 0 0 0 0 # 2 |
| 172 | |
| 173 | total action ram packing size = [0, 0, 0] |
| 174 | action_ram_packing: |
| 175 | action set_egress_port has [] |
| 176 | action send_to_cpu has [] |
| 177 | action _drop has [] |
| 178 | total action ram packing size = [0, 16, 0] |
| 179 | action_ram_packing: |
| 180 | action set_egress_port has [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 181 | action send_to_cpu has [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 182 | action _drop has [] |
| 183 | total action ram packing size = [0, 16, 0] |
| 184 | action_ram_packing: |
| 185 | action set_egress_port has [] |
| 186 | action send_to_cpu has [] |
| 187 | action _drop has [] |
| 188 | byte_enables = [] |
| 189 | After allocation of 32s, available_slots is [] |
| 190 | final packing is [] |
| 191 | final packing is [] |
| 192 | final packing is [] |
| 193 | byte_enables = [1, 1] |
| 194 | Allocating Action Parameter Bus Byte 32 in stage 0 for Byte 0 of 16-bit constant |
| 195 | Allocating Action Parameter Bus Byte 33 in stage 0 for Byte 1 of 16-bit constant |
| 196 | Allocating Action Parameter Bus Byte 34 in stage 0 for Byte 0 of 16-bit constant |
| 197 | Allocating Action Parameter Bus Byte 35 in stage 0 for Byte 1 of 16-bit constant |
| 198 | After allocation of 32s, available_slots is [(16, 0, 0), (32, 8, 0), (16, 1, 16)] |
| 199 | final packing is [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 200 | final packing is [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 201 | final packing is [] |
| 202 | byte_enables = [] |
| 203 | After allocation of 32s, available_slots is [] |
| 204 | final packing is [] |
| 205 | final packing is [] |
| 206 | final packing is [] |
| 207 | Action Data SRAMs to use = 0 |
| 208 | TODO: Total RAMs use when put 16 bits in match overhead: 1 |
| 209 | TODO: Total RAMs use when put 16 bits in match overhead: 1 |
| 210 | ~~~~~~~~~~~~~~~~~~~~~ |
| 211 | Examining placing 24 bits in match overhead |
| 212 | Overhead bit width for table table0 is 3 bits. |
| 213 | Overhead SRAMs to use = 1 |
| 214 | Entries requested = 512 and match entries get = 512 |
| 215 | ram_size_matrix = |
| 216 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 217 | 0 0 0 0 0 0 0 0 # 0 |
| 218 | 0 0 0 0 0 0 0 0 # 1 |
| 219 | 0 0 0 0 0 0 0 0 # 2 |
| 220 | |
| 221 | immediate_size_matrix = |
| 222 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 223 | 0 0 0 1 0 0 0 0 # 0 |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 224 | 0 0 0 1 0 0 0 0 # 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 225 | 0 0 0 0 0 0 0 0 # 2 |
| 226 | |
| 227 | hash_to_phv_matrix = |
| 228 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 229 | 0 0 0 0 0 0 0 0 # 0 |
| 230 | 0 0 0 0 0 0 0 0 # 1 |
| 231 | 0 0 0 0 0 0 0 0 # 2 |
| 232 | |
| 233 | total action ram packing size = [0, 0, 0] |
| 234 | action_ram_packing: |
| 235 | action set_egress_port has [] |
| 236 | action send_to_cpu has [] |
| 237 | action _drop has [] |
| 238 | total action ram packing size = [0, 16, 0] |
| 239 | action_ram_packing: |
| 240 | action set_egress_port has [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 241 | action send_to_cpu has [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 242 | action _drop has [] |
| 243 | total action ram packing size = [0, 16, 0] |
| 244 | action_ram_packing: |
| 245 | action set_egress_port has [] |
| 246 | action send_to_cpu has [] |
| 247 | action _drop has [] |
| 248 | byte_enables = [] |
| 249 | After allocation of 32s, available_slots is [] |
| 250 | final packing is [] |
| 251 | final packing is [] |
| 252 | final packing is [] |
| 253 | byte_enables = [1, 1] |
| 254 | Allocating Action Parameter Bus Byte 32 in stage 0 for Byte 0 of 16-bit constant |
| 255 | Allocating Action Parameter Bus Byte 33 in stage 0 for Byte 1 of 16-bit constant |
| 256 | Allocating Action Parameter Bus Byte 34 in stage 0 for Byte 0 of 16-bit constant |
| 257 | Allocating Action Parameter Bus Byte 35 in stage 0 for Byte 1 of 16-bit constant |
| 258 | After allocation of 32s, available_slots is [(16, 0, 0), (32, 8, 0), (16, 1, 16)] |
| 259 | final packing is [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 260 | final packing is [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 261 | final packing is [] |
| 262 | byte_enables = [] |
| 263 | After allocation of 32s, available_slots is [] |
| 264 | final packing is [] |
| 265 | final packing is [] |
| 266 | final packing is [] |
| 267 | Action Data SRAMs to use = 0 |
| 268 | TODO: Total RAMs use when put 24 bits in match overhead: 1 |
| 269 | TODO: Total RAMs use when put 24 bits in match overhead: 1 |
| 270 | ~~~~~~~~~~~~~~~~~~~~~ |
| 271 | Examining placing 32 bits in match overhead |
| 272 | Overhead bit width for table table0 is 3 bits. |
| 273 | Overhead SRAMs to use = 1 |
| 274 | Entries requested = 512 and match entries get = 512 |
| 275 | ram_size_matrix = |
| 276 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 277 | 0 0 0 0 0 0 0 0 # 0 |
| 278 | 0 0 0 0 0 0 0 0 # 1 |
| 279 | 0 0 0 0 0 0 0 0 # 2 |
| 280 | |
| 281 | immediate_size_matrix = |
| 282 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 283 | 0 0 0 1 0 0 0 0 # 0 |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 284 | 0 0 0 1 0 0 0 0 # 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 285 | 0 0 0 0 0 0 0 0 # 2 |
| 286 | |
| 287 | hash_to_phv_matrix = |
| 288 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 289 | 0 0 0 0 0 0 0 0 # 0 |
| 290 | 0 0 0 0 0 0 0 0 # 1 |
| 291 | 0 0 0 0 0 0 0 0 # 2 |
| 292 | |
| 293 | total action ram packing size = [0, 0, 0] |
| 294 | action_ram_packing: |
| 295 | action set_egress_port has [] |
| 296 | action send_to_cpu has [] |
| 297 | action _drop has [] |
| 298 | total action ram packing size = [0, 16, 0] |
| 299 | action_ram_packing: |
| 300 | action set_egress_port has [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 301 | action send_to_cpu has [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 302 | action _drop has [] |
| 303 | total action ram packing size = [0, 16, 0] |
| 304 | action_ram_packing: |
| 305 | action set_egress_port has [] |
| 306 | action send_to_cpu has [] |
| 307 | action _drop has [] |
| 308 | byte_enables = [] |
| 309 | After allocation of 32s, available_slots is [] |
| 310 | final packing is [] |
| 311 | final packing is [] |
| 312 | final packing is [] |
| 313 | byte_enables = [1, 1] |
| 314 | Allocating Action Parameter Bus Byte 32 in stage 0 for Byte 0 of 16-bit constant |
| 315 | Allocating Action Parameter Bus Byte 33 in stage 0 for Byte 1 of 16-bit constant |
| 316 | Allocating Action Parameter Bus Byte 34 in stage 0 for Byte 0 of 16-bit constant |
| 317 | Allocating Action Parameter Bus Byte 35 in stage 0 for Byte 1 of 16-bit constant |
| 318 | After allocation of 32s, available_slots is [(16, 0, 0), (32, 8, 0), (16, 1, 16)] |
| 319 | final packing is [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 320 | final packing is [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 321 | final packing is [] |
| 322 | byte_enables = [] |
| 323 | After allocation of 32s, available_slots is [] |
| 324 | final packing is [] |
| 325 | final packing is [] |
| 326 | final packing is [] |
| 327 | Action Data SRAMs to use = 0 |
| 328 | TODO: Total RAMs use when put 32 bits in match overhead: 1 |
| 329 | TODO: Total RAMs use when put 32 bits in match overhead: 1 |
| 330 | |
| 331 | ########################################## |
| 332 | |
| 333 | Best Ram Usage is 1 rams |
| 334 | Best Immediate placement is 16 bits |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 335 | Cannot implement table0 in phase 0 resources because table uses side effect tables. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 336 | |
| 337 | ---------------------------------------------- |
| 338 | Call to Allocate P4 Table with table table0__action__, number_entries = 512, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 339 | Allocating in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 340 | ---------------------------------------------- |
| 341 | |
| 342 | ram_size_matrix = |
| 343 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 344 | 0 0 0 0 0 0 0 0 # 0 |
| 345 | 0 0 0 0 0 0 0 0 # 1 |
| 346 | 0 0 0 0 0 0 0 0 # 2 |
| 347 | |
| 348 | immediate_size_matrix = |
| 349 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 350 | 0 0 0 1 0 0 0 0 # 0 |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 351 | 0 0 0 1 0 0 0 0 # 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 352 | 0 0 0 0 0 0 0 0 # 2 |
| 353 | |
| 354 | hash_to_phv_matrix = |
| 355 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 356 | 0 0 0 0 0 0 0 0 # 0 |
| 357 | 0 0 0 0 0 0 0 0 # 1 |
| 358 | 0 0 0 0 0 0 0 0 # 2 |
| 359 | |
| 360 | total action ram packing size = [0, 0, 0] |
| 361 | action_ram_packing: |
| 362 | action set_egress_port has [] |
| 363 | action send_to_cpu has [] |
| 364 | action _drop has [] |
| 365 | total action ram packing size = [0, 16, 0] |
| 366 | action_ram_packing: |
| 367 | action set_egress_port has [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 368 | action send_to_cpu has [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 369 | action _drop has [] |
| 370 | total action ram packing size = [0, 16, 0] |
| 371 | action_ram_packing: |
| 372 | action set_egress_port has [] |
| 373 | action send_to_cpu has [] |
| 374 | action _drop has [] |
| 375 | byte_enables = [] |
| 376 | After allocation of 32s, available_slots is [] |
| 377 | final packing is [] |
| 378 | final packing is [] |
| 379 | final packing is [] |
| 380 | byte_enables = [1, 1] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 381 | Allocating Action Parameter Bus Byte 32 in stage 0 for Byte 0 of 16-bit constant |
| 382 | Allocating Action Parameter Bus Byte 33 in stage 0 for Byte 1 of 16-bit constant |
| 383 | Allocating Action Parameter Bus Byte 34 in stage 0 for Byte 0 of 16-bit constant |
| 384 | Allocating Action Parameter Bus Byte 35 in stage 0 for Byte 1 of 16-bit constant |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 385 | After allocation of 32s, available_slots is [(16, 0, 0), (32, 8, 0), (16, 1, 16)] |
| 386 | final packing is [(16, 16, False)] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 387 | final packing is [(16, 16, False)] |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 388 | final packing is [] |
| 389 | byte_enables = [] |
| 390 | After allocation of 32s, available_slots is [] |
| 391 | final packing is [] |
| 392 | final packing is [] |
| 393 | final packing is [] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 394 | Allocating Action Logical Table ID 0 in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 395 | |
| 396 | ---------------------------------------------- |
| 397 | Call to Allocate P4 Table with table table0_counter, number_entries = 512, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 398 | Allocating in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 399 | ---------------------------------------------- |
| 400 | |
| 401 | stat_stage_table referenced: direct |
| 402 | stat Table Resource Request is: |
| 403 | SRAM Resource Request for table table0_counter (of type statistics), with 1 ways wants 2 rams. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 404 | Sram Resource Request for P4 table table0_counter with handle 67108867 of type statistics in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 405 | table_type : statistics |
| 406 | rams_for_width : 1 |
| 407 | use_stash : False |
| 408 | number_ways : 1 |
| 409 | way #0 |
| 410 | SRAM Request Group 0 |
| 411 | rams_for_depth : 2 |
| 412 | map_rams : 0 |
| 413 | way_number : 0 |
| 414 | ram_word_select_bits : 0 |
| 415 | ram_enable_select_bits : 0 |
| 416 | |
| 417 | |
| 418 | ---------------------------------------------- |
| 419 | Call to Allocate P4 Table with table table0, number_entries = 512, table id = None, and match type = ternary |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 420 | Allocating in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 421 | ---------------------------------------------- |
| 422 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 423 | Logical Table ID in stage 0 was not supplied by table placement for table table0. |
| 424 | Allocating Logical Table ID 0 in stage 0 |
| 425 | Allocating Table Type ID 0 of type ternary in stage 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 426 | |
| 427 | ----------------------------------------- |
| 428 | Call to allocate_ternary_match_key_2 |
| 429 | ----------------------------------------- |
| 430 | Total crossbar bytes to allocate = 16 |
| 431 | Minimum key bytes required by this match key = 16 |
| 432 | Allocating: Byte 133 is of type ternary and member of group 0 with 1 bytes |
| 433 | version/valid in nibble 1 for table table0. for version/valid |
| 434 | {unused[6:0], ig_intr_md.ingress_port[8:8]}. |
| 435 | Allocating: Byte 128 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[7:0]}. |
| 436 | Allocating: Byte 129 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[15:8]}. |
| 437 | Allocating: Byte 130 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[23:16]}. |
| 438 | Allocating: Byte 131 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[31:24]}. |
| 439 | Allocating: Byte 132 is of type ternary and member of group 0 with 5 bytes. for {ethernet.dstAddr[15:8]}. |
| 440 | Allocating: Byte 134 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[31:24]}. |
| 441 | Allocating: Byte 135 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[39:32]}. |
| 442 | Allocating: Byte 136 is of type ternary and member of group 1 with 5 bytes. for {ethernet.etherType[7:0]}. |
| 443 | Allocating: Byte 137 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[23:16]}. |
| 444 | Allocating: Byte 138 is of type ternary and member of group 1 with 5 bytes. for {ethernet.srcAddr[47:40]}. |
| 445 | Allocating: Byte 139 is of type ternary and member of group 2 with 5 bytes. for {ethernet.etherType[15:8]}. |
| 446 | Allocating: Byte 140 is of type ternary and member of group 2 with 5 bytes. for {ig_intr_md.ingress_port[7:0]}. |
| 447 | Allocating: Byte 141 is of type ternary and member of group 2 with 5 bytes. for {ethernet.dstAddr[7:0]}. |
| 448 | Allocating: Byte 142 is of type ternary and member of group 2 with 5 bytes. for {ethernet.srcAddr[39:32]}. |
| 449 | Allocating: Byte 143 is of type ternary and member of group 2 with 5 bytes. for {ethernet.dstAddr[47:40]}. |
| 450 | Formed Ternary Match Key: |
| 451 | {--unused--[3:0], ethernet.dstAddr[47:40], ethernet.srcAddr[39:32], ethernet.dstAddr[7:0], ig_intr_md.ingress_port[7:0], ethernet.etherType[15:8], --version--[1:0], --unused--[1:0], ethernet.srcAddr[47:40], ethernet.dstAddr[23:16], ethernet.etherType[7:0], ethernet.dstAddr[39:24], --unused--[2:0], ig_intr_md.ingress_port[8:8], ethernet.dstAddr[15:8], ethernet.srcAddr[31:0]} |
| 452 | |
| 453 | --------------------------------------------- |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 454 | Call to can_any_match_key_fields_be_shared(stage=0, table=table0) |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 455 | --------------------------------------------- |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 456 | Decided way to allocate for table table0 in stage 0 WAS non_shared |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 457 | |
| 458 | ----------------------------------------- |
| 459 | Call to allocate_ternary_match_key_2 |
| 460 | ----------------------------------------- |
| 461 | Total crossbar bytes to allocate = 16 |
| 462 | Minimum key bytes required by this match key = 16 |
| 463 | Allocating: Byte 133 is of type ternary and member of group 0 with 1 bytes |
| 464 | version/valid in nibble 1 for table table0. for version/valid |
| 465 | {unused[6:0], ig_intr_md.ingress_port[8:8]}. |
| 466 | Allocating: Byte 128 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[7:0]}. |
| 467 | Allocating: Byte 129 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[15:8]}. |
| 468 | Allocating: Byte 130 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[23:16]}. |
| 469 | Allocating: Byte 131 is of type ternary and member of group 0 with 5 bytes. for {ethernet.srcAddr[31:24]}. |
| 470 | Allocating: Byte 132 is of type ternary and member of group 0 with 5 bytes. for {ethernet.dstAddr[15:8]}. |
| 471 | Allocating: Byte 134 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[31:24]}. |
| 472 | Allocating: Byte 135 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[39:32]}. |
| 473 | Allocating: Byte 136 is of type ternary and member of group 1 with 5 bytes. for {ethernet.etherType[7:0]}. |
| 474 | Allocating: Byte 137 is of type ternary and member of group 1 with 5 bytes. for {ethernet.dstAddr[23:16]}. |
| 475 | Allocating: Byte 138 is of type ternary and member of group 1 with 5 bytes. for {ethernet.srcAddr[47:40]}. |
| 476 | Allocating: Byte 139 is of type ternary and member of group 2 with 5 bytes. for {ethernet.etherType[15:8]}. |
| 477 | Allocating: Byte 140 is of type ternary and member of group 2 with 5 bytes. for {ig_intr_md.ingress_port[7:0]}. |
| 478 | Allocating: Byte 141 is of type ternary and member of group 2 with 5 bytes. for {ethernet.dstAddr[7:0]}. |
| 479 | Allocating: Byte 142 is of type ternary and member of group 2 with 5 bytes. for {ethernet.srcAddr[39:32]}. |
| 480 | Allocating: Byte 143 is of type ternary and member of group 2 with 5 bytes. for {ethernet.dstAddr[47:40]}. |
| 481 | Formed Ternary Match Key: |
| 482 | {--unused--[3:0], ethernet.dstAddr[47:40], ethernet.srcAddr[39:32], ethernet.dstAddr[7:0], ig_intr_md.ingress_port[7:0], ethernet.etherType[15:8], --version--[1:0], --unused--[1:0], ethernet.srcAddr[47:40], ethernet.dstAddr[23:16], ethernet.etherType[7:0], ethernet.dstAddr[39:24], --unused--[2:0], ig_intr_md.ingress_port[8:8], ethernet.dstAddr[15:8], ethernet.srcAddr[31:0]} |
| 483 | Allocating: Byte 0 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[5:0], --validity_check--packet_out_hdr[0:0], unused[0:0]}. |
| 484 | Allocating: Byte 0 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[5:0], --validity_check--packet_out_hdr[0:0], unused[0:0]}. |
| 485 | For action set_egress_port, formed micro_instruction: |
| 486 | Micro Instruction deposit-field for PHV Container 130 has bit width 23 |
| 487 | Field Src2 [3:0] : 0x2 (4 bits in instruction bits [3:0]) |
| 488 | Field Src1 [4:0] : 0x0 (5 bits in instruction bits [8:4]) |
| 489 | Field Src1i [0:0] : 0x1 (1 bits in instruction bits [9:9]) |
| 490 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 491 | Field high_bit [3:0] : 0x8 (4 bits in instruction bits [14:11]) |
| 492 | Field low_bit_lo [0:0] : 0x0 (1 bits in instruction bits [15:15]) |
| 493 | Field right_rotate [3:0] : 0x0 (4 bits in instruction bits [19:16]) |
| 494 | Field low_bit_hi [2:0] : 0x0 (3 bits in instruction bits [22:20]) |
| 495 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 496 | Allocating Action ALU 2 (16 bits) in stage 0 for match table table0's action set_egress_port |
| 497 | Allocating VLIW Instruction : 0 in stage 0 for match table table0's action set_egress_port |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 498 | For action send_to_cpu, formed micro_instruction: |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 499 | Micro Instruction deposit-field for PHV Container 130 has bit width 23 |
| 500 | Field Src2 [3:0] : 0x2 (4 bits in instruction bits [3:0]) |
| 501 | Field Src1 [4:0] : 0x0 (5 bits in instruction bits [8:4]) |
| 502 | Field Src1i [0:0] : 0x1 (1 bits in instruction bits [9:9]) |
| 503 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 504 | Field high_bit [3:0] : 0x8 (4 bits in instruction bits [14:11]) |
| 505 | Field low_bit_lo [0:0] : 0x0 (1 bits in instruction bits [15:15]) |
| 506 | Field right_rotate [3:0] : 0x0 (4 bits in instruction bits [19:16]) |
| 507 | Field low_bit_hi [2:0] : 0x0 (3 bits in instruction bits [22:20]) |
| 508 | |
| 509 | For action send_to_cpu, formed micro_instruction: |
| 510 | Micro Instruction deposit-field for PHV Container 66 has bit width 20 |
| 511 | Field Src2 [3:0] : 0x2 (4 bits in instruction bits [3:0]) |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 512 | Field Src1 [4:0] : 0x19 (5 bits in instruction bits [8:4]) |
| 513 | Field Src1i [0:0] : 0x0 (1 bits in instruction bits [9:9]) |
| 514 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 515 | Field high_bit [2:0] : 0x0 (3 bits in instruction bits [13:11]) |
| 516 | Field low_bit_lo [1:0] : 0x0 (2 bits in instruction bits [15:14]) |
| 517 | Field right_rotate [2:0] : 0x0 (3 bits in instruction bits [18:16]) |
| 518 | Field low_bit_hi [0:0] : 0x0 (1 bits in instruction bits [19:19]) |
| 519 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 520 | For action send_to_cpu, formed micro_instruction: |
| 521 | Micro Instruction deposit-field for PHV Container 129 has bit width 23 |
| 522 | Field Src2 [3:0] : 0x1 (4 bits in instruction bits [3:0]) |
| 523 | Field Src1 [4:0] : 0x0 (5 bits in instruction bits [8:4]) |
| 524 | Field Src1i [0:0] : 0x0 (1 bits in instruction bits [9:9]) |
| 525 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 526 | Field high_bit [3:0] : 0xf (4 bits in instruction bits [14:11]) |
| 527 | Field low_bit_lo [0:0] : 0x1 (1 bits in instruction bits [15:15]) |
| 528 | Field right_rotate [3:0] : 0x9 (4 bits in instruction bits [19:16]) |
| 529 | Field low_bit_hi [2:0] : 0x3 (3 bits in instruction bits [22:20]) |
| 530 | |
| 531 | Allocating Action ALU 2 (16 bits) in stage 0 for match table table0's action send_to_cpu |
| 532 | Allocating Action ALU 2 (8 bits) in stage 0 for match table table0's action send_to_cpu |
| 533 | Allocating Action ALU 1 (16 bits) in stage 0 for match table table0's action send_to_cpu |
| 534 | Allocating VLIW Instruction : 1 in stage 0 for match table table0's action send_to_cpu |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 535 | For action _drop, formed micro_instruction: |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 536 | Micro Instruction deposit-field for PHV Container 67 has bit width 20 |
| 537 | Field Src2 [3:0] : 0x3 (4 bits in instruction bits [3:0]) |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 538 | Field Src1 [4:0] : 0x19 (5 bits in instruction bits [8:4]) |
| 539 | Field Src1i [0:0] : 0x0 (1 bits in instruction bits [9:9]) |
| 540 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 541 | Field high_bit [2:0] : 0x7 (3 bits in instruction bits [13:11]) |
| 542 | Field low_bit_lo [1:0] : 0x1 (2 bits in instruction bits [15:14]) |
| 543 | Field right_rotate [2:0] : 0x3 (3 bits in instruction bits [18:16]) |
| 544 | Field low_bit_hi [0:0] : 0x1 (1 bits in instruction bits [19:19]) |
| 545 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 546 | Allocating Action ALU 3 (8 bits) in stage 0 for match table table0's action _drop |
| 547 | Allocating VLIW Instruction : 1 in stage 0 for match table table0's action _drop |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 548 | Ternary table Pack Format = |
| 549 | Pack Format: |
| 550 | table_word_width: 141 |
| 551 | memory_word_width: 47 |
| 552 | entries_per_table_word: 1 |
| 553 | number_memory_units_per_table_word: 3 |
| 554 | entry_list: [ |
| 555 | entry_number : 0 |
| 556 | field_list : [ |
| 557 | ] |
| 558 | Field --tcam_parity_2-- [1:0] : in bits [140:139] |
| 559 | Field --unused-- [3:0] : in bits [138:135] |
| 560 | Field ethernet.dstAddr [47:40] : in bits [134:127] |
| 561 | Field ethernet.srcAddr [39:32] : in bits [126:119] |
| 562 | Field ethernet.dstAddr [7:0] : in bits [118:111] |
| 563 | Field ig_intr_md.ingress_port [7:0] : in bits [110:103] |
| 564 | Field ethernet.etherType [15:8] : in bits [102:95] |
| 565 | Field --tcam_payload_2-- [0:0] : in bits [94:94] |
| 566 | Field --tcam_parity_1-- [1:0] : in bits [93:92] |
| 567 | Field --version-- [1:0] : in bits [91:90] |
| 568 | Field --unused-- [1:0] : in bits [89:88] |
| 569 | Field ethernet.srcAddr [47:40] : in bits [87:80] |
| 570 | Field ethernet.dstAddr [23:16] : in bits [79:72] |
| 571 | Field ethernet.etherType [7:0] : in bits [71:64] |
| 572 | Field ethernet.dstAddr [39:24] : in bits [63:48] |
| 573 | Field --tcam_payload_1-- [0:0] : in bits [47:47] |
| 574 | Field --tcam_parity_0-- [1:0] : in bits [46:45] |
| 575 | Field --unused-- [2:0] : in bits [44:42] |
| 576 | Field ig_intr_md.ingress_port [8:8] : in bits [41:41] |
| 577 | Field ethernet.dstAddr [15:8] : in bits [40:33] |
| 578 | Field ethernet.srcAddr [31:0] : in bits [32:1] |
| 579 | Field --tcam_payload_0-- [0:0] : in bits [0:0] |
| 580 | ] |
| 581 | |
| 582 | |
| 583 | ---------------------------------------------- |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 584 | Call to Allocate P4 Table with table process_packet_out_table__action__, number_entries = 1024, table id = None, and match type = exact |
| 585 | Allocating in stage 0 |
| 586 | ---------------------------------------------- |
| 587 | |
| 588 | ram_size_matrix = |
| 589 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 590 | 0 0 0 0 0 0 0 0 # 0 |
| 591 | |
| 592 | immediate_size_matrix = |
| 593 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 594 | 0 0 0 0 0 0 0 0 # 0 |
| 595 | |
| 596 | hash_to_phv_matrix = |
| 597 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 598 | 0 0 0 0 0 0 0 0 # 0 |
| 599 | |
| 600 | total action ram packing size = [0, 0, 0] |
| 601 | action_ram_packing: |
| 602 | action _process_packet_out has [] |
| 603 | total action ram packing size = [0, 0, 0] |
| 604 | action_ram_packing: |
| 605 | action _process_packet_out has [] |
| 606 | total action ram packing size = [0, 0, 0] |
| 607 | action_ram_packing: |
| 608 | action _process_packet_out has [] |
| 609 | byte_enables = [] |
| 610 | After allocation of 32s, available_slots is [] |
| 611 | final packing is [] |
| 612 | byte_enables = [] |
| 613 | After allocation of 32s, available_slots is [] |
| 614 | final packing is [] |
| 615 | byte_enables = [] |
| 616 | After allocation of 32s, available_slots is [] |
| 617 | final packing is [] |
| 618 | Allocating Action Logical Table ID 1 in stage 0 |
| 619 | |
| 620 | ---------------------------------------------- |
| 621 | Call to Allocate P4 Table with table process_packet_out_table, number_entries = 1024, table id = None, and match type = exact |
| 622 | Allocating in stage 0 |
| 623 | ---------------------------------------------- |
| 624 | |
| 625 | Logical Table ID in stage 0 was not supplied by table placement for table process_packet_out_table. |
| 626 | Allocating Logical Table ID 1 in stage 0 |
| 627 | Allocating Table Type ID 0 of type exact in stage 0 |
| 628 | Match Overhead: |
| 629 | Field --version_valid-- [3:0] (4 bits) |
| 630 | |
| 631 | Logical Table ID in stage 0 was not supplied by table placement for table process_packet_out_table. |
| 632 | Allocating Logical Table ID 1 in stage 0 |
| 633 | Allocating Table Type ID 0 of type exact in stage 0 |
| 634 | Allocating: Byte 0 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[5:0], --validity_check--packet_out_hdr[0:0], unused[0:0]}. |
| 635 | Match Table Resource Request is: |
| 636 | SRAM Resource Request for table process_packet_out_table (of type match), with 0 ways wants 0 rams. |
| 637 | Allocating: Byte 0 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[5:0], --validity_check--packet_out_hdr[0:0], unused[0:0]}. |
| 638 | For action _process_packet_out, formed micro_instruction: |
| 639 | Micro Instruction deposit-field for PHV Container 130 has bit width 23 |
| 640 | Field Src2 [3:0] : 0x2 (4 bits in instruction bits [3:0]) |
| 641 | Field Src1 [4:0] : 0x1 (5 bits in instruction bits [8:4]) |
| 642 | Field Src1i [0:0] : 0x0 (1 bits in instruction bits [9:9]) |
| 643 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 644 | Field high_bit [3:0] : 0x8 (4 bits in instruction bits [14:11]) |
| 645 | Field low_bit_lo [0:0] : 0x0 (1 bits in instruction bits [15:15]) |
| 646 | Field right_rotate [3:0] : 0x7 (4 bits in instruction bits [19:16]) |
| 647 | Field low_bit_hi [2:0] : 0x0 (3 bits in instruction bits [22:20]) |
| 648 | |
| 649 | For action _process_packet_out, formed micro_instruction: |
| 650 | Micro Instruction deposit-field for PHV Container 66 has bit width 20 |
| 651 | Field Src2 [3:0] : 0x2 (4 bits in instruction bits [3:0]) |
| 652 | Field Src1 [4:0] : 0x18 (5 bits in instruction bits [8:4]) |
| 653 | Field Src1i [0:0] : 0x0 (1 bits in instruction bits [9:9]) |
| 654 | Field opcode [0:0] : 0x1 (1 bits in instruction bits [10:10]) |
| 655 | Field high_bit [2:0] : 0x1 (3 bits in instruction bits [13:11]) |
| 656 | Field low_bit_lo [1:0] : 0x1 (2 bits in instruction bits [15:14]) |
| 657 | Field right_rotate [2:0] : 0x7 (3 bits in instruction bits [18:16]) |
| 658 | Field low_bit_hi [0:0] : 0x0 (1 bits in instruction bits [19:19]) |
| 659 | |
| 660 | Allocating Action ALU 2 (16 bits) in stage 0 for match table process_packet_out_table's action _process_packet_out |
| 661 | Allocating Action ALU 2 (8 bits) in stage 0 for match table process_packet_out_table's action _process_packet_out |
| 662 | Allocating VLIW Instruction : 2 in stage 0 for match table process_packet_out_table's action _process_packet_out |
| 663 | |
| 664 | ---------------------------------------------- |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 665 | Call to Allocate P4 Table with table ingress_port_count_table__action__, number_entries = 1024, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 666 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 667 | ---------------------------------------------- |
| 668 | |
| 669 | ram_size_matrix = |
| 670 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 671 | 0 0 0 0 0 0 0 0 # 0 |
| 672 | |
| 673 | immediate_size_matrix = |
| 674 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 675 | 0 0 0 0 0 0 0 0 # 0 |
| 676 | |
| 677 | hash_to_phv_matrix = |
| 678 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 679 | 0 0 0 0 0 0 0 0 # 0 |
| 680 | |
| 681 | total action ram packing size = [0, 0, 0] |
| 682 | action_ram_packing: |
| 683 | action count_ingress has [] |
| 684 | total action ram packing size = [0, 0, 0] |
| 685 | action_ram_packing: |
| 686 | action count_ingress has [] |
| 687 | total action ram packing size = [0, 0, 0] |
| 688 | action_ram_packing: |
| 689 | action count_ingress has [] |
| 690 | byte_enables = [] |
| 691 | After allocation of 32s, available_slots is [] |
| 692 | final packing is [] |
| 693 | byte_enables = [] |
| 694 | After allocation of 32s, available_slots is [] |
| 695 | final packing is [] |
| 696 | byte_enables = [] |
| 697 | After allocation of 32s, available_slots is [] |
| 698 | final packing is [] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 699 | Allocating Action Logical Table ID 0 in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 700 | |
| 701 | ---------------------------------------------- |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 702 | Call to Allocate P4 Table with table ingress_port_counter, number_entries = 512, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 703 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 704 | ---------------------------------------------- |
| 705 | |
| 706 | stat_stage_table referenced: indirect |
| 707 | stat Table Resource Request is: |
| 708 | SRAM Resource Request for table ingress_port_counter (of type statistics), with 1 ways wants 2 rams. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 709 | Sram Resource Request for P4 table ingress_port_counter with handle 67108865 of type statistics in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 710 | table_type : statistics |
| 711 | rams_for_width : 1 |
| 712 | use_stash : False |
| 713 | number_ways : 1 |
| 714 | way #0 |
| 715 | SRAM Request Group 0 |
| 716 | rams_for_depth : 2 |
| 717 | map_rams : 0 |
| 718 | way_number : 0 |
| 719 | ram_word_select_bits : 0 |
| 720 | ram_enable_select_bits : 0 |
| 721 | |
| 722 | |
| 723 | ---------------------------------------------- |
| 724 | Call to Allocate P4 Table with table ingress_port_count_table, number_entries = 1024, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 725 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 726 | ---------------------------------------------- |
| 727 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 728 | Logical Table ID in stage 1 was not supplied by table placement for table ingress_port_count_table. |
| 729 | Allocating Logical Table ID 0 in stage 1 |
| 730 | Allocating Table Type ID 0 of type exact in stage 1 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 731 | Too few bits (9) specified to address ingress_port_counter from table ingress_port_count_table. 10 are needed. |
| 732 | The most significant 1 bit will be padded with zeros. |
| 733 | ---------------------------------------------- |
| 734 | Call to allocate_hash_distribution_units with |
| 735 | hash_algorithm = identity |
| 736 | hash_output_width = 10 |
| 737 | hash_bits_need = 10 |
| 738 | output_hash_bit_start = 0 |
| 739 | immediate_bit_positions = None |
| 740 | used_for = Statistics Address |
| 741 | ---------------------------------------------- |
| 742 | available_tuples_sorted_by_parity_bytes_available = [(0, 3, 0), (1, 3, 0)] |
| 743 | available_tuples_split_sorted_by_parity_bytes_available = [] |
| 744 | Allocate fresh exact match group / hash group |
| 745 | Allocating: Byte 0 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md.ingress_port[7:0]}. |
| 746 | Allocating: Byte 1 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md.ingress_port[8:8]}. |
| 747 | ------------------- |
| 748 | Call to _allocate_hash_distribution_and_hash_bits |
| 749 | p4_table = ingress_port_count_table |
| 750 | used_for = Statistics Address |
| 751 | hash_distribution_hash_id = 0 |
| 752 | hash_group_id = 0 |
| 753 | hash_bits_in_units = OrderedDict([(0, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])]) |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 754 | address_left_shift = 2 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 755 | ------------------- |
| 756 | Allocating Hash Distribution Group 0/0 for table ingress_port_count_table in stage 1. |
| 757 | Allocating Hash Bit 0 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 758 | Allocating Hash Bit 1 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 759 | Allocating Hash Bit 2 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 760 | Allocating Hash Bit 3 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 761 | Allocating Hash Bit 4 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 762 | Allocating Hash Bit 5 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 763 | Allocating Hash Bit 6 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 764 | Allocating Hash Bit 7 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 765 | Allocating Hash Bit 8 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 766 | Allocating Hash Bit 9 in hash match group 0 for table ingress_port_count_table in stage 1. |
| 767 | seed = 0x0 |
| 768 | set the seed to be [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] |
| 769 | Hash Function 0 |
| 770 | hash_bit_0 = ig_intr_md.ingress_port[0] ^ 0 |
| 771 | hash_bit_1 = ig_intr_md.ingress_port[1] ^ 0 |
| 772 | hash_bit_2 = ig_intr_md.ingress_port[2] ^ 0 |
| 773 | hash_bit_3 = ig_intr_md.ingress_port[3] ^ 0 |
| 774 | hash_bit_4 = ig_intr_md.ingress_port[4] ^ 0 |
| 775 | hash_bit_5 = ig_intr_md.ingress_port[5] ^ 0 |
| 776 | hash_bit_6 = ig_intr_md.ingress_port[6] ^ 0 |
| 777 | hash_bit_7 = ig_intr_md.ingress_port[7] ^ 0 |
| 778 | hash_bit_8 = ig_intr_md.ingress_port[8] ^ 0 |
| 779 | hash_bit_9 = 0 |
| 780 | hash_bit_10 = 0 |
| 781 | hash_bit_11 = 0 |
| 782 | hash_bit_12 = 0 |
| 783 | hash_bit_13 = 0 |
| 784 | hash_bit_14 = 0 |
| 785 | hash_bit_15 = 0 |
| 786 | hash_bit_16 = 0 |
| 787 | hash_bit_17 = 0 |
| 788 | hash_bit_18 = 0 |
| 789 | hash_bit_19 = 0 |
| 790 | hash_bit_20 = 0 |
| 791 | hash_bit_21 = 0 |
| 792 | hash_bit_22 = 0 |
| 793 | hash_bit_23 = 0 |
| 794 | hash_bit_24 = 0 |
| 795 | hash_bit_25 = 0 |
| 796 | hash_bit_26 = 0 |
| 797 | hash_bit_27 = 0 |
| 798 | hash_bit_28 = 0 |
| 799 | hash_bit_29 = 0 |
| 800 | hash_bit_30 = 0 |
| 801 | hash_bit_31 = 0 |
| 802 | hash_bit_32 = 0 |
| 803 | hash_bit_33 = 0 |
| 804 | hash_bit_34 = 0 |
| 805 | hash_bit_35 = 0 |
| 806 | hash_bit_36 = 0 |
| 807 | hash_bit_37 = 0 |
| 808 | hash_bit_38 = 0 |
| 809 | hash_bit_39 = 0 |
| 810 | hash_bit_40 = 0 |
| 811 | hash_bit_41 = 0 |
| 812 | hash_bit_42 = 0 |
| 813 | hash_bit_43 = 0 |
| 814 | hash_bit_44 = 0 |
| 815 | hash_bit_45 = 0 |
| 816 | hash_bit_46 = 0 |
| 817 | hash_bit_47 = 0 |
| 818 | hash_bit_48 = 0 |
| 819 | hash_bit_49 = 0 |
| 820 | hash_bit_50 = 0 |
| 821 | hash_bit_51 = 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 822 | |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 823 | Allocating: Byte 2 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 824 | Allocating: Byte 3 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 825 | Match Table Resource Request is: |
| 826 | SRAM Resource Request for table ingress_port_count_table (of type match), with 0 ways wants 0 rams. |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 827 | Allocating: Byte 2 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 828 | Allocating: Byte 3 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 829 | No micro instructions needed for action count_ingress executed from table ingress_port_count_table. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 830 | Allocating Action ALU 0 (32 bits) in stage 1 for match table ingress_port_count_table's action count_ingress |
| 831 | Allocating VLIW Instruction : 0 in stage 1 for match table ingress_port_count_table's action count_ingress |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 832 | My hash-action stage table is |
| 833 | StageHashActionTable |
| 834 | stage_number: 1 |
| 835 | number_entries 1024 |
| 836 | pack_format: |
| 837 | Pack Format: |
| 838 | table_word_width: 0 |
| 839 | memory_word_width: 0 |
| 840 | entries_per_table_word: 0 |
| 841 | number_memory_units_per_table_word: 0 |
| 842 | entry_list: [ |
| 843 | ] |
| 844 | |
| 845 | p4_table: 'ingress_port_count_table' |
| 846 | stage_table_handle: 0 |
| 847 | stage_table_type_handle: 0 |
| 848 | stage_gateway_table: StageGatewayTable |
| 849 | stage_number: 1 |
| 850 | number_entries 0 |
| 851 | memory_resource_allocation GatewayMemoryResourceAllocation: |
| 852 | memory_type: gateway |
| 853 | memory_units: [[15]] |
| 854 | home_row: -1 |
| 855 | stateful_action_bus_output: None |
| 856 | |
| 857 | p4_table: '_condition_2' |
| 858 | |
| 859 | match_group_resource_allocation: |
| 860 | vliw_resource_allocation: |
| 861 | action handle 536870914 maps to: |
| 862 | VliwResourceAllocation: |
| 863 | match_table_name: ingress_port_count_table |
| 864 | p4_action: count_ingress |
| 865 | address_to_use: 1 |
| 866 | full_address: 64 |
| 867 | vliw_instruction_number: 0 |
| 868 | color: 0 |
| 869 | direction: ingress |
| 870 | micro_instructions: |
| 871 | |
| 872 | action_to_vliw_mapping: |
| 873 | action handle 536870914 maps to vliw instruction 0, color 0, and direction ingress and is found in instruction address 1 |
| 874 | hash_distribution_usages: |
| 875 | MAU Hash Distribution Resource Usage for P4 table ingress_port_count_table |
| 876 | exact_match_group_resource_allocation : HashMatchGroupResourceAllocation: |
| 877 | match_groups: [(0, 16)] |
| 878 | match_group_key_bit_width: 9 |
| 879 | match_group_phv_bit_scrambling: OrderedDict([(('ig_intr_md.ingress_port', 0), 0), (('ig_intr_md.ingress_port', 1), 1), (('ig_intr_md.ingress_port', 2), 2), (('ig_intr_md.ingress_port', 3), 3), (('ig_intr_md.ingress_port', 4), 4), (('ig_intr_md.ingress_port', 5), 5), (('ig_intr_md.ingress_port', 6), 6), (('ig_intr_md.ingress_port', 7), 7), (('ig_intr_md.ingress_port', 8), 8)]) |
| 880 | ('ig_intr_md.ingress_port', 0) -> 0 |
| 881 | ('ig_intr_md.ingress_port', 1) -> 1 |
| 882 | ('ig_intr_md.ingress_port', 2) -> 2 |
| 883 | ('ig_intr_md.ingress_port', 3) -> 3 |
| 884 | ('ig_intr_md.ingress_port', 4) -> 4 |
| 885 | ('ig_intr_md.ingress_port', 5) -> 5 |
| 886 | ('ig_intr_md.ingress_port', 6) -> 6 |
| 887 | ('ig_intr_md.ingress_port', 7) -> 7 |
| 888 | ('ig_intr_md.ingress_port', 8) -> 8 |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 889 | hash_function_dictionary: OrderedDict([(0, <p4c_tofino.target.tofino.llir.mau.stage.resources.hash_function.HashFunction object at 0x7f56d9e86bd0>)]) |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 890 | hash_group_id: 0 |
| 891 | seed: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] |
| 892 | table_direction: ingress |
| 893 | |
| 894 | hash_distribution_resource_allocations : |
| 895 | Hash Distribution: |
| 896 | source_hash_group : 0 |
| 897 | hash_distribution_hash_id : 0 |
| 898 | hash_distribution_group_id : 0 |
| 899 | hash_distribution_used_for : Statistics Address |
| 900 | table_direction : ingress |
| 901 | bits_to_use : [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 902 | left_shift : 2 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 903 | expanded_lo : False |
| 904 | expanded_hi : False |
| 905 | expanded_bit_width : 0 |
| 906 | immediate_position : unused |
| 907 | |
| 908 | |
| 909 | |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 910 | |
| 911 | ---------------------------------------------- |
| 912 | Call to Allocate P4 Table with table egress_port_count_table__action__, number_entries = 1024, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 913 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 914 | ---------------------------------------------- |
| 915 | |
| 916 | ram_size_matrix = |
| 917 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 918 | 0 0 0 0 0 0 0 0 # 0 |
| 919 | |
| 920 | immediate_size_matrix = |
| 921 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 922 | 0 0 0 0 0 0 0 0 # 0 |
| 923 | |
| 924 | hash_to_phv_matrix = |
| 925 | (8, 8, False) (8, 8, True) (8, 32, False) (16, 16, False) (16, 16, True) (16, 32, False) (32, 32, False) (32, 32, True) |
| 926 | 0 0 0 0 0 0 0 0 # 0 |
| 927 | |
| 928 | total action ram packing size = [0, 0, 0] |
| 929 | action_ram_packing: |
| 930 | action count_egress has [] |
| 931 | total action ram packing size = [0, 0, 0] |
| 932 | action_ram_packing: |
| 933 | action count_egress has [] |
| 934 | total action ram packing size = [0, 0, 0] |
| 935 | action_ram_packing: |
| 936 | action count_egress has [] |
| 937 | byte_enables = [] |
| 938 | After allocation of 32s, available_slots is [] |
| 939 | final packing is [] |
| 940 | byte_enables = [] |
| 941 | After allocation of 32s, available_slots is [] |
| 942 | final packing is [] |
| 943 | byte_enables = [] |
| 944 | After allocation of 32s, available_slots is [] |
| 945 | final packing is [] |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 946 | Allocating Action Logical Table ID 1 in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 947 | |
| 948 | ---------------------------------------------- |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 949 | Call to Allocate P4 Table with table egress_port_counter, number_entries = 512, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 950 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 951 | ---------------------------------------------- |
| 952 | |
| 953 | stat_stage_table referenced: indirect |
| 954 | stat Table Resource Request is: |
| 955 | SRAM Resource Request for table egress_port_counter (of type statistics), with 1 ways wants 2 rams. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 956 | Sram Resource Request for P4 table egress_port_counter with handle 67108866 of type statistics in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 957 | table_type : statistics |
| 958 | rams_for_width : 1 |
| 959 | use_stash : False |
| 960 | number_ways : 1 |
| 961 | way #0 |
| 962 | SRAM Request Group 0 |
| 963 | rams_for_depth : 2 |
| 964 | map_rams : 0 |
| 965 | way_number : 0 |
| 966 | ram_word_select_bits : 0 |
| 967 | ram_enable_select_bits : 0 |
| 968 | |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 969 | Allocating: Byte 2 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 970 | Allocating: Byte 3 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 971 | |
| 972 | ---------------------------------------------- |
| 973 | Call to Allocate P4 Table with table egress_port_count_table, number_entries = 1024, table id = None, and match type = exact |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 974 | Allocating in stage 1 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 975 | ---------------------------------------------- |
| 976 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 977 | Logical Table ID in stage 1 was not supplied by table placement for table egress_port_count_table. |
| 978 | Allocating Logical Table ID 1 in stage 1 |
| 979 | Allocating Table Type ID 1 of type exact in stage 1 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 980 | Too few bits (9) specified to address egress_port_counter from table egress_port_count_table. 10 are needed. |
| 981 | The most significant 1 bit will be padded with zeros. |
| 982 | ---------------------------------------------- |
| 983 | Call to allocate_hash_distribution_units with |
| 984 | hash_algorithm = identity |
| 985 | hash_output_width = 10 |
| 986 | hash_bits_need = 10 |
| 987 | output_hash_bit_start = 0 |
| 988 | immediate_bit_positions = None |
| 989 | used_for = Statistics Address |
| 990 | ---------------------------------------------- |
| 991 | available_tuples_sorted_by_parity_bytes_available = [(1, 3, 0), (0, 2, 4)] |
| 992 | available_tuples_split_sorted_by_parity_bytes_available = [] |
| 993 | Allocate fresh exact match group / hash group |
| 994 | Allocating: Byte 8 is of type exact and member of group 0 (parity group 1) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 995 | Allocating: Byte 9 is of type exact and member of group 0 (parity group 1) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
| 996 | ------------------- |
| 997 | Call to _allocate_hash_distribution_and_hash_bits |
| 998 | p4_table = egress_port_count_table |
| 999 | used_for = Statistics Address |
| 1000 | hash_distribution_hash_id = 1 |
| 1001 | hash_group_id = 1 |
| 1002 | hash_bits_in_units = OrderedDict([(0, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])]) |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 1003 | address_left_shift = 2 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1004 | ------------------- |
| 1005 | Allocating Hash Distribution Group 1/0 for table egress_port_count_table in stage 1. |
| 1006 | Allocating Hash Bit 0 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1007 | Allocating Hash Bit 1 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1008 | Allocating Hash Bit 2 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1009 | Allocating Hash Bit 3 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1010 | Allocating Hash Bit 4 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1011 | Allocating Hash Bit 5 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1012 | Allocating Hash Bit 6 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1013 | Allocating Hash Bit 7 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1014 | Allocating Hash Bit 8 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1015 | Allocating Hash Bit 9 in hash match group 1 for table egress_port_count_table in stage 1. |
| 1016 | seed = 0x0 |
| 1017 | set the seed to be [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] |
| 1018 | Hash Function 0 |
| 1019 | hash_bit_0 = ig_intr_md_for_tm.ucast_egress_port[0] ^ 0 |
| 1020 | hash_bit_1 = ig_intr_md_for_tm.ucast_egress_port[1] ^ 0 |
| 1021 | hash_bit_2 = ig_intr_md_for_tm.ucast_egress_port[2] ^ 0 |
| 1022 | hash_bit_3 = ig_intr_md_for_tm.ucast_egress_port[3] ^ 0 |
| 1023 | hash_bit_4 = ig_intr_md_for_tm.ucast_egress_port[4] ^ 0 |
| 1024 | hash_bit_5 = ig_intr_md_for_tm.ucast_egress_port[5] ^ 0 |
| 1025 | hash_bit_6 = ig_intr_md_for_tm.ucast_egress_port[6] ^ 0 |
| 1026 | hash_bit_7 = ig_intr_md_for_tm.ucast_egress_port[7] ^ 0 |
| 1027 | hash_bit_8 = ig_intr_md_for_tm.ucast_egress_port[8] ^ 0 |
| 1028 | hash_bit_9 = 0 |
| 1029 | hash_bit_10 = 0 |
| 1030 | hash_bit_11 = 0 |
| 1031 | hash_bit_12 = 0 |
| 1032 | hash_bit_13 = 0 |
| 1033 | hash_bit_14 = 0 |
| 1034 | hash_bit_15 = 0 |
| 1035 | hash_bit_16 = 0 |
| 1036 | hash_bit_17 = 0 |
| 1037 | hash_bit_18 = 0 |
| 1038 | hash_bit_19 = 0 |
| 1039 | hash_bit_20 = 0 |
| 1040 | hash_bit_21 = 0 |
| 1041 | hash_bit_22 = 0 |
| 1042 | hash_bit_23 = 0 |
| 1043 | hash_bit_24 = 0 |
| 1044 | hash_bit_25 = 0 |
| 1045 | hash_bit_26 = 0 |
| 1046 | hash_bit_27 = 0 |
| 1047 | hash_bit_28 = 0 |
| 1048 | hash_bit_29 = 0 |
| 1049 | hash_bit_30 = 0 |
| 1050 | hash_bit_31 = 0 |
| 1051 | hash_bit_32 = 0 |
| 1052 | hash_bit_33 = 0 |
| 1053 | hash_bit_34 = 0 |
| 1054 | hash_bit_35 = 0 |
| 1055 | hash_bit_36 = 0 |
| 1056 | hash_bit_37 = 0 |
| 1057 | hash_bit_38 = 0 |
| 1058 | hash_bit_39 = 0 |
| 1059 | hash_bit_40 = 0 |
| 1060 | hash_bit_41 = 0 |
| 1061 | hash_bit_42 = 0 |
| 1062 | hash_bit_43 = 0 |
| 1063 | hash_bit_44 = 0 |
| 1064 | hash_bit_45 = 0 |
| 1065 | hash_bit_46 = 0 |
| 1066 | hash_bit_47 = 0 |
| 1067 | hash_bit_48 = 0 |
| 1068 | hash_bit_49 = 0 |
| 1069 | hash_bit_50 = 0 |
| 1070 | hash_bit_51 = 0 |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1071 | |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1072 | Allocating: Byte 2 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 1073 | Allocating: Byte 3 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1074 | Match Table Resource Request is: |
| 1075 | SRAM Resource Request for table egress_port_count_table (of type match), with 0 ways wants 0 rams. |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1076 | Allocating: Byte 2 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {ig_intr_md_for_tm.ucast_egress_port[7:0]}. |
| 1077 | Allocating: Byte 3 is of type exact and member of group 0 (parity group 0) with 16 bytes. for {unused[6:0], ig_intr_md_for_tm.ucast_egress_port[8:8]}. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1078 | No micro instructions needed for action count_egress executed from table egress_port_count_table. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1079 | Allocating Action ALU 0 (32 bits) in stage 1 for match table egress_port_count_table's action count_egress |
| 1080 | Allocating VLIW Instruction : 0 in stage 1 for match table egress_port_count_table's action count_egress |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1081 | My hash-action stage table is |
| 1082 | StageHashActionTable |
| 1083 | stage_number: 1 |
| 1084 | number_entries 1024 |
| 1085 | pack_format: |
| 1086 | Pack Format: |
| 1087 | table_word_width: 0 |
| 1088 | memory_word_width: 0 |
| 1089 | entries_per_table_word: 0 |
| 1090 | number_memory_units_per_table_word: 0 |
| 1091 | entry_list: [ |
| 1092 | ] |
| 1093 | |
| 1094 | p4_table: 'egress_port_count_table' |
| 1095 | stage_table_handle: 1 |
| 1096 | stage_table_type_handle: 1 |
| 1097 | stage_gateway_table: StageGatewayTable |
| 1098 | stage_number: 1 |
| 1099 | number_entries 0 |
| 1100 | memory_resource_allocation GatewayMemoryResourceAllocation: |
| 1101 | memory_type: gateway |
| 1102 | memory_units: [[14]] |
| 1103 | home_row: -1 |
| 1104 | stateful_action_bus_output: None |
| 1105 | |
| 1106 | p4_table: 'egress_port_count_table_always_true_condition' |
| 1107 | |
| 1108 | match_group_resource_allocation: |
| 1109 | vliw_resource_allocation: |
| 1110 | action handle 536870916 maps to: |
| 1111 | VliwResourceAllocation: |
| 1112 | match_table_name: egress_port_count_table |
| 1113 | p4_action: count_egress |
| 1114 | address_to_use: 0 |
| 1115 | full_address: 64 |
| 1116 | vliw_instruction_number: 0 |
| 1117 | color: 0 |
| 1118 | direction: ingress |
| 1119 | micro_instructions: |
| 1120 | |
| 1121 | action_to_vliw_mapping: |
| 1122 | action handle 536870916 maps to vliw instruction 0, color 0, and direction ingress and is found in instruction address 0 |
| 1123 | hash_distribution_usages: |
| 1124 | MAU Hash Distribution Resource Usage for P4 table egress_port_count_table |
| 1125 | exact_match_group_resource_allocation : HashMatchGroupResourceAllocation: |
| 1126 | match_groups: [(0, 16)] |
| 1127 | match_group_key_bit_width: 73 |
| 1128 | match_group_phv_bit_scrambling: OrderedDict([(('ig_intr_md_for_tm.ucast_egress_port', 0), 64), (('ig_intr_md_for_tm.ucast_egress_port', 1), 65), (('ig_intr_md_for_tm.ucast_egress_port', 2), 66), (('ig_intr_md_for_tm.ucast_egress_port', 3), 67), (('ig_intr_md_for_tm.ucast_egress_port', 4), 68), (('ig_intr_md_for_tm.ucast_egress_port', 5), 69), (('ig_intr_md_for_tm.ucast_egress_port', 6), 70), (('ig_intr_md_for_tm.ucast_egress_port', 7), 71), (('ig_intr_md_for_tm.ucast_egress_port', 8), 72)]) |
| 1129 | ('ig_intr_md_for_tm.ucast_egress_port', 0) -> 64 |
| 1130 | ('ig_intr_md_for_tm.ucast_egress_port', 1) -> 65 |
| 1131 | ('ig_intr_md_for_tm.ucast_egress_port', 2) -> 66 |
| 1132 | ('ig_intr_md_for_tm.ucast_egress_port', 3) -> 67 |
| 1133 | ('ig_intr_md_for_tm.ucast_egress_port', 4) -> 68 |
| 1134 | ('ig_intr_md_for_tm.ucast_egress_port', 5) -> 69 |
| 1135 | ('ig_intr_md_for_tm.ucast_egress_port', 6) -> 70 |
| 1136 | ('ig_intr_md_for_tm.ucast_egress_port', 7) -> 71 |
| 1137 | ('ig_intr_md_for_tm.ucast_egress_port', 8) -> 72 |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 1138 | hash_function_dictionary: OrderedDict([(0, <p4c_tofino.target.tofino.llir.mau.stage.resources.hash_function.HashFunction object at 0x7f56d9c34490>)]) |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1139 | hash_group_id: 1 |
| 1140 | seed: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] |
| 1141 | table_direction: ingress |
| 1142 | |
| 1143 | hash_distribution_resource_allocations : |
| 1144 | Hash Distribution: |
| 1145 | source_hash_group : 1 |
| 1146 | hash_distribution_hash_id : 1 |
| 1147 | hash_distribution_group_id : 0 |
| 1148 | hash_distribution_used_for : Statistics Address |
| 1149 | table_direction : ingress |
| 1150 | bits_to_use : [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] |
Carmelo Cascone | 133c7b1 | 2017-09-13 15:36:08 +0200 | [diff] [blame] | 1151 | left_shift : 2 |
Carmelo Cascone | 6230a61 | 2017-09-13 03:25:41 +0200 | [diff] [blame] | 1152 | expanded_lo : False |
| 1153 | expanded_hi : False |
| 1154 | expanded_bit_width : 0 |
| 1155 | immediate_position : unused |
| 1156 | |
| 1157 | |
| 1158 | |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1159 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1160 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1161 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1162 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1163 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1164 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1165 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1166 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1167 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1168 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1169 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1170 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1171 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1172 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1173 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1174 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1175 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1176 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1177 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1178 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1179 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1180 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
Brian O'Connor | a6862e0 | 2017-09-08 01:17:39 -0700 | [diff] [blame] | 1181 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
| 1182 | Cannot find table object for 'egress_port_count_table_always_true_condition'. |
| 1183 | Cannot find table object for 'process_packet_out_table_always_true_condition'. |
Carmelo Cascone | 5db3968 | 2017-09-07 16:36:42 +0200 | [diff] [blame] | 1184 | Field ig_intr_md_for_tm.ucast_egress_port not contiguous on gateway input |
| 1185 | Field ig_intr_md_for_tm.ucast_egress_port not contiguous on gateway input |
| 1186 | Writing configuration registers: regs.match_action_stage.00 |
| 1187 | Writing configuration registers: regs.match_action_stage.01 |
| 1188 | Writing configuration registers: regs.match_action_stage.02 |
| 1189 | Writing configuration registers: regs.match_action_stage.03 |
| 1190 | Writing configuration registers: regs.match_action_stage.04 |
| 1191 | Writing configuration registers: regs.match_action_stage.05 |
| 1192 | Writing configuration registers: regs.match_action_stage.06 |
| 1193 | Writing configuration registers: regs.match_action_stage.07 |
| 1194 | Writing configuration registers: regs.match_action_stage.08 |
| 1195 | Writing configuration registers: regs.match_action_stage.09 |
| 1196 | Writing configuration registers: regs.match_action_stage.0a |
| 1197 | Writing configuration registers: regs.match_action_stage.0b |