Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp16482lqz; Fri, 29 Mar 2024 07:15:53 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCV6Zl5msA572qhhcmlUk3QUvNhC5qfIGNGlIVOuf12+xaHheumbDpOxYPfmKFZ1E3KdL1ZAn3LQfoDbL0YHJbcVGdnpRElQgaLocco6iQ== X-Google-Smtp-Source: AGHT+IH41xwWltPa+CdHPODCYSKV6FxchsVeII2KVPgXHbfNt4JmV2ubcJtoBlvsqvhRbtjN9PO1 X-Received: by 2002:a05:6870:512:b0:22a:4b7b:6428 with SMTP id j18-20020a056870051200b0022a4b7b6428mr2622623oao.2.1711721753332; Fri, 29 Mar 2024 07:15:53 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711721753; cv=pass; d=google.com; s=arc-20160816; b=i+6mwpbuwLyiTvUsKFg9Pi6auCqGlaQkKlNIlhHWfxeRKGHS2ctT94TYOkPGK+s2o/ oXi7BaybQC05XOZQzMyNPn6e+nSXL13Y0H7RumfZX8w6lcaOyZsh80wn1Q4gvKjbw60Q 13UPvutIlFcadzU1/h4fdMj5PhVbSg2JJDSMSJE9NTaQnY5nWWoHUwenAgoBpKojvpQt DROGwWAs6hJiOZmFmnDY1Dg/rtSK9TqfpP64mNTZ5aEfswl8ccQZXG+l6GV8U+CSKJpW tlGdBtuQ56U8z6f6XarJPs5PtLkiCgNLaKbdnwdaAz5QrOYt6/r4a7bEWVQBFFlU399t ks8A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=Ho3yJDv2EKKuJwjZ7bll8S45//ILY4jrj919h1rzgwE=; fh=TWTyTjU6SFQTzyWjbOYv6OxpKkNnC4lPeb9vj3E1sW4=; b=bjmfO2mxHx8Z7awHHElaSLMDf+i4R+Otu4HqiALHwDgVeesjFH7f3a716A8yUcGmsn BN+qdjLnZlnG9Uf+pk4dBXx1jXqP6n0jq5gCFJj6LMMlD/CHSkpR1XQVtv41xi5TmkNN mSiCH6/xbpYD1mLr/gV1S1dNYUxW98Dz7QWBLcC6lenAbNGVo0mg3fPy/D1Bw43eRB3z GGQ91ukrhw9EuGDNJ+GXwRFcglWWCOF9CCjduNohL/VDwlH6riQ+a/qK+SvBOtyJfduF Z6cl1pMx4lEW6oJkx+nNxc8n3m/SM0IjiZiV8ceff6BDoQAUXjbfZ8+T1HiBrOJ9Onsj tr1A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=F35rQpfR; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-124876-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-124876-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id dj19-20020a05622a4e9300b00432c53a408bsi785081qtb.31.2024.03.29.07.15.53 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 29 Mar 2024 07:15:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-124876-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=F35rQpfR; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-124876-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-124876-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 10AAC1C2750F for ; Fri, 29 Mar 2024 14:15:53 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 57B1520126C; Fri, 29 Mar 2024 12:45:30 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="F35rQpfR" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 743DE201253; Fri, 29 Mar 2024 12:45:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711716329; cv=none; b=Pdb/DSdvKaoGfpOZLbqnh4f7jAxnL+g8zWPh4eFcfaqXJE17KG25rDrMsX+/mFwlaUtOiYIuP2+tOCENeYT1SptRruU1KkZ4AYUbjILYcgCtd7ug5l9M5Ur3bUXvK18JAtLYpGBJEcDC8ZWY1bzVG1/HxWXIDvNuQDiMu/zTlig= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711716329; c=relaxed/simple; bh=q2BWX4NtxKmcgK3P7af7UtWPPDXWCKw/GYQhqCUTSNY=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=FCjdy7C+1vxZ1t8ZKV03DB9MQJ7xXh/GtenhG1JqY8HWvJRBb2Ca1daAuKOm7D9s2JZ1PXELk7hBHgWAN39OS1dnA0OwKieUBogXfUdpy+SI6bOhfGgLl4U68bFikiXOLQhvxGd5AnZMcbk3BRitau5rBt3LWnFgh9UaRS+gU54= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=F35rQpfR; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 8913AC433F1; Fri, 29 Mar 2024 12:45:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711716329; bh=q2BWX4NtxKmcgK3P7af7UtWPPDXWCKw/GYQhqCUTSNY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=F35rQpfRG174f0dpulZ+ORK7qwM9AGBPXaDmL+QvQ5AIcNlxt433+LCFHqkUZMFYM s0Bl7aTYprMmFwKbogEtYH1eQ4s7QNrBZb4+ll5tEEkoIl3eNYNnI+PycQVYg/BZP3 6rSV51Hx9JFd29Zv1DJI0r4p7cinAxUBuC4I0vjIN2Fi2NCV4WLDgffiWU/NffP8R9 D9hBZ4hB0n7iQcuVyNV8UVAzhOAWhQjuXsaLk5pBV4vO6mVcojY8k1qfjCjYT3AVnP UArjxHYS78Xm/tVnhrgFSP1hFHH1lVPy3sIhtxs+2LviX2s2w13wbjQUoMstmzwDjC UA1t1KvlLOP0Q== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: =?UTF-8?q?Duje=20Mihanovi=C4=87?= , Dmitry Torokhov , Sasha Levin , markuss.broks@gmail.com, linux-input@vger.kernel.org Subject: [PATCH AUTOSEL 6.6 67/75] Input: imagis - use FIELD_GET where applicable Date: Fri, 29 Mar 2024 08:42:48 -0400 Message-ID: <20240329124330.3089520-67-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240329124330.3089520-1-sashal@kernel.org> References: <20240329124330.3089520-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.6.23 Content-Transfer-Encoding: 8bit From: Duje Mihanović [ Upstream commit c0ca3dbd03d66c6b9e044f48720e6ab5cef37ae5 ] Instead of manually extracting certain bits from registers with binary ANDs and shifts, the FIELD_GET macro can be used. With this in mind, the *_SHIFT macros can be dropped. Signed-off-by: Duje Mihanović Link: https://lore.kernel.org/r/20240306-b4-imagis-keys-v3-1-2c429afa8420@skole.hr Signed-off-by: Dmitry Torokhov Signed-off-by: Sasha Levin --- drivers/input/touchscreen/imagis.c | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/drivers/input/touchscreen/imagis.c b/drivers/input/touchscreen/imagis.c index e1fafa561ee38..fe65e083fd49b 100644 --- a/drivers/input/touchscreen/imagis.c +++ b/drivers/input/touchscreen/imagis.c @@ -1,5 +1,6 @@ // SPDX-License-Identifier: GPL-2.0-only +#include #include #include #include @@ -29,12 +30,9 @@ #define IST3038C_I2C_RETRY_COUNT 3 #define IST3038C_MAX_FINGER_NUM 10 #define IST3038C_X_MASK GENMASK(23, 12) -#define IST3038C_X_SHIFT 12 #define IST3038C_Y_MASK GENMASK(11, 0) #define IST3038C_AREA_MASK GENMASK(27, 24) -#define IST3038C_AREA_SHIFT 24 #define IST3038C_FINGER_COUNT_MASK GENMASK(15, 12) -#define IST3038C_FINGER_COUNT_SHIFT 12 #define IST3038C_FINGER_STATUS_MASK GENMASK(9, 0) struct imagis_properties { @@ -106,8 +104,7 @@ static irqreturn_t imagis_interrupt(int irq, void *dev_id) goto out; } - finger_count = (intr_message & IST3038C_FINGER_COUNT_MASK) >> - IST3038C_FINGER_COUNT_SHIFT; + finger_count = FIELD_GET(IST3038C_FINGER_COUNT_MASK, intr_message); if (finger_count > IST3038C_MAX_FINGER_NUM) { dev_err(&ts->client->dev, "finger count %d is more than maximum supported\n", @@ -115,7 +112,7 @@ static irqreturn_t imagis_interrupt(int irq, void *dev_id) goto out; } - finger_pressed = intr_message & IST3038C_FINGER_STATUS_MASK; + finger_pressed = FIELD_GET(IST3038C_FINGER_STATUS_MASK, intr_message); for (i = 0; i < finger_count; i++) { if (ts->tdata->protocol_b) @@ -136,12 +133,11 @@ static irqreturn_t imagis_interrupt(int irq, void *dev_id) input_mt_report_slot_state(ts->input_dev, MT_TOOL_FINGER, finger_pressed & BIT(i)); touchscreen_report_pos(ts->input_dev, &ts->prop, - (finger_status & IST3038C_X_MASK) >> - IST3038C_X_SHIFT, - finger_status & IST3038C_Y_MASK, 1); + FIELD_GET(IST3038C_X_MASK, finger_status), + FIELD_GET(IST3038C_Y_MASK, finger_status), + true); input_report_abs(ts->input_dev, ABS_MT_TOUCH_MAJOR, - (finger_status & IST3038C_AREA_MASK) >> - IST3038C_AREA_SHIFT); + FIELD_GET(IST3038C_AREA_MASK, finger_status)); } input_mt_sync_frame(ts->input_dev); -- 2.43.0