Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp4003030pxb; Tue, 25 Jan 2022 01:07:13 -0800 (PST) X-Google-Smtp-Source: ABdhPJwVOyIAFEOyKa+iJ8qIvhwBNrP5NqlXDEEZ+xEOeKILDI3b59NJr1UhtNlFhabFHB0O5iFw X-Received: by 2002:a17:902:b947:b0:14a:a6aa:4fa6 with SMTP id h7-20020a170902b94700b0014aa6aa4fa6mr17988057pls.149.1643101633421; Tue, 25 Jan 2022 01:07:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643101633; cv=none; d=google.com; s=arc-20160816; b=liadEUf1QBtokWEVoouByYQgFeeVIZdPBz00lloTxOKBhSA07rraYWKYEQowa4oDJa YxOyOi5elAhnYh0JDyExKWOY9FrUXHSREG98kOo3qxpU2Ib4BXuBItyuTwiLWGKKuxBO rlpNip/YTKR5dh+txdejkW7KIf9aw8cuZNLCqbXpz3sa4YVeS6Iom4fPTxE3qy1hMAsq 4CfLjS26Yb20Yr9kqZqTUA872O4pLgCRQTF94bPtNs0NFsxT84TmAQt4sn+/Oxk4E7DU QY/nZupzkN4EJu1TMyTs+JDpUSDng6dUNNY3cG6H8oBdSITqg25bx1xRkgVT3Bdm9K0n Ix4g== 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 :references:in-reply-to:message-id:date:subject:to:from; bh=yZ5uLID34GvLufnindTfj0hv+RjaJwiB08WgorrInSU=; b=WyWUXS0Spa7sAkm0xKvoHpUEkOGAwfPHxM5J7MyaY8UftyczM16u6wb/aLvrB3Hv32 4z+vsN/nuTeGbjp+2iTxFmgHL7/PHmcprs4DnrQtxHZrnoELBUwhDmmw+XWPhKi0UERe lVU03VdC53Lzr8iYRHVv8rIzp1k0MkLm24mlgkTQXcMVRegFvS3wTKheM7fD6IVCK3So 9a+iQ2yY3cxg0+hg99WLiP5zZzhM7IQvji2KxpxTRtpEf+suWXDccaqiJP1wKfPVwjp4 fnBO44z3ufXOMWT5Xo9AripWohHk919BLV3hOSJ0LqAubvJtgTecFSf8iFJfm7fal8QD Gybw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f7si15234526pgg.204.2022.01.25.01.07.01; Tue, 25 Jan 2022 01:07:13 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350037AbiAYGrU (ORCPT + 99 others); Tue, 25 Jan 2022 01:47:20 -0500 Received: from twspam01.aspeedtech.com ([211.20.114.71]:47034 "EHLO twspam01.aspeedtech.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1358016AbiAYGo1 (ORCPT ); Tue, 25 Jan 2022 01:44:27 -0500 Received: from mail.aspeedtech.com ([192.168.0.24]) by twspam01.aspeedtech.com with ESMTP id 20P6aluv078229; Tue, 25 Jan 2022 14:36:47 +0800 (GMT-8) (envelope-from jammy_huang@aspeedtech.com) Received: from JammyHuang-PC.aspeed.com (192.168.2.115) by TWMBX02.aspeed.com (192.168.0.24) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Tue, 25 Jan 2022 14:44:07 +0800 From: Jammy Huang To: , , , , , , , , Subject: [PATCH v4 2/3] media: aspeed: Use FIELD_GET to improve readability Date: Tue, 25 Jan 2022 14:44:08 +0800 Message-ID: <20220125064409.5502-3-jammy_huang@aspeedtech.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220125064409.5502-1-jammy_huang@aspeedtech.com> References: <20220125064409.5502-1-jammy_huang@aspeedtech.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [192.168.2.115] X-ClientProxiedBy: TWMBX02.aspeed.com (192.168.0.24) To TWMBX02.aspeed.com (192.168.0.24) X-DNSRBL: X-MAIL: twspam01.aspeedtech.com 20P6aluv078229 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use the bitfield macro FIELD_GET, and GENMASK to do the shift and mask in one go for reg values. Signed-off-by: Jammy Huang Reviewed-by: Joel Stanley --- v4: - no update v3: - no update v2: - Put some codes on one line --- drivers/media/platform/aspeed-video.c | 31 +++++++++++---------------- 1 file changed, 12 insertions(+), 19 deletions(-) diff --git a/drivers/media/platform/aspeed-video.c b/drivers/media/platform/aspeed-video.c index d5f77b205175..c241038ee27c 100644 --- a/drivers/media/platform/aspeed-video.c +++ b/drivers/media/platform/aspeed-video.c @@ -156,26 +156,22 @@ #define VE_SRC_LR_EDGE_DET_NO_H BIT(13) #define VE_SRC_LR_EDGE_DET_NO_DISP BIT(14) #define VE_SRC_LR_EDGE_DET_NO_CLK BIT(15) -#define VE_SRC_LR_EDGE_DET_RT_SHF 16 -#define VE_SRC_LR_EDGE_DET_RT GENMASK(27, VE_SRC_LR_EDGE_DET_RT_SHF) +#define VE_SRC_LR_EDGE_DET_RT GENMASK(27, 16) #define VE_SRC_LR_EDGE_DET_INTERLACE BIT(31) #define VE_SRC_TB_EDGE_DET 0x094 #define VE_SRC_TB_EDGE_DET_TOP GENMASK(12, 0) -#define VE_SRC_TB_EDGE_DET_BOT_SHF 16 -#define VE_SRC_TB_EDGE_DET_BOT GENMASK(28, VE_SRC_TB_EDGE_DET_BOT_SHF) +#define VE_SRC_TB_EDGE_DET_BOT GENMASK(28, 16) #define VE_MODE_DETECT_STATUS 0x098 #define VE_MODE_DETECT_H_PERIOD GENMASK(11, 0) -#define VE_MODE_DETECT_V_LINES_SHF 16 -#define VE_MODE_DETECT_V_LINES GENMASK(27, VE_MODE_DETECT_V_LINES_SHF) +#define VE_MODE_DETECT_V_LINES GENMASK(27, 16) #define VE_MODE_DETECT_STATUS_VSYNC BIT(28) #define VE_MODE_DETECT_STATUS_HSYNC BIT(29) #define VE_SYNC_STATUS 0x09c #define VE_SYNC_STATUS_HSYNC GENMASK(11, 0) -#define VE_SYNC_STATUS_VSYNC_SHF 16 -#define VE_SYNC_STATUS_VSYNC GENMASK(27, VE_SYNC_STATUS_VSYNC_SHF) +#define VE_SYNC_STATUS_VSYNC GENMASK(27, 16) #define VE_H_TOTAL_PIXELS 0x0A0 @@ -988,23 +984,20 @@ static void aspeed_video_get_resolution(struct aspeed_video *video) sync = aspeed_video_read(video, VE_SYNC_STATUS); htotal = aspeed_video_read(video, VE_H_TOTAL_PIXELS); - video->frame_bottom = (src_tb_edge & VE_SRC_TB_EDGE_DET_BOT) >> - VE_SRC_TB_EDGE_DET_BOT_SHF; - video->frame_top = src_tb_edge & VE_SRC_TB_EDGE_DET_TOP; + video->frame_bottom = FIELD_GET(VE_SRC_TB_EDGE_DET_BOT, src_tb_edge); + video->frame_top = FIELD_GET(VE_SRC_TB_EDGE_DET_TOP, src_tb_edge); det->vfrontporch = video->frame_top; - det->vbackporch = ((mds & VE_MODE_DETECT_V_LINES) >> - VE_MODE_DETECT_V_LINES_SHF) - video->frame_bottom; - det->vsync = (sync & VE_SYNC_STATUS_VSYNC) >> - VE_SYNC_STATUS_VSYNC_SHF; + det->vbackporch = FIELD_GET(VE_MODE_DETECT_V_LINES, mds) - + video->frame_bottom; + det->vsync = FIELD_GET(VE_SYNC_STATUS_VSYNC, sync); if (video->frame_top > video->frame_bottom) continue; - video->frame_right = (src_lr_edge & VE_SRC_LR_EDGE_DET_RT) >> - VE_SRC_LR_EDGE_DET_RT_SHF; - video->frame_left = src_lr_edge & VE_SRC_LR_EDGE_DET_LEFT; + video->frame_right = FIELD_GET(VE_SRC_LR_EDGE_DET_RT, src_lr_edge); + video->frame_left = FIELD_GET(VE_SRC_LR_EDGE_DET_LEFT, src_lr_edge); det->hfrontporch = video->frame_left; det->hbackporch = htotal - video->frame_right; - det->hsync = sync & VE_SYNC_STATUS_HSYNC; + det->hsync = FIELD_GET(VE_SYNC_STATUS_HSYNC, sync); if (video->frame_left > video->frame_right) continue; -- 2.25.1