blob: 95b1e0cbfa6386b6bfffd9c133281ee4e643b57a [file] [log] [blame]
Peter Maydelle16f4c82016-01-29 17:49:51 +00001#include "qemu/osdep.h"
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +01002#include "sysemu/sysemu.h"
3#include "ui/keymaps.h"
4#include "ui/input.h"
5
Gerd Hoffmann606eb0c2017-07-26 17:29:15 +02006#include "standard-headers/linux/input.h"
7
Daniel P. Berrange2ec78702018-01-17 16:47:15 +00008#include "ui/input-keymap-atset1-to-qcode.c"
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +01009#include "ui/input-keymap-linux-to-qcode.c"
10#include "ui/input-keymap-qcode-to-qnum.c"
11#include "ui/input-keymap-qnum-to-qcode.c"
Owen Smithde80d782017-11-03 11:56:28 +000012#include "ui/input-keymap-qcode-to-linux.c"
Daniel P. Berrangeed7b2622018-01-17 16:47:14 +000013#include "ui/input-keymap-usb-to-qcode.c"
Daniel P. Berrange2ec78702018-01-17 16:47:15 +000014#include "ui/input-keymap-win32-to-qcode.c"
15#include "ui/input-keymap-x11-to-qcode.c"
16#include "ui/input-keymap-xorgevdev-to-qcode.c"
17#include "ui/input-keymap-xorgkbd-to-qcode.c"
18#include "ui/input-keymap-xorgxquartz-to-qcode.c"
19#include "ui/input-keymap-xorgxwin-to-qcode.c"
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010020
Gerd Hoffmann606eb0c2017-07-26 17:29:15 +020021int qemu_input_linux_to_qcode(unsigned int lnx)
22{
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +010023 if (lnx >= qemu_input_map_linux_to_qcode_len) {
24 return 0;
25 }
26 return qemu_input_map_linux_to_qcode[lnx];
Gerd Hoffmann606eb0c2017-07-26 17:29:15 +020027}
28
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010029int qemu_input_key_value_to_number(const KeyValue *value)
30{
Eric Blake568c73a2015-10-26 16:34:58 -060031 if (value->type == KEY_VALUE_KIND_QCODE) {
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +010032 if (value->u.qcode.data >= qemu_input_map_qcode_to_qnum_len) {
33 return 0;
34 }
35 return qemu_input_map_qcode_to_qnum[value->u.qcode.data];
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010036 } else {
Eric Blake568c73a2015-10-26 16:34:58 -060037 assert(value->type == KEY_VALUE_KIND_NUMBER);
Eric Blake32bafa82016-03-17 16:48:37 -060038 return value->u.number.data;
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010039 }
40}
41
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +010042int qemu_input_key_number_to_qcode(unsigned int nr)
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010043{
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +010044 if (nr >= qemu_input_map_qnum_to_qcode_len) {
45 return 0;
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010046 }
Daniel P. Berrangebcd5ac92017-09-29 11:11:59 +010047 return qemu_input_map_qnum_to_qcode[nr];
Gerd Hoffmann11c7fa72014-05-21 13:28:32 +020048}
49
50int qemu_input_key_value_to_qcode(const KeyValue *value)
51{
Eric Blake568c73a2015-10-26 16:34:58 -060052 if (value->type == KEY_VALUE_KIND_QCODE) {
Eric Blake32bafa82016-03-17 16:48:37 -060053 return value->u.qcode.data;
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010054 } else {
Eric Blake568c73a2015-10-26 16:34:58 -060055 assert(value->type == KEY_VALUE_KIND_NUMBER);
Eric Blake32bafa82016-03-17 16:48:37 -060056 return qemu_input_key_number_to_qcode(value->u.number.data);
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010057 }
58}
59
60int qemu_input_key_value_to_scancode(const KeyValue *value, bool down,
61 int *codes)
62{
63 int keycode = qemu_input_key_value_to_number(value);
64 int count = 0;
65
Eric Blake568c73a2015-10-26 16:34:58 -060066 if (value->type == KEY_VALUE_KIND_QCODE &&
Eric Blake32bafa82016-03-17 16:48:37 -060067 value->u.qcode.data == Q_KEY_CODE_PAUSE) {
Gerd Hoffmann02aa76c2014-03-11 12:15:39 +010068 /* specific case */
69 int v = down ? 0 : 0x80;
70 codes[count++] = 0xe1;
71 codes[count++] = 0x1d | v;
72 codes[count++] = 0x45 | v;
73 return count;
74 }
75 if (keycode & SCANCODE_GREY) {
76 codes[count++] = SCANCODE_EMUL0;
77 keycode &= ~SCANCODE_GREY;
78 }
79 if (!down) {
80 keycode |= SCANCODE_UP;
81 }
82 codes[count++] = keycode;
83
84 return count;
85}