mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-10 22:54:11 +08:00
d2912cb15b
Based on 2 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation # extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 4122 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Enrico Weigelt <info@metux.net> Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190604081206.933168790@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
59 lines
1.9 KiB
C
59 lines
1.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
#ifndef _SPARSE_KEYMAP_H
|
|
#define _SPARSE_KEYMAP_H
|
|
|
|
/*
|
|
* Copyright (c) 2009 Dmitry Torokhov
|
|
*/
|
|
|
|
#define KE_END 0 /* Indicates end of keymap */
|
|
#define KE_KEY 1 /* Ordinary key/button */
|
|
#define KE_SW 2 /* Switch (predetermined value) */
|
|
#define KE_VSW 3 /* Switch (value supplied at runtime) */
|
|
#define KE_IGNORE 4 /* Known entry that should be ignored */
|
|
#define KE_LAST KE_IGNORE
|
|
|
|
/**
|
|
* struct key_entry - keymap entry for use in sparse keymap
|
|
* @type: Type of the key entry (KE_KEY, KE_SW, KE_VSW, KE_END);
|
|
* drivers are allowed to extend the list with their own
|
|
* private definitions.
|
|
* @code: Device-specific data identifying the button/switch
|
|
* @keycode: KEY_* code assigned to a key/button
|
|
* @sw.code: SW_* code assigned to a switch
|
|
* @sw.value: Value that should be sent in an input even when KE_SW
|
|
* switch is toggled. KE_VSW switches ignore this field and
|
|
* expect driver to supply value for the event.
|
|
*
|
|
* This structure defines an entry in a sparse keymap used by some
|
|
* input devices for which traditional table-based approach is not
|
|
* suitable.
|
|
*/
|
|
struct key_entry {
|
|
int type; /* See KE_* above */
|
|
u32 code;
|
|
union {
|
|
u16 keycode; /* For KE_KEY */
|
|
struct { /* For KE_SW, KE_VSW */
|
|
u8 code;
|
|
u8 value; /* For KE_SW, ignored by KE_VSW */
|
|
} sw;
|
|
};
|
|
};
|
|
|
|
struct key_entry *sparse_keymap_entry_from_scancode(struct input_dev *dev,
|
|
unsigned int code);
|
|
struct key_entry *sparse_keymap_entry_from_keycode(struct input_dev *dev,
|
|
unsigned int code);
|
|
int sparse_keymap_setup(struct input_dev *dev,
|
|
const struct key_entry *keymap,
|
|
int (*setup)(struct input_dev *, struct key_entry *));
|
|
|
|
void sparse_keymap_report_entry(struct input_dev *dev, const struct key_entry *ke,
|
|
unsigned int value, bool autorelease);
|
|
|
|
bool sparse_keymap_report_event(struct input_dev *dev, unsigned int code,
|
|
unsigned int value, bool autorelease);
|
|
|
|
#endif /* _SPARSE_KEYMAP_H */
|