14273a380SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */ 2e705c121SKalle Valo /****************************************************************************** 3e705c121SKalle Valo * 4e705c121SKalle Valo * Copyright(c) 2009 - 2014 Intel Corporation. All rights reserved. 56eb5e529SEmmanuel Grumbach * Copyright(c) 2015 Intel Deutschland GmbH 6*9b08ae22SJohannes Berg * Copyright(c) 2018 - 2019 Intel Corporation 7e705c121SKalle Valo *****************************************************************************/ 8e705c121SKalle Valo 9e705c121SKalle Valo #if !defined(__IWLWIFI_DEVICE_TRACE_DATA) || defined(TRACE_HEADER_MULTI_READ) 10e705c121SKalle Valo #define __IWLWIFI_DEVICE_TRACE_DATA 11e705c121SKalle Valo 12e705c121SKalle Valo #include <linux/tracepoint.h> 13e705c121SKalle Valo 14e705c121SKalle Valo #undef TRACE_SYSTEM 15e705c121SKalle Valo #define TRACE_SYSTEM iwlwifi_data 16e705c121SKalle Valo 17bf77ee2eSSara Sharon TRACE_EVENT(iwlwifi_dev_tx_tb, 18bf77ee2eSSara Sharon TP_PROTO(const struct device *dev, struct sk_buff *skb, 19*9b08ae22SJohannes Berg u8 *data_src, dma_addr_t phys, size_t data_len), 20*9b08ae22SJohannes Berg TP_ARGS(dev, skb, data_src, phys, data_len), 21e705c121SKalle Valo TP_STRUCT__entry( 22e705c121SKalle Valo DEV_ENTRY 23*9b08ae22SJohannes Berg __field(u64, phys) 24e705c121SKalle Valo 2578c1acf3SJohannes Berg __dynamic_array(u8, data, 26bf77ee2eSSara Sharon iwl_trace_data(skb) ? data_len : 0) 27e705c121SKalle Valo ), 28e705c121SKalle Valo TP_fast_assign( 29e705c121SKalle Valo DEV_ASSIGN; 30*9b08ae22SJohannes Berg __entry->phys = phys; 31e705c121SKalle Valo if (iwl_trace_data(skb)) 326eb5e529SEmmanuel Grumbach memcpy(__get_dynamic_array(data), data_src, data_len); 336eb5e529SEmmanuel Grumbach ), 346eb5e529SEmmanuel Grumbach TP_printk("[%s] TX frame data", __get_str(dev)) 356eb5e529SEmmanuel Grumbach ); 366eb5e529SEmmanuel Grumbach 37e705c121SKalle Valo TRACE_EVENT(iwlwifi_dev_rx_data, 38e705c121SKalle Valo TP_PROTO(const struct device *dev, 39e705c121SKalle Valo const struct iwl_trans *trans, 40e705c121SKalle Valo void *rxbuf, size_t len), 41e705c121SKalle Valo TP_ARGS(dev, trans, rxbuf, len), 42e705c121SKalle Valo TP_STRUCT__entry( 43e705c121SKalle Valo DEV_ENTRY 44e705c121SKalle Valo __dynamic_array(u8, data, 4538bd7e58SMordechay Goodstein len - iwl_rx_trace_len(trans, rxbuf, len, NULL)) 46e705c121SKalle Valo ), 47e705c121SKalle Valo TP_fast_assign( 4838bd7e58SMordechay Goodstein size_t offs = iwl_rx_trace_len(trans, rxbuf, len, NULL); 49e705c121SKalle Valo DEV_ASSIGN; 50e705c121SKalle Valo if (offs < len) 51e705c121SKalle Valo memcpy(__get_dynamic_array(data), 52e705c121SKalle Valo ((u8 *)rxbuf) + offs, len - offs); 53e705c121SKalle Valo ), 54e705c121SKalle Valo TP_printk("[%s] RX frame data", __get_str(dev)) 55e705c121SKalle Valo ); 56e705c121SKalle Valo #endif /* __IWLWIFI_DEVICE_TRACE_DATA */ 57e705c121SKalle Valo 58e705c121SKalle Valo #undef TRACE_INCLUDE_PATH 59e705c121SKalle Valo #define TRACE_INCLUDE_PATH . 60e705c121SKalle Valo #undef TRACE_INCLUDE_FILE 61e705c121SKalle Valo #define TRACE_INCLUDE_FILE iwl-devtrace-data 62e705c121SKalle Valo #include <trace/define_trace.h> 63