1bfcc09ddSBjoern A. Zeeb /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */ 2bfcc09ddSBjoern A. Zeeb /* 3*a4128aadSBjoern A. Zeeb * Copyright (C) 2018-2023 Intel Corporation 4bfcc09ddSBjoern A. Zeeb */ 5bfcc09ddSBjoern A. Zeeb #ifndef __iwl_dbg_tlv_h__ 6bfcc09ddSBjoern A. Zeeb #define __iwl_dbg_tlv_h__ 7bfcc09ddSBjoern A. Zeeb 8bfcc09ddSBjoern A. Zeeb #include <linux/device.h> 9bfcc09ddSBjoern A. Zeeb #include <linux/types.h> 10bfcc09ddSBjoern A. Zeeb #include <fw/file.h> 11bfcc09ddSBjoern A. Zeeb #include <fw/api/dbg-tlv.h> 12bfcc09ddSBjoern A. Zeeb 13fac1f593SBjoern A. Zeeb #define IWL_DBG_TLV_MAX_PRESET 15 14*a4128aadSBjoern A. Zeeb #define ENABLE_INI (IWL_DBG_TLV_MAX_PRESET + 1) 15fac1f593SBjoern A. Zeeb 16bfcc09ddSBjoern A. Zeeb /** 17bfcc09ddSBjoern A. Zeeb * struct iwl_dbg_tlv_node - debug TLV node 18bfcc09ddSBjoern A. Zeeb * @list: list of &struct iwl_dbg_tlv_node 19bfcc09ddSBjoern A. Zeeb * @tlv: debug TLV 20bfcc09ddSBjoern A. Zeeb */ 21bfcc09ddSBjoern A. Zeeb struct iwl_dbg_tlv_node { 22bfcc09ddSBjoern A. Zeeb struct list_head list; 23bfcc09ddSBjoern A. Zeeb struct iwl_ucode_tlv tlv; 24bfcc09ddSBjoern A. Zeeb }; 25bfcc09ddSBjoern A. Zeeb 26bfcc09ddSBjoern A. Zeeb /** 27bfcc09ddSBjoern A. Zeeb * union iwl_dbg_tlv_tp_data - data that is given in a time point 28bfcc09ddSBjoern A. Zeeb * @fw_pkt: a packet received from the FW 29bfcc09ddSBjoern A. Zeeb */ 30bfcc09ddSBjoern A. Zeeb union iwl_dbg_tlv_tp_data { 31bfcc09ddSBjoern A. Zeeb struct iwl_rx_packet *fw_pkt; 32bfcc09ddSBjoern A. Zeeb }; 33bfcc09ddSBjoern A. Zeeb 34bfcc09ddSBjoern A. Zeeb /** 35bfcc09ddSBjoern A. Zeeb * struct iwl_dbg_tlv_time_point_data 36bfcc09ddSBjoern A. Zeeb * @trig_list: list of triggers 37bfcc09ddSBjoern A. Zeeb * @active_trig_list: list of active triggers 38bfcc09ddSBjoern A. Zeeb * @hcmd_list: list of host commands 39bfcc09ddSBjoern A. Zeeb * @config_list: list of configuration 40bfcc09ddSBjoern A. Zeeb */ 41bfcc09ddSBjoern A. Zeeb struct iwl_dbg_tlv_time_point_data { 42bfcc09ddSBjoern A. Zeeb struct list_head trig_list; 43bfcc09ddSBjoern A. Zeeb struct list_head active_trig_list; 44bfcc09ddSBjoern A. Zeeb struct list_head hcmd_list; 45bfcc09ddSBjoern A. Zeeb struct list_head config_list; 46bfcc09ddSBjoern A. Zeeb }; 47bfcc09ddSBjoern A. Zeeb 48bfcc09ddSBjoern A. Zeeb struct iwl_trans; 49bfcc09ddSBjoern A. Zeeb struct iwl_fw_runtime; 50bfcc09ddSBjoern A. Zeeb 51bfcc09ddSBjoern A. Zeeb void iwl_dbg_tlv_load_bin(struct device *dev, struct iwl_trans *trans); 52bfcc09ddSBjoern A. Zeeb void iwl_dbg_tlv_free(struct iwl_trans *trans); 53bfcc09ddSBjoern A. Zeeb void iwl_dbg_tlv_alloc(struct iwl_trans *trans, const struct iwl_ucode_tlv *tlv, 54bfcc09ddSBjoern A. Zeeb bool ext); 55bfcc09ddSBjoern A. Zeeb void iwl_dbg_tlv_init(struct iwl_trans *trans); 56bfcc09ddSBjoern A. Zeeb void _iwl_dbg_tlv_time_point(struct iwl_fw_runtime *fwrt, 57bfcc09ddSBjoern A. Zeeb enum iwl_fw_ini_time_point tp_id, 58bfcc09ddSBjoern A. Zeeb union iwl_dbg_tlv_tp_data *tp_data, 59bfcc09ddSBjoern A. Zeeb bool sync); 60*a4128aadSBjoern A. Zeeb void iwl_dbg_tlv_init_cfg(struct iwl_fw_runtime *fwrt); 61bfcc09ddSBjoern A. Zeeb 62bfcc09ddSBjoern A. Zeeb static inline void iwl_dbg_tlv_time_point(struct iwl_fw_runtime *fwrt, 63bfcc09ddSBjoern A. Zeeb enum iwl_fw_ini_time_point tp_id, 64bfcc09ddSBjoern A. Zeeb union iwl_dbg_tlv_tp_data *tp_data) 65bfcc09ddSBjoern A. Zeeb { 66bfcc09ddSBjoern A. Zeeb _iwl_dbg_tlv_time_point(fwrt, tp_id, tp_data, false); 67bfcc09ddSBjoern A. Zeeb } 68bfcc09ddSBjoern A. Zeeb 69bfcc09ddSBjoern A. Zeeb static inline void iwl_dbg_tlv_time_point_sync(struct iwl_fw_runtime *fwrt, 70bfcc09ddSBjoern A. Zeeb enum iwl_fw_ini_time_point tp_id, 71bfcc09ddSBjoern A. Zeeb union iwl_dbg_tlv_tp_data *tp_data) 72bfcc09ddSBjoern A. Zeeb { 73bfcc09ddSBjoern A. Zeeb _iwl_dbg_tlv_time_point(fwrt, tp_id, tp_data, true); 74bfcc09ddSBjoern A. Zeeb } 75bfcc09ddSBjoern A. Zeeb 76bfcc09ddSBjoern A. Zeeb void iwl_dbg_tlv_del_timers(struct iwl_trans *trans); 77bfcc09ddSBjoern A. Zeeb 78bfcc09ddSBjoern A. Zeeb #endif /* __iwl_dbg_tlv_h__*/ 79