Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2829494pxv; Mon, 12 Jul 2021 02:59:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx6SnJL+wSj+pZM2y+z7eHIGNx5oqdEDtXWktmROy2M9/XJoY1DxVdx6pqF/5je/EwPVAae X-Received: by 2002:a02:628b:: with SMTP id d133mr43247862jac.27.1626083994681; Mon, 12 Jul 2021 02:59:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626083994; cv=none; d=google.com; s=arc-20160816; b=wj8HV3vb6NdPxUrIKPlSZoW3Of8xhYApU7+PD1Pi80dXKgXGBI+FuLvMwA6gt+Bdj5 YB9YycaLTV0zOA0VPvSoVxd2Nv1xL6vDT29lvicxmdPf33HQroUmHwBJ+FhlfzKl76bB qUrNSJIoEnNj3NNVtz+FuzdAF+PayvFGTi+tqNGUew72w+akTwc5iQreSpzRikyDoBCX 1qx3eD8DlrN1KFARO0nvU+XIJQGD106Scqef9i9ZcCHn5lNmgM3nNRiPdkLVaB/ZUO/z Oe2p1e+FvYPvEommmy5HqY1UZ8XEb2Cn6iDlv9K+Voi7W//BiwL0O/fCcTEf4bcpwaqQ 1jUA== 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=jZ44EWTmX0Tuwbkpz6U4Nm/mFgEv8smJZJ1rwJnQO74=; b=bcjCkWaQ33UJLqEbbYz6gdiAnm4b18CygVabl9vZlQEoqibt2eh0+AdOQniwQjhhBu iiQwr+k4tZPFHsxBU0cUg3t7ojQAWtMq9Sk1R9GU6i9RedJlPU6bat0n3URswVddVZXt 7RQOAHAPgLgugB8gXOhYc6aikGjxk1zH7aoZei4hPmV8KBO+67zdjJ1vOwBFL2xpcSvJ gTmPFxMKN5OF/xemeYWZugHi81+q+bJIHFVJPlrKtXtrM6GMTW132zkpVV8UAaiIwT5V 01PTqkkTO6rn1BkUN+ZPm32C2mEpHo53beZ2AUc7hFO/iAluGRm+YOLL0RVYR2GSrKWq uxzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=qiQnCkJ4; 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=pass (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 x7si5863632ilu.63.2021.07.12.02.59.39; Mon, 12 Jul 2021 02:59:54 -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=@linuxfoundation.org header.s=korg header.b=qiQnCkJ4; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242179AbhGLHGT (ORCPT + 99 others); Mon, 12 Jul 2021 03:06:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:41760 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236404AbhGLGrj (ORCPT ); Mon, 12 Jul 2021 02:47:39 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id B53EE610FB; Mon, 12 Jul 2021 06:43:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626072208; bh=lpcMqwgaGCM3YNXRNUtFY+meGk25ETElQRXkSv2v/oc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qiQnCkJ4pE+P3nComD4vYji84Ez0dr91aWGFYOw5A1PyhaN7yZLM7MZnxcy/XAoD8 Ov10uPGYTHccR8PnaZ3DAf7WuzzI8alny9t4CBcjmJ+zXANGM6to1R7ffLbiA6LAhN pRb/HhU5ey416cKAGygOnzYQ9pgowxCOE3IZbqcc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Sukadev Bhattiprolu , "David S. Miller" , Sasha Levin Subject: [PATCH 5.10 401/593] ibmvnic: free tx_pool if tso_pool alloc fails Date: Mon, 12 Jul 2021 08:09:21 +0200 Message-Id: <20210712060931.730713687@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sukadev Bhattiprolu [ Upstream commit f6ebca8efa52e4ae770f0325d618e7bcf08ada0c ] Free tx_pool and clear it, if allocation of tso_pool fails. release_tx_pools() assumes we have both tx and tso_pools if ->tx_pool is non-NULL. If allocation of tso_pool fails in init_tx_pools(), the assumption will not be true and we would end up dereferencing ->tx_buff, ->free_map fields from a NULL pointer. Fixes: 3205306c6b8d ("ibmvnic: Update TX pool initialization routine") Signed-off-by: Sukadev Bhattiprolu Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/ibm/ibmvnic.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/ibm/ibmvnic.c b/drivers/net/ethernet/ibm/ibmvnic.c index 458619aa84f4..3134c1988db3 100644 --- a/drivers/net/ethernet/ibm/ibmvnic.c +++ b/drivers/net/ethernet/ibm/ibmvnic.c @@ -751,8 +751,11 @@ static int init_tx_pools(struct net_device *netdev) adapter->tso_pool = kcalloc(tx_subcrqs, sizeof(struct ibmvnic_tx_pool), GFP_KERNEL); - if (!adapter->tso_pool) + if (!adapter->tso_pool) { + kfree(adapter->tx_pool); + adapter->tx_pool = NULL; return -1; + } adapter->num_active_tx_pools = tx_subcrqs; -- 2.30.2