Lines Matching +full:cros +full:- +full:cbas

1 // SPDX-License-Identifier: GPL-2.0+
6 * Author: Wei-Ning Huang <wnhuang@google.com>
18 #include <linux/input/vivaldi-fmap.h>
28 #include "hid-ids.h"
29 #include "hid-vivaldi-common.h"
32 * C(hrome)B(ase)A(ttached)S(witch) - switch exported by Chrome EC and reporting
33 * state of the "Whiskers" base - attached or detached. Whiskers USB device also
34 * reports position of the keyboard - folded or not. Combining base state and
66 return -ENOMEM; in cbas_ec_query_base()
68 msg->command = EC_CMD_MKBP_INFO; in cbas_ec_query_base()
69 msg->version = 1; in cbas_ec_query_base()
70 msg->outsize = sizeof(*params); in cbas_ec_query_base()
71 msg->insize = sizeof(u32); in cbas_ec_query_base()
72 params = (struct ec_params_mkbp_info *)msg->data; in cbas_ec_query_base()
73 params->info_type = get_state ? in cbas_ec_query_base()
75 params->event_type = EC_MKBP_EVENT_SWITCH; in cbas_ec_query_base()
80 dev_warn(ec_dev->dev, "wrong result size: %d != %zu\n", in cbas_ec_query_base()
82 ret = -EPROTO; in cbas_ec_query_base()
84 *state = cbas_parse_base_state(msg->data); in cbas_ec_query_base()
102 if (ec->event_data.event_type == EC_MKBP_EVENT_SWITCH) { in cbas_ec_notify()
104 &ec->event_data.data.switches); in cbas_ec_notify()
139 struct cros_ec_device *ec = dev_get_drvdata(dev->parent); in cbas_ec_resume()
180 struct cros_ec_device *ec = dev_get_drvdata(pdev->dev.parent); in __cbas_ec_probe()
190 return -ENXIO; in __cbas_ec_probe()
192 input = devm_input_allocate_device(&pdev->dev); in __cbas_ec_probe()
194 return -ENOMEM; in __cbas_ec_probe()
196 input->name = "Whiskers Tablet Mode Switch"; in __cbas_ec_probe()
197 input->id.bustype = BUS_HOST; in __cbas_ec_probe()
203 dev_err(&pdev->dev, "cannot register input device: %d\n", in __cbas_ec_probe()
211 dev_err(&pdev->dev, "cannot query base state: %d\n", error); in __cbas_ec_probe()
218 dev_dbg(&pdev->dev, "%s: base: %d, folded: %d\n", __func__, in __cbas_ec_probe()
226 cbas_ec.dev = &pdev->dev; in __cbas_ec_probe()
228 error = blocking_notifier_chain_register(&ec->event_notifier, in __cbas_ec_probe()
231 dev_err(&pdev->dev, "cannot register notifier: %d\n", error); in __cbas_ec_probe()
236 device_init_wakeup(&pdev->dev, true); in __cbas_ec_probe()
247 retval = -EBUSY; in cbas_ec_probe()
260 struct cros_ec_device *ec = dev_get_drvdata(pdev->dev.parent); in cbas_ec_remove()
264 blocking_notifier_chain_unregister(&ec->event_notifier, in cbas_ec_remove()
279 { .compatible = "google,cros-cbas" },
312 led->buf[0] = 0; in hammer_kbd_brightness_set_blocking()
313 led->buf[1] = br; in hammer_kbd_brightness_set_blocking()
319 ret = hid_hw_power(led->hdev, PM_HINT_FULLON); in hammer_kbd_brightness_set_blocking()
321 hid_err(led->hdev, "failed: device not resumed %d\n", ret); in hammer_kbd_brightness_set_blocking()
325 ret = hid_hw_output_report(led->hdev, led->buf, sizeof(led->buf)); in hammer_kbd_brightness_set_blocking()
326 if (ret == -ENOSYS) in hammer_kbd_brightness_set_blocking()
327 ret = hid_hw_raw_request(led->hdev, 0, led->buf, in hammer_kbd_brightness_set_blocking()
328 sizeof(led->buf), in hammer_kbd_brightness_set_blocking()
332 hid_err(led->hdev, "failed to set keyboard backlight: %d\n", in hammer_kbd_brightness_set_blocking()
336 hid_hw_power(led->hdev, PM_HINT_NORMAL); in hammer_kbd_brightness_set_blocking()
345 kbd_backlight = devm_kzalloc(&hdev->dev, sizeof(*kbd_backlight), in hammer_register_leds()
348 return -ENOMEM; in hammer_register_leds()
350 kbd_backlight->hdev = hdev; in hammer_register_leds()
351 kbd_backlight->cdev.name = "hammer::kbd_backlight"; in hammer_register_leds()
352 kbd_backlight->cdev.max_brightness = MAX_BRIGHTNESS; in hammer_register_leds()
353 kbd_backlight->cdev.brightness_set_blocking = in hammer_register_leds()
355 kbd_backlight->cdev.flags = LED_HW_PLUGGABLE; in hammer_register_leds()
358 hammer_kbd_brightness_set_blocking(&kbd_backlight->cdev, 0); in hammer_register_leds()
360 return devm_led_classdev_register(&hdev->dev, &kbd_backlight->cdev); in hammer_register_leds()
375 if (usage->hid == HID_USAGE_KBD_FOLDED) { in hammer_input_mapping()
381 return -1; in hammer_input_mapping()
413 if (usage->hid == HID_USAGE_KBD_FOLDED) { in hammer_event()
440 report = hdev->report_enum[HID_INPUT_REPORT].report_id_hash[0x0]; in hammer_get_folded_state()
442 if (!report || report->maxfield < 1) in hammer_get_folded_state()
451 rlen = hid_hw_raw_request(hdev, report->id, buf, len, report->type, HID_REQ_GET_REPORT); in hammer_get_folded_state()
458 for (a = 0; a < report->maxfield; a++) { in hammer_get_folded_state()
459 struct hid_field *field = report->field[a]; in hammer_get_folded_state()
461 if (field->usage->hid == HID_USAGE_KBD_FOLDED) { in hammer_get_folded_state()
463 field->report_offset, field->report_size); in hammer_get_folded_state()
485 vdata = devm_kzalloc(&hdev->dev, sizeof(*vdata), GFP_KERNEL); in hammer_probe()
487 return -ENOMEM; in hammer_probe()
499 error = devm_add_action(&hdev->dev, hammer_stop, hdev); in hammer_probe()
510 hdev->quirks |= HID_QUIRK_ALWAYS_POLL; in hammer_probe()