Lines Matching defs:iqs62x_keys

46 				  struct iqs62x_keys_private *iqs62x_keys)
60 iqs62x_keys->keycodemax = ret;
63 iqs62x_keys->keycode,
64 iqs62x_keys->keycodemax);
70 for (i = 0; i < ARRAY_SIZE(iqs62x_keys->switches); i++) {
83 iqs62x_keys->switches[i].code = val;
84 iqs62x_keys->switches[i].enabled = true;
87 iqs62x_keys->switches[i].flag = (i == IQS62X_SW_HALL_N ?
91 iqs62x_keys->switches[i].flag = (i == IQS62X_SW_HALL_N ?
101 static int iqs62x_keys_init(struct iqs62x_keys_private *iqs62x_keys)
103 struct iqs62x_core *iqs62x = iqs62x_keys->iqs62x;
119 for (i = 0; i < iqs62x_keys->keycodemax; i++) {
120 if (iqs62x_keys->keycode[i] == KEY_RESERVED)
139 for (i = 0; i < ARRAY_SIZE(iqs62x_keys->switches); i++) {
140 if (!(iqs62x_keys->switches[i].enabled))
143 flag = iqs62x_keys->switches[i].flag;
150 input_report_switch(iqs62x_keys->input,
151 iqs62x_keys->switches[i].code,
156 input_sync(iqs62x_keys->input);
166 if (iqs62x_keys->keycode[IQS62X_EVENT_WHEEL_UP] != KEY_RESERVED)
169 if (iqs62x_keys->keycode[IQS62X_EVENT_WHEEL_DN] != KEY_RESERVED)
177 iqs62x_keys->interval = val;
191 struct iqs62x_keys_private *iqs62x_keys;
194 iqs62x_keys = container_of(notifier, struct iqs62x_keys_private,
198 ret = iqs62x_keys_init(iqs62x_keys);
200 dev_err(iqs62x_keys->input->dev.parent,
208 for (i = 0; i < iqs62x_keys->keycodemax; i++) {
210 event_data->interval == iqs62x_keys->interval)
213 input_report_key(iqs62x_keys->input, iqs62x_keys->keycode[i],
217 for (i = 0; i < ARRAY_SIZE(iqs62x_keys->switches); i++)
218 if (iqs62x_keys->switches[i].enabled)
219 input_report_switch(iqs62x_keys->input,
220 iqs62x_keys->switches[i].code,
222 BIT(iqs62x_keys->switches[i].flag));
224 input_sync(iqs62x_keys->input);
226 if (event_data->interval == iqs62x_keys->interval)
234 input_report_key(iqs62x_keys->input,
235 iqs62x_keys->keycode[IQS62X_EVENT_WHEEL_UP],
237 input_sync(iqs62x_keys->input);
239 input_report_key(iqs62x_keys->input,
240 iqs62x_keys->keycode[IQS62X_EVENT_WHEEL_DN],
242 input_sync(iqs62x_keys->input);
245 iqs62x_keys->interval = event_data->interval;
253 struct iqs62x_keys_private *iqs62x_keys;
257 iqs62x_keys = devm_kzalloc(&pdev->dev, sizeof(*iqs62x_keys),
259 if (!iqs62x_keys)
262 platform_set_drvdata(pdev, iqs62x_keys);
264 ret = iqs62x_keys_parse_prop(pdev, iqs62x_keys);
272 input->keycodemax = iqs62x_keys->keycodemax;
273 input->keycode = iqs62x_keys->keycode;
274 input->keycodesize = sizeof(*iqs62x_keys->keycode);
279 for (i = 0; i < iqs62x_keys->keycodemax; i++)
280 if (iqs62x_keys->keycode[i] != KEY_RESERVED)
282 iqs62x_keys->keycode[i]);
284 for (i = 0; i < ARRAY_SIZE(iqs62x_keys->switches); i++)
285 if (iqs62x_keys->switches[i].enabled)
287 iqs62x_keys->switches[i].code);
289 iqs62x_keys->iqs62x = iqs62x;
290 iqs62x_keys->input = input;
292 ret = iqs62x_keys_init(iqs62x_keys);
298 ret = input_register_device(iqs62x_keys->input);
304 iqs62x_keys->notifier.notifier_call = iqs62x_keys_notifier;
305 ret = blocking_notifier_chain_register(&iqs62x_keys->iqs62x->nh,
306 &iqs62x_keys->notifier);
315 struct iqs62x_keys_private *iqs62x_keys = platform_get_drvdata(pdev);
318 ret = blocking_notifier_chain_unregister(&iqs62x_keys->iqs62x->nh,
319 &iqs62x_keys->notifier);