1 /*
2  * Copyright (c) 2021, Intel Corporation
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 /**
8  * @file
9  * @brief GPIO macros for the Elkhart Lake SoC
10  *
11  * This header file is used to specify the GPIO macros for
12  * the ELkhart Lake SoC.
13  */
14 
15 #ifndef __SOC_GPIO_H_
16 #define __SOC_GPIO_H_
17 
18 #define GPIO_INTEL_NR_SUBDEVS		15
19 
20 #define REG_PAD_OWNER_BASE              0x0020
21 #define REG_GPI_INT_STS_BASE            0x0100
22 #define PAD_CFG0_PMODE_MASK             (0x0F << 10)
23 
24 #define REG_PAD_BASE_ADDR		0x000C
25 #define REG_GPI_INT_EN_BASE		0x0120
26 #define REG_PAD_HOST_SW_OWNER		0x0B0
27 #define PAD_BASE_ADDR_MASK              0xfff
28 
29 #define GPIO_REG_BASE(reg_base) \
30 	(reg_base & ~PAD_BASE_ADDR_MASK)
31 
32 #define GPIO_PAD_BASE(reg_base) \
33 	(reg_base & PAD_BASE_ADDR_MASK)
34 
35 #define GPIO_PAD_OWNERSHIP(raw_pin, pin_offset)					\
36 	(pin_offset % 8) ?							\
37 		REG_PAD_OWNER_BASE +						\
38 			 ((((pin_offset / 8) + 1) + (raw_pin / 8)) * 0x4) :	\
39 		REG_PAD_OWNER_BASE +						\
40 			 (((pin_offset / 8) + (raw_pin / 8)) * 0x4);		\
41 
42 #define GPIO_OWNERSHIP_BIT(raw_pin) ((raw_pin % 8) * 4)
43 
44 #define GPIO_RAW_PIN(pin, pin_offset) pin
45 
46 #define GPIO_INTERRUPT_BASE(cfg) \
47 	(cfg->group_index * 0x4)
48 
49 #define GPIO_BASE(cfg) \
50 	(cfg->group_index * 0x4)
51 
52 #define PIN_OFFSET 0x10
53 
54 #endif /* __SOC_GPIO_H_ */
55