ice_sched.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /* Copyright (c) 2018, Intel Corporation. */
  3. #ifndef _ICE_SCHED_H_
  4. #define _ICE_SCHED_H_
  5. #include "ice_common.h"
  6. #define ICE_QGRP_LAYER_OFFSET 2
  7. #define ICE_VSI_LAYER_OFFSET 4
  8. struct ice_sched_agg_vsi_info {
  9. struct list_head list_entry;
  10. DECLARE_BITMAP(tc_bitmap, ICE_MAX_TRAFFIC_CLASS);
  11. };
  12. struct ice_sched_agg_info {
  13. struct list_head agg_vsi_list;
  14. struct list_head list_entry;
  15. DECLARE_BITMAP(tc_bitmap, ICE_MAX_TRAFFIC_CLASS);
  16. u32 agg_id;
  17. enum ice_agg_type agg_type;
  18. };
  19. /* FW AQ command calls */
  20. enum ice_status ice_sched_init_port(struct ice_port_info *pi);
  21. enum ice_status ice_sched_query_res_alloc(struct ice_hw *hw);
  22. void ice_sched_cleanup_all(struct ice_hw *hw);
  23. struct ice_sched_node *
  24. ice_sched_find_node_by_teid(struct ice_sched_node *start_node, u32 teid);
  25. enum ice_status
  26. ice_sched_add_node(struct ice_port_info *pi, u8 layer,
  27. struct ice_aqc_txsched_elem_data *info);
  28. void ice_free_sched_node(struct ice_port_info *pi, struct ice_sched_node *node);
  29. struct ice_sched_node *ice_sched_get_tc_node(struct ice_port_info *pi, u8 tc);
  30. struct ice_sched_node *
  31. ice_sched_get_free_qparent(struct ice_port_info *pi, u16 vsi_handle, u8 tc,
  32. u8 owner);
  33. enum ice_status
  34. ice_sched_cfg_vsi(struct ice_port_info *pi, u16 vsi_handle, u8 tc, u16 maxqs,
  35. u8 owner, bool enable);
  36. #endif /* _ICE_SCHED_H_ */