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 * 653e0c72dSLiam Girdwood * Copyright(c) 2018 Intel Corporation. All rights reserved. 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 46*8f6cfbb6SKarol Trzcinski /* Values used in sof_ipc_trace_filter_elem: */ 47*8f6cfbb6SKarol Trzcinski 48*8f6cfbb6SKarol Trzcinski /* bits 6..0 */ 49*8f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_SET_LEVEL 0x01 /**< trace level for selected components */ 50*8f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_UUID 0x02 /**< filter by uuid key */ 51*8f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_PIPE 0x03 /**< filter by pipeline */ 52*8f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_BY_COMP 0x04 /**< filter by component id */ 53*8f6cfbb6SKarol Trzcinski 54*8f6cfbb6SKarol Trzcinski /* bit 7 */ 55*8f6cfbb6SKarol Trzcinski #define SOF_IPC_TRACE_FILTER_ELEM_FIN 0x80 /**< mark last filter in set */ 56*8f6cfbb6SKarol Trzcinski 57*8f6cfbb6SKarol Trzcinski /* bits 31..8: Unused */ 58*8f6cfbb6SKarol Trzcinski 59*8f6cfbb6SKarol Trzcinski /** part of sof_ipc_trace_filter, ABI3.17 */ 60*8f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter_elem { 61*8f6cfbb6SKarol Trzcinski uint32_t key; /**< SOF_IPC_TRACE_FILTER_ELEM_ {LEVEL, UUID, COMP, PIPE} */ 62*8f6cfbb6SKarol Trzcinski uint32_t value; /**< element value */ 63*8f6cfbb6SKarol Trzcinski } __packed; 64*8f6cfbb6SKarol Trzcinski 65*8f6cfbb6SKarol Trzcinski /** Runtime tracing filtration data - SOF_IPC_TRACE_FILTER_UPDATE, ABI3.17 */ 66*8f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter { 67*8f6cfbb6SKarol Trzcinski struct sof_ipc_cmd_hdr hdr; /**< IPC command header */ 68*8f6cfbb6SKarol Trzcinski uint32_t elem_cnt; /**< number of entries in elems[] array */ 69*8f6cfbb6SKarol Trzcinski uint32_t reserved[8]; /**< reserved for future usage */ 70*8f6cfbb6SKarol Trzcinski /** variable size array with new filtering settings */ 71*8f6cfbb6SKarol Trzcinski struct sof_ipc_trace_filter_elem elems[]; 72*8f6cfbb6SKarol Trzcinski } __packed; 73*8f6cfbb6SKarol 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