1 /*
2 * Copyright 2022 Google LLC
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #ifndef ZEPHYR_DRIVERS_GPIO_RT1718S_H_
8 #define ZEPHYR_DRIVERS_GPIO_RT1718S_H_
9
10 #include <zephyr/device.h>
11 #include <zephyr/drivers/gpio.h>
12 #include <zephyr/drivers/i2c.h>
13 #include <zephyr/kernel.h>
14
15 #define RT1718S_GPIO_NUM 3
16
17 #define RT1718S_REG_ALERT 0x10
18 #define RT1718S_REG_ALERT_VENDOR_DEFINED_ALERT BIT(15)
19
20 #define RT1718S_REG_ALERT_MASK 0x12
21 #define RT1718S_REG_ALERT_MASK_VENDOR_DEFINED_ALERT BIT(15)
22
23 #define RT1718S_REG_RT_MASK8 0xA6
24 #define RT1718S_REG_RT_MASK8_GPIO1_R BIT(0)
25 #define RT1718S_REG_RT_MASK8_GPIO2_R BIT(1)
26 #define RT1718S_REG_RT_MASK8_GPIO3_R BIT(2)
27 #define RT1718S_REG_RT_MASK8_GPIO1_F BIT(4)
28 #define RT1718S_REG_RT_MASK8_GPIO2_F BIT(5)
29 #define RT1718S_REG_RT_MASK8_GPIO3_F BIT(6)
30
31 #define RT1718S_REG_RT_INT8 0xA8
32 #define RT1718S_REG_RT_INT8_GPIO1_R BIT(0)
33 #define RT1718S_REG_RT_INT8_GPIO2_R BIT(1)
34 #define RT1718S_REG_RT_INT8_GPIO3_R BIT(2)
35 #define RT1718S_REG_RT_INT8_GPIO1_F BIT(4)
36 #define RT1718S_REG_RT_INT8_GPIO2_F BIT(5)
37 #define RT1718S_REG_RT_INT8_GPIO3_F BIT(6)
38 #define RT1718S_GPIO_INT_MASK \
39 (RT1718S_REG_RT_INT8_GPIO1_R | RT1718S_REG_RT_INT8_GPIO2_R | RT1718S_REG_RT_INT8_GPIO3_R | \
40 RT1718S_REG_RT_INT8_GPIO1_F | RT1718S_REG_RT_INT8_GPIO2_F | RT1718S_REG_RT_INT8_GPIO3_F)
41
42 #define RT1718S_REG_RT_ST8 0xAA
43 #define RT1718S_REG_RT_ST8_GPIO1_I BIT(0)
44 #define RT1718S_REG_RT_ST8_GPIO2_I BIT(1)
45 #define RT1718S_REG_RT_ST8_GPIO3_I BIT(2)
46
47 #define RT1718S_REG_GPIO_CTRL(pin) (0xED + pin)
48 #define RT1718S_REG_GPIO_CTRL_PU BIT(5)
49 #define RT1718S_REG_GPIO_CTRL_PD BIT(4)
50 #define RT1718S_REG_GPIO_CTRL_OD_N BIT(3)
51 #define RT1718S_REG_GPIO_CTRL_OE BIT(2)
52 #define RT1718S_REG_GPIO_CTRL_O BIT(1)
53 #define RT1718S_REG_GPIO_CTRL_I BIT(0)
54
55 /* RT1718S chip driver config */
56 struct rt1718s_config {
57 /* I2C device */
58 const struct i2c_dt_spec i2c_dev;
59 /* Alert GPIO pin */
60 const struct gpio_dt_spec irq_gpio;
61 /* GPIO port device */
62 const struct device *gpio_port_dev;
63 };
64
65 /* RT1718S chip driver data */
66 struct rt1718s_data {
67 /* RT1718S device */
68 const struct device *dev;
69 /* lock TCPCI registers access */
70 struct k_sem lock_tcpci;
71 /* Alert pin callback */
72 struct gpio_callback gpio_cb;
73 /* Alert worker */
74 struct k_work alert_worker;
75 };
76
77 /**
78 * @brief Read a RT1718S register
79 *
80 * @param dev RT1718S device
81 * @param reg_addr Register address
82 * @param val A pointer to a buffer for the data to return
83 *
84 * @return 0 if successful, otherwise failed.
85 */
rt1718s_reg_read_byte(const struct device * dev,uint8_t reg_addr,uint8_t * val)86 static inline int rt1718s_reg_read_byte(const struct device *dev, uint8_t reg_addr, uint8_t *val)
87 {
88 const struct rt1718s_config *const config = (const struct rt1718s_config *)dev->config;
89
90 return i2c_reg_read_byte_dt(&config->i2c_dev, reg_addr, val);
91 }
92
93 /**
94 * @brief Read a sequence of RT1718S registers
95 *
96 * @param dev RT1718S device
97 * @param start_addr The register start address
98 * @param buf A pointer to a buffer for the data to return
99 * @param num_bytes Number of data to read
100 *
101 * @return 0 if successful, otherwise failed.
102 */
rt1718s_reg_burst_read(const struct device * dev,uint8_t start_addr,uint8_t * buf,uint32_t num_bytes)103 static inline int rt1718s_reg_burst_read(const struct device *dev, uint8_t start_addr, uint8_t *buf,
104 uint32_t num_bytes)
105 {
106 const struct rt1718s_config *const config = (const struct rt1718s_config *)dev->config;
107
108 return i2c_burst_read_dt(&config->i2c_dev, start_addr, buf, num_bytes);
109 }
110
111 /**
112 * @brief Write a RT1718S register
113 *
114 * @param dev RT1718S device
115 * @param reg_addr Register address
116 * @param val Data to write
117 *
118 * @return 0 if successful, otherwise failed.
119 */
rt1718s_reg_write_byte(const struct device * dev,uint8_t reg_addr,uint8_t val)120 static inline int rt1718s_reg_write_byte(const struct device *dev, uint8_t reg_addr, uint8_t val)
121 {
122 const struct rt1718s_config *const config = (const struct rt1718s_config *)dev->config;
123
124 return i2c_reg_write_byte_dt(&config->i2c_dev, reg_addr, val);
125 }
126
127 /**
128 * @brief Write a sequence of RT1718S registers
129 *
130 * @param dev RT1718S device
131 * @param start_addr The register start address
132 * @param buf A pointer to a buffer for the data to write
133 * @param num_bytes Number of data to write
134 *
135 * @return 0 if successful, otherwise failed.
136 */
rt1718s_reg_burst_write(const struct device * dev,uint8_t start_addr,uint8_t * buf,uint32_t num_bytes)137 static inline int rt1718s_reg_burst_write(const struct device *dev, uint8_t start_addr,
138 uint8_t *buf, uint32_t num_bytes)
139 {
140 const struct rt1718s_config *const config = (const struct rt1718s_config *)dev->config;
141
142 return i2c_burst_write_dt(&config->i2c_dev, start_addr, buf, num_bytes);
143 }
144
145 /**
146 * @brief Compare data & write a RT1718S register
147 *
148 * @param dev RT1718S device
149 * @param reg_addr Register address
150 * @param reg_val Old register data
151 * @param new_val New register data
152 *
153 * @return 0 if successful, otherwise failed.
154 */
rt1718s_reg_update(const struct device * dev,uint8_t reg_addr,uint8_t reg_val,uint8_t new_val)155 static inline int rt1718s_reg_update(const struct device *dev, uint8_t reg_addr, uint8_t reg_val,
156 uint8_t new_val)
157 {
158 if (reg_val == new_val) {
159 return 0;
160 }
161
162 return rt1718s_reg_write_byte(dev, reg_addr, new_val);
163 }
164
165 /**
166 * @brief Dispatch GPIO port alert
167 *
168 * @param dev RT1718S device
169 */
170 void rt1718s_gpio_alert_handler(const struct device *dev);
171
172 #endif /* ZEPHYR_DRIVERS_GPIO_RT1718S_H_*/
173