1 /* Copyright(c) 2022 Intel Corporation. All rights reserved.
2 * SPDX-License-Identifier: Apache-2.0
3 */
4
5 #include <zephyr/cache.h>
6 #include <zephyr/device.h>
7 #include <zephyr/devicetree.h>
8 #include <zephyr/arch/cpu.h>
9
10 #include <adsp_memory.h>
11 #include <adsp_shim.h>
12 #include <mem_window.h>
13 #include <soc_util.h>
14
15 /* host windows */
16 #define DMWBA(win_base) (win_base + 0x0)
17 #define DMWLO(win_base) (win_base + 0x4)
18
19 #define DT_DRV_COMPAT intel_adsp_mem_window
20
mem_win_init(const struct device * dev)21 __imr int mem_win_init(const struct device *dev)
22 {
23 const struct mem_win_config *config = dev->config;
24
25 if (config->initialize) {
26 bbzero((void *)config->mem_base, config->size);
27 }
28
29 sys_write32(config->size | 0x7, DMWLO(config->base_addr));
30 if (config->read_only) {
31 sys_write32((config->mem_base | ADSP_DMWBA_READONLY | ADSP_DMWBA_ENABLE),
32 DMWBA(config->base_addr));
33 } else {
34 sys_write32((config->mem_base | ADSP_DMWBA_ENABLE), DMWBA(config->base_addr));
35 }
36
37 return 0;
38 }
39
mem_window_idle_exit(void)40 void mem_window_idle_exit(void)
41 {
42 mem_win_init(DEVICE_DT_GET(MEM_WINDOW_NODE(0)));
43 mem_win_init(DEVICE_DT_GET(MEM_WINDOW_NODE(1)));
44 mem_win_init(DEVICE_DT_GET(MEM_WINDOW_NODE(2)));
45 mem_win_init(DEVICE_DT_GET(MEM_WINDOW_NODE(3)));
46 }
47
48 #define MEM_WINDOW_DEFINE(n) \
49 static const struct mem_win_config mem_win_config_##n = { \
50 .base_addr = DT_REG_ADDR(MEM_WINDOW_NODE(n)), \
51 .size = WIN_SIZE(n), \
52 .offset = WIN_OFFSET(n), \
53 .read_only = DT_PROP(MEM_WINDOW_NODE(n), read_only), \
54 .mem_base = DT_REG_ADDR(DT_PHANDLE(MEM_WINDOW_NODE(n), memory)) + WIN_OFFSET(n), \
55 .initialize = DT_PROP(MEM_WINDOW_NODE(n), initialize), \
56 }; \
57 DEVICE_DT_DEFINE(MEM_WINDOW_NODE(n), mem_win_init, NULL, NULL, \
58 &mem_win_config_##n, PRE_KERNEL_1, \
59 CONFIG_KERNEL_INIT_PRIORITY_DEFAULT, NULL);
60
61 #if DT_NODE_HAS_STATUS_OKAY(MEM_WINDOW_NODE(0))
62 MEM_WINDOW_DEFINE(0)
63 #endif
64 #if DT_NODE_HAS_STATUS_OKAY(MEM_WINDOW_NODE(1))
65 MEM_WINDOW_DEFINE(1)
66 #endif
67 #if DT_NODE_HAS_STATUS_OKAY(MEM_WINDOW_NODE(2))
68 MEM_WINDOW_DEFINE(2)
69 #endif
70 #if DT_NODE_HAS_STATUS_OKAY(MEM_WINDOW_NODE(3))
71 MEM_WINDOW_DEFINE(3)
72 #endif
73