2 * Keystone Navigator QMSS driver internal header
4 * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com
5 * Author: Sandeep Nair <sandeep_n@ti.com>
6 * Cyril Chemparathy <cyril@ti.com>
7 * Santosh Shilimkar <santosh.shilimkar@ti.com>
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * version 2 as published by the Free Software Foundation.
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
19 #ifndef __KNAV_QMSS_H__
20 #define __KNAV_QMSS_H__
22 #include <linux/percpu.h>
24 #define THRESH_GTE BIT(7)
27 #define PDSP_CTRL_PC_MASK 0xffff0000
28 #define PDSP_CTRL_SOFT_RESET BIT(0)
29 #define PDSP_CTRL_ENABLE BIT(1)
30 #define PDSP_CTRL_RUNNING BIT(15)
32 #define ACC_MAX_CHANNEL 48
33 #define ACC_DEFAULT_PERIOD 25 /* usecs */
35 #define ACC_CHANNEL_INT_BASE 2
37 #define ACC_LIST_ENTRY_TYPE 1
38 #define ACC_LIST_ENTRY_WORDS (1 << ACC_LIST_ENTRY_TYPE)
39 #define ACC_LIST_ENTRY_QUEUE_IDX 0
40 #define ACC_LIST_ENTRY_DESC_IDX (ACC_LIST_ENTRY_WORDS - 1)
42 #define ACC_CMD_DISABLE_CHANNEL 0x80
43 #define ACC_CMD_ENABLE_CHANNEL 0x81
44 #define ACC_CFG_MULTI_QUEUE BIT(21)
46 #define ACC_INTD_OFFSET_EOI (0x0010)
47 #define ACC_INTD_OFFSET_COUNT(ch) (0x0300 + 4 * (ch))
48 #define ACC_INTD_OFFSET_STATUS(ch) (0x0200 + 4 * ((ch) / 32))
50 #define RANGE_MAX_IRQS 64
52 #define ACC_DESCS_MAX SZ_1K
53 #define ACC_DESCS_MASK (ACC_DESCS_MAX - 1)
54 #define DESC_SIZE_MASK 0xful
55 #define DESC_PTR_MASK (~DESC_SIZE_MASK)
57 #define KNAV_NAME_SIZE 32
59 enum knav_acc_result
{
62 ACC_RET_INVALID_COMMAND
,
63 ACC_RET_INVALID_CHANNEL
,
64 ACC_RET_INACTIVE_CHANNEL
,
65 ACC_RET_ACTIVE_CHANNEL
,
66 ACC_RET_INVALID_QUEUE
,
70 struct knav_reg_config
{
81 struct knav_reg_region
{
88 struct knav_reg_pdsp_regs
{
95 struct knav_reg_acc_command
{
103 struct knav_link_ram_block
{
109 struct knav_acc_info
{
117 struct knav_pdsp_info
*pdsp
;
120 struct knav_acc_channel
{
125 dma_addr_t list_dma
[2];
126 char name
[KNAV_NAME_SIZE
];
127 atomic_t retrigger_count
;
130 struct knav_pdsp_info
{
132 struct knav_reg_pdsp_regs __iomem
*regs
;
134 void __iomem
*command
;
135 struct knav_reg_acc_command __iomem
*acc_command
;
136 u32 __iomem
*qos_command
;
141 struct list_head list
;
146 struct knav_qmgr_info
{
147 unsigned start_queue
;
149 struct knav_reg_config __iomem
*reg_config
;
150 struct knav_reg_region __iomem
*reg_region
;
151 struct knav_reg_queue __iomem
*reg_push
, *reg_pop
, *reg_peek
;
152 void __iomem
*reg_status
;
153 struct list_head list
;
156 #define KNAV_NUM_LINKRAM 2
159 * struct knav_queue_stats: queue statistics
160 * pushes: number of push operations
161 * pops: number of pop operations
162 * push_errors: number of push errors
163 * pop_errors: number of pop errors
164 * notifies: notifier counts
166 struct knav_queue_stats
{
169 unsigned int push_errors
;
170 unsigned int pop_errors
;
171 unsigned int notifies
;
175 * struct knav_reg_queue: queue registers
176 * @entry_count: valid entries in the queue
177 * @byte_count: total byte count in thhe queue
178 * @packet_size: packet size for the queue
179 * @ptr_size_thresh: packet pointer size threshold
181 struct knav_reg_queue
{
189 * struct knav_region: qmss region info
190 * @dma_start, dma_end: start and end dma address
191 * @virt_start, virt_end: start and end virtual address
192 * @desc_size: descriptor size
193 * @used_desc: consumed descriptors
195 * @num_desc: total descriptors
196 * @link_index: index of the first descriptor
198 * @list: instance in the device's region list
199 * @pools: list of descriptor pools in the region
202 dma_addr_t dma_start
, dma_end
;
203 void *virt_start
, *virt_end
;
210 struct list_head list
;
211 struct list_head pools
;
215 * struct knav_pool: qmss pools
216 * @dev: device pointer
217 * @region: qmss region info
218 * @queue: queue registers
219 * @kdev: qmss device pointer
220 * @region_offset: offset from the base
221 * @num_desc: total descriptors
222 * @desc_size: descriptor size
223 * @region_id: region number
226 * @region_inst: instance in the region's pool list
230 struct knav_region
*region
;
231 struct knav_queue
*queue
;
232 struct knav_device
*kdev
;
238 struct list_head list
;
239 struct list_head region_inst
;
243 * struct knav_queue_inst: qmss queue instace properties
244 * @descs: descriptor pointer
245 * @desc_head, desc_tail, desc_count: descriptor counters
246 * @acc: accumulator channel pointer
247 * @kdev: qmss device pointer
249 * @qmgr: queue manager info
250 * @id: queue instace id
251 * @irq_num: irq line number
252 * @notify_needed: notifier needed based on queue type
253 * @num_notifiers: total notifiers
254 * @handles: list head
255 * @name: queue instance name
256 * @irq_name: irq line name
258 struct knav_queue_inst
{
260 atomic_t desc_head
, desc_tail
, desc_count
;
261 struct knav_acc_channel
*acc
;
262 struct knav_device
*kdev
;
263 struct knav_range_info
*range
;
264 struct knav_qmgr_info
*qmgr
;
268 atomic_t num_notifiers
;
269 struct list_head handles
;
271 const char *irq_name
;
275 * struct knav_queue: qmss queue properties
276 * @reg_push, reg_pop, reg_peek: push, pop queue registers
277 * @inst: qmss queue instace properties
278 * @notifier_fn: notifier function
279 * @notifier_fn_arg: notifier function argument
280 * @notifier_enabled: notier enabled for a give queue
282 * @flags: queue flags
286 struct knav_reg_queue __iomem
*reg_push
, *reg_pop
, *reg_peek
;
287 struct knav_queue_inst
*inst
;
288 struct knav_queue_stats __percpu
*stats
;
289 knav_queue_notify_fn notifier_fn
;
290 void *notifier_fn_arg
;
291 atomic_t notifier_enabled
;
294 struct list_head list
;
306 unsigned num_queues_in_use
;
308 struct knav_link_ram_block link_rams
[KNAV_NUM_LINKRAM
];
310 struct list_head regions
;
311 struct list_head queue_ranges
;
312 struct list_head pools
;
313 struct list_head pdsps
;
314 struct list_head qmgrs
;
315 enum qmss_version version
;
318 struct knav_range_ops
{
319 int (*init_range
)(struct knav_range_info
*range
);
320 int (*free_range
)(struct knav_range_info
*range
);
321 int (*init_queue
)(struct knav_range_info
*range
,
322 struct knav_queue_inst
*inst
);
323 int (*open_queue
)(struct knav_range_info
*range
,
324 struct knav_queue_inst
*inst
, unsigned flags
);
325 int (*close_queue
)(struct knav_range_info
*range
,
326 struct knav_queue_inst
*inst
);
327 int (*set_notify
)(struct knav_range_info
*range
,
328 struct knav_queue_inst
*inst
, bool enabled
);
331 struct knav_irq_info
{
336 struct knav_range_info
{
338 struct knav_device
*kdev
;
341 void *queue_base_inst
;
343 struct list_head list
;
344 struct knav_range_ops
*ops
;
345 struct knav_acc_info acc_info
;
346 struct knav_acc_channel
*acc
;
348 struct knav_irq_info irqs
[RANGE_MAX_IRQS
];
351 #define RANGE_RESERVED BIT(0)
352 #define RANGE_HAS_IRQ BIT(1)
353 #define RANGE_HAS_ACCUMULATOR BIT(2)
354 #define RANGE_MULTI_QUEUE BIT(3)
356 #define for_each_region(kdev, region) \
357 list_for_each_entry(region, &kdev->regions, list)
359 #define first_region(kdev) \
360 list_first_entry_or_null(&kdev->regions, \
361 struct knav_region, list)
363 #define for_each_queue_range(kdev, range) \
364 list_for_each_entry(range, &kdev->queue_ranges, list)
366 #define first_queue_range(kdev) \
367 list_first_entry_or_null(&kdev->queue_ranges, \
368 struct knav_range_info, list)
370 #define for_each_pool(kdev, pool) \
371 list_for_each_entry(pool, &kdev->pools, list)
373 #define for_each_pdsp(kdev, pdsp) \
374 list_for_each_entry(pdsp, &kdev->pdsps, list)
376 #define for_each_qmgr(kdev, qmgr) \
377 list_for_each_entry(qmgr, &kdev->qmgrs, list)
379 static inline struct knav_pdsp_info
*
380 knav_find_pdsp(struct knav_device
*kdev
, unsigned pdsp_id
)
382 struct knav_pdsp_info
*pdsp
;
384 for_each_pdsp(kdev
, pdsp
)
385 if (pdsp_id
== pdsp
->id
)
390 extern int knav_init_acc_range(struct knav_device
*kdev
,
391 struct device_node
*node
,
392 struct knav_range_info
*range
);
393 extern void knav_queue_notify(struct knav_queue_inst
*inst
);
395 #endif /* __KNAV_QMSS_H__ */