Lines Matching refs:path
106 struct tb_path *path; in tb_path_discover() local
151 path = kzalloc(sizeof(*path), GFP_KERNEL); in tb_path_discover()
152 if (!path) in tb_path_discover()
155 path->name = name; in tb_path_discover()
156 path->tb = src->sw->tb; in tb_path_discover()
157 path->path_length = num_hops; in tb_path_discover()
158 path->activated = true; in tb_path_discover()
160 path->hops = kcalloc(num_hops, sizeof(*path->hops), GFP_KERNEL); in tb_path_discover()
161 if (!path->hops) { in tb_path_discover()
162 kfree(path); in tb_path_discover()
191 path->hops[i].in_port = p; in tb_path_discover()
192 path->hops[i].in_hop_index = h; in tb_path_discover()
193 path->hops[i].in_counter_index = -1; in tb_path_discover()
194 path->hops[i].out_port = out_port; in tb_path_discover()
195 path->hops[i].next_hop_index = next_hop; in tb_path_discover()
201 return path; in tb_path_discover()
206 tb_path_free(path); in tb_path_discover()
233 struct tb_path *path; in tb_path_alloc() local
237 path = kzalloc(sizeof(*path), GFP_KERNEL); in tb_path_alloc()
238 if (!path) in tb_path_alloc()
248 path->hops = kcalloc(num_hops, sizeof(*path->hops), GFP_KERNEL); in tb_path_alloc()
249 if (!path->hops) { in tb_path_alloc()
250 kfree(path); in tb_path_alloc()
287 path->hops[i].in_hop_index = in_hopid; in tb_path_alloc()
288 path->hops[i].in_port = in_port; in tb_path_alloc()
289 path->hops[i].in_counter_index = -1; in tb_path_alloc()
290 path->hops[i].out_port = out_port; in tb_path_alloc()
291 path->hops[i].next_hop_index = out_hopid; in tb_path_alloc()
296 path->tb = tb; in tb_path_alloc()
297 path->path_length = num_hops; in tb_path_alloc()
298 path->name = name; in tb_path_alloc()
300 return path; in tb_path_alloc()
303 tb_path_free(path); in tb_path_alloc()
313 void tb_path_free(struct tb_path *path) in tb_path_free() argument
317 for (i = 0; i < path->path_length; i++) { in tb_path_free()
318 const struct tb_path_hop *hop = &path->hops[i]; in tb_path_free()
328 kfree(path->hops); in tb_path_free()
329 kfree(path); in tb_path_free()
332 static void __tb_path_deallocate_nfc(struct tb_path *path, int first_hop) in __tb_path_deallocate_nfc() argument
335 for (i = first_hop; i < path->path_length; i++) { in __tb_path_deallocate_nfc()
336 res = tb_port_add_nfc_credits(path->hops[i].in_port, in __tb_path_deallocate_nfc()
337 -path->nfc_credits); in __tb_path_deallocate_nfc()
339 tb_port_warn(path->hops[i].in_port, in __tb_path_deallocate_nfc()
395 static void __tb_path_deactivate_hops(struct tb_path *path, int first_hop) in __tb_path_deactivate_hops() argument
399 for (i = first_hop; i < path->path_length; i++) { in __tb_path_deactivate_hops()
400 res = __tb_path_deactivate_hop(path->hops[i].in_port, in __tb_path_deactivate_hops()
401 path->hops[i].in_hop_index, in __tb_path_deactivate_hops()
402 path->clear_fc); in __tb_path_deactivate_hops()
404 tb_port_warn(path->hops[i].in_port, in __tb_path_deactivate_hops()
406 i, path->hops[i].in_hop_index); in __tb_path_deactivate_hops()
410 void tb_path_deactivate(struct tb_path *path) in tb_path_deactivate() argument
412 if (!path->activated) { in tb_path_deactivate()
413 tb_WARN(path->tb, "trying to deactivate an inactive path\n"); in tb_path_deactivate()
416 tb_dbg(path->tb, in tb_path_deactivate()
418 path->name, tb_route(path->hops[0].in_port->sw), in tb_path_deactivate()
419 path->hops[0].in_port->port, in tb_path_deactivate()
420 tb_route(path->hops[path->path_length - 1].out_port->sw), in tb_path_deactivate()
421 path->hops[path->path_length - 1].out_port->port); in tb_path_deactivate()
422 __tb_path_deactivate_hops(path, 0); in tb_path_deactivate()
423 __tb_path_deallocate_nfc(path, 0); in tb_path_deactivate()
424 path->activated = false; in tb_path_deactivate()
435 int tb_path_activate(struct tb_path *path) in tb_path_activate() argument
439 if (path->activated) { in tb_path_activate()
440 tb_WARN(path->tb, "trying to activate already activated path\n"); in tb_path_activate()
444 tb_dbg(path->tb, in tb_path_activate()
446 path->name, tb_route(path->hops[0].in_port->sw), in tb_path_activate()
447 path->hops[0].in_port->port, in tb_path_activate()
448 tb_route(path->hops[path->path_length - 1].out_port->sw), in tb_path_activate()
449 path->hops[path->path_length - 1].out_port->port); in tb_path_activate()
452 for (i = path->path_length - 1; i >= 0; i--) { in tb_path_activate()
453 if (path->hops[i].in_counter_index == -1) in tb_path_activate()
455 res = tb_port_clear_counter(path->hops[i].in_port, in tb_path_activate()
456 path->hops[i].in_counter_index); in tb_path_activate()
462 for (i = path->path_length - 1; i >= 0; i--) { in tb_path_activate()
463 res = tb_port_add_nfc_credits(path->hops[i].in_port, in tb_path_activate()
464 path->nfc_credits); in tb_path_activate()
466 __tb_path_deallocate_nfc(path, i); in tb_path_activate()
472 for (i = path->path_length - 1; i >= 0; i--) { in tb_path_activate()
476 __tb_path_deactivate_hop(path->hops[i].in_port, in tb_path_activate()
477 path->hops[i].in_hop_index, path->clear_fc); in tb_path_activate()
480 hop.next_hop = path->hops[i].next_hop_index; in tb_path_activate()
481 hop.out_port = path->hops[i].out_port->port; in tb_path_activate()
482 hop.initial_credits = path->hops[i].initial_credits; in tb_path_activate()
487 out_mask = (i == path->path_length - 1) ? in tb_path_activate()
490 hop.weight = path->weight; in tb_path_activate()
492 hop.priority = path->priority; in tb_path_activate()
493 hop.drop_packages = path->drop_packages; in tb_path_activate()
494 hop.counter = path->hops[i].in_counter_index; in tb_path_activate()
495 hop.counter_enable = path->hops[i].in_counter_index != -1; in tb_path_activate()
496 hop.ingress_fc = path->ingress_fc_enable & in_mask; in tb_path_activate()
497 hop.egress_fc = path->egress_fc_enable & out_mask; in tb_path_activate()
498 hop.ingress_shared_buffer = path->ingress_shared_buffer in tb_path_activate()
500 hop.egress_shared_buffer = path->egress_shared_buffer in tb_path_activate()
504 tb_port_dbg(path->hops[i].in_port, "Writing hop %d\n", i); in tb_path_activate()
505 tb_dump_hop(&path->hops[i], &hop); in tb_path_activate()
506 res = tb_port_write(path->hops[i].in_port, &hop, TB_CFG_HOPS, in tb_path_activate()
507 2 * path->hops[i].in_hop_index, 2); in tb_path_activate()
509 __tb_path_deactivate_hops(path, i); in tb_path_activate()
510 __tb_path_deallocate_nfc(path, 0); in tb_path_activate()
514 path->activated = true; in tb_path_activate()
515 tb_dbg(path->tb, "path activation complete\n"); in tb_path_activate()
518 tb_WARN(path->tb, "path activation failed\n"); in tb_path_activate()
527 bool tb_path_is_invalid(struct tb_path *path) in tb_path_is_invalid() argument
530 for (i = 0; i < path->path_length; i++) { in tb_path_is_invalid()
531 if (path->hops[i].in_port->sw->is_unplugged) in tb_path_is_invalid()
533 if (path->hops[i].out_port->sw->is_unplugged) in tb_path_is_invalid()