Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp4156605pxv; Mon, 19 Jul 2021 18:44:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwEo9h248f0kAdQk8nxDMj55SeBIJk8c55rGheyDFPuTK0JlauZ1KlQGmPueJSXADzrjemM X-Received: by 2002:a92:d07:: with SMTP id 7mr18280325iln.114.1626745451191; Mon, 19 Jul 2021 18:44:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626745451; cv=none; d=google.com; s=arc-20160816; b=eqz4yMJupdvYpUmvmaVOGRjNKxWf4dyZdZpqSfkJ1et6m0BdMPfENdXGprd2nNPdsx p51tmCsznmBu3zwvpJeh1ejI5ZAVQ9TMC+QLuZVLWl4H/iKyxO2ZpzYTFZZyLe788abg abCClyZRXRCiwn1fXHH49mkX8JQ3XZeAUs7sN9SvffI5eRf3ja5D2CzCgQ7z/aiGp9yW egvr4/hB9PZ9ROwfJZDIe1siegF+hhUzg5lPmqdfcufXD5/c7yo/mygTrEkFsXjmKgo5 WurLCHZBbj+fKySSR74jzxo9SphyAJtKqxU9YTelOsBLTkRzrnlWDp9a1pGK7YSGJE3/ cBEw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=56Iqjr9yycYmKZKdaRMZjRiJDEWG4/hcty7cgcon2Iw=; b=vnIqSbpGGOn8a2+CVMbdbywo/po+g4n+KeqCkZNJ3K6+pxLrJFQsDE7vGU+RkMPF73 n8AVnZUUTXcWEt0Ic9daMCPRtyNZliNeH7WwWamREWtjuEJujYMQbSYI2Gka64cg3V6J ryC4SGBxmZ8zsWNzQnKQGI+0grrUqFM2MBtbg26fgnlMUOudG1s/gkD7k+98ZrU/drdZ U3El17hMZrAkPrceLGtc1Gkql587ZfmTmKABjmlreD9gd+Vp3we41L2rk3DOLdrVaEvi +XbPQ8hgFgHZ6teWUdiHkdbZHsuBOAK4IvtaJbws8SDRFgZeVGJJbGcYysSt8RDZvSrp ssMw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=bdXCmziL; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j1si4606007ile.62.2021.07.19.18.43.59; Mon, 19 Jul 2021 18:44:11 -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=pass header.i=@linuxfoundation.org header.s=korg header.b=bdXCmziL; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S245481AbhGSO6Y (ORCPT + 99 others); Mon, 19 Jul 2021 10:58:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:54162 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343859AbhGSOjr (ORCPT ); Mon, 19 Jul 2021 10:39:47 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 11EEA613AA; Mon, 19 Jul 2021 15:19:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626707987; bh=QA02mMdXZSWl0ubKkp4Oiy6y8Z2qmOYBGuEpv++eWQM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bdXCmziLMCuQSZcJwwWcJDJZ/+dH7B7yVVWTNWvrsuoC+w8fruFcQVFKzvpKTT7eV ivH5U4x96Il9y4vpltIRqLvdr+uwZKmIVX2JpNKPYqFfJbBU9vI759wvlmBxhHyI8X 2LLBR3TE7ari02sR3p0RuHFzRPFSD6SnhyoWZark= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jonathan Cameron , Andy Shevchenko , Sasha Levin Subject: [PATCH 4.14 135/315] iio: light: tcs3414: Fix buffer alignment in iio_push_to_buffers_with_timestamp() Date: Mon, 19 Jul 2021 16:50:24 +0200 Message-Id: <20210719144947.315411748@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.861561397@linuxfoundation.org> References: <20210719144942.861561397@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jonathan Cameron [ Upstream commit ff08fbc22ab32ccc6690c21b0e5e1d402dcc076f ] To make code more readable, use a structure to express the channel layout and ensure the timestamp is 8 byte aligned. Found during an audit of all calls of uses of iio_push_to_buffers_with_timestamp() Fixes: a244e7b57f0f ("iio: Add driver for AMS/TAOS tcs3414 digital color sensor") Signed-off-by: Jonathan Cameron Reviewed-by: Andy Shevchenko Link: https://lore.kernel.org/r/20210501170121.512209-19-jic23@kernel.org Signed-off-by: Sasha Levin --- drivers/iio/light/tcs3414.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/drivers/iio/light/tcs3414.c b/drivers/iio/light/tcs3414.c index a795afb7667b..b51cd43ef824 100644 --- a/drivers/iio/light/tcs3414.c +++ b/drivers/iio/light/tcs3414.c @@ -56,7 +56,11 @@ struct tcs3414_data { u8 control; u8 gain; u8 timing; - u16 buffer[8]; /* 4x 16-bit + 8 bytes timestamp */ + /* Ensure timestamp is naturally aligned */ + struct { + u16 chans[4]; + s64 timestamp __aligned(8); + } scan; }; #define TCS3414_CHANNEL(_color, _si, _addr) { \ @@ -212,10 +216,10 @@ static irqreturn_t tcs3414_trigger_handler(int irq, void *p) if (ret < 0) goto done; - data->buffer[j++] = ret; + data->scan.chans[j++] = ret; } - iio_push_to_buffers_with_timestamp(indio_dev, data->buffer, + iio_push_to_buffers_with_timestamp(indio_dev, &data->scan, iio_get_time_ns(indio_dev)); done: -- 2.30.2