Lines Matching +full:fn +full:- +full:keymap
1 // SPDX-License-Identifier: GPL-2.0-or-later
6 * Copyright (C) 2014-2015 Pali Rohár <pali@kernel.org>
22 #include <linux/input/sparse-keymap.h>
28 #include "dell-smbios.h"
29 #include "dell-wmi-descriptor.h"
36 #define DELL_EVENT_GUID "9DBB5994-A997-11DA-B012-B622A1EF5492"
72 * Keymap for WMI events of type 0x0000
157 * Originally Matthew Garrett created this dell-wmi driver specially for
188 struct dell_bios_keymap_entry keymap[]; member
195 struct key_entry *keymap; member
243 * Keymap for WMI events of type 0x0010
249 /* Fn-lock switched to function keys */
252 /* Fn-lock switched to multimedia keys */
268 /* Fn-lock */
275 * Radio disable (notify only -- there is no model for which the
286 * a notification. On the XPS 13 9350, this is Fn+F7, and there's
301 * Radio disable (notify only -- there is no model for which the
306 /* Fn-lock */
311 * Keymap for WMI events of type 0x0011
341 * Keymap for WMI events of type 0x0012
345 /* Fn-lock button pressed */
351 struct dell_wmi_priv *priv = dev_get_drvdata(&wdev->dev); in dell_wmi_process_key()
354 key = sparse_keymap_entry_from_scancode(priv->input_dev, in dell_wmi_process_key()
365 if ((key->keycode == KEY_BRIGHTNESSUP || in dell_wmi_process_key()
366 key->keycode == KEY_BRIGHTNESSDOWN) && in dell_wmi_process_key()
373 if (key->keycode == KEY_KBDILLUMTOGGLE) in dell_wmi_process_key()
377 sparse_keymap_report_entry(priv->input_dev, key, 1, true); in dell_wmi_process_key()
383 struct dell_wmi_priv *priv = dev_get_drvdata(&wdev->dev); in dell_wmi_notify()
388 if (obj->type != ACPI_TYPE_BUFFER) { in dell_wmi_notify()
389 pr_warn("bad response type %x\n", obj->type); in dell_wmi_notify()
394 obj->buffer.length, obj->buffer.pointer); in dell_wmi_notify()
396 buffer_entry = (u16 *)obj->buffer.pointer; in dell_wmi_notify()
397 buffer_size = obj->buffer.length/2; in dell_wmi_notify()
412 if (priv->interface_version == 0 && buffer_entry < buffer_end) in dell_wmi_notify()
457 static bool have_scancode(u32 scancode, const struct key_entry *keymap, int len) in have_scancode() argument
462 if (keymap[i].code == scancode) in have_scancode()
473 struct key_entry *keymap; in handle_dmi_entry() local
475 if (results->err || results->keymap) in handle_dmi_entry()
479 if (dm->type != 0xb2) in handle_dmi_entry()
484 hotkey_num = (table->header.length - in handle_dmi_entry()
489 * Historically, dell-wmi would ignore a DMI entry of in handle_dmi_entry()
498 keymap = kcalloc(hotkey_num, sizeof(struct key_entry), GFP_KERNEL); in handle_dmi_entry()
499 if (!keymap) { in handle_dmi_entry()
500 results->err = -ENOMEM; in handle_dmi_entry()
506 &table->keymap[i]; in handle_dmi_entry()
509 u16 keycode = (bios_entry->keycode < in handle_dmi_entry()
511 bios_to_linux_keycode[bios_entry->keycode] : in handle_dmi_entry()
512 (bios_entry->keycode == 0xffff ? KEY_UNKNOWN : KEY_RESERVED); in handle_dmi_entry()
521 bios_entry->scancode, bios_entry->keycode); in handle_dmi_entry()
526 keymap[pos].type = KE_IGNORE; in handle_dmi_entry()
528 keymap[pos].type = KE_KEY; in handle_dmi_entry()
529 keymap[pos].code = bios_entry->scancode; in handle_dmi_entry()
530 keymap[pos].keycode = keycode; in handle_dmi_entry()
535 results->keymap = keymap; in handle_dmi_entry()
536 results->keymap_size = pos; in handle_dmi_entry()
541 struct dell_wmi_priv *priv = dev_get_drvdata(&wdev->dev); in dell_wmi_input_setup()
543 struct key_entry *keymap; in dell_wmi_input_setup() local
546 priv->input_dev = input_allocate_device(); in dell_wmi_input_setup()
547 if (!priv->input_dev) in dell_wmi_input_setup()
548 return -ENOMEM; in dell_wmi_input_setup()
550 priv->input_dev->name = "Dell WMI hotkeys"; in dell_wmi_input_setup()
551 priv->input_dev->id.bustype = BUS_HOST; in dell_wmi_input_setup()
552 priv->input_dev->dev.parent = &wdev->dev; in dell_wmi_input_setup()
556 * Historically, dell-wmi ignored dmi_walk errors. A failure in dell_wmi_input_setup()
560 pr_warn("no DMI; using the old-style hotkey interface\n"); in dell_wmi_input_setup()
568 keymap = kcalloc(dmi_results.keymap_size + in dell_wmi_input_setup()
575 if (!keymap) { in dell_wmi_input_setup()
576 kfree(dmi_results.keymap); in dell_wmi_input_setup()
577 err = -ENOMEM; in dell_wmi_input_setup()
583 keymap[pos] = dmi_results.keymap[i]; in dell_wmi_input_setup()
584 keymap[pos].code |= (0x0010 << 16); in dell_wmi_input_setup()
588 kfree(dmi_results.keymap); in dell_wmi_input_setup()
600 have_scancode(entry->code | (0x0010 << 16), in dell_wmi_input_setup()
601 keymap, dmi_results.keymap_size) in dell_wmi_input_setup()
605 keymap[pos] = *entry; in dell_wmi_input_setup()
606 keymap[pos].code |= (0x0010 << 16); in dell_wmi_input_setup()
612 keymap[pos] = dell_wmi_keymap_type_0011[i]; in dell_wmi_input_setup()
613 keymap[pos].code |= (0x0011 << 16); in dell_wmi_input_setup()
619 keymap[pos] = dell_wmi_keymap_type_0012[i]; in dell_wmi_input_setup()
620 keymap[pos].code |= (0x0012 << 16); in dell_wmi_input_setup()
629 keymap[pos] = dell_wmi_keymap_type_0000[i]; in dell_wmi_input_setup()
633 keymap[pos].type = KE_END; in dell_wmi_input_setup()
635 err = sparse_keymap_setup(priv->input_dev, keymap, NULL); in dell_wmi_input_setup()
637 * Sparse keymap library makes a copy of keymap so we don't need the in dell_wmi_input_setup()
640 kfree(keymap); in dell_wmi_input_setup()
644 err = input_register_device(priv->input_dev); in dell_wmi_input_setup()
651 input_free_device(priv->input_dev); in dell_wmi_input_setup()
657 struct dell_wmi_priv *priv = dev_get_drvdata(&wdev->dev); in dell_wmi_input_destroy()
659 input_unregister_device(priv->input_dev); in dell_wmi_input_destroy()
675 * cbRes1 Standard return codes (0, -1, -2)
685 return -ENOMEM; in dell_wmi_events_set_enabled()
686 buffer->cmd_class = CLASS_INFO; in dell_wmi_events_set_enabled()
687 buffer->cmd_select = SELECT_APP_REGISTRATION; in dell_wmi_events_set_enabled()
688 buffer->input[0] = 0x10000; in dell_wmi_events_set_enabled()
689 buffer->input[1] = 0x51534554; in dell_wmi_events_set_enabled()
690 buffer->input[3] = enable; in dell_wmi_events_set_enabled()
693 ret = buffer->output[0]; in dell_wmi_events_set_enabled()
709 &wdev->dev, sizeof(struct dell_wmi_priv), GFP_KERNEL); in dell_wmi_probe()
711 return -ENOMEM; in dell_wmi_probe()
712 dev_set_drvdata(&wdev->dev, priv); in dell_wmi_probe()
714 if (!dell_wmi_get_interface_version(&priv->interface_version)) in dell_wmi_probe()
715 return -EPROBE_DEFER; in dell_wmi_probe()
732 .name = "dell-wmi",