Replace the number_to_qcode, qcode_to_number and linux_to_qcode tables with automatically generated tables. Missing entries in linux_to_qcode now fixed: KEY_LINEFEED -> Q_KEY_CODE_LF KEY_KPEQUAL -> Q_KEY_CODE_KP_EQUALS KEY_COMPOSE -> Q_KEY_CODE_COMPOSE KEY_AGAIN -> Q_KEY_CODE_AGAIN KEY_PROPS -> Q_KEY_CODE_PROPS KEY_UNDO -> Q_KEY_CODE_UNDO KEY_FRONT -> Q_KEY_CODE_FRONT KEY_COPY -> Q_KEY_CODE_COPY KEY_OPEN -> Q_KEY_CODE_OPEN KEY_PASTE -> Q_KEY_CODE_PASTE KEY_CUT -> Q_KEY_CODE_CUT KEY_HELP -> Q_KEY_CODE_HELP KEY_MEDIA -> Q_KEY_CODE_MEDIASELECT In addition, some fixes: - KEY_PLAYPAUSE now maps to Q_KEY_CODE_AUDIOPLAY, instead of KEY_PLAYCD. KEY_PLAYPAUSE is defined across almost all scancodes sets, while KEY_PLAYCD only appears in AT set1, so the former is a more useful mapping. Missing entries in qcode_to_number now fixed: Q_KEY_CODE_AGAIN -> 0x85 Q_KEY_CODE_PROPS -> 0x86 Q_KEY_CODE_UNDO -> 0x87 Q_KEY_CODE_FRONT -> 0x8c Q_KEY_CODE_COPY -> 0xf8 Q_KEY_CODE_OPEN -> 0x64 Q_KEY_CODE_PASTE -> 0x65 Q_KEY_CODE_CUT -> 0xbc Q_KEY_CODE_LF -> 0x5b Q_KEY_CODE_HELP -> 0xf5 Q_KEY_CODE_COMPOSE -> 0xdd Q_KEY_CODE_KP_EQUALS -> 0x59 Q_KEY_CODE_MEDIASELECT -> 0xed In addition, some fixes: - Q_KEY_CODE_MENU was incorrectly mapped to the compose scancode (0xdd) and is now mapped to 0x9e - Q_KEY_CODE_FIND was mapped to 0xe065 (Search) instead of to 0xe041 (Find) - Q_KEY_CODE_HIRAGANA was mapped to 0x70 (Katakanahiragana) instead of of 0x77 (Hirigana) - Q_KEY_CODE_PRINT was mapped to 0xb7 which is not a defined scan code in AT set 1, it is now mapped to 0x54 (sysrq) Signed-off-by: Daniel P. Berrange <berrange@redhat.com> Message-id: 20170929101201.21039-5-berrange@redhat.com Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include "qemu/osdep.h"
 | 
						|
#include "sysemu/sysemu.h"
 | 
						|
#include "ui/keymaps.h"
 | 
						|
#include "ui/input.h"
 | 
						|
 | 
						|
#include "standard-headers/linux/input.h"
 | 
						|
 | 
						|
#include "ui/input-keymap-linux-to-qcode.c"
 | 
						|
#include "ui/input-keymap-qcode-to-qnum.c"
 | 
						|
#include "ui/input-keymap-qnum-to-qcode.c"
 | 
						|
 | 
						|
int qemu_input_linux_to_qcode(unsigned int lnx)
 | 
						|
{
 | 
						|
    if (lnx >= qemu_input_map_linux_to_qcode_len) {
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
    return qemu_input_map_linux_to_qcode[lnx];
 | 
						|
}
 | 
						|
 | 
						|
int qemu_input_key_value_to_number(const KeyValue *value)
 | 
						|
{
 | 
						|
    if (value->type == KEY_VALUE_KIND_QCODE) {
 | 
						|
        if (value->u.qcode.data >= qemu_input_map_qcode_to_qnum_len) {
 | 
						|
            return 0;
 | 
						|
        }
 | 
						|
        return qemu_input_map_qcode_to_qnum[value->u.qcode.data];
 | 
						|
    } else {
 | 
						|
        assert(value->type == KEY_VALUE_KIND_NUMBER);
 | 
						|
        return value->u.number.data;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
int qemu_input_key_number_to_qcode(unsigned int nr)
 | 
						|
{
 | 
						|
    if (nr >= qemu_input_map_qnum_to_qcode_len) {
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
    return qemu_input_map_qnum_to_qcode[nr];
 | 
						|
}
 | 
						|
 | 
						|
int qemu_input_key_value_to_qcode(const KeyValue *value)
 | 
						|
{
 | 
						|
    if (value->type == KEY_VALUE_KIND_QCODE) {
 | 
						|
        return value->u.qcode.data;
 | 
						|
    } else {
 | 
						|
        assert(value->type == KEY_VALUE_KIND_NUMBER);
 | 
						|
        return qemu_input_key_number_to_qcode(value->u.number.data);
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
int qemu_input_key_value_to_scancode(const KeyValue *value, bool down,
 | 
						|
                                     int *codes)
 | 
						|
{
 | 
						|
    int keycode = qemu_input_key_value_to_number(value);
 | 
						|
    int count = 0;
 | 
						|
 | 
						|
    if (value->type == KEY_VALUE_KIND_QCODE &&
 | 
						|
        value->u.qcode.data == Q_KEY_CODE_PAUSE) {
 | 
						|
        /* specific case */
 | 
						|
        int v = down ? 0 : 0x80;
 | 
						|
        codes[count++] = 0xe1;
 | 
						|
        codes[count++] = 0x1d | v;
 | 
						|
        codes[count++] = 0x45 | v;
 | 
						|
        return count;
 | 
						|
    }
 | 
						|
    if (keycode & SCANCODE_GREY) {
 | 
						|
        codes[count++] = SCANCODE_EMUL0;
 | 
						|
        keycode &= ~SCANCODE_GREY;
 | 
						|
    }
 | 
						|
    if (!down) {
 | 
						|
        keycode |= SCANCODE_UP;
 | 
						|
    }
 | 
						|
    codes[count++] = keycode;
 | 
						|
 | 
						|
    return count;
 | 
						|
}
 |