1 /* SPDX-License-Identifier: GPL-2.0+ */
3 * Azoteq IQS620A/621/622/624/625 Multi-Function Sensors
8 #ifndef __LINUX_MFD_IQS62X_H
9 #define __LINUX_MFD_IQS62X_H
11 #define IQS620_PROD_NUM 0x41
12 #define IQS621_PROD_NUM 0x46
13 #define IQS622_PROD_NUM 0x42
14 #define IQS624_PROD_NUM 0x43
15 #define IQS625_PROD_NUM 0x4E
17 #define IQS621_ALS_FLAGS 0x16
18 #define IQS622_ALS_FLAGS 0x14
20 #define IQS624_HALL_UI 0x70
21 #define IQS624_HALL_UI_WHL_EVENT BIT(4)
22 #define IQS624_HALL_UI_INT_EVENT BIT(3)
23 #define IQS624_HALL_UI_AUTO_CAL BIT(2)
25 #define IQS624_INTERVAL_DIV 0x7D
27 #define IQS620_GLBL_EVENT_MASK 0xD7
28 #define IQS620_GLBL_EVENT_MASK_PMU BIT(6)
30 #define IQS62X_NUM_KEYS 16
31 #define IQS62X_NUM_EVENTS (IQS62X_NUM_KEYS + 5)
33 #define IQS62X_EVENT_SIZE 10
40 enum iqs62x_event_reg {
54 enum iqs62x_event_flag {
56 IQS62X_EVENT_PROX_CH0_T,
57 IQS62X_EVENT_PROX_CH0_P,
58 IQS62X_EVENT_PROX_CH1_T,
59 IQS62X_EVENT_PROX_CH1_P,
60 IQS62X_EVENT_PROX_CH2_T,
61 IQS62X_EVENT_PROX_CH2_P,
62 IQS62X_EVENT_HYST_POS_T,
63 IQS62X_EVENT_HYST_POS_P,
64 IQS62X_EVENT_HYST_NEG_T,
65 IQS62X_EVENT_HYST_NEG_P,
66 IQS62X_EVENT_SAR1_ACT,
67 IQS62X_EVENT_SAR1_QRD,
68 IQS62X_EVENT_SAR1_MOVE,
69 IQS62X_EVENT_SAR1_HALT,
70 IQS62X_EVENT_WHEEL_UP,
71 IQS62X_EVENT_WHEEL_DN,
74 IQS62X_EVENT_HALL_N_T,
75 IQS62X_EVENT_HALL_N_P,
76 IQS62X_EVENT_HALL_S_T,
77 IQS62X_EVENT_HALL_S_P,
80 IQS62X_EVENT_SYS_RESET,
83 struct iqs62x_event_data {
90 struct iqs62x_event_desc {
91 enum iqs62x_event_reg reg;
96 struct iqs62x_dev_desc {
98 const struct mfd_cell *sub_devs;
124 const enum iqs62x_event_reg (*event_regs)[IQS62X_EVENT_SIZE];
128 const struct iqs62x_dev_desc *dev_desc;
129 struct i2c_client *client;
130 struct regmap *regmap;
131 struct blocking_notifier_head nh;
132 struct list_head fw_blk_head;
133 struct completion fw_done;
134 enum iqs62x_ui_sel ui_sel;
137 extern const struct iqs62x_event_desc iqs62x_events[IQS62X_NUM_EVENTS];
139 #endif /* __LINUX_MFD_IQS62X_H */