HIDManagement.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * Copyright (c) 2021, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/Singleton.h>
  7. #include <Kernel/ACPI/Parser.h>
  8. #include <Kernel/CommandLine.h>
  9. #include <Kernel/Devices/HID/HIDManagement.h>
  10. #include <Kernel/Devices/HID/I8042Controller.h>
  11. #include <Kernel/Sections.h>
  12. namespace Kernel {
  13. Atomic<bool> g_caps_lock_remapped_to_ctrl;
  14. static Singleton<HIDManagement> s_the;
  15. // clang-format off
  16. static constexpr Keyboard::CharacterMapData DEFAULT_CHARACTER_MAP =
  17. {
  18. .map = {
  19. 0, '\033', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0x08,
  20. '\t', 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', '\n',
  21. 0, 'a', 's', 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '`', 0,
  22. '\\', 'z', 'x', 'c', 'v', 'b', 'n', 'm', ',', '.', '/', 0, '*', 0,
  23. ' ', 0, 0,
  24. //60 70 80
  25. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '7', '8', '9', '-', '4', '5', '6', '+', '1', '2', '3', '0', '.', 0, 0, '\\', 0, 0, 0,
  26. },
  27. .shift_map = {
  28. 0, '\033', '!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '_', '+', 0x08,
  29. '\t', 'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', '{', '}', '\n',
  30. 0, 'A', 'S', 'D', 'F', 'G', 'H', 'J', 'K', 'L', ':', '"', '~', 0,
  31. '|', 'Z', 'X', 'C', 'V', 'B', 'N', 'M', '<', '>', '?', 0, '*', 0,
  32. ' ', 0, 0,
  33. //60 70 80
  34. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '7', '8', '9', '-', '4', '5', '6', '+', '1', '2', '3', '0', '.', 0, 0, '|', 0, 0, 0,
  35. },
  36. .alt_map = {
  37. 0, '\033', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0x08,
  38. '\t', 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', '\n',
  39. 0, 'a', 's', 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '`', 0,
  40. '\\', 'z', 'x', 'c', 'v', 'b', 'n', 'm', ',', '.', '/', 0, '*', 0,
  41. ' ', 0, 0,
  42. //60 70 80
  43. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '7', '8', '9', '-', '4', '5', '6', '+', '1', '2', '3', '0', '.', 0, 0, '\\', 0, 0, 0,
  44. },
  45. .altgr_map = {
  46. 0, '\033', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0x08,
  47. '\t', 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', '\n',
  48. 0, 'a', 's', 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '`', 0,
  49. '\\', 'z', 'x', 'c', 'v', 'b', 'n', 'm', ',', '.', '/', 0, '*', 0,
  50. ' ', 0, 0,
  51. //60 70 80
  52. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '7', '8', '9', '-', '4', '5', '6', '+', '1', '2', '3', '0', '.', 0, 0, '\\', 0, 0, 0,
  53. },
  54. .shift_altgr_map = {
  55. 0, '\033', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0x08,
  56. '\t', 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', '\n',
  57. 0, 'a', 's', 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '`', 0,
  58. '\\', 'z', 'x', 'c', 'v', 'b', 'n', 'm', ',', '.', '/', 0, '*', 0,
  59. ' ', 0, 0,
  60. //60 70 80
  61. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '7', '8', '9', '-', '4', '5', '6', '+', '1', '2', '3', '0', '.', 0, 0, '\\', 0, 0, 0,
  62. },
  63. };
  64. // clang-format on
  65. size_t HIDManagement::generate_minor_device_number_for_mouse()
  66. {
  67. // FIXME: Lock this to prevent race conditions with hot-plugging devices!
  68. return m_mouse_minor_number++;
  69. }
  70. size_t HIDManagement::generate_minor_device_number_for_keyboard()
  71. {
  72. // FIXME: Lock this to prevent race conditions with hot-plugging devices!
  73. return m_keyboard_minor_number++;
  74. }
  75. UNMAP_AFTER_INIT HIDManagement::HIDManagement()
  76. : m_character_map("en-us", DEFAULT_CHARACTER_MAP)
  77. {
  78. }
  79. void HIDManagement::set_maps(const Keyboard::CharacterMapData& character_map_data, const String& character_map_name)
  80. {
  81. m_character_map.set_character_map_data(character_map_data);
  82. m_character_map.set_character_map_name(character_map_name);
  83. dbgln("New Character map '{}' passed in by client.", character_map_name);
  84. }
  85. UNMAP_AFTER_INIT void HIDManagement::enumerate()
  86. {
  87. // FIXME: When we have USB HID support, we should ensure that we disable
  88. // emulation of the PS/2 controller if it was set by the BIOS.
  89. // If ACPI indicates we have an i8042 controller and the USB controller was
  90. // set to emulate PS/2, we should not initialize the PS/2 controller.
  91. if (kernel_command_line().disable_ps2_controller())
  92. return;
  93. if (ACPI::Parser::the() && !ACPI::Parser::the()->have_8042())
  94. return;
  95. m_i8042_controller = I8042Controller::initialize();
  96. m_i8042_controller->detect_devices();
  97. if (m_i8042_controller->mouse())
  98. m_hid_devices.append(m_i8042_controller->mouse().release_nonnull());
  99. if (m_i8042_controller->keyboard())
  100. m_hid_devices.append(m_i8042_controller->keyboard().release_nonnull());
  101. }
  102. UNMAP_AFTER_INIT void HIDManagement::initialize()
  103. {
  104. VERIFY(!s_the.is_initialized());
  105. s_the.ensure_instance();
  106. s_the->enumerate();
  107. }
  108. HIDManagement& HIDManagement::the()
  109. {
  110. return *s_the;
  111. }
  112. }