From patchwork Fri Feb 18 01:51:45 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: William Mahon X-Patchwork-Id: 543945 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 68663C433F5 for ; Fri, 18 Feb 2022 01:51:56 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231344AbiBRBwK (ORCPT ); Thu, 17 Feb 2022 20:52:10 -0500 Received: from gmail-smtp-in.l.google.com ([23.128.96.19]:57322 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231371AbiBRBwJ (ORCPT ); Thu, 17 Feb 2022 20:52:09 -0500 Received: from mail-pj1-x102b.google.com (mail-pj1-x102b.google.com [IPv6:2607:f8b0:4864:20::102b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1FA483A728 for ; Thu, 17 Feb 2022 17:51:53 -0800 (PST) Received: by mail-pj1-x102b.google.com with SMTP id h14-20020a17090a130e00b001b88991a305so11036189pja.3 for ; Thu, 17 Feb 2022 17:51:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=X16XPp9/gYEXnP8aB8/5NjFWebpL9jucU/uxnbVHGDg=; b=To3yKrVDYmnsHF7QSf9+Js9ZmJsCfl25GO5Px9cfLDWxuHZ+nACzurfpxj9AftFu+t zxFKeXc4flLsacRHixoebzVwaYhuTK/19I28t+zNdjSsXTApi0CiCGNqSb9xOYY2KcXU f5iXeWEQJpgdqqwO08hI7Rt9ctjn90CCs1Czk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=X16XPp9/gYEXnP8aB8/5NjFWebpL9jucU/uxnbVHGDg=; b=nyt4ps25+wyIenAVIDs0zU4ll8Uo08y54FI+A5kKDU9nLqXPAtrCJ+hGAWx3TYzM4n sKbHka4+2M/Uf9S1TK/LUEFCcEtpwlrJy+Hb3mpDEn8XTBA6twr0jskH6pA6dSry++MG JAP3uivr/s4NDqcIjMsG4XwZQEMJvlsKjq0UUyzxu3qH9plGdTfWItYnSsHL9AdyqaE1 rsLfSQ75ElUtlBT4fe8uJhAPH2zgWuz2L6hUAv+jAn8xHune+pWNQYAu8/gGPZ1+pyIF DKzmOwSc2DMQ+vuQiUjig1o+Fb55DcDu8jttPUCEKh8InmgWBIPC+HR9GRqf9RU5nqQD KUOw== X-Gm-Message-State: AOAM533qIWHqM77HDjfDnd4cpBwcvF4yxEiUPAyXWCgd1/CV7zdV6QnK 11YbBNrQOS3ruXcx6pr9wWdBvw== X-Google-Smtp-Source: ABdhPJyKySdytsGZuvvOE5n50thjnrwuCkw5BLF0AFMznLsqjvp5c4Q1A8oW1XjilnQFWtwdh4IEiQ== X-Received: by 2002:a17:90a:d3c1:b0:1b9:d7a7:f022 with SMTP id d1-20020a17090ad3c100b001b9d7a7f022mr10412375pjw.25.1645149112682; Thu, 17 Feb 2022 17:51:52 -0800 (PST) Received: from wmahon.c.googlers.com.com (218.180.124.34.bc.googleusercontent.com. [34.124.180.218]) by smtp.gmail.com with ESMTPSA id s11sm884072pfk.8.2022.02.17.17.51.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 17 Feb 2022 17:51:52 -0800 (PST) From: William Mahon X-Google-Original-From: William Mahon To: LKML Cc: William Mahon , Benjamin Tissoires , Dmitry Torokhov , Jiri Kosina , linux-input@vger.kernel.org Subject: [PATCH v2] HID: Add mapping for KEY_DICTATE Date: Fri, 18 Feb 2022 01:51:45 +0000 Message-Id: <20220218015136.1.I5dbf50eb1a7a6734ee727bda4a8573358c6d3ec0@changeid> X-Mailer: git-send-email 2.35.1.473.g83b2b277ed-goog MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org Numerous keyboards are adding dictate keys which allows for text messages to be dicated by a microphone. This patch adds a new key definition KEY_DICTATE and maps 0x0c/0x0d8 usage code to this new keycode. Additionally hid-debug is adjusted to recognize this new usage code as well. Signed-off-by: William Mahon --- drivers/hid/hid-debug.c | 1 + drivers/hid/hid-input.c | 1 + include/uapi/linux/input-event-codes.h | 2 ++ 3 files changed, 4 insertions(+) diff --git a/drivers/hid/hid-debug.c b/drivers/hid/hid-debug.c index 26c31d759914..8aa68416b1d7 100644 --- a/drivers/hid/hid-debug.c +++ b/drivers/hid/hid-debug.c @@ -969,6 +969,7 @@ static const char *keys[KEY_MAX + 1] = { [KEY_ASSISTANT] = "Assistant", [KEY_KBD_LAYOUT_NEXT] = "KbdLayoutNext", [KEY_EMOJI_PICKER] = "EmojiPicker", + [KEY_DICTATE] = "Dictate", [KEY_BRIGHTNESS_MIN] = "BrightnessMin", [KEY_BRIGHTNESS_MAX] = "BrightnessMax", [KEY_BRIGHTNESS_AUTO] = "BrightnessAuto", diff --git a/drivers/hid/hid-input.c b/drivers/hid/hid-input.c index 112901d2d8d2..ce2b75a67cb8 100644 --- a/drivers/hid/hid-input.c +++ b/drivers/hid/hid-input.c @@ -992,6 +992,7 @@ static void hidinput_configure_usage(struct hid_input *hidinput, struct hid_fiel case 0x0cd: map_key_clear(KEY_PLAYPAUSE); break; case 0x0cf: map_key_clear(KEY_VOICECOMMAND); break; + case 0x0d8: map_key_clear(KEY_DICTATE); break; case 0x0d9: map_key_clear(KEY_EMOJI_PICKER); break; case 0x0e0: map_abs_clear(ABS_VOLUME); break; diff --git a/include/uapi/linux/input-event-codes.h b/include/uapi/linux/input-event-codes.h index 225ec87d4f22..9aa994cbcd60 100644 --- a/include/uapi/linux/input-event-codes.h +++ b/include/uapi/linux/input-event-codes.h @@ -660,6 +660,8 @@ /* Select an area of screen to be copied */ #define KEY_SELECTIVE_SCREENSHOT 0x27a +#define KEY_DICTATE 0x27b + /* * Some keyboards have keys which do not have a defined meaning, these keys * are intended to be programmed / bound to macros by the user. For most