Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp2181174iof; Tue, 7 Jun 2022 22:23:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxD8LF/35aqwpGhub9HpJf4KeXg2DfsCdUVog+B/8ItbBfvstS7aU8vMT02PMKwZCu74KoM X-Received: by 2002:a17:902:ce11:b0:167:7d4a:964b with SMTP id k17-20020a170902ce1100b001677d4a964bmr13657360plg.37.1654665824326; Tue, 07 Jun 2022 22:23:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654665824; cv=none; d=google.com; s=arc-20160816; b=T3j7bWLojkk19gyEHZwKCHYwyWBUTd6qU+fjFjyTYbo4jC8/3HkeCRM54QthNqtEHG v7VPRsev2yCLLfLgUsWbTX6333MaDCvdUpdpaBMnjkKdZ9qtycwQrFEqAXSAxmUZ2mgZ svYSr70dvntUUiTNGjNBNQ1VXssYndQDIKA4b7gb+VYvynqt7vGdrfZocMvMTb5Ah63w 15RJ58RncDz1a0lI6zqFDPwKP2yPkZVMLhzJ4MZ4UThQ0PktEPjabsCUU+HFj7cqvl7T m0MSUsHjrRgTcnNomQTxCZWKHi2gMTqK+lxZoCMRJJQwElBl/4W5v3hirl1IVLfw/Hgl xoTA== 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=GnLdJwbKCULJmxXvCpZ++BlJQQsKmxQgZTo5qFkZQME=; b=d0QqPeZUkYSFiewBdO3cwMrLMbKTJYSOPF/l9ILWOYUkzukOuywkBpoxLOOSu/ANEp 3+pdyXSJy3bN894AzGYh+tXwhU5tSJyxlK6rysETg2wq/emGmoMZnG4zaDyU57khnIFV SnzexMV3EuVKqKkxySF4/Bda9ZpoSq/i8m5Gpv33rX0SwQdK+CpSf2US+mW1pr4d+BRI ySyOZWSU1t21DDsCEapv0gGnmNZOczT79NEBNVTI9FDvONRmF4mko2tdQ1bGWeim19PQ hF7D6kP7biughmGadOreHj0hNdMjD1/PZfnMGqbB0FVy6fTwdXCj0mvkDdUZsHT7XLKp RrMw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="GY46bbm/"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id l73-20020a63914c000000b003fe0f4990ddsi4004215pge.255.2022.06.07.22.23.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 Jun 2022 22:23:44 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="GY46bbm/"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 44C87474419; Tue, 7 Jun 2022 21:52:00 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1358302AbiFGUSC (ORCPT + 99 others); Tue, 7 Jun 2022 16:18:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51536 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1356709AbiFGT2I (ORCPT ); Tue, 7 Jun 2022 15:28:08 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 150E51A0AFF; Tue, 7 Jun 2022 11:10:33 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id A0B36B8233E; Tue, 7 Jun 2022 18:10:31 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 18528C385A2; Tue, 7 Jun 2022 18:10:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1654625430; bh=COKzPOsl7kaNsDvx+z01yEVI+nhAt+B84z1IsdH3tzE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=GY46bbm/tF8NaEk9F8u/QwxKZ3fd7CSHltfPaIeMBE4nt2QpVaCqHs60dymHbLorc Q7jTkywr4qXP4H6segSiUp3LUeIUw5z62mOIsYtmDgPLrvU+Tj/B6T8DcaeuoasnOo qRJuokoZnmFRnbC7xCZIUaYMJYg/usbPp1bCbuyY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Rui Miguel Silva , Dietmar Eggemann , Linus Walleij Subject: [PATCH 5.17 017/772] usb: isp1760: Fix out-of-bounds array access Date: Tue, 7 Jun 2022 18:53:29 +0200 Message-Id: <20220607164949.512983939@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220607164948.980838585@linuxfoundation.org> References: <20220607164948.980838585@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 From: Linus Walleij commit 26ae2c942b5702f2e43d36b2a4389cfb7d616b6a upstream. Running the driver through kasan gives an interesting splat: BUG: KASAN: global-out-of-bounds in isp1760_register+0x180/0x70c Read of size 20 at addr f1db2e64 by task swapper/0/1 (...) isp1760_register from isp1760_plat_probe+0x1d8/0x220 (...) This happens because the loop reading the regmap fields for the different ISP1760 variants look like this: for (i = 0; i < HC_FIELD_MAX; i++) { ... } Meaning it expects the arrays to be at least HC_FIELD_MAX - 1 long. However the arrays isp1760_hc_reg_fields[], isp1763_hc_reg_fields[], isp1763_hc_volatile_ranges[] and isp1763_dc_volatile_ranges[] are dynamically sized during compilation. Fix this by putting an empty assignment to the [HC_FIELD_MAX] and [DC_FIELD_MAX] array member at the end of each array. This will make the array one member longer than it needs to be, but avoids the risk of overwriting whatever is inside [HC_FIELD_MAX - 1] and is simple and intuitive to read. Also add comments explaining what is going on. Fixes: 1da9e1c06873 ("usb: isp1760: move to regmap for register access") Cc: stable@vger.kernel.org Cc: Rui Miguel Silva Cc: Dietmar Eggemann Reviewed-by: Rui Miguel Silva Signed-off-by: Linus Walleij Link: https://lore.kernel.org/r/20220516091424.391209-1-linus.walleij@linaro.org Signed-off-by: Greg Kroah-Hartman --- drivers/usb/isp1760/isp1760-core.c | 8 ++++++++ 1 file changed, 8 insertions(+) --- a/drivers/usb/isp1760/isp1760-core.c +++ b/drivers/usb/isp1760/isp1760-core.c @@ -251,6 +251,8 @@ static const struct reg_field isp1760_hc [HW_DM_PULLDOWN] = REG_FIELD(ISP176x_HC_OTG_CTRL, 2, 2), [HW_DP_PULLDOWN] = REG_FIELD(ISP176x_HC_OTG_CTRL, 1, 1), [HW_DP_PULLUP] = REG_FIELD(ISP176x_HC_OTG_CTRL, 0, 0), + /* Make sure the array is sized properly during compilation */ + [HC_FIELD_MAX] = {}, }; static const struct reg_field isp1763_hc_reg_fields[] = { @@ -321,6 +323,8 @@ static const struct reg_field isp1763_hc [HW_DM_PULLDOWN_CLEAR] = REG_FIELD(ISP1763_HC_OTG_CTRL_CLEAR, 2, 2), [HW_DP_PULLDOWN_CLEAR] = REG_FIELD(ISP1763_HC_OTG_CTRL_CLEAR, 1, 1), [HW_DP_PULLUP_CLEAR] = REG_FIELD(ISP1763_HC_OTG_CTRL_CLEAR, 0, 0), + /* Make sure the array is sized properly during compilation */ + [HC_FIELD_MAX] = {}, }; static const struct regmap_range isp1763_hc_volatile_ranges[] = { @@ -405,6 +409,8 @@ static const struct reg_field isp1761_dc [DC_CHIP_ID_HIGH] = REG_FIELD(ISP176x_DC_CHIPID, 16, 31), [DC_CHIP_ID_LOW] = REG_FIELD(ISP176x_DC_CHIPID, 0, 15), [DC_SCRATCH] = REG_FIELD(ISP176x_DC_SCRATCH, 0, 15), + /* Make sure the array is sized properly during compilation */ + [DC_FIELD_MAX] = {}, }; static const struct regmap_range isp1763_dc_volatile_ranges[] = { @@ -458,6 +464,8 @@ static const struct reg_field isp1763_dc [DC_CHIP_ID_HIGH] = REG_FIELD(ISP1763_DC_CHIPID_HIGH, 0, 15), [DC_CHIP_ID_LOW] = REG_FIELD(ISP1763_DC_CHIPID_LOW, 0, 15), [DC_SCRATCH] = REG_FIELD(ISP1763_DC_SCRATCH, 0, 15), + /* Make sure the array is sized properly during compilation */ + [DC_FIELD_MAX] = {}, }; static const struct regmap_config isp1763_dc_regmap_conf = {