Received: by 2002:a05:6358:701b:b0:131:369:b2a3 with SMTP id 27csp4703220rwo; Tue, 25 Jul 2023 09:42:04 -0700 (PDT) X-Google-Smtp-Source: APBJJlE+kWgTYgwN8OqRdzQMs/yaYGCdbbqT9O+jpZLi/Ujv6yWj17ul5hBufa+bo1/Z4nei2j6t X-Received: by 2002:a05:6402:6cf:b0:51d:8f9b:b6ce with SMTP id n15-20020a05640206cf00b0051d8f9bb6cemr13123396edy.1.1690303323762; Tue, 25 Jul 2023 09:42:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690303323; cv=none; d=google.com; s=arc-20160816; b=HdFri8R+10ekTYgQ90t/xX8/h66QXgE6iKO+7QsFb2rwakODy+g4Vixv15vjoF/ncz RDj6SIaelueosP1AaDnUuTohy7qKQc5Rc25fvArGInI/IPywTiNVib3sTm+oXoEEmXUm 7HjURSZlNOc2qsFOuLw76yt6zbcyVi3HUkAOf2ezaNf4x+kl2Edy5EX9cRIiObdH8FFB 7e/CRBVFmqdRMVwowDHAkgNnGcvbQP5JIVAbGwVbsSKKhHuguV4b9cifN6TOlPS62qzb 40yEWYqR5F+3VQe0O3s81RSHTqgClCi5QI2BaX34cFq7GKqMmz4+aYPsq3kJzFAgHAjI hFKA== 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 :message-id:date:subject:cc:to:from:sender:dkim-signature; bh=WvsRPcat3uxMMRmKyeqCHUTRDfz2SfBv2BE/yxjT+xg=; fh=qQfQn41I33w9pejKGXOVSCM4Acfp9qIpLZp/SumhAF8=; b=bNmfI937frt+rKLPkLZ7Q4p7MeUaEe0zhIGGxT0pBtrtfP8CWxQ16HmnnQM3/2syd4 PWIGzcMAqHqsrMLgmYoWMDQRJUaV+X2wSbYN+6JBPp0F5nA+4WT0ETa7MvfyEikO575N hTofcMgNl283DlWkciNDhIypXbU3bMKMfd0PzPJZp34IbABae3PFqFjkX+x0NbMH++EO CMVDbSO3algPGHsiPAL8BjYLw1E023cD9E4G6TrXkkkDu5L0rxOWIz/jqXJRGSVylKAM eO1JyWqyyWKvWTYIh2u/6dRMVGZxSiXAN21Mr3TpGMzRwDJmQd+D13rzSY7ngGMdv7v8 4ZHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@equiv.tech header.s=mx header.b=p4YLZler; 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=REJECT sp=REJECT dis=NONE) header.from=equiv.tech Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s2-20020aa7c542000000b0051e28cead02si7906629edr.337.2023.07.25.09.41.39; Tue, 25 Jul 2023 09:42:03 -0700 (PDT) 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; dkim=pass header.i=@equiv.tech header.s=mx header.b=p4YLZler; 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=REJECT sp=REJECT dis=NONE) header.from=equiv.tech Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230376AbjGYQOX (ORCPT + 99 others); Tue, 25 Jul 2023 12:14:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48858 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231897AbjGYQON (ORCPT ); Tue, 25 Jul 2023 12:14:13 -0400 Received: from so254-32.mailgun.net (so254-32.mailgun.net [198.61.254.32]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8A074E74 for ; Tue, 25 Jul 2023 09:14:10 -0700 (PDT) DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=equiv.tech; q=dns/txt; s=mx; t=1690301649; x=1690308849; h=Content-Transfer-Encoding: MIME-Version: Message-Id: Date: Subject: Subject: Cc: To: To: From: From: Sender: Sender; bh=WvsRPcat3uxMMRmKyeqCHUTRDfz2SfBv2BE/yxjT+xg=; b=p4YLZler3o1rHeyet3ce0fvNiw8T1BxdsUJYsopUHSXRaSs7gF95ec7XhvxvhAILE6nCQujbLe5k9ud9n7y5oeSKguu2FB/scRE+Bpptb4o7L+m6nTS48h49e7VlIzxQ4AoOeH+xZn2Zhn2VZUB/ybc7TIA1jUpEol1tQua48pgfmRy53u3XquACx3Q93yiF+QCYEQERIFFY4cQuSvbk4tfDGv/UHS4FSWNbshoU4lj344kRV/GeByYCl31ZqLeFeNeuPYBIlS0yWrJAolbIJRg5pBMG1hFLk2TnWC8AUGqsuSi6xE/rbTkcE335nA6JvJ2QirGxvg/Vs53ePccNeA== X-Mailgun-Sending-Ip: 198.61.254.32 X-Mailgun-Sid: WyI4ZWI3MiIsImxpbnV4LWtlcm5lbEB2Z2VyLmtlcm5lbC5vcmciLCI5M2Q1YWIiXQ== Received: from mail.equiv.tech (equiv.tech [142.93.28.83]) by d53bb90da10c with SMTP id 64bff4d113929ab6cbff2c7d (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 25 Jul 2023 16:14:09 GMT Sender: james@equiv.tech From: James Seo To: Sathya Prakash , Sreekanth Reddy , Suganath Prabu Subramani Cc: James Seo , "James E.J. Bottomley" , "Martin K. Petersen" , Kees Cook , "Gustavo A. R. Silva" , MPT-FusionLinux.pdl@broadcom.com, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 0/6] scsi: mpt3sas: Use flexible arrays and do a few cleanups Date: Tue, 25 Jul 2023 09:13:25 -0700 Message-Id: <20230725161331.27481-1-james@equiv.tech> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H4,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham 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 Commit df8fc4e934c1 ("kbuild: Enable -fstrict-flex-arrays=3") has resulted in the only arrays that UBSAN_BOUNDS considers unbounded being trailing arrays declared with [] as the last member of a struct. Unbounded trailing arrays declared with [1] are common in mpt3sas, which is causing spurious warnings to appear in some situations with UBSAN array bounds checks enabled, e.g. when more than one physical disk is connected: UBSAN: array-index-out-of-bounds in drivers/scsi/mpt3sas/mpt3sas_scsih.c:6810:36 index 1 is out of range for type 'MPI2_SAS_IO_UNIT0_PHY_DATA [1]' which relates to this unbounded array access: port_id = sas_iounit_pg0->PhyData[i].Port; and is just one example of 10 currently occurring for me during boot. This series converts most trailing arrays in mpt3sas into proper C99 flexible array members. Those that really are fixed-length arrays of length >=1 are left alone. I didn't find any conversions that required further source edits besides changing [1] to [], and everything seems to work with my SAS2008-based add-in card, but please look things over in case I missed something subtle. Rounding out the series are some opportunistic cleanups. James Seo (6): scsi: mpt3sas: Use flexible arrays when obviously possible scsi: mpt3sas: Use flexible arrays when less obviously possible scsi: mpt3sas: Use struct_size() for struct size calculations scsi: mpt3sas: Fix an outdated comment scsi: mpt3sas: Fix typo of "TRIGGER" scsi: mpt3sas: Replace a dynamic allocation with a local variable drivers/scsi/mpt3sas/mpi/mpi2_cnfg.h | 231 ++++++------------- drivers/scsi/mpt3sas/mpi/mpi2_image.h | 32 +-- drivers/scsi/mpt3sas/mpi/mpi2_ioc.h | 27 +-- drivers/scsi/mpt3sas/mpt3sas_base.c | 28 +-- drivers/scsi/mpt3sas/mpt3sas_config.c | 6 +- drivers/scsi/mpt3sas/mpt3sas_scsih.c | 18 +- drivers/scsi/mpt3sas/mpt3sas_transport.c | 9 +- drivers/scsi/mpt3sas/mpt3sas_trigger_pages.h | 44 ++-- drivers/scsi/mpt3sas/mpt3sas_warpdrive.c | 3 +- 9 files changed, 135 insertions(+), 263 deletions(-) base-commit: 7e9609d2daea0ebe4add444b26b76479ecfda504 -- 2.39.2