1e149ca29SPierre-Louis Bossart /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */ 253e0c72dSLiam Girdwood /* 353e0c72dSLiam Girdwood * This file is provided under a dual BSD/GPLv2 license. When using or 453e0c72dSLiam Girdwood * redistributing this file, you may do so under either license. 553e0c72dSLiam Girdwood * 6*ea89a742SPierre-Louis Bossart * Copyright(c) 2018 Intel Corporation 753e0c72dSLiam Girdwood */ 853e0c72dSLiam Girdwood 953e0c72dSLiam Girdwood #ifndef __INCLUDE_SOUND_SOF_TRACE_H__ 1053e0c72dSLiam Girdwood #define __INCLUDE_SOUND_SOF_TRACE_H__ 1153e0c72dSLiam Girdwood 1253e0c72dSLiam Girdwood #include <sound/sof/header.h> 1353e0c72dSLiam Girdwood #include <sound/sof/stream.h> 1453e0c72dSLiam Girdwood 1553e0c72dSLiam Girdwood /* 1653e0c72dSLiam Girdwood * DMA for Trace 1753e0c72dSLiam Girdwood */ 1853e0c72dSLiam Girdwood 1953e0c72dSLiam Girdwood #define SOF_TRACE_FILENAME_SIZE 32 2053e0c72dSLiam Girdwood 2153e0c72dSLiam Girdwood /* DMA for Trace params info - SOF_IPC_DEBUG_DMA_PARAMS */ 22e3adc949SBard liao /* Deprecated - use sof_ipc_dma_trace_params_ext */ 2353e0c72dSLiam Girdwood struct sof_ipc_dma_trace_params { 2453e0c72dSLiam Girdwood struct sof_ipc_cmd_hdr hdr; 2553e0c72dSLiam Girdwood struct sof_ipc_host_buffer buffer; 2653e0c72dSLiam Girdwood uint32_t stream_tag; 2753e0c72dSLiam Girdwood } __packed; 2853e0c72dSLiam Girdwood 29e3adc949SBard liao /* DMA for Trace params info - SOF_IPC_DEBUG_DMA_PARAMS_EXT */ 30e3adc949SBard liao struct sof_ipc_dma_trace_params_ext { 31e3adc949SBard liao struct sof_ipc_cmd_hdr hdr; 32e3adc949SBard liao struct sof_ipc_host_buffer buffer; 33e3adc949SBard liao uint32_t stream_tag; 34e3adc949SBard liao uint64_t timestamp_ns; /* in nanosecond */ 35e3adc949SBard liao uint32_t reserved[8]; 36e3adc949SBard liao } __packed; 37e3adc949SBard liao 3853e0c72dSLiam Girdwood /* DMA for Trace params info - SOF_IPC_DEBUG_DMA_PARAMS */ 3953e0c72dSLiam Girdwood struct sof_ipc_dma_trace_posn { 4053e0c72dSLiam Girdwood struct sof_ipc_reply rhdr; 4153e0c72dSLiam Girdwood uint32_t host_offset; /* Offset of DMA host buffer */ 4253e0c72dSLiam Girdwood uint32_t overflow; /* overflow bytes if any */ 4353e0c72dSLiam Girdwood uint32_t messages; /* total trace messages */ 4453e0c72dSLiam Girdwood } __packed; 4553e0c72dSLiam Girdwood 468f6cfbb6SKarol Trzcinski /* Values used in sof_ipc_trace_filter_elem: */ 478f6cfbb6SKarol Trzcinski 488f6cfbb6SKarol Trzcinski /* bits 6..0 */ 498f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_SET_LEVEL 0x01 /**< trace level for selected components */ 508f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_UUID 0x02 /**< filter by uuid key */ 518f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_PIPE 0x03 /**< filter by pipeline */ 528f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_COMP 0x04 /**< filter by component id */ 538f6cfbb6SKarol Trzcinski 548f6cfbb6SKarol Trzcinski /* bit 7 */ 558f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_FIN 0x80 /**< mark last filter in set */ 568f6cfbb6SKarol Trzcinski 578f6cfbb6SKarol Trzcinski /* bits 31..8: Unused */ 588f6cfbb6SKarol Trzcinski 598f6cfbb6SKarol Trzcinski /** part of sof_ipc_trace_filter, ABI3.17 */ 608f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter_elem { 618f6cfbb6SKarol Trzcinski uint32_t key; /**< SOF_IPC_TRACE_FILTER_ELEM_ {LEVEL, UUID, COMP, PIPE} */ 628f6cfbb6SKarol Trzcinski uint32_t value; /**< element value */ 638f6cfbb6SKarol Trzcinski } __packed; 648f6cfbb6SKarol Trzcinski 658f6cfbb6SKarol Trzcinski /** Runtime tracing filtration data - SOF_IPC_TRACE_FILTER_UPDATE, ABI3.17 */ 668f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter { 678f6cfbb6SKarol Trzcinski struct sof_ipc_cmd_hdr hdr; /**< IPC command header */ 688f6cfbb6SKarol Trzcinski uint32_t elem_cnt; /**< number of entries in elems[] array */ 698f6cfbb6SKarol Trzcinski uint32_t reserved[8]; /**< reserved for future usage */ 708f6cfbb6SKarol Trzcinski /** variable size array with new filtering settings */ 718f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter_elem elems[]; 728f6cfbb6SKarol Trzcinski } __packed; 738f6cfbb6SKarol Trzcinski 7453e0c72dSLiam Girdwood /* 7553e0c72dSLiam Girdwood * Commom debug 7653e0c72dSLiam Girdwood */ 7753e0c72dSLiam Girdwood 7853e0c72dSLiam Girdwood /* 7953e0c72dSLiam Girdwood * SOF panic codes 8053e0c72dSLiam Girdwood */ 8153e0c72dSLiam Girdwood #define SOF_IPC_PANIC_MAGIC 0x0dead000 8253e0c72dSLiam Girdwood #define SOF_IPC_PANIC_MAGIC_MASK 0x0ffff000 8353e0c72dSLiam Girdwood #define SOF_IPC_PANIC_CODE_MASK 0x00000fff 8453e0c72dSLiam Girdwood #define SOF_IPC_PANIC_MEM (SOF_IPC_PANIC_MAGIC | 0x0) 8553e0c72dSLiam Girdwood #define SOF_IPC_PANIC_WORK (SOF_IPC_PANIC_MAGIC | 0x1) 8653e0c72dSLiam Girdwood #define SOF_IPC_PANIC_IPC (SOF_IPC_PANIC_MAGIC | 0x2) 8753e0c72dSLiam Girdwood #define SOF_IPC_PANIC_ARCH (SOF_IPC_PANIC_MAGIC | 0x3) 8853e0c72dSLiam Girdwood #define SOF_IPC_PANIC_PLATFORM (SOF_IPC_PANIC_MAGIC | 0x4) 8953e0c72dSLiam Girdwood #define SOF_IPC_PANIC_TASK (SOF_IPC_PANIC_MAGIC | 0x5) 9053e0c72dSLiam Girdwood #define SOF_IPC_PANIC_EXCEPTION (SOF_IPC_PANIC_MAGIC | 0x6) 9153e0c72dSLiam Girdwood #define SOF_IPC_PANIC_DEADLOCK (SOF_IPC_PANIC_MAGIC | 0x7) 9253e0c72dSLiam Girdwood #define SOF_IPC_PANIC_STACK (SOF_IPC_PANIC_MAGIC | 0x8) 9353e0c72dSLiam Girdwood #define SOF_IPC_PANIC_IDLE (SOF_IPC_PANIC_MAGIC | 0x9) 9453e0c72dSLiam Girdwood #define SOF_IPC_PANIC_WFI (SOF_IPC_PANIC_MAGIC | 0xa) 9553e0c72dSLiam Girdwood #define SOF_IPC_PANIC_ASSERT (SOF_IPC_PANIC_MAGIC | 0xb) 9653e0c72dSLiam Girdwood 97b943f798SPierre-Louis Bossart /* panic info include filename and line number 98b943f798SPierre-Louis Bossart * filename array will not include null terminator if fully filled 99b943f798SPierre-Louis Bossart */ 10053e0c72dSLiam Girdwood struct sof_ipc_panic_info { 10153e0c72dSLiam Girdwood struct sof_ipc_hdr hdr; 10253e0c72dSLiam Girdwood uint32_t code; /* SOF_IPC_PANIC_ */ 103f480f804SPan Xiuli uint8_t filename[SOF_TRACE_FILENAME_SIZE]; 10453e0c72dSLiam Girdwood uint32_t linenum; 10553e0c72dSLiam Girdwood } __packed; 10653e0c72dSLiam Girdwood 10753e0c72dSLiam Girdwood #endif 108