Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/drivers/hsi/controllers/omap_ssi.h
29266 views
1
/* SPDX-License-Identifier: GPL-2.0-only */
2
/* OMAP SSI internal interface.
3
*
4
* Copyright (C) 2010 Nokia Corporation. All rights reserved.
5
* Copyright (C) 2013 Sebastian Reichel
6
*
7
* Contact: Carlos Chinea <[email protected]>
8
*/
9
10
#ifndef __LINUX_HSI_OMAP_SSI_H__
11
#define __LINUX_HSI_OMAP_SSI_H__
12
13
#include <linux/device.h>
14
#include <linux/module.h>
15
#include <linux/platform_device.h>
16
#include <linux/hsi/hsi.h>
17
#include <linux/gpio/consumer.h>
18
#include <linux/interrupt.h>
19
#include <linux/io.h>
20
21
#define SSI_MAX_CHANNELS 8
22
#define SSI_MAX_GDD_LCH 8
23
#define SSI_BYTES_TO_FRAMES(x) ((((x) - 1) >> 2) + 1)
24
25
#define SSI_WAKE_EN 0
26
27
/**
28
* struct omap_ssm_ctx - OMAP synchronous serial module (TX/RX) context
29
* @mode: Bit transmission mode
30
* @channels: Number of channels
31
* @framesize: Frame size in bits
32
* @timeout: RX frame timeout
33
* @divisor: TX divider
34
* @arb_mode: Arbitration mode for TX frame (Round robin, priority)
35
*/
36
struct omap_ssm_ctx {
37
u32 mode;
38
u32 channels;
39
u32 frame_size;
40
union {
41
u32 timeout; /* Rx Only */
42
struct {
43
u32 arb_mode;
44
u32 divisor;
45
}; /* Tx only */
46
};
47
};
48
49
/**
50
* struct omap_ssi_port - OMAP SSI port data
51
* @dev: device associated to the port (HSI port)
52
* @pdev: platform device associated to the port
53
* @sst_dma: SSI transmitter physical base address
54
* @ssr_dma: SSI receiver physical base address
55
* @sst_base: SSI transmitter base address
56
* @ssr_base: SSI receiver base address
57
* @wk_lock: spin lock to serialize access to the wake lines
58
* @lock: Spin lock to serialize access to the SSI port
59
* @channels: Current number of channels configured (1,2,4 or 8)
60
* @txqueue: TX message queues
61
* @rxqueue: RX message queues
62
* @brkqueue: Queue of incoming HWBREAK requests (FRAME mode)
63
* @errqueue: Queue for failed messages
64
* @errqueue_work: Delayed Work for failed messages
65
* @irq: IRQ number
66
* @wake_irq: IRQ number for incoming wake line (-1 if none)
67
* @wake_gpio: GPIO number for incoming wake line (-1 if none)
68
* @flags: flags to keep track of states
69
* @wk_refcount: Reference count for output wake line
70
* @work: worker for starting TX
71
* @sys_mpu_enable: Context for the interrupt enable register for irq 0
72
* @sst: Context for the synchronous serial transmitter
73
* @ssr: Context for the synchronous serial receiver
74
*/
75
struct omap_ssi_port {
76
struct device *dev;
77
struct device *pdev;
78
dma_addr_t sst_dma;
79
dma_addr_t ssr_dma;
80
void __iomem *sst_base;
81
void __iomem *ssr_base;
82
spinlock_t wk_lock;
83
spinlock_t lock;
84
unsigned int channels;
85
struct list_head txqueue[SSI_MAX_CHANNELS];
86
struct list_head rxqueue[SSI_MAX_CHANNELS];
87
struct list_head brkqueue;
88
struct list_head errqueue;
89
struct delayed_work errqueue_work;
90
unsigned int irq;
91
int wake_irq;
92
struct gpio_desc *wake_gpio;
93
bool wktest:1; /* FIXME: HACK to be removed */
94
unsigned long flags;
95
unsigned int wk_refcount;
96
struct work_struct work;
97
/* OMAP SSI port context */
98
u32 sys_mpu_enable; /* We use only one irq */
99
struct omap_ssm_ctx sst;
100
struct omap_ssm_ctx ssr;
101
u32 loss_count;
102
u32 port_id;
103
#ifdef CONFIG_DEBUG_FS
104
struct dentry *dir;
105
#endif
106
};
107
108
/**
109
* struct gdd_trn - GDD transaction data
110
* @msg: Pointer to the HSI message being served
111
* @sg: Pointer to the current sg entry being served
112
*/
113
struct gdd_trn {
114
struct hsi_msg *msg;
115
struct scatterlist *sg;
116
};
117
118
/**
119
* struct omap_ssi_controller - OMAP SSI controller data
120
* @dev: device associated to the controller (HSI controller)
121
* @sys: SSI I/O base address
122
* @gdd: GDD I/O base address
123
* @fck: SSI functional clock
124
* @gdd_irq: IRQ line for GDD
125
* @gdd_tasklet: bottom half for DMA transfers
126
* @gdd_trn: Array of GDD transaction data for ongoing GDD transfers
127
* @lock: lock to serialize access to GDD
128
* @fck_nb: DVFS notfifier block
129
* @fck_rate: clock rate
130
* @loss_count: To follow if we need to restore context or not
131
* @max_speed: Maximum TX speed (Kb/s) set by the clients.
132
* @gdd_gcr: SSI GDD saved context
133
* @get_loss: Pointer to omap_pm_get_dev_context_loss_count, if any
134
* @port: Array of pointers of the ports of the controller
135
* @dir: Debugfs SSI root directory
136
*/
137
struct omap_ssi_controller {
138
struct device *dev;
139
void __iomem *sys;
140
void __iomem *gdd;
141
struct clk *fck;
142
unsigned int gdd_irq;
143
struct tasklet_struct gdd_tasklet;
144
struct gdd_trn gdd_trn[SSI_MAX_GDD_LCH];
145
spinlock_t lock;
146
struct notifier_block fck_nb;
147
unsigned long fck_rate;
148
u32 loss_count;
149
u32 max_speed;
150
/* OMAP SSI Controller context */
151
u32 gdd_gcr;
152
int (*get_loss)(struct device *dev);
153
struct omap_ssi_port **port;
154
#ifdef CONFIG_DEBUG_FS
155
struct dentry *dir;
156
#endif
157
};
158
159
void omap_ssi_port_update_fclk(struct hsi_controller *ssi,
160
struct omap_ssi_port *omap_port);
161
162
extern struct platform_driver ssi_port_pdriver;
163
164
#endif /* __LINUX_HSI_OMAP_SSI_H__ */
165
166