From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F00FF1A0BF3; Fri, 23 May 2025 16:12:45 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1748016767; cv=none; b=tgqB25/Ll+9FRlKMxmBIGYAsp9P6nQnf3XJ+CfZUABnB+E3mIJn5B/gz/ypxJySo2/LJmAF/r9gyPpzSEwkMwWJu4jyUkznRXKTsPLHjUapY5O2DuACp2dNHcyqz2uU3yR+qIWtzC6Klkyu+rMRZUaxt3iJutNWOXgC3kk8NQ3c= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1748016767; c=relaxed/simple; bh=stvsu4xByc6n2n97XoQi+HIP09rpdP6ynB7YbbNj4KI=; h=Date:From:To:Cc:Subject:Message-ID:MIME-Version:Content-Type: Content-Disposition:In-Reply-To; b=NMJM7CwH2DJIgbGIyGbEj5Niq7BT/0EC7ueUHpv+mHfsXp/hNZMZ6pDx9iWemYt3B9nLEWnBoLSK3mFC68HLXh6KcNLf97AZOf1QYFXlpcEqS7PVA3ChWKGxMIGq7xXhSUEhc3JH3K9lL9Ufo8AGuHjWWqRmHUFlnbVmVOKVZ8I= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=gLMKIQgl; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="gLMKIQgl" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 2EA36C4CEE9; Fri, 23 May 2025 16:12:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1748016765; bh=stvsu4xByc6n2n97XoQi+HIP09rpdP6ynB7YbbNj4KI=; h=Date:From:To:Cc:Subject:In-Reply-To:From; b=gLMKIQglZVHVJrIBT9fuUVoEk86gspRrdu0MSmpWv4I37u4mbh7bM8U2FW2ASJWm0 HlIOeJvO4pZYGWJuJTnHz2PDV8OA/gJTLwYNKILEdQlX+bk5xR1FEJyNmY0EA6VKH4 HCQNhmtcMFAyGAN5/ymkOF+c94t0ZjngYAfYSCF6GmhvElNxa5t5IH8hmvHXlIlJ4m TPsZdJYlCtR2X3tZL3w8BkiBiwBaeNbrUZSwFNNTtyHlYQ/7iZieQLMwdw6+IOg2CL xSA8Jnjrim//zklWRD/FijrAmNqWRBlJbsq9QFcfyZ9qpt5aYozEULjAbgbSxzXBx7 WPrGOeLcX/jfw== Date: Fri, 23 May 2025 11:12:43 -0500 From: Bjorn Helgaas To: Ilpo =?utf-8?B?SsOkcnZpbmVu?= Cc: linux-pci@vger.kernel.org, Jon Pan-Doh , Karolina Stolarek , Weinan Liu , Martin Petersen , Ben Fuller , Drew Walton , Anil Agrawal , Tony Luck , Sathyanarayanan Kuppuswamy , Lukas Wunner , Jonathan Cameron , Sargun Dhillon , "Paul E . McKenney" , Mahesh J Salgaonkar , Oliver O'Halloran , Kai-Heng Feng , Keith Busch , Robert Richter , Terry Bowman , Shiju Jose , Dave Jiang , LKML , linuxppc-dev@lists.ozlabs.org, Bjorn Helgaas Subject: Re: [PATCH v8 16/20] PCI/AER: Convert aer_get_device_error_info(), aer_print_error() to index Message-ID: <20250523161243.GA1559290@bhelgaas> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: On Fri, May 23, 2025 at 02:13:52PM +0300, Ilpo Järvinen wrote: > On Thu, 22 May 2025, Bjorn Helgaas wrote: > > > From: Bjorn Helgaas > > > > Previously aer_get_device_error_info() and aer_print_error() took a pointer > > to struct aer_err_info and a pointer to a pci_dev. Typically the pci_dev > > was one of the elements of the aer_err_info.dev[] array (DPC was an > > exception, where the dev[] array was unused). > > -void aer_print_error(struct pci_dev *dev, struct aer_err_info *info) > > +void aer_print_error(struct aer_err_info *info, int i) > > { > > - int layer, agent; > > - int id = pci_dev_id(dev); > > + struct pci_dev *dev; > > + int layer, agent, id; > > const char *level = info->level; > > > > + if (i >= AER_MAX_MULTI_ERR_DEVICES) > > + return; > > Are these OoB checks actually indication of a logic error in the caller > side which would perhaps warrant using > if (WARN_ON_ONCE(i >= AER_MAX_MULTI_ERR_DEVICES)) > ? Good idea, thanks! I hope we can someday get rid of this info->dev[] array and the headaches associated with it.