Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp4935376rwb; Tue, 17 Jan 2023 07:16:49 -0800 (PST) X-Google-Smtp-Source: AMrXdXvrVOmXtR6zxD/G0TiTrY0WGSOdfulSUbrr+KlmeUCAY42CW75c/p4aJZ7pLj3yrB+YUCwy X-Received: by 2002:aa7:c603:0:b0:46b:203:f388 with SMTP id h3-20020aa7c603000000b0046b0203f388mr14111595edq.39.1673968609036; Tue, 17 Jan 2023 07:16:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673968609; cv=none; d=google.com; s=arc-20160816; b=paYxB4Cqjc+CIi17jRxPPC8NTM53wA168dFsB4BE7FpaCxA0XLlmnAsIzXcB+5c3MO TQVTvcYkWeV9Bj2RCj3Wg6xT/t6ZW7N75D02qqNESsdSWGfGA8WeXyVsxoZq4hzitlZu DvyJQNOC9sLQk1u7JJZGoYzdcixB/bou2g3vhwAoG4eQ2mZicdBEEbXD3PYBu8TwVMGq LhH2EiV4a7cXvVm/bcKq1oB1qd8FqVMkyshiee/Q+hN1k9/SA6HhREFlTrAgvMy03RzX wzJi7/wxUUgK9e5nlhZIqDlCmi2tRUGy3qtJbpY0g9HmS1Kb6X2zK+Iv5pXKdYRSxt6Q pF5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=2v3DeE/W1CyFIMPERqc2eH5GXaew0PxtCjey83Glkpo=; b=luVtZbKCr+4EAzjY3/JvtmPhJiqzsThruqz8kiZL53zhgDWYb3zn2TW8ZiKCMhJR/8 5H+XvCF+gdbnu3vxumfi2kA+7BjpGcO7aSbnr68NQML2jNmXFUsHtmRXQE65bkHzy4ro AkzAf4TOH42+lYCcLsaSWF+NjdPOfSAiO/rX8C0H7Qh/OKeWSiZwvxn9jqKkNjGBCj86 O4S3OIdabZWIFyRV63PMp7Ze1wG3QkXnBI23eaHkdcDTiMg0b9AyOMgMeeQoOY3eqy6w 89mEaAmJpHa/yIUN9/tNEm/hghUUwobeHtOmM7fgf4pDAM9Jc7gVrHdv6RF8pUDZoh7k exAQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ho13-20020a1709070e8d00b0084d44edc334si27889581ejc.204.2023.01.17.07.16.33; Tue, 17 Jan 2023 07:16:49 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S232764AbjAQOnX (ORCPT + 48 others); Tue, 17 Jan 2023 09:43:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60660 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232789AbjAQOnK (ORCPT ); Tue, 17 Jan 2023 09:43:10 -0500 Received: from mail-ed1-f53.google.com (mail-ed1-f53.google.com [209.85.208.53]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4F2193EFD2; Tue, 17 Jan 2023 06:42:59 -0800 (PST) Received: by mail-ed1-f53.google.com with SMTP id s21so1144417edi.12; Tue, 17 Jan 2023 06:42:59 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=2v3DeE/W1CyFIMPERqc2eH5GXaew0PxtCjey83Glkpo=; b=F500R2DA4hfN4Q9Ab88lRMDDvXA55DBb6XDwbqoPNVU08487hvErtNYe6coxcTyI02 3ZHJ2nO2dgDdXdawOdZMdgAKcf3Pjd2MtJC8Ug09KIfa5N6ows4alhQIqKnFEo6NLpO3 SxxMyqJtdLsyfH7q+QPtQUwAuQmZCCOmQejKYvAWgxOjOyGw20QL2A5InbaQypBnM/sR eFgL40qEsPg7vwNJ/IKseftSZ+bxC3GOCbY3S0pRfN09VLFSZ7qmU3Y5sPUfEfViWQvo by+xpl3Z1IGangPGAv98VaaKhI+hLAU6sh//zGtOTo5E4xJsOInvGBRPkQPzRVCLE6Fg oqIQ== X-Gm-Message-State: AFqh2kqAyoJkLSHLV+bFj19nxvwqzjZJsn8USbtcE6IhJlO7quz+hOEL DiFO1HrqqQnwd8ZVi7BB4LQcCTVl5zE2Wk233zU= X-Received: by 2002:a05:6402:1392:b0:46d:731c:2baf with SMTP id b18-20020a056402139200b0046d731c2bafmr372874edv.280.1673966577778; Tue, 17 Jan 2023 06:42:57 -0800 (PST) MIME-Version: 1.0 References: <20230114085053.72059-1-W_Armin@gmx.de> <20230114085053.72059-3-W_Armin@gmx.de> In-Reply-To: <20230114085053.72059-3-W_Armin@gmx.de> From: "Rafael J. Wysocki" Date: Tue, 17 Jan 2023 15:42:46 +0100 Message-ID: Subject: Re: [PATCH 2/4] ACPI: battery: Fix buffer overread if not NUL-terminated To: Armin Wolf Cc: rafael@kernel.org, lenb@kernel.org, linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-1.4 required=5.0 tests=BAYES_00, FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Jan 14, 2023 at 9:51 AM Armin Wolf wrote: > > If the buffer containing string data is not NUL-terminated > (which is perfectly legal according to the ACPI specification), > the acpi battery driver might not honor its length. Note that this is about extracting package entries of type ACPI_TYPE_BUFFER. And please spell ACPI in capitals. > Fix this by limiting the amount of data to be copied to > the buffer length while also using strscpy() to make sure > that the resulting string is always NUL-terminated. OK > Also use '\0' instead of a plain 0. Why? It's a u8, not a char. > Signed-off-by: Armin Wolf > --- > drivers/acpi/battery.c | 23 ++++++++++++++++------- > 1 file changed, 16 insertions(+), 7 deletions(-) > > diff --git a/drivers/acpi/battery.c b/drivers/acpi/battery.c > index fb64bd217d82..9f6daa9f2010 100644 > --- a/drivers/acpi/battery.c > +++ b/drivers/acpi/battery.c > @@ -438,15 +438,24 @@ static int extract_package(struct acpi_battery *battery, > if (offsets[i].mode) { > u8 *ptr = (u8 *)battery + offsets[i].offset; I would add u32 len = 32; > > - if (element->type == ACPI_TYPE_STRING || > - element->type == ACPI_TYPE_BUFFER) > + switch (element->type) { And here I would do case ACPI_TYPE_BUFFER: if (len > element->buffer.length + 1) len = element->buffer.length + 1; fallthrough; case ACPI_TYPE_STRING: strscpy(ptr, element->buffer.pointer, len); break; case ACPI_TYPE_INTEGER: and so on. > + case ACPI_TYPE_STRING: > strscpy(ptr, element->string.pointer, 32); > - else if (element->type == ACPI_TYPE_INTEGER) { > - strncpy(ptr, (u8 *)&element->integer.value, > - sizeof(u64)); > + > + break; > + case ACPI_TYPE_BUFFER: > + strscpy(ptr, element->buffer.pointer, > + min_t(u32, element->buffer.length + 1, 32)); > + > + break; > + case ACPI_TYPE_INTEGER: > + strncpy(ptr, (u8 *)&element->integer.value, sizeof(u64)); > ptr[sizeof(u64)] = 0; > - } else > - *ptr = 0; /* don't have value */ > + > + break; > + default: > + *ptr = '\0'; /* don't have value */ > + } > } else { > int *x = (int *)((u8 *)battery + offsets[i].offset); > *x = (element->type == ACPI_TYPE_INTEGER) ? > --