Lines Matching +full:sw +full:- +full:exception
1 // SPDX-License-Identifier: GPL-2.0
3 * Generic Loongson processor based LAPTOP/ALL-IN-ONE driver
20 #include <linux/input/sparse-keymap.h>
26 /* 1. Driver-wide structs and misc. variables */
32 #define ACPI_LAPTOP_NAME "loongson-laptop"
143 return -EIO; in hotkey_status_get()
152 if (!sub_driver || !sub_driver->notify) in dispatch_acpi_notify()
154 sub_driver->notify(sub_driver, event); in dispatch_acpi_notify()
161 if (!*sub_driver->handle) in setup_acpi_notify()
164 sub_driver->device = acpi_fetch_acpi_dev(*sub_driver->handle); in setup_acpi_notify()
165 if (!sub_driver->device) { in setup_acpi_notify()
166 pr_err("acpi_fetch_acpi_dev(%s) failed\n", sub_driver->name); in setup_acpi_notify()
167 return -ENODEV; in setup_acpi_notify()
170 sub_driver->device->driver_data = sub_driver; in setup_acpi_notify()
171 sprintf(acpi_device_class(sub_driver->device), "%s/%s", in setup_acpi_notify()
172 ACPI_LAPTOP_ACPI_EVENT_PREFIX, sub_driver->name); in setup_acpi_notify()
174 status = acpi_install_notify_handler(*sub_driver->handle, in setup_acpi_notify()
175 sub_driver->type, dispatch_acpi_notify, sub_driver); in setup_acpi_notify()
179 "handling %s events\n", sub_driver->name); in setup_acpi_notify()
182 sub_driver->name, acpi_format_exception(status)); in setup_acpi_notify()
184 return -ENODEV; in setup_acpi_notify()
186 sub_driver->acpi_notify_installed = 1; in setup_acpi_notify()
206 pr_info("Loongson_backlight: resume brightness %d\n", bd->props.brightness); in loongson_hotkey_resume()
213 if (test_bit(SW_LID, generic_inputdev->swbit)) { in loongson_hotkey_resume()
215 return -EIO; in loongson_hotkey_resume()
217 * The input device sw element records the last lid status. in loongson_hotkey_resume()
218 * When the system is awakened by other wake-up sources, in loongson_hotkey_resume()
220 * adding SW_LID bit which in sw element can avoid this in loongson_hotkey_resume()
227 * Lid status is generally 0, but hardware exception is in loongson_hotkey_resume()
230 if (test_bit(SW_LID, generic_inputdev->sw) && !(status & (1 << SW_LID))) { in loongson_hotkey_resume()
232 ke.sw.value = (u8)status; in loongson_hotkey_resume()
233 ke.sw.code = SW_LID; in loongson_hotkey_resume()
246 hotkey_handle = ACPI_HANDLE(&pdev->dev); in loongson_hotkey_probe()
249 return -ENODEV; in loongson_hotkey_probe()
263 .name = "loongson-hotkey",
280 pr_err("ACPI exception: %s\n", acpi_format_exception(status)); in hotkey_map()
281 return -1; in hotkey_map()
284 for (index = 0; index < pack->package.count; index++) { in hotkey_map()
287 sub_pack = &pack->package.elements[index]; in hotkey_map()
289 element = &sub_pack->package.elements[0]; in hotkey_map()
290 hotkey_keycode_map[index].type = element->integer.value; in hotkey_map()
291 element = &sub_pack->package.elements[1]; in hotkey_map()
292 hotkey_keycode_map[index].code = element->integer.value; in hotkey_map()
293 element = &sub_pack->package.elements[2]; in hotkey_map()
294 hotkey_keycode_map[index].keycode = element->integer.value; in hotkey_map()
303 return -EIO; in hotkey_backlight_set()
313 return -ENXIO; in ec_get_brightness()
316 return -EIO; in ec_get_brightness()
327 return -ENXIO; in ec_set_brightness()
330 ret = -EIO; in ec_set_brightness()
340 return -ENXIO; in ec_backlight_level()
343 return -EIO; in ec_backlight_level()
349 return -EIO; in ec_backlight_level()
359 int lvl = ec_backlight_level(bd->props.brightness); in loongson_laptop_backlight_update()
362 return -EIO; in loongson_laptop_backlight_update()
364 return -EIO; in loongson_laptop_backlight_update()
375 return -EIO; in loongson_laptop_get_brightness()
393 return -EIO; in laptop_backlight_register()
415 return -ENODEV; in loongson_laptop_turn_on_backlight()
431 return -ENODEV; in loongson_laptop_turn_off_backlight()
485 ke->sw.value = !!(status & (1 << ke->sw.code)); in event_notify()
499 if (!sub_driver || !sub_driver->driver) in generic_subdriver_init()
500 return -EINVAL; in generic_subdriver_init()
502 ret = platform_driver_register(sub_driver->driver); in generic_subdriver_init()
504 return -EINVAL; in generic_subdriver_init()
506 if (sub_driver->init) { in generic_subdriver_init()
507 ret = sub_driver->init(sub_driver); in generic_subdriver_init()
512 if (sub_driver->notify) { in generic_subdriver_init()
514 if (ret == -ENODEV) { in generic_subdriver_init()
532 if (sub_driver->acpi_notify_installed) { in generic_subdriver_exit()
533 acpi_remove_notify_handler(*sub_driver->handle, in generic_subdriver_exit()
534 sub_driver->type, dispatch_acpi_notify); in generic_subdriver_exit()
535 sub_driver->acpi_notify_installed = 0; in generic_subdriver_exit()
537 platform_driver_unregister(sub_driver->driver); in generic_subdriver_exit()
557 return -ENODEV; in generic_acpi_laptop_init()
562 return -ENODEV; in generic_acpi_laptop_init()
570 return -ENOMEM; in generic_acpi_laptop_init()
574 generic_inputdev->name = in generic_acpi_laptop_init()
575 "Loongson Generic Laptop/All-in-One Extra Buttons"; in generic_acpi_laptop_init()
576 generic_inputdev->phys = ACPI_LAPTOP_NAME "/input0"; in generic_acpi_laptop_init()
577 generic_inputdev->id.bustype = BUS_HOST; in generic_acpi_laptop_init()
578 generic_inputdev->dev.parent = NULL; in generic_acpi_laptop_init()
585 while (--i >= 0) in generic_acpi_laptop_init()
594 while (--i >= 0) in generic_acpi_laptop_init()
606 pr_err("Loongson Laptop: laptop-backlight device register failed\n"); in generic_acpi_laptop_init()
627 MODULE_DESCRIPTION("Loongson Laptop/All-in-One ACPI Driver");