Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp48054pxk; Tue, 15 Sep 2020 17:24:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy4aveoOhKC1pFFFowYbChmbuYgg7RwG20ZaXrmhH9QHFL4+86OsbV9rk8x7PK1kBOz8p/4 X-Received: by 2002:a17:907:72c2:: with SMTP id du2mr23529105ejc.512.1600215870702; Tue, 15 Sep 2020 17:24:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600215870; cv=none; d=google.com; s=arc-20160816; b=a919yaEzHAz/fLqHm4TAGqaWxJI2oOenCem58H06LVcUQzTnEOaYbHHE/KKKN6syKz fal2vhuVr1yYJnHKv3NWMg+daylyX/xotbnpV1/UlSMlM9Uz5pRCpBUs0uVfpSaJp3+k 7hPoCT4b50yLfkUawvWltSSzQy4dEPZDbYJG+5bHZEjMdrSxVLdPFdaVgRaLPWd1eQRa +hxc8ws0/6ejJy9N9wu2DCcFyBlw7UdAGWFT5v3DczvLFegCsviS2+MS5K9nMCv9VNGU dIkqNz5H9Op8t81SezSd+RVQS3L0+z9Ue6XRz52VSuyPlkIIp+Y/Rjrbc3yad+8xBnX3 iKDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=dQ0XFQ7VmbUOG7Jx/n8f2oJ5pGTWerEN/FElJWFHBpU=; b=UMOEKGE32qzATSM2H0+Vq0fmkhA7017CaRd37xe7xAAzIBfHEEBZ915XiZAoOSJU4L Yhw2NAbFfBq7zKzZZMdVb8Jd9FBWEiA7h465R4gs4vfs84UQ/IzoTURb1F8WjZvPbid1 Cq2m//yi+olCI+18ZqI1x4MF22riLI1H6IxazIe/FVZqorlCSuqiyuYctNYxdUBI4xVa i29tLDRCC7aVRBPv8ztu5GXsU9ZSIUCnWGzwV+I29RUNEgpHHVjsFMCLquw3hmRGcETC 3nm/KjoZTt25In1xs15NLTfuGD6quP73nmcwgIIhD1HCMqCByA2RYxAtUkbwt671ImEv N8dA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=AmwaORaJ; 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=fail (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 z3si11229495ejw.596.2020.09.15.17.24.07; Tue, 15 Sep 2020 17:24:30 -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=@kernel.org header.s=default header.b=AmwaORaJ; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727246AbgIPAX0 (ORCPT + 99 others); Tue, 15 Sep 2020 20:23:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:34640 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726758AbgIOOU7 (ORCPT ); Tue, 15 Sep 2020 10:20:59 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (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 947082224D; Tue, 15 Sep 2020 14:16:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1600179415; bh=yuMN3nwIBBvJ+B3GHNkulw+InTyhB2bQpvw+wmFDtiw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=AmwaORaJ0aw0i8DtM2SwZI+O0qvrKBVoXiSJIH2JK2fE1v7g3dT9kbmVWVWhGCuH/ IO5/1HyG6nXUzW0XCs4Jg+Oa0D6RQWVkVxQR1+zxkCa5mM3NAWLk+SSsNjmrEF92US bAwhBdE4B2uKpDPhrHGMJHoF52uI2PpFz/+VDj7E= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lars-Peter Clausen , Narcisa Ana Maria Vasile , Jonathan Cameron , Andy Shevchenko , Stable@vger.kernel.org Subject: [PATCH 4.19 50/78] iio:chemical:ccs811: Fix timestamp alignment and prevent data leak. Date: Tue, 15 Sep 2020 16:13:15 +0200 Message-Id: <20200915140636.078227972@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200915140633.552502750@linuxfoundation.org> References: <20200915140633.552502750@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jonathan Cameron commit eb1a148ef41d8ae8d9201efc3f1b145976290331 upstream. One of a class of bugs pointed out by Lars in a recent review. iio_push_to_buffers_with_timestamp assumes the buffer used is aligned to the size of the timestamp (8 bytes). This is not guaranteed in this driver which uses an array of smaller elements on the stack. As Lars also noted this anti pattern can involve a leak of data to userspace and that indeed can happen here. We close both issues by moving to a suitable structure in the iio_priv() data with alignment explicitly requested. This data is allocated with kzalloc so no data can leak appart from previous readings. The explicit alignment of ts is necessary to ensure consistent padding for x86_32 in which the ts would otherwise be 4 byte aligned. Fixes: 283d26917ad6 ("iio: chemical: ccs811: Add triggered buffer support") Reported-by: Lars-Peter Clausen Cc: Narcisa Ana Maria Vasile Signed-off-by: Jonathan Cameron Reviewed-by: Andy Shevchenko Cc: Signed-off-by: Greg Kroah-Hartman --- drivers/iio/chemical/ccs811.c | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) --- a/drivers/iio/chemical/ccs811.c +++ b/drivers/iio/chemical/ccs811.c @@ -78,6 +78,11 @@ struct ccs811_data { struct ccs811_reading buffer; struct iio_trigger *drdy_trig; bool drdy_trig_on; + /* Ensures correct alignment of timestamp if present */ + struct { + s16 channels[2]; + s64 ts __aligned(8); + } scan; }; static const struct iio_chan_spec ccs811_channels[] = { @@ -309,17 +314,17 @@ static irqreturn_t ccs811_trigger_handle struct iio_dev *indio_dev = pf->indio_dev; struct ccs811_data *data = iio_priv(indio_dev); struct i2c_client *client = data->client; - s16 buf[8]; /* s16 eCO2 + s16 TVOC + padding + 8 byte timestamp */ int ret; - ret = i2c_smbus_read_i2c_block_data(client, CCS811_ALG_RESULT_DATA, 4, - (u8 *)&buf); + ret = i2c_smbus_read_i2c_block_data(client, CCS811_ALG_RESULT_DATA, + sizeof(data->scan.channels), + (u8 *)data->scan.channels); if (ret != 4) { dev_err(&client->dev, "cannot read sensor data\n"); goto err; } - iio_push_to_buffers_with_timestamp(indio_dev, buf, + iio_push_to_buffers_with_timestamp(indio_dev, &data->scan, iio_get_time_ns(indio_dev)); err: