Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp805693pxb; Tue, 3 Nov 2020 13:03:11 -0800 (PST) X-Google-Smtp-Source: ABdhPJxBX0jkIxujLJva0PytoLDto8LSY6ljcHokTRx6TfchBQHLONdHqsnPwBub/JrPu6XBSK3c X-Received: by 2002:a50:bf4b:: with SMTP id g11mr16674625edk.170.1604437390799; Tue, 03 Nov 2020 13:03:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604437390; cv=none; d=google.com; s=arc-20160816; b=THYvtFLK7C79A5zk2Fl+qcWZ9H52DLffgygs2Mzu5U3xOlPlgvKBOgQn++aLGneWSs cqrdyQaYE2Puoakpw1taFMxCINjpbuNwaWXXsoHiNC4YuOkuSN5wK73dUZR9MeW9Gbk8 kzinXK5XMB2frlKk2bUeiVUAx5aKZiWNyezq2t9U9cO9bFqUd3LLcMeMVG77MCgrfeEJ t4FgWA7wrO6UTLdJReqEUTB1iir65zQJnkgL7eFS4/rBxiOTmKEAxmaNlqkJBitkuC0p n/YM1z77MqEydTozN11GdTDu3Z+Qb+5gufIJ2JZdduZP5MrupGcfPF+YuF7rWMWPZDuH TCJw== 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=HFKkOYzfdyxjOE1+JlWmXTpu3MaIBLi9Og/ElAwIdAk=; b=Id6j9rbtSK/geqPFMFtJapI4b9TMfdwyg/3leqlCguI5pmY8tpFcub1qCZfspFMmyj bqFlH8OKzagLizUVDb1C3ssZ1heQSUYJ4NR89KZ99MdGA0D6jtV+FuM5UyyJgM0ZLTrY 2YnZXAToB5H/h9/w69PkEs1Wr91Td+5GMTKuyn8iYG0/l/R+IR4KVtoz/8iPRwnMkzay HGaFB3lIMVGHYPiAPb97HlH/+q/nbVajLETdFQSSFEp+kkusR0QyKCpTDBSKh51xCDmx x7djLdrtcc+WEMCeOwLaqRB8l4GaAawqTWZlCr7E7R1ESULY2f5cUkxW3FVzJzbsIEc8 Vvug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=aVmPhQzt; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bk9si13636ejb.42.2020.11.03.13.02.46; Tue, 03 Nov 2020 13:03:10 -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; dkim=pass header.i=@kernel.org header.s=default header.b=aVmPhQzt; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733118AbgKCU7c (ORCPT + 99 others); Tue, 3 Nov 2020 15:59:32 -0500 Received: from mail.kernel.org ([198.145.29.99]:34626 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731817AbgKCU72 (ORCPT ); Tue, 3 Nov 2020 15:59:28 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 337EF2053B; Tue, 3 Nov 2020 20:59:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604437167; bh=j43P6qp85e/ygXkNNIca/FOFKaOvVJMudsEesMHcvBM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=aVmPhQztxBtXniz89zfpfZZxox+dfgbcMovRI9924/sN4EGeNAlotL9ju2/OC/xen 0rQGG1pR9ZobpcIyyoZf36+Y82tYHs7JCm34IgTub/np/gH+Ai1N19/6QLNeUQpH+c M8BkYxpXjZlJcJ3hIarLLr83rEq1K8KcnLcWrB6M= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Zhihao Cheng , syzbot+853639d0cb16c31c7a14@syzkaller.appspotmail.com, Richard Weinberger Subject: [PATCH 5.4 175/214] ubi: check kthread_should_stop() after the setting of task state Date: Tue, 3 Nov 2020 21:37:03 +0100 Message-Id: <20201103203307.130230296@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203249.448706377@linuxfoundation.org> References: <20201103203249.448706377@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: Zhihao Cheng commit d005f8c6588efcfbe88099b6edafc6f58c84a9c1 upstream. A detach hung is possible when a race occurs between the detach process and the ubi background thread. The following sequences outline the race: ubi thread: if (list_empty(&ubi->works)... ubi detach: set_bit(KTHREAD_SHOULD_STOP, &kthread->flags) => by kthread_stop() wake_up_process() => ubi thread is still running, so 0 is returned ubi thread: set_current_state(TASK_INTERRUPTIBLE) schedule() => ubi thread will never be scheduled again ubi detach: wait_for_completion() => hung task! To fix that, we need to check kthread_should_stop() after we set the task state, so the ubi thread will either see the stop bit and exit or the task state is reset to runnable such that it isn't scheduled out indefinitely. Signed-off-by: Zhihao Cheng Cc: Fixes: 801c135ce73d5df1ca ("UBI: Unsorted Block Images") Reported-by: syzbot+853639d0cb16c31c7a14@syzkaller.appspotmail.com Signed-off-by: Richard Weinberger Signed-off-by: Greg Kroah-Hartman --- drivers/mtd/ubi/wl.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) --- a/drivers/mtd/ubi/wl.c +++ b/drivers/mtd/ubi/wl.c @@ -1629,6 +1629,19 @@ int ubi_thread(void *u) !ubi->thread_enabled || ubi_dbg_is_bgt_disabled(ubi)) { set_current_state(TASK_INTERRUPTIBLE); spin_unlock(&ubi->wl_lock); + + /* + * Check kthread_should_stop() after we set the task + * state to guarantee that we either see the stop bit + * and exit or the task state is reset to runnable such + * that it's not scheduled out indefinitely and detects + * the stop bit at kthread_should_stop(). + */ + if (kthread_should_stop()) { + set_current_state(TASK_RUNNING); + break; + } + schedule(); continue; }