From: "Philippe Mathieu-Daudé" <philmd@oss.qualcomm.com>
To: qemu-devel@nongnu.org
Subject: [PULL 33/48] ui/cocoa: Use qemu_input_map_osx_to_linux
Date: Thu, 18 Jun 2026 14:28:10 +0200 [thread overview]
Message-ID: <20260618122825.90331-34-philmd@oss.qualcomm.com> (raw)
In-Reply-To: <20260618122825.90331-1-philmd@oss.qualcomm.com>
From: Akihiko Odaki <odaki@rsg.ci.i.u-tokyo.ac.jp>
ui/cocoa used to have a conversion table from macOS keycode to Linux
key code. It is an unnecessary redundancy as ui/input-keymap.c already
has such a table. Worse, I added an incorrect mapping of kVK_JIS_Eisu and
kVK_JIS_Kana with commit 708b72557ff5 ("ui/cocoa: Support unique keys of
JIS keyboards").
According to the following documentations, the definitions in
ui/keycodemapdb/keymaps.csv, which ui/input-keymap.c uses, are correct:
https://developer.apple.com/documentation/uikit/uikeyboardhidusage/uikeyboardhidusagekeyboardlang1?language=objc
https://developer.apple.com/documentation/uikit/uikeyboardhidusage/uikeyboardhidusagekeyboardlang2?language=objc
https://docs.microsoft.com/en-us/windows-hardware/design/component-guidelines/keyboard-japan-ime
Use qemu_input_map_osx_to_linux to eliminate the redundancy and
incorrect mappings.
Fixes: 708b72557ff5 ("ui/cocoa: Support unique keys of JIS keyboards")
Signed-off-by: Akihiko Odaki <odaki@rsg.ci.i.u-tokyo.ac.jp>
Reviewed-by: Philippe Mathieu-Daudé <philmd@mailo.com>
Message-ID: <20260604-osx-v3-1-453b4ee0e072@rsg.ci.i.u-tokyo.ac.jp>
Signed-off-by: Philippe Mathieu-Daudé <philmd@oss.qualcomm.com>
---
ui/cocoa.m | 131 ++---------------------------------------------------
1 file changed, 3 insertions(+), 128 deletions(-)
diff --git a/ui/cocoa.m b/ui/cocoa.m
index c5e639ab98d..e157ad01d85 100644
--- a/ui/cocoa.m
+++ b/ui/cocoa.m
@@ -141,138 +141,13 @@ static bool bool_with_bql(BoolCodeBlock block)
return val;
}
-// Mac to Linux conversion
-static const unsigned int mac_to_linux_map[] = {
- [kVK_ANSI_A] = KEY_A,
- [kVK_ANSI_B] = KEY_B,
- [kVK_ANSI_C] = KEY_C,
- [kVK_ANSI_D] = KEY_D,
- [kVK_ANSI_E] = KEY_E,
- [kVK_ANSI_F] = KEY_F,
- [kVK_ANSI_G] = KEY_G,
- [kVK_ANSI_H] = KEY_H,
- [kVK_ANSI_I] = KEY_I,
- [kVK_ANSI_J] = KEY_J,
- [kVK_ANSI_K] = KEY_K,
- [kVK_ANSI_L] = KEY_L,
- [kVK_ANSI_M] = KEY_M,
- [kVK_ANSI_N] = KEY_N,
- [kVK_ANSI_O] = KEY_O,
- [kVK_ANSI_P] = KEY_P,
- [kVK_ANSI_Q] = KEY_Q,
- [kVK_ANSI_R] = KEY_R,
- [kVK_ANSI_S] = KEY_S,
- [kVK_ANSI_T] = KEY_T,
- [kVK_ANSI_U] = KEY_U,
- [kVK_ANSI_V] = KEY_V,
- [kVK_ANSI_W] = KEY_W,
- [kVK_ANSI_X] = KEY_X,
- [kVK_ANSI_Y] = KEY_Y,
- [kVK_ANSI_Z] = KEY_Z,
-
- [kVK_ANSI_0] = KEY_0,
- [kVK_ANSI_1] = KEY_1,
- [kVK_ANSI_2] = KEY_2,
- [kVK_ANSI_3] = KEY_3,
- [kVK_ANSI_4] = KEY_4,
- [kVK_ANSI_5] = KEY_5,
- [kVK_ANSI_6] = KEY_6,
- [kVK_ANSI_7] = KEY_7,
- [kVK_ANSI_8] = KEY_8,
- [kVK_ANSI_9] = KEY_9,
-
- [kVK_ANSI_Grave] = KEY_GRAVE,
- [kVK_ANSI_Minus] = KEY_MINUS,
- [kVK_ANSI_Equal] = KEY_EQUAL,
- [kVK_Delete] = KEY_BACKSPACE,
- [kVK_CapsLock] = KEY_CAPSLOCK,
- [kVK_Tab] = KEY_TAB,
- [kVK_Return] = KEY_ENTER,
- [kVK_ANSI_LeftBracket] = KEY_LEFTBRACE,
- [kVK_ANSI_RightBracket] = KEY_RIGHTBRACE,
- [kVK_ANSI_Backslash] = KEY_BACKSLASH,
- [kVK_ANSI_Semicolon] = KEY_SEMICOLON,
- [kVK_ANSI_Quote] = KEY_APOSTROPHE,
- [kVK_ANSI_Comma] = KEY_COMMA,
- [kVK_ANSI_Period] = KEY_DOT,
- [kVK_ANSI_Slash] = KEY_SLASH,
- [kVK_Space] = KEY_SPACE,
-
- [kVK_ANSI_Keypad0] = KEY_KP0,
- [kVK_ANSI_Keypad1] = KEY_KP1,
- [kVK_ANSI_Keypad2] = KEY_KP2,
- [kVK_ANSI_Keypad3] = KEY_KP3,
- [kVK_ANSI_Keypad4] = KEY_KP4,
- [kVK_ANSI_Keypad5] = KEY_KP5,
- [kVK_ANSI_Keypad6] = KEY_KP6,
- [kVK_ANSI_Keypad7] = KEY_KP7,
- [kVK_ANSI_Keypad8] = KEY_KP8,
- [kVK_ANSI_Keypad9] = KEY_KP9,
- [kVK_ANSI_KeypadDecimal] = KEY_KPDOT,
- [kVK_ANSI_KeypadEnter] = KEY_KPENTER,
- [kVK_ANSI_KeypadPlus] = KEY_KPPLUS,
- [kVK_ANSI_KeypadMinus] = KEY_KPMINUS,
- [kVK_ANSI_KeypadMultiply] = KEY_KPASTERISK,
- [kVK_ANSI_KeypadDivide] = KEY_KPSLASH,
- [kVK_ANSI_KeypadEquals] = KEY_KPEQUAL,
- [kVK_ANSI_KeypadClear] = KEY_NUMLOCK,
-
- [kVK_UpArrow] = KEY_UP,
- [kVK_DownArrow] = KEY_DOWN,
- [kVK_LeftArrow] = KEY_LEFT,
- [kVK_RightArrow] = KEY_RIGHT,
-
- [kVK_Help] = KEY_INSERT,
- [kVK_Home] = KEY_HOME,
- [kVK_PageUp] = KEY_PAGEUP,
- [kVK_PageDown] = KEY_PAGEDOWN,
- [kVK_End] = KEY_END,
- [kVK_ForwardDelete] = KEY_DELETE,
-
- [kVK_Escape] = KEY_ESC,
-
- /* The Power key can't be used directly because the operating system uses
- * it. This key can be emulated by using it in place of another key such as
- * F1. Don't forget to disable the real key binding.
- */
- /* [kVK_F1] = KEY_POWER, */
-
- [kVK_F1] = KEY_F1,
- [kVK_F2] = KEY_F2,
- [kVK_F3] = KEY_F3,
- [kVK_F4] = KEY_F4,
- [kVK_F5] = KEY_F5,
- [kVK_F6] = KEY_F6,
- [kVK_F7] = KEY_F7,
- [kVK_F8] = KEY_F8,
- [kVK_F9] = KEY_F9,
- [kVK_F10] = KEY_F10,
- [kVK_F11] = KEY_F11,
- [kVK_F12] = KEY_F12,
- [kVK_F13] = KEY_SYSRQ,
- [kVK_F14] = KEY_SCROLLLOCK,
- [kVK_F15] = KEY_PAUSE,
-
- // JIS keyboards only
- [kVK_JIS_Yen] = KEY_YEN,
- [kVK_JIS_Underscore] = KEY_RO,
- [kVK_JIS_KeypadComma] = KEY_KPCOMMA,
- [kVK_JIS_Eisu] = KEY_MUHENKAN,
- [kVK_JIS_Kana] = KEY_HENKAN,
-
- /*
- * The eject and volume keys can't be used here because they are handled at
- * a lower level than what an Application can see.
- */
-};
-
-static unsigned int cocoa_keycode_to_linux(int keycode)
+static int cocoa_keycode_to_linux(int keycode)
{
- if (ARRAY_SIZE(mac_to_linux_map) <= keycode) {
+ if (qemu_input_map_osx_to_linux_len <= keycode) {
error_report("(cocoa) warning unknown keycode 0x%x", keycode);
return 0;
}
- return mac_to_linux_map[keycode];
+ return qemu_input_map_osx_to_linux[keycode];
}
/* Displays an alert dialog box with the specified message */
--
2.53.0
next prev parent reply other threads:[~2026-06-18 12:33 UTC|newest]
Thread overview: 50+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-06-18 12:27 [PULL 00/48] Accel patches for 2026-06-18 Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 01/48] system/cpu: Reset vCPU %exception_index before resuming it Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 02/48] system/memory: Constify various AddressSpace arguments (checks) Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 03/48] system/memory: Constify various AddressSpace arguments (flat-range) Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 04/48] system/memory: Constify various AddressSpace arguments (notify) Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 05/48] system/memory: Constify various AddressSpace arguments (cache) Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 06/48] system/memory: Constify various AddressSpace arguments (access) Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 07/48] system/memory: Constify various MemoryRegionCache arguments Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 08/48] system: Document cpu_physical_memory_*() declarations Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 09/48] accel/kvm: Replace legacy cpu_physical_memory_write() call Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 10/48] gdbstub/system: Replace legacy cpu_physical_memory_read/write() calls Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 11/48] target/s390x: Factor common s390_ipl_read/write() helpers Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 12/48] target/s390x: Replace legacy cpu_physical_memory_read/write() calls Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 13/48] system: Move cpu_physical_memory_*() declarations to 'system/physmem.h' Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 14/48] hw/xen/interface: Remove pre-C99 checks Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 15/48] qom/object: Remove pre-C11 check Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 16/48] tcg: Include missing 'qemu/bitops.h' header in tcg-gvec-desc.h Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 17/48] target/i386: Report TPR accesses to HVF Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 18/48] target/arm: Only set CPU_INTERRUPT_EXITTB for TCG Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 19/48] target/arm: Remove vcpu_dirty=true assigments in hvf_handle_exception() Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 20/48] target/arm: Better describe PMU depends on TCG or HVF Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 21/48] target/arm/ptw: Restrict PMSAv8 code to TCG Philippe Mathieu-Daudé
2026-06-18 12:27 ` [PULL 22/48] target/arm: Restrict TCG specific headers Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 23/48] target/ppc: Restrict TCGTBCPUState to TCG Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 24/48] target/loongarch: Remove unused 'accel/accel-cpu-target.h' header Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 25/48] target/sparc: Include missing 'accel/tcg/cpu-ops.h' header in cpu.c Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 26/48] accel/hvf: fix double hv_vcpu_destroy() causing teardown error on ARM Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 27/48] accel/hvf: Reduce hvf_kernel_irqchip_override scope Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 28/48] accel/tcg: remove duplicate include Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 29/48] accel/tcg: Restrict IOMMU declarations Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 30/48] meson: build macOS signed binary as part of the default target Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 31/48] configure: honor --extra-ldflags when forced to use objc_LINKER Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 32/48] util/cutils: drop qemu_strnlen() in favor of strnlen() Philippe Mathieu-Daudé
2026-06-18 12:28 ` Philippe Mathieu-Daudé [this message]
2026-06-18 12:28 ` [PULL 34/48] exec/cpu-common.h: Include missing 'qemu/thread.h' header Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 35/48] exec/cpu-common.h: Avoid including unused 'exec/vaddr.h' header Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 36/48] exec/cpu-common.h: Avoid including unused 'tcg/debug-assert.h' header Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 37/48] exec/cpu-common.h: Avoid including unused exec/page-protection.h header Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 38/48] system/memory: Remove unnecessary CONFIG_USER_ONLY guards Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 39/48] system/memory: Rename cpu_exec_init_all() -> machine_memory_init() Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 40/48] hw/s390x/ipl: Remove TCG dependency in handle_diag_308() Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 41/48] accel/tcg: Remove cpu_loop_exit() stub Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 42/48] accel/tcg: Move cpu_exec() out of 'exec/cpu-common.h' Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 43/48] accel/tcg: Move cpu_exec_step_atomic() " Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 44/48] accel/tcg: Move cpu_unwind_state_data() " Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 45/48] accel/tcg: Move cpu_restore_state() " Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 46/48] accel/tcg: Have cpu_loop_exit_requested() take const @cpu argument Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 47/48] accel/tcg: Move cpu_loop_exit_*() out of 'exec/cpu-common.h' Philippe Mathieu-Daudé
2026-06-18 12:28 ` [PULL 48/48] accel/tcg: Restrict headers being TCG specific Philippe Mathieu-Daudé
2026-06-18 17:54 ` [PULL 00/48] Accel patches for 2026-06-18 Stefan Hajnoczi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260618122825.90331-34-philmd@oss.qualcomm.com \
--to=philmd@oss.qualcomm.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.