1 /* Copyright (c) 2021 Intel Corporation 2 * SPDX-License-Identifier: Apache-2.0 3 */ 4 #ifndef _ZEPHYR_SOC_INTEL_ADSP_DEBUG_WINDOW 5 #define _ZEPHYR_SOC_INTEL_ADSP_DEBUG_WINDOW 6 7 #include <mem_window.h> 8 #include <zephyr/debug/sparse.h> 9 #include <zephyr/cache.h> 10 11 /* 12 * SRAM window for debug info (window 2) is organized in slots, 13 * described in the descriptors available on page 0. 14 * 15 * ------------------------ 16 * | Page0 - descriptors | 17 * ------------------------ 18 * | Page1 - slot0 | 19 * ------------------------ 20 * | Page2 - slot1 | 21 * ------------------------ 22 * | ... | 23 * ------------------------ 24 * | Page14 - slot13 | 25 * ------------------------ 26 * | Page15 - slot14 | 27 * ------------------------ 28 * 29 * The slot size == page size 30 * 31 * The first page contains descriptors for the remaining slots. 32 * The overall number of slots can vary based on platform. 33 * 34 * The slot descriptor is: 35 * u32 res_id; 36 * u32 type; 37 * u32 vma; 38 */ 39 40 #define ADSP_DW_PAGE_SIZE 0x1000 41 #define ADSP_DW_SLOT_SIZE ADSP_DW_PAGE_SIZE 42 #define ADSP_DW_SLOT_COUNT 15 43 44 /* debug window slots usage */ 45 #define ADSP_DW_SLOT_NUM_TRACE 1 46 #define ADSP_DW_SLOT_NUM_SHELL 0 47 48 /* debug log slot types */ 49 #define ADSP_DW_SLOT_UNUSED 0x00000000 50 #define ADSP_DW_SLOT_CRITICAL_LOG 0x54524300 51 #define ADSP_DW_SLOT_DEBUG_LOG 0x474f4c00 /* byte 0: core ID */ 52 #define ADSP_DW_SLOT_GDB_STUB 0x42444700 53 #define ADSP_DW_SLOT_TELEMETRY 0x4c455400 54 #define ADSP_DW_SLOT_TRACE 0x54524143 55 #define ADSP_DW_SLOT_SHELL 0x73686c6c 56 #define ADSP_DW_SLOT_DEBUG_STREAM 0x53523134 57 #define ADSP_DW_SLOT_BROKEN 0x44414544 58 59 /* for debug and critical types */ 60 #define ADSP_DW_SLOT_CORE_MASK GENMASK(7, 0) 61 #define ADSP_DW_SLOT_TYPE_MASK GENMASK(31, 8) 62 63 struct adsp_dw_desc { 64 uint32_t resource_id; 65 uint32_t type; 66 uint32_t vma; 67 } __packed; 68 69 struct adsp_debug_window { 70 struct adsp_dw_desc descs[ADSP_DW_SLOT_COUNT]; 71 uint8_t reserved[ADSP_DW_SLOT_SIZE - ADSP_DW_SLOT_COUNT * sizeof(struct adsp_dw_desc)]; 72 uint8_t slots[ADSP_DW_SLOT_COUNT][ADSP_DW_SLOT_SIZE]; 73 } __packed; 74 75 #define WIN2_MBASE DT_REG_ADDR(DT_PHANDLE(DT_NODELABEL(mem_window2), memory)) 76 77 #define ADSP_DW ((volatile struct adsp_debug_window *) \ 78 (sys_cache_uncached_ptr_get((__sparse_force void __sparse_cache *) \ 79 (WIN2_MBASE + WIN2_OFFSET)))) 80 81 #endif 82