Received: by 10.213.65.68 with SMTP id h4csp1126150imn; Wed, 28 Mar 2018 21:29:36 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+kjA0HfGg1zU7UdwLuE8V6M9ETARVPk/OZub6LQfEdeD+54odifvMXLEQqK33fTUE+TgpE X-Received: by 2002:a17:902:5222:: with SMTP id z31-v6mr4677898plh.145.1522297776554; Wed, 28 Mar 2018 21:29:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522297776; cv=none; d=google.com; s=arc-20160816; b=M2apucm/uFJCQVYqZ3RkPcf6mmlh4VL0ov9NYPWwfjVQHdkSo+hbjLbp2fVTGrpOGI Vp8RqkcLudKjnt1bpr3TjAPL9UwZYJmjvHFLRRYyMQyBvyAjMZet8Ult0COWr8Z6vkXB UCYb1wvVtrswH6UaYPPZlAdc4WPU16uidw9vz9ehS7O93Atne63kXnT11BWZ30Vin+7h 0dYPXz8+9fFOfw70QKJVLWdqEkDJYozL4rcCqsl2jfBwFN/aosXFcP/lwMy3sv88EiyU SWediouKACwKVspiSfgDA+8En9uteAEycnbSoh+YhxzwwsdvJ2RZnUajUirUUT9rCnnd lm7w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:cc:subject:date:to :from:arc-authentication-results; bh=GQwHaswxJkU/NYqDnGu5IQadXf9QjrXc/PVoXUiDJ8I=; b=G8NlhwgRfx4zgJpfOyOnAw5verT6yD5ERAGDnn0vieRU130o4yZrwRfnzgxLCM42Oa ilQnYSLlw9NagfeAiKXD3+LXwyZxSiEwee3wEyjMrN+6ovDl81KOw3PO5UjuBALMIMqx Z6CX6I1Bxl49n553Xp+AnxdYAjbNDLBuDzVTlNA1StU9pLkzW6mJyQ4hUqHHNE881Ura 4fnmKf6ojir2bQXhZWBp4TLp00O6Q7YNwGy5BLpNNLjnZhBkgn/2UFCD2LBTmAZ8HhUj 5V+DxL1pMdcuBGXgJm6GXN0/TihvqWYLnA0yKZ6AClX5KcPklB8JYkN/PjIuvPFZuhXF TWxQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o11-v6si4803711plk.672.2018.03.28.21.29.22; Wed, 28 Mar 2018 21:29:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752486AbeC2E2B (ORCPT + 99 others); Thu, 29 Mar 2018 00:28:01 -0400 Received: from mx2.suse.de ([195.135.220.15]:34818 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752370AbeC2E17 (ORCPT ); Thu, 29 Mar 2018 00:27:59 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (charybdis-ext.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 8F457AE46; Thu, 29 Mar 2018 04:27:58 +0000 (UTC) From: NeilBrown To: Oleg Drokin , Greg Kroah-Hartman , James Simmons , Andreas Dilger Date: Thu, 29 Mar 2018 15:26:48 +1100 Subject: [PATCH 07/17] staging: lustre: ldlm: free resource when ldlm_lock_create() fails. Cc: Linux Kernel Mailing List , Lustre Development List Message-ID: <152229760844.27689.4330202028940942080.stgit@noble> In-Reply-To: <152229732768.27689.4800156943561963977.stgit@noble> References: <152229732768.27689.4800156943561963977.stgit@noble> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ldlm_lock_create() gets a resource, but don't put it on all failure paths. It should. Signed-off-by: NeilBrown --- drivers/staging/lustre/lustre/ldlm/ldlm_lock.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c b/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c index b8fd778d9832..614caa4a9b0e 100644 --- a/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c +++ b/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c @@ -1551,8 +1551,10 @@ struct ldlm_lock *ldlm_lock_create(struct ldlm_namespace *ns, return ERR_CAST(res); lock = ldlm_lock_new(res); - if (!lock) + if (!lock) { + ldlm_resource_putref(res); return ERR_PTR(-ENOMEM); + } lock->l_req_mode = mode; lock->l_ast_data = data; @@ -1595,6 +1597,8 @@ struct ldlm_lock *ldlm_lock_create(struct ldlm_namespace *ns, return ERR_PTR(rc); } + + /** * Enqueue (request) a lock. * On the client this is called from ldlm_cli_enqueue_fini