Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3140517pxb; Mon, 9 Nov 2020 03:49:51 -0800 (PST) X-Google-Smtp-Source: ABdhPJyI/o2NZUzc6r/lP/6KzcsGn2eqjDzQdIl1JG6fV2A6n9jFkQ4XmBZN10xd1taA8if9wCdd X-Received: by 2002:aa7:c886:: with SMTP id p6mr2816407eds.352.1604922591436; Mon, 09 Nov 2020 03:49:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604922591; cv=none; d=google.com; s=arc-20160816; b=vLT5ZNn4l2aoqdIIRMpS22kILfYsCYAyGsFaHbfyLLpA3+Q25Ttd6BxhfGYwMbORxz g1stMY3mVoXMqDzkTktyrakQfxFJynfJRKHnJKIWEdi28CdgOlArBtYBYhmW8fqYFhhY 9/NQ1OyrQAogz4ucVBSu+TEl6nACY2+kzLTeQERoE98KLds2jSk6boel8b4YsPLI2F+o Nmn6W9yvlkCIoNcBlFa3uL2eA015S95oKTffuoTug+fxkV8ki4Fiv11JihN1BjsZTuqJ yEalYIu7IJoHgbcC/r6RIna08tIsDBY6pPGIKljdtRYb505/y/6yhAEtT7hNOSqAwYgX yyQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=j7Bc3UUAYBsuh3ftOQkXP6ujQd9yyo0Wr3F2mJK8OHE=; b=EOSCncz0yVhD8TsvMDgQwODy5IYhRg8OzreW8hxRzVVB1SQBRT3PqCzxwmaDNuqfob Lxx/O8XiQu6WX+sHXZbv0dwYPip2CJo1uGJD4vJxDW2sPBtrkpirvzv3xtg52wKO4Xlz s6WJLH56adRIueNtLwuYoPxy+7C0uBt40amXSksIN4Ya1O2CKf+cL3XFzm6J1LxT73Ud lM2N/WcMI1q7O0Ue4JgstzJ/LTLk2/h74NX/7qowT2OokdgwhamGtlDuJrCcbjNvwW+y MtpHbBrpAD09EDK/jKiDQDT9+zYKKHVeO3bKVMYElsHq9esx/h2th+SY6KuUxniaPMC4 CGrQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h13si7151554edt.581.2020.11.09.03.49.28; Mon, 09 Nov 2020 03:49:51 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729446AbgKILr1 (ORCPT + 99 others); Mon, 9 Nov 2020 06:47:27 -0500 Received: from out30-57.freemail.mail.aliyun.com ([115.124.30.57]:36524 "EHLO out30-57.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727774AbgKILr0 (ORCPT ); Mon, 9 Nov 2020 06:47:26 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R931e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04400;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0UEjNPeQ_1604922442; Received: from aliy8.localdomain(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0UEjNPeQ_1604922442) by smtp.aliyun-inc.com(127.0.0.1); Mon, 09 Nov 2020 19:47:22 +0800 From: Alex Shi To: linmiaohe@huawei.com, akpm@linux-foundation.org Cc: "Darrick J. Wong" , Hugh Dickins , linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [REF PATCH] mm/swap: fix swapon failure Date: Mon, 9 Nov 2020 19:47:16 +0800 Message-Id: <1604922436-16597-1-git-send-email-alex.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org One of my VM guest has a swapon issue: root #swapon -v -f /swap1 swapon /swap1 swapon: /swap1: found swap signature: version 1, page-size 4, same byte order swapon: /swap1: pagesize=4096, swapsize=1607467008, devsize=1607467008 swapon: /swap1: swapon failed: Invalid argument and bisection report commit 822bca52ee7e "mm/swapfile.c: fix potential memory leak in sys_swapon" cause the trouble. Go through the context I found the exit_swap_address_space(p->type) shouldn't be used in good result path. So just move it to error path. Fixes: 822bca52ee7e ("mm/swapfile.c: fix potential memory leak in sys_swapon") Signed-off-by: Alex Shi Cc: Andrew Morton Cc: "Darrick J. Wong" Cc: Miaohe Lin Cc: Hugh Dickins Cc: linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org --- mm/swapfile.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/mm/swapfile.c b/mm/swapfile.c index c8966b8fc6ac..1ac1f737fee3 100644 --- a/mm/swapfile.c +++ b/mm/swapfile.c @@ -3339,7 +3339,8 @@ static bool swap_discardable(struct swap_info_struct *si) error = inode_drain_writes(inode); if (error) { inode->i_flags &= ~S_SWAPFILE; - goto free_swap_address_space; + exit_swap_address_space(p->type); + goto bad_swap_unlock_inode; } mutex_lock(&swapon_mutex); @@ -3364,8 +3365,6 @@ static bool swap_discardable(struct swap_info_struct *si) error = 0; goto out; -free_swap_address_space: - exit_swap_address_space(p->type); bad_swap_unlock_inode: inode_unlock(inode); bad_swap: -- 1.8.3.1