1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * Copyright 2010 Ben Dooks <ben-linux@fluff.org>
4  *
5  * Support for wakeup mask interrupts on newer SoCs
6  */
7 
8 #ifndef __PLAT_WAKEUP_MASK_H
9 #define __PLAT_WAKEUP_MASK_H __file__
10 
11 /* if no irq yet defined, but still want to mask */
12 #define NO_WAKEUP_IRQ (0x90000000)
13 
14 /**
15  * struct samsung_wakeup_mask - wakeup mask information
16  * @irq: The interrupt associated with this wakeup.
17  * @bit: The bit, as a (1 << bitno) controlling this source.
18  */
19 struct samsung_wakeup_mask {
20 	unsigned int	irq;
21 	u32		bit;
22 };
23 
24 /**
25  * samsung_sync_wakemask - sync wakeup mask information for pm
26  * @reg: The register that is used.
27  * @masks: The list of masks to use.
28  * @nr_masks: The number of entries pointed to buy @masks.
29  *
30  * Synchronise the wakeup mask information at suspend time from the list
31  * of interrupts and control bits in @masks. We do this at suspend time
32  * as overriding the relevant irq chips is harder and the register is only
33  * required to be correct before we enter sleep.
34  */
35 extern void samsung_sync_wakemask(void __iomem *reg,
36 				  const struct samsung_wakeup_mask *masks,
37 				  int nr_masks);
38 
39 #endif /* __PLAT_WAKEUP_MASK_H */
40