Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2833934pxv; Mon, 12 Jul 2021 03:05:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy+3+lzlwmUU55iZ2CgtWZEsgq7SZF2nQoynMl+UNhnJzUCdgfG+XMzj45waq5+KmSUS8mg X-Received: by 2002:a6b:ec07:: with SMTP id c7mr20065196ioh.115.1626084344413; Mon, 12 Jul 2021 03:05:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626084344; cv=none; d=google.com; s=arc-20160816; b=GDTLpDmPuUnPMem+zBB8MwREAUEiZPQVPGqtxthAZTgA6AnWoDuWZu4KmizdtSJg+W pXzuIACpHf+xMsGTI7Y7uNggne/whIjC9EIJ7jEoKLAc0TVjkWJuNtrV/kKdV03+O8cv uqfdkwghI3isGqhAwlrFN1rAuXeNzy0xgdsSVa05hAAhS5Zn/GS61QFIoicSXxyQZra2 YsOrWqAe57NBCysgXo1eOAXf+S7SCSIEhOOPpZCJW+qPdVgM0CQlwa3zhgrDo7G95RGj UceSxS0dLgSNgFsneIikDiP2cntyywGiy8idLjGQE/nJrcaSSkfFzP0M8g0/L+EvYJkD 0Bkg== 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=quRMxlhf5GNGHqpD16tabysQkzI12g85ZQD8rpfH7es=; b=MNPH9htEun+rFFSvQP3CWSN3se96rjwJOYAMrvnVQKdr0+L/ALkIs3d4PN3PtlN6Pf ms56Jvc7suHZV5l1EKupXLVxVxtmQILTBfMlUTcxQzUk4CFASKpVNAMNB5xkUhtp9gqZ dhdjzdJVbnZ6Aq1MrvgrMln35y8CLDbHjTkEbK4JDYPq9MpXC/HxgXer+XoCKsCtPP1J Yz10UN7g2CINt5/EKeAucdBp5EKCnKwpaEvVQY1EmzBF2WTwcGkM/fJ2tXnJzuJKIkl0 kubPYiFNjy7qdw7SRbR7z6eGeyXdKCpqp5zMYVl7OJm/HfVXZ2MhJz8eNYNbdHZ1rZ4v 2sMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=sQ35hwl+; 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 r17si18859304iov.104.2021.07.12.03.05.33; Mon, 12 Jul 2021 03:05:44 -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=sQ35hwl+; 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 S243320AbhGLHf3 (ORCPT + 99 others); Mon, 12 Jul 2021 03:35:29 -0400 Received: from mail.kernel.org ([198.145.29.99]:42134 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242403AbhGLHGo (ORCPT ); Mon, 12 Jul 2021 03:06:44 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 24B49610E6; Mon, 12 Jul 2021 07:03:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626073435; bh=YXHak61v1O7A050cPtVIAPc15LkwuBJvwNxrg1ZOtAI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sQ35hwl+wNNUf6hCRkkQDrLOlyR+vIC01LWDAQq0pUYcgM68CO2JahIo35wWz2UAV aNNOhTjgN8OWLX3KhiPZRSE2lbPKdJ3cwF02zXSYM34XiN7YkvU0tcm15RQt+viRS+ 3sPtlnMWFnmLFXSijkHLQZAvIeA3nqpX0wNqS13Y= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Alexander Aring , David Teigland , Sasha Levin Subject: [PATCH 5.12 214/700] fs: dlm: fix lowcomms_start error case Date: Mon, 12 Jul 2021 08:04:57 +0200 Message-Id: <20210712060957.123521997@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060924.797321836@linuxfoundation.org> References: <20210712060924.797321836@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: Alexander Aring [ Upstream commit fcef0e6c27ce109d2c617aa12f0bfd9f7ff47d38 ] This patch fixes the error path handling in lowcomms_start(). We need to cleanup some static allocated data structure and cleanup possible workqueue if these have started. Signed-off-by: Alexander Aring Signed-off-by: David Teigland Signed-off-by: Sasha Levin --- fs/dlm/lowcomms.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/fs/dlm/lowcomms.c b/fs/dlm/lowcomms.c index 7e6736c70e11..d2a0ea0acca3 100644 --- a/fs/dlm/lowcomms.c +++ b/fs/dlm/lowcomms.c @@ -1600,10 +1600,15 @@ static void process_send_sockets(struct work_struct *work) static void work_stop(void) { - if (recv_workqueue) + if (recv_workqueue) { destroy_workqueue(recv_workqueue); - if (send_workqueue) + recv_workqueue = NULL; + } + + if (send_workqueue) { destroy_workqueue(send_workqueue); + send_workqueue = NULL; + } } static int work_start(void) @@ -1620,6 +1625,7 @@ static int work_start(void) if (!send_workqueue) { log_print("can't start dlm_send"); destroy_workqueue(recv_workqueue); + recv_workqueue = NULL; return -ENOMEM; } @@ -1751,7 +1757,7 @@ int dlm_lowcomms_start(void) error = work_start(); if (error) - goto fail; + goto fail_local; dlm_allow_conn = 1; @@ -1768,6 +1774,9 @@ int dlm_lowcomms_start(void) fail_unlisten: dlm_allow_conn = 0; dlm_close_sock(&listen_con.sock); + work_stop(); +fail_local: + deinit_local(); fail: return error; } -- 2.30.2