Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / arch / arm / include / asm / cti.h
bloba0ada3ea4358dfa21c9a08fe36b06897d4a16ff3
1 #ifndef __ASMARM_CTI_H
2 #define __ASMARM_CTI_H
4 #include <asm/io.h>
6 /* The registers' definition is from section 3.2 of
7 * Embedded Cross Trigger Revision: r0p0
8 */
9 #define CTICONTROL 0x000
10 #define CTISTATUS 0x004
11 #define CTILOCK 0x008
12 #define CTIPROTECTION 0x00C
13 #define CTIINTACK 0x010
14 #define CTIAPPSET 0x014
15 #define CTIAPPCLEAR 0x018
16 #define CTIAPPPULSE 0x01c
17 #define CTIINEN 0x020
18 #define CTIOUTEN 0x0A0
19 #define CTITRIGINSTATUS 0x130
20 #define CTITRIGOUTSTATUS 0x134
21 #define CTICHINSTATUS 0x138
22 #define CTICHOUTSTATUS 0x13c
23 #define CTIPERIPHID0 0xFE0
24 #define CTIPERIPHID1 0xFE4
25 #define CTIPERIPHID2 0xFE8
26 #define CTIPERIPHID3 0xFEC
27 #define CTIPCELLID0 0xFF0
28 #define CTIPCELLID1 0xFF4
29 #define CTIPCELLID2 0xFF8
30 #define CTIPCELLID3 0xFFC
32 /* The below are from section 3.6.4 of
33 * CoreSight v1.0 Architecture Specification
35 #define LOCKACCESS 0xFB0
36 #define LOCKSTATUS 0xFB4
38 /* write this value to LOCKACCESS will unlock the module, and
39 * other value will lock the module
41 #define LOCKCODE 0xC5ACCE55
43 /**
44 * struct cti - cross trigger interface struct
45 * @base: mapped virtual address for the cti base
46 * @irq: irq number for the cti
47 * @trig_out_for_irq: triger out number which will cause
48 * the @irq happen
50 * cti struct used to operate cti registers.
52 struct cti {
53 void __iomem *base;
54 int irq;
55 int trig_out_for_irq;
58 /**
59 * cti_init - initialize the cti instance
60 * @cti: cti instance
61 * @base: mapped virtual address for the cti base
62 * @irq: irq number for the cti
63 * @trig_out: triger out number which will cause
64 * the @irq happen
66 * called by machine code to pass the board dependent
67 * @base, @irq and @trig_out to cti.
69 static inline void cti_init(struct cti *cti,
70 void __iomem *base, int irq, int trig_out)
72 cti->base = base;
73 cti->irq = irq;
74 cti->trig_out_for_irq = trig_out;
77 /**
78 * cti_map_trigger - use the @chan to map @trig_in to @trig_out
79 * @cti: cti instance
80 * @trig_in: trigger in number
81 * @trig_out: trigger out number
82 * @channel: channel number
84 * This function maps one trigger in of @trig_in to one trigger
85 * out of @trig_out using the channel @chan.
87 static inline void cti_map_trigger(struct cti *cti,
88 int trig_in, int trig_out, int chan)
90 void __iomem *base = cti->base;
91 unsigned long val;
93 val = __raw_readl(base + CTIINEN + trig_in * 4);
94 val |= BIT(chan);
95 __raw_writel(val, base + CTIINEN + trig_in * 4);
97 val = __raw_readl(base + CTIOUTEN + trig_out * 4);
98 val |= BIT(chan);
99 __raw_writel(val, base + CTIOUTEN + trig_out * 4);
103 * cti_enable - enable the cti module
104 * @cti: cti instance
106 * enable the cti module
108 static inline void cti_enable(struct cti *cti)
110 __raw_writel(0x1, cti->base + CTICONTROL);
114 * cti_disable - disable the cti module
115 * @cti: cti instance
117 * enable the cti module
119 static inline void cti_disable(struct cti *cti)
121 __raw_writel(0, cti->base + CTICONTROL);
125 * cti_irq_ack - clear the cti irq
126 * @cti: cti instance
128 * clear the cti irq
130 static inline void cti_irq_ack(struct cti *cti)
132 void __iomem *base = cti->base;
133 unsigned long val;
135 val = __raw_readl(base + CTIINTACK);
136 val |= BIT(cti->trig_out_for_irq);
137 __raw_writel(val, base + CTIINTACK);
141 * cti_unlock - unlock cti module
142 * @cti: cti instance
144 * unlock the cti module, or else any writes to the cti
145 * module is not allowed.
147 static inline void cti_unlock(struct cti *cti)
149 void __iomem *base = cti->base;
150 unsigned long val;
152 val = __raw_readl(base + LOCKSTATUS);
154 if (val & 1) {
155 val = LOCKCODE;
156 __raw_writel(val, base + LOCKACCESS);
161 * cti_lock - lock cti module
162 * @cti: cti instance
164 * lock the cti module, so any writes to the cti
165 * module will be not allowed.
167 static inline void cti_lock(struct cti *cti)
169 void __iomem *base = cti->base;
170 unsigned long val;
172 val = __raw_readl(base + LOCKSTATUS);
174 if (!(val & 1)) {
175 val = ~LOCKCODE;
176 __raw_writel(val, base + LOCKACCESS);
179 #endif