Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/sound/soc/intel/avs/registers.h
38189 views
1
/* SPDX-License-Identifier: GPL-2.0-only */
2
/*
3
* Copyright(c) 2021-2022 Intel Corporation
4
*
5
* Authors: Cezary Rojewski <[email protected]>
6
* Amadeusz Slawinski <[email protected]>
7
*/
8
9
#ifndef __SOUND_SOC_INTEL_AVS_REGS_H
10
#define __SOUND_SOC_INTEL_AVS_REGS_H
11
12
#include <linux/io-64-nonatomic-lo-hi.h>
13
#include <linux/iopoll.h>
14
#include <linux/sizes.h>
15
16
#define AZX_PCIREG_PGCTL 0x44
17
#define AZX_PCIREG_CGCTL 0x48
18
#define AZX_PGCTL_LSRMD_MASK BIT(4)
19
#define AZX_CGCTL_MISCBDCGE_MASK BIT(6)
20
#define AZX_VS_EM2_L1SEN BIT(13)
21
#define AZX_VS_EM2_DUM BIT(23)
22
23
/* Intel HD Audio General DSP Registers */
24
#define AVS_ADSP_GEN_BASE 0x0
25
#define AVS_ADSP_REG_ADSPCS (AVS_ADSP_GEN_BASE + 0x04)
26
#define AVS_ADSP_REG_ADSPIC (AVS_ADSP_GEN_BASE + 0x08)
27
#define AVS_ADSP_REG_ADSPIS (AVS_ADSP_GEN_BASE + 0x0C)
28
29
#define AVS_ADSP_ADSPIC_IPC BIT(0)
30
#define AVS_ADSP_ADSPIC_CLDMA BIT(1)
31
#define AVS_ADSP_ADSPIS_IPC BIT(0)
32
#define AVS_ADSP_ADSPIS_CLDMA BIT(1)
33
34
#define AVS_ADSPCS_CRST_MASK(cm) (cm)
35
#define AVS_ADSPCS_CSTALL_MASK(cm) ((cm) << 8)
36
#define AVS_ADSPCS_SPA_MASK(cm) ((cm) << 16)
37
#define AVS_ADSPCS_CPA_MASK(cm) ((cm) << 24)
38
#define AVS_ADSPCS_INTERVAL_US 500
39
#define AVS_ADSPCS_TIMEOUT_US 10000
40
#define AVS_MAIN_CORE_MASK BIT(0)
41
42
#define AVS_ADSP_HIPCCTL_BUSY BIT(0)
43
#define AVS_ADSP_HIPCCTL_DONE BIT(1)
44
45
/* SKL Intel HD Audio Inter-Processor Communication Registers */
46
#define SKL_ADSP_IPC_BASE 0x40
47
#define SKL_ADSP_REG_HIPCT (SKL_ADSP_IPC_BASE + 0x00)
48
#define SKL_ADSP_REG_HIPCTE (SKL_ADSP_IPC_BASE + 0x04)
49
#define SKL_ADSP_REG_HIPCI (SKL_ADSP_IPC_BASE + 0x08)
50
#define SKL_ADSP_REG_HIPCIE (SKL_ADSP_IPC_BASE + 0x0C)
51
#define SKL_ADSP_REG_HIPCCTL (SKL_ADSP_IPC_BASE + 0x10)
52
53
#define SKL_ADSP_HIPCI_BUSY BIT(31)
54
#define SKL_ADSP_HIPCIE_DONE BIT(30)
55
#define SKL_ADSP_HIPCT_BUSY BIT(31)
56
57
/* CNL Intel HD Audio Inter-Processor Communication Registers */
58
#define CNL_ADSP_IPC_BASE 0xC0
59
#define CNL_ADSP_REG_HIPCTDR (CNL_ADSP_IPC_BASE + 0x00)
60
#define CNL_ADSP_REG_HIPCTDA (CNL_ADSP_IPC_BASE + 0x04)
61
#define CNL_ADSP_REG_HIPCTDD (CNL_ADSP_IPC_BASE + 0x08)
62
#define CNL_ADSP_REG_HIPCIDR (CNL_ADSP_IPC_BASE + 0x10)
63
#define CNL_ADSP_REG_HIPCIDA (CNL_ADSP_IPC_BASE + 0x14)
64
#define CNL_ADSP_REG_HIPCIDD (CNL_ADSP_IPC_BASE + 0x18)
65
#define CNL_ADSP_REG_HIPCCTL (CNL_ADSP_IPC_BASE + 0x28)
66
67
#define CNL_ADSP_HIPCTDR_BUSY BIT(31)
68
#define CNL_ADSP_HIPCTDA_DONE BIT(31)
69
#define CNL_ADSP_HIPCIDR_BUSY BIT(31)
70
#define CNL_ADSP_HIPCIDA_DONE BIT(31)
71
72
/* MTL Intel HOST Inter-Processor Communication Registers */
73
#define MTL_HfIPC_BASE 0x73000
74
#define MTL_REG_HfIPCxTDR (MTL_HfIPC_BASE + 0x200)
75
#define MTL_REG_HfIPCxTDA (MTL_HfIPC_BASE + 0x204)
76
#define MTL_REG_HfIPCxIDR (MTL_HfIPC_BASE + 0x210)
77
#define MTL_REG_HfIPCxIDA (MTL_HfIPC_BASE + 0x214)
78
#define MTL_REG_HfIPCxCTL (MTL_HfIPC_BASE + 0x228)
79
#define MTL_REG_HfIPCxTDD (MTL_HfIPC_BASE + 0x300)
80
#define MTL_REG_HfIPCxIDD (MTL_HfIPC_BASE + 0x380)
81
82
#define MTL_HfIPCxTDR_BUSY BIT(31)
83
#define MTL_HfIPCxTDA_BUSY BIT(31)
84
#define MTL_HfIPCxIDR_BUSY BIT(31)
85
#define MTL_HfIPCxIDA_DONE BIT(31)
86
87
#define MTL_HfFLV_BASE 0x162000
88
#define MTL_REG_HfFLGP(x, y) (MTL_HfFLV_BASE + 0x1200 + (x) * 0x20 + (y) * 0x08)
89
#define LNL_REG_HfDFR(x) (0x160200 + (x) * 0x8)
90
91
#define MTL_DWICTL_BASE 0x1800
92
#define MTL_DWICTL_REG_INTENL (MTL_DWICTL_BASE + 0x0)
93
#define MTL_DWICTL_REG_FINALSTATUSL (MTL_DWICTL_BASE + 0x30)
94
95
#define MTL_HfPMCCU_BASE 0x1D00
96
#define MTL_REG_HfCLKCTL (MTL_HfPMCCU_BASE + 0x10)
97
#define MTL_REG_HfPWRCTL (MTL_HfPMCCU_BASE + 0x18)
98
#define MTL_REG_HfPWRSTS (MTL_HfPMCCU_BASE + 0x1C)
99
#define MTL_REG_HfPWRCTL2 (MTL_HfPMCCU_BASE + 0x20)
100
#define MTL_REG_HfPWRSTS2 (MTL_HfPMCCU_BASE + 0x24)
101
#define MTL_HfPWRCTL_WPDSPHPxPG BIT(0)
102
#define MTL_HfPWRSTS_DSPHPxPGS BIT(0)
103
#define MTL_HfPWRCTL2_WPDSPHPxPG BIT(0)
104
#define MTL_HfPWRSTS2_DSPHPxPGS BIT(0)
105
106
/* Intel HD Audio SRAM windows base addresses */
107
#define SKL_ADSP_SRAM_BASE_OFFSET 0x8000
108
#define SKL_ADSP_SRAM_WINDOW_SIZE 0x2000
109
#define APL_ADSP_SRAM_BASE_OFFSET 0x80000
110
#define APL_ADSP_SRAM_WINDOW_SIZE 0x20000
111
#define MTL_ADSP_SRAM_BASE_OFFSET 0x180000
112
#define MTL_ADSP_SRAM_WINDOW_SIZE 0x8000
113
114
/* Constants used when accessing SRAM, space shared with firmware */
115
#define AVS_FW_REG_BASE(adev) ((adev)->spec->hipc->sts_offset)
116
#define AVS_FW_REG_STATUS(adev) (AVS_FW_REG_BASE(adev) + 0x0)
117
#define AVS_FW_REG_ERROR(adev) (AVS_FW_REG_BASE(adev) + 0x4)
118
119
#define AVS_WINDOW_CHUNK_SIZE SZ_4K
120
#define AVS_FW_REGS_SIZE AVS_WINDOW_CHUNK_SIZE
121
#define AVS_FW_REGS_WINDOW 0
122
/* DSP -> HOST communication window */
123
#define AVS_UPLINK_WINDOW AVS_FW_REGS_WINDOW
124
/* HOST -> DSP communication window */
125
#define AVS_DOWNLINK_WINDOW 1
126
#define AVS_DEBUG_WINDOW 2
127
128
/* registry I/O helpers */
129
#define avs_sram_offset(adev, window_idx) \
130
((adev)->spec->sram->base_offset + \
131
(adev)->spec->sram->window_size * (window_idx))
132
133
#define avs_sram_addr(adev, window_idx) \
134
((adev)->dsp_ba + avs_sram_offset(adev, window_idx))
135
136
#define avs_uplink_addr(adev) \
137
(avs_sram_addr(adev, AVS_UPLINK_WINDOW) + AVS_FW_REGS_SIZE)
138
#define avs_downlink_addr(adev) \
139
avs_sram_addr(adev, AVS_DOWNLINK_WINDOW)
140
141
#define snd_hdac_adsp_writeb(adev, reg, value) \
142
snd_hdac_reg_writeb(&(adev)->base.core, (adev)->dsp_ba + (reg), value)
143
#define snd_hdac_adsp_readb(adev, reg) \
144
snd_hdac_reg_readb(&(adev)->base.core, (adev)->dsp_ba + (reg))
145
#define snd_hdac_adsp_writew(adev, reg, value) \
146
snd_hdac_reg_writew(&(adev)->base.core, (adev)->dsp_ba + (reg), value)
147
#define snd_hdac_adsp_readw(adev, reg) \
148
snd_hdac_reg_readw(&(adev)->base.core, (adev)->dsp_ba + (reg))
149
#define snd_hdac_adsp_writel(adev, reg, value) \
150
snd_hdac_reg_writel(&(adev)->base.core, (adev)->dsp_ba + (reg), value)
151
#define snd_hdac_adsp_readl(adev, reg) \
152
snd_hdac_reg_readl(&(adev)->base.core, (adev)->dsp_ba + (reg))
153
#define snd_hdac_adsp_writeq(adev, reg, value) \
154
snd_hdac_reg_writeq(&(adev)->base.core, (adev)->dsp_ba + (reg), value)
155
#define snd_hdac_adsp_readq(adev, reg) \
156
snd_hdac_reg_readq(&(adev)->base.core, (adev)->dsp_ba + (reg))
157
158
#define snd_hdac_adsp_updateb(adev, reg, mask, val) \
159
snd_hdac_adsp_writeb(adev, reg, \
160
(snd_hdac_adsp_readb(adev, reg) & ~(mask)) | (val))
161
#define snd_hdac_adsp_updatew(adev, reg, mask, val) \
162
snd_hdac_adsp_writew(adev, reg, \
163
(snd_hdac_adsp_readw(adev, reg) & ~(mask)) | (val))
164
#define snd_hdac_adsp_updatel(adev, reg, mask, val) \
165
snd_hdac_adsp_writel(adev, reg, \
166
(snd_hdac_adsp_readl(adev, reg) & ~(mask)) | (val))
167
#define snd_hdac_adsp_updateq(adev, reg, mask, val) \
168
snd_hdac_adsp_writeq(adev, reg, \
169
(snd_hdac_adsp_readq(adev, reg) & ~(mask)) | (val))
170
171
#define snd_hdac_adsp_readb_poll(adev, reg, val, cond, delay_us, timeout_us) \
172
readb_poll_timeout((adev)->dsp_ba + (reg), val, cond, \
173
delay_us, timeout_us)
174
#define snd_hdac_adsp_readw_poll(adev, reg, val, cond, delay_us, timeout_us) \
175
readw_poll_timeout((adev)->dsp_ba + (reg), val, cond, \
176
delay_us, timeout_us)
177
#define snd_hdac_adsp_readl_poll(adev, reg, val, cond, delay_us, timeout_us) \
178
readl_poll_timeout((adev)->dsp_ba + (reg), val, cond, \
179
delay_us, timeout_us)
180
#define snd_hdac_adsp_readq_poll(adev, reg, val, cond, delay_us, timeout_us) \
181
readq_poll_timeout((adev)->dsp_ba + (reg), val, cond, \
182
delay_us, timeout_us)
183
184
#endif /* __SOUND_SOC_INTEL_AVS_REGS_H */
185
186