From patchwork Wed Feb 23 22:09:05 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Pablo Ceballos X-Patchwork-Id: 545421 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 DFEB5C433F5 for ; Wed, 23 Feb 2022 22:09:40 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238670AbiBWWKG (ORCPT ); Wed, 23 Feb 2022 17:10:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50128 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230527AbiBWWKF (ORCPT ); Wed, 23 Feb 2022 17:10:05 -0500 Received: from mail-yw1-x114a.google.com (mail-yw1-x114a.google.com [IPv6:2607:f8b0:4864:20::114a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 557584DF62 for ; Wed, 23 Feb 2022 14:09:37 -0800 (PST) Received: by mail-yw1-x114a.google.com with SMTP id 00721157ae682-2d07ae11467so4247337b3.12 for ; Wed, 23 Feb 2022 14:09:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:message-id:mime-version:subject:from:to:cc; bh=vPsoxmLFCGTxgUe4OFTHCzlbKt11DcygrOzYKeDdnVk=; b=PRUFFxCsKwskCyK8djrzZdRUxg2aUez0XnIQ3PU0O84m0VqQodnglL5EIQUJ5fdHas 2U14yNj4V0SlRsNnyJapzMrrwLsP0A8132T+cFl02paeTiNmgFe7FleEi9rArnLc7M3/ 41t0UMnOGDP/GoPs2KoGImPtidj57XNbKhEm0G7MKcbn7SGqubp3tHRooFtj5vT3kf3n KUYgLgJpHe5OtYKX1If+T3kI7ElF3P9/LUX55tlS+sK1Dq7QZzBFK82g3/G72WaeBdYn h3UOw7joRCI5ei3Kj8yPjBwtcfdSGaQlgFHh9VLiFdLVViF53h+LNbxgTBOJHvdzepgX o2aw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=vPsoxmLFCGTxgUe4OFTHCzlbKt11DcygrOzYKeDdnVk=; b=VwatvK0oXfQw0MzltqhX1ZswVSJ0PI8hSHeDujegZIOJQ+iiS91JBRtD24FpVZgjZx IhgfEcbuyf69WEFa9D3jCUxneUU4+JkgdVuncTO6t2AqJ66DOAzJWY5WG0kHWIHCOPiR zqR5eg2OWgWvKyCew3pIYYqDnncPhmeWuKHTTIMojJ2m9y6SvG78VHoAPfOfLf7LNSXg A+xqZq4pH7wCGFGLoV29KckD8pA2qgvej2XOi4wi7tvksLPHiFp12ADKRksuj0uQLFAB H5xa+H07QY2Xyy5e+08rI0vwuKZVoziQU/8W7IExAuUEjRawh4f6CVRE5+t3eQ5gN7vq X3jg== X-Gm-Message-State: AOAM533wtoXO4HRO9584Boif2GQxlhzlFVOp4NEfdwoFuFBlrotFvMH1 uDtbidoEw/1PiLA/sDQ3PmYAPto8fGhVbIg= X-Google-Smtp-Source: ABdhPJxp71N+rU6Cf2gjQnR8QMeLSwiTiIHv/NNhBYAeIKV2aAc7k+nWHK9+YVI+6TP3Y5YuJftaj+sM4dI+nVA= X-Received: from pceballos.nyc.corp.google.com ([2620:0:1003:510:ccf7:25ec:10ba:2169]) (user=pceballos job=sendgmr) by 2002:a81:9a41:0:b0:2ca:287c:6c65 with SMTP id r62-20020a819a41000000b002ca287c6c65mr1609681ywg.266.1645654176518; Wed, 23 Feb 2022 14:09:36 -0800 (PST) Date: Wed, 23 Feb 2022 17:09:05 -0500 Message-Id: <20220223170301.1.I7a855580ce9f43fc2f598bdccf088c978d4af822@changeid> Mime-Version: 1.0 X-Mailer: git-send-email 2.35.1.574.g5d30c73bfb-goog Subject: [PATCH] HID: Add driver for Google Hangouts Meet Speakermic From: Pablo Ceballos To: Jiri Kosina , Benjamin Tissoires , linux-kernel@vger.kernel.org, linux-input@vger.kernel.org Cc: Pablo Ceballos Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org This driver handles the telephony phone mute HID usage by ignoring it. This avoids the default handling by the hid-input driver which is to map this to a KEY_MICMUTE event. The issue is that this device implements the phone mute HID usage as a toggle switch, where 1 indicates muted, and 0 indicates unmuted. However, for an EV_KEY event 1 indicates the key has been pressed and 0 indicates it has been released. Signed-off-by: Pablo Ceballos --- drivers/hid/Kconfig | 6 +++++ drivers/hid/Makefile | 1 + drivers/hid/hid-google-atrus.c | 44 ++++++++++++++++++++++++++++++++++ drivers/hid/hid-ids.h | 1 + 4 files changed, 52 insertions(+) create mode 100644 drivers/hid/hid-google-atrus.c diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index f5544157576c9..d89c57d89a699 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig @@ -403,6 +403,12 @@ config HOLTEK_FF Say Y here if you have a Holtek On Line Grip based game controller and want to have force feedback support for it. +config HID_GOOGLE_ATRUS + tristate "Google Hangouts Meet Speakermic" + depends on USB_HID + ---help--- + Say Y here if you have a Google Hangouts Meet Speakermic + config HID_GOOGLE_HAMMER tristate "Google Hammer Keyboard" depends on USB_HID && LEDS_CLASS && CROS_EC diff --git a/drivers/hid/Makefile b/drivers/hid/Makefile index 6d3e630e81af5..2ee446b5b953b 100644 --- a/drivers/hid/Makefile +++ b/drivers/hid/Makefile @@ -50,6 +50,7 @@ obj-$(CONFIG_HID_FT260) += hid-ft260.o obj-$(CONFIG_HID_GEMBIRD) += hid-gembird.o obj-$(CONFIG_HID_GFRM) += hid-gfrm.o obj-$(CONFIG_HID_GLORIOUS) += hid-glorious.o +obj-$(CONFIG_HID_GOOGLE_ATRUS) += hid-google-atrus.o obj-$(CONFIG_HID_GOOGLE_HAMMER) += hid-google-hammer.o obj-$(CONFIG_HID_VIVALDI) += hid-vivaldi.o obj-$(CONFIG_HID_GT683R) += hid-gt683r.o diff --git a/drivers/hid/hid-google-atrus.c b/drivers/hid/hid-google-atrus.c new file mode 100644 index 0000000000000..938947417f119 --- /dev/null +++ b/drivers/hid/hid-google-atrus.c @@ -0,0 +1,44 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * HID driver for Google Hangouts Meet Speakermic + * + * Copyright 2022 Google LLC. + */ + +#include +#include + +#include "hid-ids.h" + +static int atrus_event(struct hid_device *hid, struct hid_field *field, + struct hid_usage *usage, __s32 value) +{ + // Return 1 to indicate no further processing should be done for this + // usage. + return 1; +} + +static const struct hid_device_id atrus_devices[] = { + { HID_DEVICE(BUS_USB, HID_GROUP_GENERIC, + USB_VENDOR_ID_GOOGLE, USB_DEVICE_ID_GOOGLE_ATRUS) }, + { } +}; +MODULE_DEVICE_TABLE(hid, atrus_devices); + +static const struct hid_usage_id atrus_usages[] = { + // Handle only the Telephony Phone Mute usage. + { HID_UP_TELEPHONY | 0x2f, EV_KEY, HID_ANY_ID }, + { HID_TERMINATOR, HID_TERMINATOR, HID_TERMINATOR } +}; + +static struct hid_driver atrus_driver = { + .name = "atrus", + .id_table = atrus_devices, + .usage_table = atrus_usages, + .event = atrus_event, +}; +module_hid_driver(atrus_driver); + +MODULE_AUTHOR("Pablo Ceballos "); +MODULE_DESCRIPTION("Google Hangouts Meet Speakermic USB HID Driver"); +MODULE_LICENSE("GPL"); diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index 85975031389b3..9f6fc5cfbeb96 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h @@ -506,6 +506,7 @@ #define USB_DEVICE_ID_GOOGLE_MOONBALL 0x5044 #define USB_DEVICE_ID_GOOGLE_DON 0x5050 #define USB_DEVICE_ID_GOOGLE_EEL 0x5057 +#define USB_DEVICE_ID_GOOGLE_ATRUS 0x8001 #define USB_VENDOR_ID_GOTOP 0x08f2 #define USB_DEVICE_ID_SUPER_Q2 0x007f