From patchwork Sun Oct 23 16:30:28 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Job Noorman X-Patchwork-Id: 557 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a5d:6687:0:0:0:0:0 with SMTP id l7csp61735wru; Sun, 23 Oct 2022 09:42:09 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4Fc1glQgJNkeJkgQ+hgCqXzpoa+JVh5PmbwXGdKFpMq3i/Of0F3AmkFMQJVUIUjR6WjZXl X-Received: by 2002:a17:90a:e7c4:b0:20d:451f:a988 with SMTP id kb4-20020a17090ae7c400b0020d451fa988mr33134468pjb.57.1666543329457; Sun, 23 Oct 2022 09:42:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666543329; cv=none; d=google.com; s=arc-20160816; b=xzZkIWd2JIGdf7yf79wVOKxCFyHOnCT6GNuFaWVzGJ6szvIhKW+1QzBLh3J8OiMPGC ckLoHMRbfR3vT/pXs+/DdE29xV0KcskDt8F4f1EoBh/1p9hfk2FiWFqjLxTWl5kJOL6p XujCventRgyatG50mhsUFMxl5DhUmrd5ag7epD3HmpATWSm2YVfjb25RszABjkiL41Fo hUOBxqx8WRbmC8irqLrb1xWAeYw3ScMTUhPAMYkqePhZdPaHcVUmZlDNre0UfK7qFx0A s0EDJR1tWEh4TdfxOJZgBDttfjbCF9km71pUwTC/0Uo/BmbJqor8k58zDYH7WdtH0qeA xc8w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=L+Uu5fNN1Fu4LDg47Qgq7aw/zK13Z4KSJrDen1AI+eY=; b=Wm8wvHrG4fRmh2XcZMg1lMlzY58d87IxZNnjZgzW9b8ENxvSR1AUGTm2D2Q7wDiu0u edxaGhrdchD23XQne9peXI8RIkEMKldfoIShSG0dX9q3EI+GRhs4cZ7dWu8F/1hxrcTb PeYDfHpW/0f8X9U/sda4fMRKTuKW9b5v0SZjhWhwIsNBmClr4SvPg3p03VsibP+CjR8Q 4Yjsl7qyEw2g0hMiGOQx6K2UNOv+8X6FxUa7eESIipIeQWKLWORy5C+RcJJsCx6f2t7n YYnKvAOh+3UzgaOsmuMvvgBTdDlE8xattwDmUaAY788BQ6a/Y7E94L9NGbjZIgkkkwLC fi5A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@noorman.info header.s=MBO0001 header.b=kfzHDgQQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=noorman.info Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id p16-20020a056a000b5000b00565db76831esi33097357pfo.62.2022.10.23.09.41.56; Sun, 23 Oct 2022 09:42:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@noorman.info header.s=MBO0001 header.b=kfzHDgQQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=noorman.info Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230386AbiJWQb0 (ORCPT + 99 others); Sun, 23 Oct 2022 12:31:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51742 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229618AbiJWQbY (ORCPT ); Sun, 23 Oct 2022 12:31:24 -0400 Received: from mout-y-111.mailbox.org (mout-y-111.mailbox.org [91.198.250.236]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 08B9D4F6BD; Sun, 23 Oct 2022 09:31:23 -0700 (PDT) Received: from smtp102.mailbox.org (unknown [91.198.250.119]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-384) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mout-y-111.mailbox.org (Postfix) with ESMTPS id 4MwNxg2NDkz9sl2; Sun, 23 Oct 2022 18:31:19 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=noorman.info; s=MBO0001; t=1666542679; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=L+Uu5fNN1Fu4LDg47Qgq7aw/zK13Z4KSJrDen1AI+eY=; b=kfzHDgQQoAexT2MbOdTVEnjZfDXMGUB1Tfa2m05iz/3MvlUYD8GIcPhlfQ2DPzxLhiqBrH d3y32fDfQGjxln1G+lumoSf0IdxP2ul0VuXdqMhSAvgUt7rGeneeuVcL2xSUej1IO5KviP zTJn4JCLGe9h5DcPqIR4su+JzgV/kFSoeIV1l9OxzRhGng5IN+Ax4f7vUWZpmmFPM6Dw1V 4Y6reDuHBzA6aJr3Lq9JVS1zOIOVu5kGV+xDwQuvXxcpqstFO84FsjMAP6MhIROAGG8/Dv Ju1VSfz8ieFsBEQBvSOZ5wNYsud1OecUg2lBdk9q9AcNcjMd3gmh2TY3NyRZvw== From: Job Noorman To: Job Noorman , Dmitry Torokhov , Rob Herring , Krzysztof Kozlowski , Andy Gross , Bjorn Andersson , Konrad Dybcio , Henrik Rydberg Cc: Luca Weiss , linux-input@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org Subject: [PATCH v5 0/3] Add Himax hx83112b touchscreen driver Date: Sun, 23 Oct 2022 18:30:28 +0200 Message-Id: <20221023163032.144150-1-job@noorman.info> MIME-Version: 1.0 X-Rspamd-Queue-Id: 4MwNxg2NDkz9sl2 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1747497338381247302?= X-GMAIL-MSGID: =?utf-8?q?1747497338381247302?= Hi all, This series adds support for the Himax hx83112b. The hx83112b supports 10 point multitouch with hardware tracking of touch points. It is the touchschreen used by the Fairphone 3. Note that a datasheet was unavailable for this device, so it was built based on the Android driver that was tagged as GPLv2. This series is a complete rewrite, though, and the code bears no resemblence to the original implementation. It is expected that this driver can be made to work on other hx83xxx devices, especially the hx83112a used in the Fairphone 4. However, since we have been unable to verify this, this driver only declares compatibility with the hx83112b and uses very specific file names. Changes since v4 (based on Jeff LaBundy's 2nd round of comments): - Kconfig: depend on I2C and select REGMAP_I2C - Don't suppress dev_err() on EPROBE_DEFER - Some minor coding style updates Changes since v3 (based on Dmitry Torokhov's comments): - Use gpiod_set_value_cansleep (instead of gpiod_set_value) during probe - Inline some small helper functions - Use DEFINE_SIMPLE_DEV_PM_OPS() and pm_sleep_ptr() - Use PTR_ERR_OR_ZERO instead of IS_ERR+PTR_ERR - Some minor coding style updates (e.g., use C-style comments) Changes since v2 (based on Jeff LaBundy's comments): - Kconfig: depend on REGMAP_I2C instead of I2C - Don't use dev_err_probe() - Return IRQ_NONE on failed register reads to prevent possible interrupt storm - Add small delay after de-asserting reset pin - Some minor coding style updates - dt-bindings: make touchscreen-size-{x,y} required Changes since v1: - Fix sparse warnings. Reported-by: kernel test robot . - Fix dt_binding_check. Best regards, Job Previous versions: - v4: https://lore.kernel.org/lkml/20221017100409.189293-1-job@noorman.info/ - v3: https://lore.kernel.org/lkml/20221016102756.40345-1-job@noorman.info/ - v2: https://lore.kernel.org/lkml/20221012202341.295351-1-job@noorman.info/ - v1: https://lore.kernel.org/lkml/20221011190729.14747-1-job@noorman.info/ Job Noorman (3): dt-bindings: touchscreen: add Himax hx83112b bindings Input: add driver for Himax hx83112b touchscreen devices arm64: dts: qcom: sdm632: fairphone-fp3: add touchscreen .../input/touchscreen/himax,hx83112b.yaml | 63 +++ MAINTAINERS | 7 + .../boot/dts/qcom/sdm632-fairphone-fp3.dts | 14 + drivers/input/touchscreen/Kconfig | 12 + drivers/input/touchscreen/Makefile | 1 + drivers/input/touchscreen/himax_hx83112b.c | 364 ++++++++++++++++++ 6 files changed, 461 insertions(+) create mode 100644 Documentation/devicetree/bindings/input/touchscreen/himax,hx83112b.yaml create mode 100644 drivers/input/touchscreen/himax_hx83112b.c base-commit: d4a596eddb90114f5f5f32a440057a175517b090