Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp583009pxk; Wed, 2 Sep 2020 09:19:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzoLYtu90R88yEBf8J8Vb0yHszjsUbvRpr93bxtuCut0aHtzgEhnss4Mk9BLroNkd5ts6oD X-Received: by 2002:a17:906:8d8:: with SMTP id o24mr774216eje.384.1599063555910; Wed, 02 Sep 2020 09:19:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599063555; cv=none; d=google.com; s=arc-20160816; b=I6+Q6ASNK36ooEIGLc1j5VDzjTcyQTk7L1Gp5II9ZasxzBaLdhSq9Jzgy6TTy51zoY dd5F8s3YQ7bA/CWPIthk6Y0x+HDcHCT3Ly9HYrdbcS7ubjeWHuiiJR0RUqU1TUm4PG2d QYeWE+e5FvQHQqdFbMZIsZpEUAvDkoDmQI0sk31caFzkh+RtNKEYCAzkgsJcEJXFw9oU 4B3ZelTRIk8y2m6jyCq5hOgv6+CgKw8KmMR+jdpZIlZZjjiialAFxV1SMyhK05AZ0AdH O9gcprpOqdaU6m0s59Xey7VpP97Ug/LFnohSUOHGU2A8Lhp8wpYSI3xoEQ9XqSr20TBC v+lQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:from :dkim-signature; bh=U7MfCZs9ez7KMjK6cr+hf8DQRE8QbE+J2vaHktvReGk=; b=DOw1N3/QtMDByGhjQIbUS90Jp3ZfSi6Rxn7DsOR4KArWokyyY/AQKYZjBk5Fuaqecv 6CH4zV6djOuHxfqR26i2GxL7GtKi9w/h/O9kQWhx/4Ks0fpD81khAIGfjQ/+EmicZ1m6 vj+X/jFDmdc4zkhpUzlKxLnT9DVhnW4xdcsd03QVL22B8mCoLD7eKVoKPA9STdNIndB+ dN7OLZnTtQfRRddnmMgCyK68AyBiWeuDdX+P2F1KLlurAGY1mh+taF3mi6iJRJ1KWCd6 CvDH453L4qOYEoCUgMPqCQK+jAsTjvuPieIigpaN0RiV+v37OR63qMtKj1Maa3u+MgMK zjww== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@kernel.org header.s=default header.b=ifhvhUuY; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m14si2704474eds.454.2020.09.02.09.18.52; Wed, 02 Sep 2020 09:19:15 -0700 (PDT) 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; dkim=fail header.i=@kernel.org header.s=default header.b=ifhvhUuY; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728241AbgIBQKv (ORCPT + 99 others); Wed, 2 Sep 2020 12:10:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:53486 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726323AbgIBQKq (ORCPT ); Wed, 2 Sep 2020 12:10:46 -0400 Received: from mail.kernel.org (ip5f5ad5c3.dynamic.kabel-deutschland.de [95.90.213.195]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D5B0320829; Wed, 2 Sep 2020 16:10:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1599063046; bh=1OCEDwU9HDg1YRkwjzMBn5RpJKhK/uC509VN2U3vg0c=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ifhvhUuYT6pd0LE2qsDDFfRrMs8OdIaCz9X7BIOgxoGIjS6nbjFk3zb/jSh37oh2k nF6OongzJKq2WaCYU3KSWPiKn5o9cVjdXfv0Jh96z4VXkZpBNguFTgU0YhvGGBUa+O Ypt7/TzZzQ1xyDr+AhnWN65zCsVHK6mfMlG7CzEI= Received: from mchehab by mail.kernel.org with local (Exim 4.94) (envelope-from ) id 1kDVLP-000t9r-Oh; Wed, 02 Sep 2020 18:10:43 +0200 From: Mauro Carvalho Chehab Cc: Mauro Carvalho Chehab , Hans Verkuil , Allen Pais , Romain Perier , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 05/38] media: wl128x: get rid of a potential spectre issue Date: Wed, 2 Sep 2020 18:10:08 +0200 Message-Id: <17a07bd5f4a690a388ba03daf8d01b30bd9cd8d9.1599062230.git.mchehab+huawei@kernel.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As reported by smatch: drivers/media/radio/wl128x/fmdrv_common.c:736 fm_irq_handle_rdsdata_getcmd_resp() warn: potential spectre issue 'rds_fmt.data.groupdatabuff.buff> Address it by using array_index_nospec(). While here, reorder the linux/ includes. Signed-off-by: Mauro Carvalho Chehab --- drivers/media/radio/wl128x/fmdrv_common.c | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/drivers/media/radio/wl128x/fmdrv_common.c b/drivers/media/radio/wl128x/fmdrv_common.c index 5c395da74e17..9abc8e0283c1 100644 --- a/drivers/media/radio/wl128x/fmdrv_common.c +++ b/drivers/media/radio/wl128x/fmdrv_common.c @@ -19,9 +19,11 @@ * Author: Manjunatha Halli */ -#include -#include #include +#include +#include +#include + #include "fmdrv.h" #include "fmdrv_v4l2.h" #include "fmdrv_common.h" @@ -700,7 +702,7 @@ static void fm_irq_handle_rdsdata_getcmd_resp(struct fmdev *fmdev) struct fm_rds *rds = &fmdev->rx.rds; unsigned long group_idx, flags; u8 *rds_data, meta_data, tmpbuf[FM_RDS_BLK_SIZE]; - u8 type, blk_idx; + u8 type, blk_idx, idx; u16 cur_picode; u32 rds_len; @@ -733,9 +735,11 @@ static void fm_irq_handle_rdsdata_getcmd_resp(struct fmdev *fmdev) } /* Skip checkword (control) byte and copy only data byte */ - memcpy(&rds_fmt.data.groupdatabuff. - buff[blk_idx * (FM_RDS_BLK_SIZE - 1)], - rds_data, (FM_RDS_BLK_SIZE - 1)); + idx = array_index_nospec(blk_idx * (FM_RDS_BLK_SIZE - 1), + FM_RX_RDS_INFO_FIELD_MAX - (FM_RDS_BLK_SIZE - 1)); + + memcpy(&rds_fmt.data.groupdatabuff.buff[idx], rds_data, + FM_RDS_BLK_SIZE - 1); rds->last_blk_idx = blk_idx; -- 2.26.2