Merge branch 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/evalenti/linux...
[linux/fpc-iii.git] / sound / soc / intel / skylake / skl-sst-cldma.h
blob99e4c86b6358594941e06de887e2750b874ce305
1 /*
2 * Intel Code Loader DMA support
4 * Copyright (C) 2015, Intel Corporation.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as version 2, as
8 * published by the Free Software Foundation.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
16 #ifndef SKL_SST_CLDMA_H_
17 #define SKL_SST_CLDMA_H_
19 #define FW_CL_STREAM_NUMBER 0x1
21 #define DMA_ADDRESS_128_BITS_ALIGNMENT 7
22 #define BDL_ALIGN(x) (x >> DMA_ADDRESS_128_BITS_ALIGNMENT)
24 #define SKL_ADSPIC_CL_DMA 0x2
25 #define SKL_ADSPIS_CL_DMA 0x2
26 #define SKL_CL_DMA_SD_INT_DESC_ERR 0x10 /* Descriptor error interrupt */
27 #define SKL_CL_DMA_SD_INT_FIFO_ERR 0x08 /* FIFO error interrupt */
28 #define SKL_CL_DMA_SD_INT_COMPLETE 0x04 /* Buffer completion interrupt */
30 /* Intel HD Audio Code Loader DMA Registers */
32 #define HDA_ADSP_LOADER_BASE 0x80
34 /* Stream Registers */
35 #define SKL_ADSP_REG_CL_SD_CTL (HDA_ADSP_LOADER_BASE + 0x00)
36 #define SKL_ADSP_REG_CL_SD_STS (HDA_ADSP_LOADER_BASE + 0x03)
37 #define SKL_ADSP_REG_CL_SD_LPIB (HDA_ADSP_LOADER_BASE + 0x04)
38 #define SKL_ADSP_REG_CL_SD_CBL (HDA_ADSP_LOADER_BASE + 0x08)
39 #define SKL_ADSP_REG_CL_SD_LVI (HDA_ADSP_LOADER_BASE + 0x0c)
40 #define SKL_ADSP_REG_CL_SD_FIFOW (HDA_ADSP_LOADER_BASE + 0x0e)
41 #define SKL_ADSP_REG_CL_SD_FIFOSIZE (HDA_ADSP_LOADER_BASE + 0x10)
42 #define SKL_ADSP_REG_CL_SD_FORMAT (HDA_ADSP_LOADER_BASE + 0x12)
43 #define SKL_ADSP_REG_CL_SD_FIFOL (HDA_ADSP_LOADER_BASE + 0x14)
44 #define SKL_ADSP_REG_CL_SD_BDLPL (HDA_ADSP_LOADER_BASE + 0x18)
45 #define SKL_ADSP_REG_CL_SD_BDLPU (HDA_ADSP_LOADER_BASE + 0x1c)
47 /* CL: Software Position Based FIFO Capability Registers */
48 #define SKL_ADSP_REG_CL_SPBFIFO (HDA_ADSP_LOADER_BASE + 0x20)
49 #define SKL_ADSP_REG_CL_SPBFIFO_SPBFCH (SKL_ADSP_REG_CL_SPBFIFO + 0x0)
50 #define SKL_ADSP_REG_CL_SPBFIFO_SPBFCCTL (SKL_ADSP_REG_CL_SPBFIFO + 0x4)
51 #define SKL_ADSP_REG_CL_SPBFIFO_SPIB (SKL_ADSP_REG_CL_SPBFIFO + 0x8)
52 #define SKL_ADSP_REG_CL_SPBFIFO_MAXFIFOS (SKL_ADSP_REG_CL_SPBFIFO + 0xc)
54 /* CL: Stream Descriptor x Control */
56 /* Stream Reset */
57 #define CL_SD_CTL_SRST_SHIFT 0
58 #define CL_SD_CTL_SRST_MASK (1 << CL_SD_CTL_SRST_SHIFT)
59 #define CL_SD_CTL_SRST(x) \
60 ((x << CL_SD_CTL_SRST_SHIFT) & CL_SD_CTL_SRST_MASK)
62 /* Stream Run */
63 #define CL_SD_CTL_RUN_SHIFT 1
64 #define CL_SD_CTL_RUN_MASK (1 << CL_SD_CTL_RUN_SHIFT)
65 #define CL_SD_CTL_RUN(x) \
66 ((x << CL_SD_CTL_RUN_SHIFT) & CL_SD_CTL_RUN_MASK)
68 /* Interrupt On Completion Enable */
69 #define CL_SD_CTL_IOCE_SHIFT 2
70 #define CL_SD_CTL_IOCE_MASK (1 << CL_SD_CTL_IOCE_SHIFT)
71 #define CL_SD_CTL_IOCE(x) \
72 ((x << CL_SD_CTL_IOCE_SHIFT) & CL_SD_CTL_IOCE_MASK)
74 /* FIFO Error Interrupt Enable */
75 #define CL_SD_CTL_FEIE_SHIFT 3
76 #define CL_SD_CTL_FEIE_MASK (1 << CL_SD_CTL_FEIE_SHIFT)
77 #define CL_SD_CTL_FEIE(x) \
78 ((x << CL_SD_CTL_FEIE_SHIFT) & CL_SD_CTL_FEIE_MASK)
80 /* Descriptor Error Interrupt Enable */
81 #define CL_SD_CTL_DEIE_SHIFT 4
82 #define CL_SD_CTL_DEIE_MASK (1 << CL_SD_CTL_DEIE_SHIFT)
83 #define CL_SD_CTL_DEIE(x) \
84 ((x << CL_SD_CTL_DEIE_SHIFT) & CL_SD_CTL_DEIE_MASK)
86 /* FIFO Limit Change */
87 #define CL_SD_CTL_FIFOLC_SHIFT 5
88 #define CL_SD_CTL_FIFOLC_MASK (1 << CL_SD_CTL_FIFOLC_SHIFT)
89 #define CL_SD_CTL_FIFOLC(x) \
90 ((x << CL_SD_CTL_FIFOLC_SHIFT) & CL_SD_CTL_FIFOLC_MASK)
92 /* Stripe Control */
93 #define CL_SD_CTL_STRIPE_SHIFT 16
94 #define CL_SD_CTL_STRIPE_MASK (0x3 << CL_SD_CTL_STRIPE_SHIFT)
95 #define CL_SD_CTL_STRIPE(x) \
96 ((x << CL_SD_CTL_STRIPE_SHIFT) & CL_SD_CTL_STRIPE_MASK)
98 /* Traffic Priority */
99 #define CL_SD_CTL_TP_SHIFT 18
100 #define CL_SD_CTL_TP_MASK (1 << CL_SD_CTL_TP_SHIFT)
101 #define CL_SD_CTL_TP(x) \
102 ((x << CL_SD_CTL_TP_SHIFT) & CL_SD_CTL_TP_MASK)
104 /* Bidirectional Direction Control */
105 #define CL_SD_CTL_DIR_SHIFT 19
106 #define CL_SD_CTL_DIR_MASK (1 << CL_SD_CTL_DIR_SHIFT)
107 #define CL_SD_CTL_DIR(x) \
108 ((x << CL_SD_CTL_DIR_SHIFT) & CL_SD_CTL_DIR_MASK)
110 /* Stream Number */
111 #define CL_SD_CTL_STRM_SHIFT 20
112 #define CL_SD_CTL_STRM_MASK (0xf << CL_SD_CTL_STRM_SHIFT)
113 #define CL_SD_CTL_STRM(x) \
114 ((x << CL_SD_CTL_STRM_SHIFT) & CL_SD_CTL_STRM_MASK)
116 /* CL: Stream Descriptor x Status */
118 /* Buffer Completion Interrupt Status */
119 #define CL_SD_STS_BCIS(x) CL_SD_CTL_IOCE(x)
121 /* FIFO Error */
122 #define CL_SD_STS_FIFOE(x) CL_SD_CTL_FEIE(x)
124 /* Descriptor Error */
125 #define CL_SD_STS_DESE(x) CL_SD_CTL_DEIE(x)
127 /* FIFO Ready */
128 #define CL_SD_STS_FIFORDY(x) CL_SD_CTL_FIFOLC(x)
131 /* CL: Stream Descriptor x Last Valid Index */
132 #define CL_SD_LVI_SHIFT 0
133 #define CL_SD_LVI_MASK (0xff << CL_SD_LVI_SHIFT)
134 #define CL_SD_LVI(x) ((x << CL_SD_LVI_SHIFT) & CL_SD_LVI_MASK)
136 /* CL: Stream Descriptor x FIFO Eviction Watermark */
137 #define CL_SD_FIFOW_SHIFT 0
138 #define CL_SD_FIFOW_MASK (0x7 << CL_SD_FIFOW_SHIFT)
139 #define CL_SD_FIFOW(x) \
140 ((x << CL_SD_FIFOW_SHIFT) & CL_SD_FIFOW_MASK)
142 /* CL: Stream Descriptor x Buffer Descriptor List Pointer Lower Base Address */
144 /* Protect Bits */
145 #define CL_SD_BDLPLBA_PROT_SHIFT 0
146 #define CL_SD_BDLPLBA_PROT_MASK (1 << CL_SD_BDLPLBA_PROT_SHIFT)
147 #define CL_SD_BDLPLBA_PROT(x) \
148 ((x << CL_SD_BDLPLBA_PROT_SHIFT) & CL_SD_BDLPLBA_PROT_MASK)
150 /* Buffer Descriptor List Lower Base Address */
151 #define CL_SD_BDLPLBA_SHIFT 7
152 #define CL_SD_BDLPLBA_MASK (0x1ffffff << CL_SD_BDLPLBA_SHIFT)
153 #define CL_SD_BDLPLBA(x) \
154 ((BDL_ALIGN(lower_32_bits(x)) << CL_SD_BDLPLBA_SHIFT) & CL_SD_BDLPLBA_MASK)
156 /* Buffer Descriptor List Upper Base Address */
157 #define CL_SD_BDLPUBA_SHIFT 0
158 #define CL_SD_BDLPUBA_MASK (0xffffffff << CL_SD_BDLPUBA_SHIFT)
159 #define CL_SD_BDLPUBA(x) \
160 ((upper_32_bits(x) << CL_SD_BDLPUBA_SHIFT) & CL_SD_BDLPUBA_MASK)
163 * Code Loader - Software Position Based FIFO
164 * Capability Registers x Software Position Based FIFO Header
167 /* Next Capability Pointer */
168 #define CL_SPBFIFO_SPBFCH_PTR_SHIFT 0
169 #define CL_SPBFIFO_SPBFCH_PTR_MASK (0xff << CL_SPBFIFO_SPBFCH_PTR_SHIFT)
170 #define CL_SPBFIFO_SPBFCH_PTR(x) \
171 ((x << CL_SPBFIFO_SPBFCH_PTR_SHIFT) & CL_SPBFIFO_SPBFCH_PTR_MASK)
173 /* Capability Identifier */
174 #define CL_SPBFIFO_SPBFCH_ID_SHIFT 16
175 #define CL_SPBFIFO_SPBFCH_ID_MASK (0xfff << CL_SPBFIFO_SPBFCH_ID_SHIFT)
176 #define CL_SPBFIFO_SPBFCH_ID(x) \
177 ((x << CL_SPBFIFO_SPBFCH_ID_SHIFT) & CL_SPBFIFO_SPBFCH_ID_MASK)
179 /* Capability Version */
180 #define CL_SPBFIFO_SPBFCH_VER_SHIFT 28
181 #define CL_SPBFIFO_SPBFCH_VER_MASK (0xf << CL_SPBFIFO_SPBFCH_VER_SHIFT)
182 #define CL_SPBFIFO_SPBFCH_VER(x) \
183 ((x << CL_SPBFIFO_SPBFCH_VER_SHIFT) & CL_SPBFIFO_SPBFCH_VER_MASK)
185 /* Software Position in Buffer Enable */
186 #define CL_SPBFIFO_SPBFCCTL_SPIBE_SHIFT 0
187 #define CL_SPBFIFO_SPBFCCTL_SPIBE_MASK (1 << CL_SPBFIFO_SPBFCCTL_SPIBE_SHIFT)
188 #define CL_SPBFIFO_SPBFCCTL_SPIBE(x) \
189 ((x << CL_SPBFIFO_SPBFCCTL_SPIBE_SHIFT) & CL_SPBFIFO_SPBFCCTL_SPIBE_MASK)
191 /* SST IPC SKL defines */
192 #define SKL_WAIT_TIMEOUT 500 /* 500 msec */
193 #define SKL_MAX_BUFFER_SIZE (32 * PAGE_SIZE)
195 enum skl_cl_dma_wake_states {
196 SKL_CL_DMA_STATUS_NONE = 0,
197 SKL_CL_DMA_BUF_COMPLETE,
198 SKL_CL_DMA_ERR, /* TODO: Expand the error states */
201 struct sst_dsp;
203 struct skl_cl_dev_ops {
204 void (*cl_setup_bdle)(struct sst_dsp *ctx,
205 struct snd_dma_buffer *dmab_data,
206 u32 **bdlp, int size, int with_ioc);
207 void (*cl_setup_controller)(struct sst_dsp *ctx,
208 struct snd_dma_buffer *dmab_bdl,
209 unsigned int max_size, u32 page_count);
210 void (*cl_setup_spb)(struct sst_dsp *ctx,
211 unsigned int size, bool enable);
212 void (*cl_cleanup_spb)(struct sst_dsp *ctx);
213 void (*cl_trigger)(struct sst_dsp *ctx, bool enable);
214 void (*cl_cleanup_controller)(struct sst_dsp *ctx);
215 int (*cl_copy_to_dmabuf)(struct sst_dsp *ctx,
216 const void *bin, u32 size);
217 void (*cl_stop_dma)(struct sst_dsp *ctx);
221 * skl_cl_dev - holds information for code loader dma transfer
223 * @dmab_data: buffer pointer
224 * @dmab_bdl: buffer descriptor list
225 * @bufsize: ring buffer size
226 * @frags: Last valid buffer descriptor index in the BDL
227 * @curr_spib_pos: Current position in ring buffer
228 * @dma_buffer_offset: dma buffer offset
229 * @ops: operations supported on CL dma
230 * @wait_queue: wait queue to wake for wake event
231 * @wake_status: DMA wake status
232 * @wait_condition: condition to wait on wait queue
233 * @cl_dma_lock: for synchronized access to cldma
235 struct skl_cl_dev {
236 struct snd_dma_buffer dmab_data;
237 struct snd_dma_buffer dmab_bdl;
239 unsigned int bufsize;
240 unsigned int frags;
242 unsigned int curr_spib_pos;
243 unsigned int dma_buffer_offset;
244 struct skl_cl_dev_ops ops;
246 wait_queue_head_t wait_queue;
247 int wake_status;
248 bool wait_condition;
251 #endif /* SKL_SST_CLDMA_H_ */