/* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */ /* Copyright (c) 2021, NVIDIA CORPORATION & AFFILIATES. All rights reserved. */ #undef TRACE_SYSTEM #define TRACE_SYSTEM mlx5 #if !defined(_MLX5_SF_TP_) || defined(TRACE_HEADER_MULTI_READ) #define _MLX5_SF_TP_ #include #include #include "sf/vhca_event.h" TRACE_EVENT(mlx5_sf_add, TP_PROTO(const struct mlx5_core_dev *dev, unsigned int port_index, u32 controller, u16 hw_fn_id, u32 sfnum), TP_ARGS(dev, port_index, controller, hw_fn_id, sfnum), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(unsigned int, port_index) __field(u32, controller) __field(u16, hw_fn_id) __field(u32, sfnum) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->port_index = port_index; __entry->controller = controller; __entry->hw_fn_id = hw_fn_id; __entry->sfnum = sfnum; ), TP_printk("(%s) port_index=%u controller=%u hw_id=0x%x sfnum=%u\n", __get_str(devname), __entry->port_index, __entry->controller, __entry->hw_fn_id, __entry->sfnum) ); TRACE_EVENT(mlx5_sf_free, TP_PROTO(const struct mlx5_core_dev *dev, unsigned int port_index, u32 controller, u16 hw_fn_id), TP_ARGS(dev, port_index, controller, hw_fn_id), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(unsigned int, port_index) __field(u32, controller) __field(u16, hw_fn_id) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->port_index = port_index; __entry->controller = controller; __entry->hw_fn_id = hw_fn_id; ), TP_printk("(%s) port_index=%u controller=%u hw_id=0x%x\n", __get_str(devname), __entry->port_index, __entry->controller, __entry->hw_fn_id) ); TRACE_EVENT(mlx5_sf_hwc_alloc, TP_PROTO(const struct mlx5_core_dev *dev, u32 controller, u16 hw_fn_id, u32 sfnum), TP_ARGS(dev, controller, hw_fn_id, sfnum), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(u32, controller) __field(u16, hw_fn_id) __field(u32, sfnum) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->controller = controller; __entry->hw_fn_id = hw_fn_id; __entry->sfnum = sfnum; ), TP_printk("(%s) controller=%u hw_id=0x%x sfnum=%u\n", __get_str(devname), __entry->controller, __entry->hw_fn_id, __entry->sfnum) ); TRACE_EVENT(mlx5_sf_hwc_free, TP_PROTO(const struct mlx5_core_dev *dev, u16 hw_fn_id), TP_ARGS(dev, hw_fn_id), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(u16, hw_fn_id) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->hw_fn_id = hw_fn_id; ), TP_printk("(%s) hw_id=0x%x\n", __get_str(devname), __entry->hw_fn_id) ); TRACE_EVENT(mlx5_sf_hwc_deferred_free, TP_PROTO(const struct mlx5_core_dev *dev, u16 hw_fn_id), TP_ARGS(dev, hw_fn_id), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(u16, hw_fn_id) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->hw_fn_id = hw_fn_id; ), TP_printk("(%s) hw_id=0x%x\n", __get_str(devname), __entry->hw_fn_id) ); DECLARE_EVENT_CLASS(mlx5_sf_state_template, TP_PROTO(const struct mlx5_core_dev *dev, u32 port_index, u32 controller, u16 hw_fn_id), TP_ARGS(dev, port_index, controller, hw_fn_id), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(unsigned int, port_index) __field(u32, controller) __field(u16, hw_fn_id)), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->port_index = port_index; __entry->controller = controller; __entry->hw_fn_id = hw_fn_id; ), TP_printk("(%s) port_index=%u controller=%u hw_id=0x%x\n", __get_str(devname), __entry->port_index, __entry->controller, __entry->hw_fn_id) ); DEFINE_EVENT(mlx5_sf_state_template, mlx5_sf_activate, TP_PROTO(const struct mlx5_core_dev *dev, u32 port_index, u32 controller, u16 hw_fn_id), TP_ARGS(dev, port_index, controller, hw_fn_id) ); DEFINE_EVENT(mlx5_sf_state_template, mlx5_sf_deactivate, TP_PROTO(const struct mlx5_core_dev *dev, u32 port_index, u32 controller, u16 hw_fn_id), TP_ARGS(dev, port_index, controller, hw_fn_id) ); TRACE_EVENT(mlx5_sf_update_state, TP_PROTO(const struct mlx5_core_dev *dev, unsigned int port_index, u32 controller, u16 hw_fn_id, u8 state), TP_ARGS(dev, port_index, controller, hw_fn_id, state), TP_STRUCT__entry(__string(devname, dev_name(dev->device)) __field(unsigned int, port_index) __field(u32, controller) __field(u16, hw_fn_id) __field(u8, state) ), TP_fast_assign(__assign_str(devname, dev_name(dev->device)); __entry->port_index = port_index; __entry->controller = controller; __entry->hw_fn_id = hw_fn_id; __entry->state = state; ), TP_printk("(%s) port_index=%u controller=%u hw_id=0x%x state=%u\n", __get_str(devname), __entry->port_index, __entry->controller, __entry->hw_fn_id, __entry->state) ); #endif /* _MLX5_SF_TP_ */ /* This part must be outside protection */ #undef TRACE_INCLUDE_PATH #define TRACE_INCLUDE_PATH sf/diag #undef TRACE_INCLUDE_FILE #define TRACE_INCLUDE_FILE sf_tracepoint #include