xref: /openbmc/linux/drivers/irqchip/irq-stm32-exti.c (revision 22fc4c4c9fd60427bcda00878cee94e7622cfa7a)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (C) Maxime Coquelin 2015
4  * Copyright (C) STMicroelectronics 2017
5  * Author:  Maxime Coquelin <mcoquelin.stm32@gmail.com>
6  */
7 
8 #include <linux/bitops.h>
9 #include <linux/delay.h>
10 #include <linux/hwspinlock.h>
11 #include <linux/interrupt.h>
12 #include <linux/io.h>
13 #include <linux/irq.h>
14 #include <linux/irqchip.h>
15 #include <linux/irqchip/chained_irq.h>
16 #include <linux/irqdomain.h>
17 #include <linux/of_address.h>
18 #include <linux/of_irq.h>
19 #include <linux/syscore_ops.h>
20 
21 #include <dt-bindings/interrupt-controller/arm-gic.h>
22 
23 #define IRQS_PER_BANK 32
24 
25 #define HWSPNLCK_TIMEOUT	1000 /* usec */
26 #define HWSPNLCK_RETRY_DELAY	100  /* usec */
27 
28 struct stm32_exti_bank {
29 	u32 imr_ofst;
30 	u32 emr_ofst;
31 	u32 rtsr_ofst;
32 	u32 ftsr_ofst;
33 	u32 swier_ofst;
34 	u32 rpr_ofst;
35 	u32 fpr_ofst;
36 };
37 
38 #define UNDEF_REG ~0
39 
40 enum stm32_exti_hwspinlock {
41 	HWSPINLOCK_UNKNOWN,
42 	HWSPINLOCK_NONE,
43 	HWSPINLOCK_READY,
44 };
45 
46 struct stm32_desc_irq {
47 	u32 exti;
48 	u32 irq_parent;
49 };
50 
51 struct stm32_exti_drv_data {
52 	const struct stm32_exti_bank **exti_banks;
53 	const struct stm32_desc_irq *desc_irqs;
54 	u32 bank_nr;
55 	u32 irq_nr;
56 };
57 
58 struct stm32_exti_chip_data {
59 	struct stm32_exti_host_data *host_data;
60 	const struct stm32_exti_bank *reg_bank;
61 	struct raw_spinlock rlock;
62 	u32 wake_active;
63 	u32 mask_cache;
64 	u32 rtsr_cache;
65 	u32 ftsr_cache;
66 };
67 
68 struct stm32_exti_host_data {
69 	void __iomem *base;
70 	struct stm32_exti_chip_data *chips_data;
71 	const struct stm32_exti_drv_data *drv_data;
72 	struct device_node *node;
73 	enum stm32_exti_hwspinlock hwlock_state;
74 	struct hwspinlock *hwlock;
75 };
76 
77 static struct stm32_exti_host_data *stm32_host_data;
78 
79 static const struct stm32_exti_bank stm32f4xx_exti_b1 = {
80 	.imr_ofst	= 0x00,
81 	.emr_ofst	= 0x04,
82 	.rtsr_ofst	= 0x08,
83 	.ftsr_ofst	= 0x0C,
84 	.swier_ofst	= 0x10,
85 	.rpr_ofst	= 0x14,
86 	.fpr_ofst	= UNDEF_REG,
87 };
88 
89 static const struct stm32_exti_bank *stm32f4xx_exti_banks[] = {
90 	&stm32f4xx_exti_b1,
91 };
92 
93 static const struct stm32_exti_drv_data stm32f4xx_drv_data = {
94 	.exti_banks = stm32f4xx_exti_banks,
95 	.bank_nr = ARRAY_SIZE(stm32f4xx_exti_banks),
96 };
97 
98 static const struct stm32_exti_bank stm32h7xx_exti_b1 = {
99 	.imr_ofst	= 0x80,
100 	.emr_ofst	= 0x84,
101 	.rtsr_ofst	= 0x00,
102 	.ftsr_ofst	= 0x04,
103 	.swier_ofst	= 0x08,
104 	.rpr_ofst	= 0x88,
105 	.fpr_ofst	= UNDEF_REG,
106 };
107 
108 static const struct stm32_exti_bank stm32h7xx_exti_b2 = {
109 	.imr_ofst	= 0x90,
110 	.emr_ofst	= 0x94,
111 	.rtsr_ofst	= 0x20,
112 	.ftsr_ofst	= 0x24,
113 	.swier_ofst	= 0x28,
114 	.rpr_ofst	= 0x98,
115 	.fpr_ofst	= UNDEF_REG,
116 };
117 
118 static const struct stm32_exti_bank stm32h7xx_exti_b3 = {
119 	.imr_ofst	= 0xA0,
120 	.emr_ofst	= 0xA4,
121 	.rtsr_ofst	= 0x40,
122 	.ftsr_ofst	= 0x44,
123 	.swier_ofst	= 0x48,
124 	.rpr_ofst	= 0xA8,
125 	.fpr_ofst	= UNDEF_REG,
126 };
127 
128 static const struct stm32_exti_bank *stm32h7xx_exti_banks[] = {
129 	&stm32h7xx_exti_b1,
130 	&stm32h7xx_exti_b2,
131 	&stm32h7xx_exti_b3,
132 };
133 
134 static const struct stm32_exti_drv_data stm32h7xx_drv_data = {
135 	.exti_banks = stm32h7xx_exti_banks,
136 	.bank_nr = ARRAY_SIZE(stm32h7xx_exti_banks),
137 };
138 
139 static const struct stm32_exti_bank stm32mp1_exti_b1 = {
140 	.imr_ofst	= 0x80,
141 	.emr_ofst	= 0x84,
142 	.rtsr_ofst	= 0x00,
143 	.ftsr_ofst	= 0x04,
144 	.swier_ofst	= 0x08,
145 	.rpr_ofst	= 0x0C,
146 	.fpr_ofst	= 0x10,
147 };
148 
149 static const struct stm32_exti_bank stm32mp1_exti_b2 = {
150 	.imr_ofst	= 0x90,
151 	.emr_ofst	= 0x94,
152 	.rtsr_ofst	= 0x20,
153 	.ftsr_ofst	= 0x24,
154 	.swier_ofst	= 0x28,
155 	.rpr_ofst	= 0x2C,
156 	.fpr_ofst	= 0x30,
157 };
158 
159 static const struct stm32_exti_bank stm32mp1_exti_b3 = {
160 	.imr_ofst	= 0xA0,
161 	.emr_ofst	= 0xA4,
162 	.rtsr_ofst	= 0x40,
163 	.ftsr_ofst	= 0x44,
164 	.swier_ofst	= 0x48,
165 	.rpr_ofst	= 0x4C,
166 	.fpr_ofst	= 0x50,
167 };
168 
169 static const struct stm32_exti_bank *stm32mp1_exti_banks[] = {
170 	&stm32mp1_exti_b1,
171 	&stm32mp1_exti_b2,
172 	&stm32mp1_exti_b3,
173 };
174 
175 static const struct stm32_desc_irq stm32mp1_desc_irq[] = {
176 	{ .exti = 0, .irq_parent = 6 },
177 	{ .exti = 1, .irq_parent = 7 },
178 	{ .exti = 2, .irq_parent = 8 },
179 	{ .exti = 3, .irq_parent = 9 },
180 	{ .exti = 4, .irq_parent = 10 },
181 	{ .exti = 5, .irq_parent = 23 },
182 	{ .exti = 6, .irq_parent = 64 },
183 	{ .exti = 7, .irq_parent = 65 },
184 	{ .exti = 8, .irq_parent = 66 },
185 	{ .exti = 9, .irq_parent = 67 },
186 	{ .exti = 10, .irq_parent = 40 },
187 	{ .exti = 11, .irq_parent = 42 },
188 	{ .exti = 12, .irq_parent = 76 },
189 	{ .exti = 13, .irq_parent = 77 },
190 	{ .exti = 14, .irq_parent = 121 },
191 	{ .exti = 15, .irq_parent = 127 },
192 	{ .exti = 16, .irq_parent = 1 },
193 	{ .exti = 65, .irq_parent = 144 },
194 	{ .exti = 68, .irq_parent = 143 },
195 	{ .exti = 73, .irq_parent = 129 },
196 };
197 
198 static const struct stm32_exti_drv_data stm32mp1_drv_data = {
199 	.exti_banks = stm32mp1_exti_banks,
200 	.bank_nr = ARRAY_SIZE(stm32mp1_exti_banks),
201 	.desc_irqs = stm32mp1_desc_irq,
202 	.irq_nr = ARRAY_SIZE(stm32mp1_desc_irq),
203 };
204 
205 static int stm32_exti_to_irq(const struct stm32_exti_drv_data *drv_data,
206 			     irq_hw_number_t hwirq)
207 {
208 	const struct stm32_desc_irq *desc_irq;
209 	int i;
210 
211 	if (!drv_data->desc_irqs)
212 		return -EINVAL;
213 
214 	for (i = 0; i < drv_data->irq_nr; i++) {
215 		desc_irq = &drv_data->desc_irqs[i];
216 		if (desc_irq->exti == hwirq)
217 			return desc_irq->irq_parent;
218 	}
219 
220 	return -EINVAL;
221 }
222 
223 static unsigned long stm32_exti_pending(struct irq_chip_generic *gc)
224 {
225 	struct stm32_exti_chip_data *chip_data = gc->private;
226 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
227 	unsigned long pending;
228 
229 	pending = irq_reg_readl(gc, stm32_bank->rpr_ofst);
230 	if (stm32_bank->fpr_ofst != UNDEF_REG)
231 		pending |= irq_reg_readl(gc, stm32_bank->fpr_ofst);
232 
233 	return pending;
234 }
235 
236 static void stm32_irq_handler(struct irq_desc *desc)
237 {
238 	struct irq_domain *domain = irq_desc_get_handler_data(desc);
239 	struct irq_chip *chip = irq_desc_get_chip(desc);
240 	unsigned int virq, nbanks = domain->gc->num_chips;
241 	struct irq_chip_generic *gc;
242 	unsigned long pending;
243 	int n, i, irq_base = 0;
244 
245 	chained_irq_enter(chip, desc);
246 
247 	for (i = 0; i < nbanks; i++, irq_base += IRQS_PER_BANK) {
248 		gc = irq_get_domain_generic_chip(domain, irq_base);
249 
250 		while ((pending = stm32_exti_pending(gc))) {
251 			for_each_set_bit(n, &pending, IRQS_PER_BANK) {
252 				virq = irq_find_mapping(domain, irq_base + n);
253 				generic_handle_irq(virq);
254 			}
255 		}
256 	}
257 
258 	chained_irq_exit(chip, desc);
259 }
260 
261 static int stm32_exti_set_type(struct irq_data *d,
262 			       unsigned int type, u32 *rtsr, u32 *ftsr)
263 {
264 	u32 mask = BIT(d->hwirq % IRQS_PER_BANK);
265 
266 	switch (type) {
267 	case IRQ_TYPE_EDGE_RISING:
268 		*rtsr |= mask;
269 		*ftsr &= ~mask;
270 		break;
271 	case IRQ_TYPE_EDGE_FALLING:
272 		*rtsr &= ~mask;
273 		*ftsr |= mask;
274 		break;
275 	case IRQ_TYPE_EDGE_BOTH:
276 		*rtsr |= mask;
277 		*ftsr |= mask;
278 		break;
279 	default:
280 		return -EINVAL;
281 	}
282 
283 	return 0;
284 }
285 
286 static int stm32_exti_hwspin_lock(struct stm32_exti_chip_data *chip_data)
287 {
288 	struct stm32_exti_host_data *host_data = chip_data->host_data;
289 	struct hwspinlock *hwlock;
290 	int id, ret = 0, timeout = 0;
291 
292 	/* first time, check for hwspinlock availability */
293 	if (unlikely(host_data->hwlock_state == HWSPINLOCK_UNKNOWN)) {
294 		id = of_hwspin_lock_get_id(host_data->node, 0);
295 		if (id >= 0) {
296 			hwlock = hwspin_lock_request_specific(id);
297 			if (hwlock) {
298 				/* found valid hwspinlock */
299 				host_data->hwlock_state = HWSPINLOCK_READY;
300 				host_data->hwlock = hwlock;
301 				pr_debug("%s hwspinlock = %d\n", __func__, id);
302 			} else {
303 				host_data->hwlock_state = HWSPINLOCK_NONE;
304 			}
305 		} else if (id != -EPROBE_DEFER) {
306 			host_data->hwlock_state = HWSPINLOCK_NONE;
307 		} else {
308 			/* hwspinlock driver shall be ready at that stage */
309 			ret = -EPROBE_DEFER;
310 		}
311 	}
312 
313 	if (likely(host_data->hwlock_state == HWSPINLOCK_READY)) {
314 		/*
315 		 * Use the x_raw API since we are under spin_lock protection.
316 		 * Do not use the x_timeout API because we are under irq_disable
317 		 * mode (see __setup_irq())
318 		 */
319 		do {
320 			ret = hwspin_trylock_raw(host_data->hwlock);
321 			if (!ret)
322 				return 0;
323 
324 			udelay(HWSPNLCK_RETRY_DELAY);
325 			timeout += HWSPNLCK_RETRY_DELAY;
326 		} while (timeout < HWSPNLCK_TIMEOUT);
327 
328 		if (ret == -EBUSY)
329 			ret = -ETIMEDOUT;
330 	}
331 
332 	if (ret)
333 		pr_err("%s can't get hwspinlock (%d)\n", __func__, ret);
334 
335 	return ret;
336 }
337 
338 static void stm32_exti_hwspin_unlock(struct stm32_exti_chip_data *chip_data)
339 {
340 	if (likely(chip_data->host_data->hwlock_state == HWSPINLOCK_READY))
341 		hwspin_unlock_raw(chip_data->host_data->hwlock);
342 }
343 
344 static int stm32_irq_set_type(struct irq_data *d, unsigned int type)
345 {
346 	struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
347 	struct stm32_exti_chip_data *chip_data = gc->private;
348 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
349 	u32 rtsr, ftsr;
350 	int err;
351 
352 	irq_gc_lock(gc);
353 
354 	err = stm32_exti_hwspin_lock(chip_data);
355 	if (err)
356 		goto unlock;
357 
358 	rtsr = irq_reg_readl(gc, stm32_bank->rtsr_ofst);
359 	ftsr = irq_reg_readl(gc, stm32_bank->ftsr_ofst);
360 
361 	err = stm32_exti_set_type(d, type, &rtsr, &ftsr);
362 	if (err)
363 		goto unspinlock;
364 
365 	irq_reg_writel(gc, rtsr, stm32_bank->rtsr_ofst);
366 	irq_reg_writel(gc, ftsr, stm32_bank->ftsr_ofst);
367 
368 unspinlock:
369 	stm32_exti_hwspin_unlock(chip_data);
370 unlock:
371 	irq_gc_unlock(gc);
372 
373 	return err;
374 }
375 
376 static void stm32_chip_suspend(struct stm32_exti_chip_data *chip_data,
377 			       u32 wake_active)
378 {
379 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
380 	void __iomem *base = chip_data->host_data->base;
381 
382 	/* save rtsr, ftsr registers */
383 	chip_data->rtsr_cache = readl_relaxed(base + stm32_bank->rtsr_ofst);
384 	chip_data->ftsr_cache = readl_relaxed(base + stm32_bank->ftsr_ofst);
385 
386 	writel_relaxed(wake_active, base + stm32_bank->imr_ofst);
387 }
388 
389 static void stm32_chip_resume(struct stm32_exti_chip_data *chip_data,
390 			      u32 mask_cache)
391 {
392 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
393 	void __iomem *base = chip_data->host_data->base;
394 
395 	/* restore rtsr, ftsr, registers */
396 	writel_relaxed(chip_data->rtsr_cache, base + stm32_bank->rtsr_ofst);
397 	writel_relaxed(chip_data->ftsr_cache, base + stm32_bank->ftsr_ofst);
398 
399 	writel_relaxed(mask_cache, base + stm32_bank->imr_ofst);
400 }
401 
402 static void stm32_irq_suspend(struct irq_chip_generic *gc)
403 {
404 	struct stm32_exti_chip_data *chip_data = gc->private;
405 
406 	irq_gc_lock(gc);
407 	stm32_chip_suspend(chip_data, gc->wake_active);
408 	irq_gc_unlock(gc);
409 }
410 
411 static void stm32_irq_resume(struct irq_chip_generic *gc)
412 {
413 	struct stm32_exti_chip_data *chip_data = gc->private;
414 
415 	irq_gc_lock(gc);
416 	stm32_chip_resume(chip_data, gc->mask_cache);
417 	irq_gc_unlock(gc);
418 }
419 
420 static int stm32_exti_alloc(struct irq_domain *d, unsigned int virq,
421 			    unsigned int nr_irqs, void *data)
422 {
423 	struct irq_fwspec *fwspec = data;
424 	irq_hw_number_t hwirq;
425 
426 	hwirq = fwspec->param[0];
427 
428 	irq_map_generic_chip(d, virq, hwirq);
429 
430 	return 0;
431 }
432 
433 static void stm32_exti_free(struct irq_domain *d, unsigned int virq,
434 			    unsigned int nr_irqs)
435 {
436 	struct irq_data *data = irq_domain_get_irq_data(d, virq);
437 
438 	irq_domain_reset_irq_data(data);
439 }
440 
441 static const struct irq_domain_ops irq_exti_domain_ops = {
442 	.map	= irq_map_generic_chip,
443 	.alloc  = stm32_exti_alloc,
444 	.free	= stm32_exti_free,
445 };
446 
447 static void stm32_irq_ack(struct irq_data *d)
448 {
449 	struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
450 	struct stm32_exti_chip_data *chip_data = gc->private;
451 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
452 
453 	irq_gc_lock(gc);
454 
455 	irq_reg_writel(gc, d->mask, stm32_bank->rpr_ofst);
456 	if (stm32_bank->fpr_ofst != UNDEF_REG)
457 		irq_reg_writel(gc, d->mask, stm32_bank->fpr_ofst);
458 
459 	irq_gc_unlock(gc);
460 }
461 
462 static inline u32 stm32_exti_set_bit(struct irq_data *d, u32 reg)
463 {
464 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
465 	void __iomem *base = chip_data->host_data->base;
466 	u32 val;
467 
468 	val = readl_relaxed(base + reg);
469 	val |= BIT(d->hwirq % IRQS_PER_BANK);
470 	writel_relaxed(val, base + reg);
471 
472 	return val;
473 }
474 
475 static inline u32 stm32_exti_clr_bit(struct irq_data *d, u32 reg)
476 {
477 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
478 	void __iomem *base = chip_data->host_data->base;
479 	u32 val;
480 
481 	val = readl_relaxed(base + reg);
482 	val &= ~BIT(d->hwirq % IRQS_PER_BANK);
483 	writel_relaxed(val, base + reg);
484 
485 	return val;
486 }
487 
488 static void stm32_exti_h_eoi(struct irq_data *d)
489 {
490 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
491 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
492 
493 	raw_spin_lock(&chip_data->rlock);
494 
495 	stm32_exti_set_bit(d, stm32_bank->rpr_ofst);
496 	if (stm32_bank->fpr_ofst != UNDEF_REG)
497 		stm32_exti_set_bit(d, stm32_bank->fpr_ofst);
498 
499 	raw_spin_unlock(&chip_data->rlock);
500 
501 	if (d->parent_data->chip)
502 		irq_chip_eoi_parent(d);
503 }
504 
505 static void stm32_exti_h_mask(struct irq_data *d)
506 {
507 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
508 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
509 
510 	raw_spin_lock(&chip_data->rlock);
511 	chip_data->mask_cache = stm32_exti_clr_bit(d, stm32_bank->imr_ofst);
512 	raw_spin_unlock(&chip_data->rlock);
513 
514 	if (d->parent_data->chip)
515 		irq_chip_mask_parent(d);
516 }
517 
518 static void stm32_exti_h_unmask(struct irq_data *d)
519 {
520 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
521 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
522 
523 	raw_spin_lock(&chip_data->rlock);
524 	chip_data->mask_cache = stm32_exti_set_bit(d, stm32_bank->imr_ofst);
525 	raw_spin_unlock(&chip_data->rlock);
526 
527 	if (d->parent_data->chip)
528 		irq_chip_unmask_parent(d);
529 }
530 
531 static int stm32_exti_h_set_type(struct irq_data *d, unsigned int type)
532 {
533 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
534 	const struct stm32_exti_bank *stm32_bank = chip_data->reg_bank;
535 	void __iomem *base = chip_data->host_data->base;
536 	u32 rtsr, ftsr;
537 	int err;
538 
539 	raw_spin_lock(&chip_data->rlock);
540 
541 	err = stm32_exti_hwspin_lock(chip_data);
542 	if (err)
543 		goto unlock;
544 
545 	rtsr = readl_relaxed(base + stm32_bank->rtsr_ofst);
546 	ftsr = readl_relaxed(base + stm32_bank->ftsr_ofst);
547 
548 	err = stm32_exti_set_type(d, type, &rtsr, &ftsr);
549 	if (err)
550 		goto unspinlock;
551 
552 	writel_relaxed(rtsr, base + stm32_bank->rtsr_ofst);
553 	writel_relaxed(ftsr, base + stm32_bank->ftsr_ofst);
554 
555 unspinlock:
556 	stm32_exti_hwspin_unlock(chip_data);
557 unlock:
558 	raw_spin_unlock(&chip_data->rlock);
559 
560 	return err;
561 }
562 
563 static int stm32_exti_h_set_wake(struct irq_data *d, unsigned int on)
564 {
565 	struct stm32_exti_chip_data *chip_data = irq_data_get_irq_chip_data(d);
566 	u32 mask = BIT(d->hwirq % IRQS_PER_BANK);
567 
568 	raw_spin_lock(&chip_data->rlock);
569 
570 	if (on)
571 		chip_data->wake_active |= mask;
572 	else
573 		chip_data->wake_active &= ~mask;
574 
575 	raw_spin_unlock(&chip_data->rlock);
576 
577 	return 0;
578 }
579 
580 static int stm32_exti_h_set_affinity(struct irq_data *d,
581 				     const struct cpumask *dest, bool force)
582 {
583 	if (d->parent_data->chip)
584 		return irq_chip_set_affinity_parent(d, dest, force);
585 
586 	return -EINVAL;
587 }
588 
589 #ifdef CONFIG_PM
590 static int stm32_exti_h_suspend(void)
591 {
592 	struct stm32_exti_chip_data *chip_data;
593 	int i;
594 
595 	for (i = 0; i < stm32_host_data->drv_data->bank_nr; i++) {
596 		chip_data = &stm32_host_data->chips_data[i];
597 		raw_spin_lock(&chip_data->rlock);
598 		stm32_chip_suspend(chip_data, chip_data->wake_active);
599 		raw_spin_unlock(&chip_data->rlock);
600 	}
601 
602 	return 0;
603 }
604 
605 static void stm32_exti_h_resume(void)
606 {
607 	struct stm32_exti_chip_data *chip_data;
608 	int i;
609 
610 	for (i = 0; i < stm32_host_data->drv_data->bank_nr; i++) {
611 		chip_data = &stm32_host_data->chips_data[i];
612 		raw_spin_lock(&chip_data->rlock);
613 		stm32_chip_resume(chip_data, chip_data->mask_cache);
614 		raw_spin_unlock(&chip_data->rlock);
615 	}
616 }
617 
618 static struct syscore_ops stm32_exti_h_syscore_ops = {
619 	.suspend	= stm32_exti_h_suspend,
620 	.resume		= stm32_exti_h_resume,
621 };
622 
623 static void stm32_exti_h_syscore_init(void)
624 {
625 	register_syscore_ops(&stm32_exti_h_syscore_ops);
626 }
627 #else
628 static inline void stm32_exti_h_syscore_init(void) {}
629 #endif
630 
631 static struct irq_chip stm32_exti_h_chip = {
632 	.name			= "stm32-exti-h",
633 	.irq_eoi		= stm32_exti_h_eoi,
634 	.irq_mask		= stm32_exti_h_mask,
635 	.irq_unmask		= stm32_exti_h_unmask,
636 	.irq_retrigger		= irq_chip_retrigger_hierarchy,
637 	.irq_set_type		= stm32_exti_h_set_type,
638 	.irq_set_wake		= stm32_exti_h_set_wake,
639 	.flags			= IRQCHIP_MASK_ON_SUSPEND,
640 	.irq_set_affinity	= IS_ENABLED(CONFIG_SMP) ? stm32_exti_h_set_affinity : NULL,
641 };
642 
643 static int stm32_exti_h_domain_alloc(struct irq_domain *dm,
644 				     unsigned int virq,
645 				     unsigned int nr_irqs, void *data)
646 {
647 	struct stm32_exti_host_data *host_data = dm->host_data;
648 	struct stm32_exti_chip_data *chip_data;
649 	struct irq_fwspec *fwspec = data;
650 	struct irq_fwspec p_fwspec;
651 	irq_hw_number_t hwirq;
652 	int p_irq, bank;
653 
654 	hwirq = fwspec->param[0];
655 	bank  = hwirq / IRQS_PER_BANK;
656 	chip_data = &host_data->chips_data[bank];
657 
658 	irq_domain_set_hwirq_and_chip(dm, virq, hwirq,
659 				      &stm32_exti_h_chip, chip_data);
660 
661 	p_irq = stm32_exti_to_irq(host_data->drv_data, hwirq);
662 	if (p_irq >= 0) {
663 		p_fwspec.fwnode = dm->parent->fwnode;
664 		p_fwspec.param_count = 3;
665 		p_fwspec.param[0] = GIC_SPI;
666 		p_fwspec.param[1] = p_irq;
667 		p_fwspec.param[2] = IRQ_TYPE_LEVEL_HIGH;
668 
669 		return irq_domain_alloc_irqs_parent(dm, virq, 1, &p_fwspec);
670 	}
671 
672 	return 0;
673 }
674 
675 static struct
676 stm32_exti_host_data *stm32_exti_host_init(const struct stm32_exti_drv_data *dd,
677 					   struct device_node *node)
678 {
679 	struct stm32_exti_host_data *host_data;
680 
681 	host_data = kzalloc(sizeof(*host_data), GFP_KERNEL);
682 	if (!host_data)
683 		return NULL;
684 
685 	host_data->drv_data = dd;
686 	host_data->node = node;
687 	host_data->hwlock_state = HWSPINLOCK_UNKNOWN;
688 	host_data->chips_data = kcalloc(dd->bank_nr,
689 					sizeof(struct stm32_exti_chip_data),
690 					GFP_KERNEL);
691 	if (!host_data->chips_data)
692 		goto free_host_data;
693 
694 	host_data->base = of_iomap(node, 0);
695 	if (!host_data->base) {
696 		pr_err("%pOF: Unable to map registers\n", node);
697 		goto free_chips_data;
698 	}
699 
700 	stm32_host_data = host_data;
701 
702 	return host_data;
703 
704 free_chips_data:
705 	kfree(host_data->chips_data);
706 free_host_data:
707 	kfree(host_data);
708 
709 	return NULL;
710 }
711 
712 static struct
713 stm32_exti_chip_data *stm32_exti_chip_init(struct stm32_exti_host_data *h_data,
714 					   u32 bank_idx)
715 {
716 	const struct stm32_exti_bank *stm32_bank;
717 	struct stm32_exti_chip_data *chip_data;
718 	void __iomem *base = h_data->base;
719 	u32 irqs_mask;
720 
721 	stm32_bank = h_data->drv_data->exti_banks[bank_idx];
722 	chip_data = &h_data->chips_data[bank_idx];
723 	chip_data->host_data = h_data;
724 	chip_data->reg_bank = stm32_bank;
725 
726 	raw_spin_lock_init(&chip_data->rlock);
727 
728 	/* Determine number of irqs supported */
729 	writel_relaxed(~0UL, base + stm32_bank->rtsr_ofst);
730 	irqs_mask = readl_relaxed(base + stm32_bank->rtsr_ofst);
731 
732 	/*
733 	 * This IP has no reset, so after hot reboot we should
734 	 * clear registers to avoid residue
735 	 */
736 	writel_relaxed(0, base + stm32_bank->imr_ofst);
737 	writel_relaxed(0, base + stm32_bank->emr_ofst);
738 	writel_relaxed(0, base + stm32_bank->rtsr_ofst);
739 	writel_relaxed(0, base + stm32_bank->ftsr_ofst);
740 	writel_relaxed(~0UL, base + stm32_bank->rpr_ofst);
741 	if (stm32_bank->fpr_ofst != UNDEF_REG)
742 		writel_relaxed(~0UL, base + stm32_bank->fpr_ofst);
743 
744 	pr_info("%pOF: bank%d\n", h_data->node, bank_idx);
745 
746 	return chip_data;
747 }
748 
749 static int __init stm32_exti_init(const struct stm32_exti_drv_data *drv_data,
750 				  struct device_node *node)
751 {
752 	struct stm32_exti_host_data *host_data;
753 	unsigned int clr = IRQ_NOREQUEST | IRQ_NOPROBE | IRQ_NOAUTOEN;
754 	int nr_irqs, ret, i;
755 	struct irq_chip_generic *gc;
756 	struct irq_domain *domain;
757 
758 	host_data = stm32_exti_host_init(drv_data, node);
759 	if (!host_data)
760 		return -ENOMEM;
761 
762 	domain = irq_domain_add_linear(node, drv_data->bank_nr * IRQS_PER_BANK,
763 				       &irq_exti_domain_ops, NULL);
764 	if (!domain) {
765 		pr_err("%pOFn: Could not register interrupt domain.\n",
766 		       node);
767 		ret = -ENOMEM;
768 		goto out_unmap;
769 	}
770 
771 	ret = irq_alloc_domain_generic_chips(domain, IRQS_PER_BANK, 1, "exti",
772 					     handle_edge_irq, clr, 0, 0);
773 	if (ret) {
774 		pr_err("%pOF: Could not allocate generic interrupt chip.\n",
775 		       node);
776 		goto out_free_domain;
777 	}
778 
779 	for (i = 0; i < drv_data->bank_nr; i++) {
780 		const struct stm32_exti_bank *stm32_bank;
781 		struct stm32_exti_chip_data *chip_data;
782 
783 		stm32_bank = drv_data->exti_banks[i];
784 		chip_data = stm32_exti_chip_init(host_data, i);
785 
786 		gc = irq_get_domain_generic_chip(domain, i * IRQS_PER_BANK);
787 
788 		gc->reg_base = host_data->base;
789 		gc->chip_types->type = IRQ_TYPE_EDGE_BOTH;
790 		gc->chip_types->chip.irq_ack = stm32_irq_ack;
791 		gc->chip_types->chip.irq_mask = irq_gc_mask_clr_bit;
792 		gc->chip_types->chip.irq_unmask = irq_gc_mask_set_bit;
793 		gc->chip_types->chip.irq_set_type = stm32_irq_set_type;
794 		gc->chip_types->chip.irq_set_wake = irq_gc_set_wake;
795 		gc->suspend = stm32_irq_suspend;
796 		gc->resume = stm32_irq_resume;
797 		gc->wake_enabled = IRQ_MSK(IRQS_PER_BANK);
798 
799 		gc->chip_types->regs.mask = stm32_bank->imr_ofst;
800 		gc->private = (void *)chip_data;
801 	}
802 
803 	nr_irqs = of_irq_count(node);
804 	for (i = 0; i < nr_irqs; i++) {
805 		unsigned int irq = irq_of_parse_and_map(node, i);
806 
807 		irq_set_handler_data(irq, domain);
808 		irq_set_chained_handler(irq, stm32_irq_handler);
809 	}
810 
811 	return 0;
812 
813 out_free_domain:
814 	irq_domain_remove(domain);
815 out_unmap:
816 	iounmap(host_data->base);
817 	kfree(host_data->chips_data);
818 	kfree(host_data);
819 	return ret;
820 }
821 
822 static const struct irq_domain_ops stm32_exti_h_domain_ops = {
823 	.alloc	= stm32_exti_h_domain_alloc,
824 	.free	= irq_domain_free_irqs_common,
825 };
826 
827 static int
828 __init stm32_exti_hierarchy_init(const struct stm32_exti_drv_data *drv_data,
829 				 struct device_node *node,
830 				 struct device_node *parent)
831 {
832 	struct irq_domain *parent_domain, *domain;
833 	struct stm32_exti_host_data *host_data;
834 	int ret, i;
835 
836 	parent_domain = irq_find_host(parent);
837 	if (!parent_domain) {
838 		pr_err("interrupt-parent not found\n");
839 		return -EINVAL;
840 	}
841 
842 	host_data = stm32_exti_host_init(drv_data, node);
843 	if (!host_data)
844 		return -ENOMEM;
845 
846 	for (i = 0; i < drv_data->bank_nr; i++)
847 		stm32_exti_chip_init(host_data, i);
848 
849 	domain = irq_domain_add_hierarchy(parent_domain, 0,
850 					  drv_data->bank_nr * IRQS_PER_BANK,
851 					  node, &stm32_exti_h_domain_ops,
852 					  host_data);
853 
854 	if (!domain) {
855 		pr_err("%pOFn: Could not register exti domain.\n", node);
856 		ret = -ENOMEM;
857 		goto out_unmap;
858 	}
859 
860 	stm32_exti_h_syscore_init();
861 
862 	return 0;
863 
864 out_unmap:
865 	iounmap(host_data->base);
866 	kfree(host_data->chips_data);
867 	kfree(host_data);
868 	return ret;
869 }
870 
871 static int __init stm32f4_exti_of_init(struct device_node *np,
872 				       struct device_node *parent)
873 {
874 	return stm32_exti_init(&stm32f4xx_drv_data, np);
875 }
876 
877 IRQCHIP_DECLARE(stm32f4_exti, "st,stm32-exti", stm32f4_exti_of_init);
878 
879 static int __init stm32h7_exti_of_init(struct device_node *np,
880 				       struct device_node *parent)
881 {
882 	return stm32_exti_init(&stm32h7xx_drv_data, np);
883 }
884 
885 IRQCHIP_DECLARE(stm32h7_exti, "st,stm32h7-exti", stm32h7_exti_of_init);
886 
887 static int __init stm32mp1_exti_of_init(struct device_node *np,
888 					struct device_node *parent)
889 {
890 	return stm32_exti_hierarchy_init(&stm32mp1_drv_data, np, parent);
891 }
892 
893 IRQCHIP_DECLARE(stm32mp1_exti, "st,stm32mp1-exti", stm32mp1_exti_of_init);
894