Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp1667208imm; Fri, 8 Jun 2018 22:34:31 -0700 (PDT) X-Google-Smtp-Source: ADUXVKK8jFaAujhx6Qd27BRyO/g8Xek2CdaYny6sKZbYvSCMYHh9DuoVj5Em5kXBQysPrGcLyCLa X-Received: by 2002:a63:6b43:: with SMTP id g64-v6mr7609058pgc.337.1528522470850; Fri, 08 Jun 2018 22:34:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528522470; cv=none; d=google.com; s=arc-20160816; b=go9AL9RQyX5molbJJ05NmuL0huiS0EAj/clQ71u6LsBh2WV7Dhq/1gtPMvbugetGYM 9iuNZAQ8Z/X/gB9oSSZI2Bdvxz3L6PrWcLm0yEURNlzfbcdkejp+6xbYuQrS846i1UZE hBISjmUNpzrTTyyIyTofUX47g8LbeJAVyTHXCqOajLw2X3jztbNu+Ghc8BdYaABeG7a8 I0y2KhXB9oM8oKe/HoWvhOBigM57/oqD+1y6kva78YWCJONdZyl+b4yw+MhxHZ49Y48I JIq54s4wgKo3Z+GNR/jigtP0Bh9V9O63V2PfUtnLGKBx2Q7fRTYzcjB9LnqIRiPI8sjk Reqw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=ZxRotY4kFpX0zIg02l+6EF/hQogIPrhbFCimxej3IL8=; b=zUUYfEde/SjHqhD63pHiF9BNLHaRuBdkk1yi96uATiRYtwE5Keec8VpAAZcXCTAiqy LmDmuxh+Djg6vhcHnCoa+fNY4FnNh/VbB5PYpfLuZG/mWHO1cOaH63BCeMnS1vOglUSj B44auwuyU3snlUe8ebeFGKSkChd29sEHXqdL8BbNVH89I3FqVyODR+/ZubdgGbWdwVEQ GJRFg6ZMRwz7uUd9jYLh7OnctD9qBStOUmVB8BeT3vfx3RrJsikuRFrwbHjGpvU28+RF qUX2xCQF7j7iurrWY91UvwSc41trR+V2lJq1LP6xK3lFbqGUdk28HCJdi4L3oz9DVRF9 ievA== 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 bf10-v6si18363365plb.423.2018.06.08.22.33.50; Fri, 08 Jun 2018 22:34:30 -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 S1751456AbeFIFdB (ORCPT + 99 others); Sat, 9 Jun 2018 01:33:01 -0400 Received: from www262.sakura.ne.jp ([202.181.97.72]:16527 "EHLO www262.sakura.ne.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751257AbeFIFdA (ORCPT ); Sat, 9 Jun 2018 01:33:00 -0400 Received: from fsav305.sakura.ne.jp (fsav305.sakura.ne.jp [153.120.85.136]) by www262.sakura.ne.jp (8.15.2/8.15.2) with ESMTP id w595UleC074809; Sat, 9 Jun 2018 14:30:47 +0900 (JST) (envelope-from penguin-kernel@i-love.sakura.ne.jp) Received: from www262.sakura.ne.jp (202.181.97.72) by fsav305.sakura.ne.jp (F-Secure/fsigk_smtp/530/fsav305.sakura.ne.jp); Sat, 09 Jun 2018 14:30:47 +0900 (JST) X-Virus-Status: clean(F-Secure/fsigk_smtp/530/fsav305.sakura.ne.jp) Received: from [192.168.1.8] (softbank126074194044.bbtec.net [126.74.194.44]) (authenticated bits=0) by www262.sakura.ne.jp (8.15.2/8.15.2) with ESMTPSA id w595Ugl3074791 (version=TLSv1.2 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sat, 9 Jun 2018 14:30:47 +0900 (JST) (envelope-from penguin-kernel@i-love.sakura.ne.jp) Subject: Re: general protection fault in wb_workfn (2) To: Dmitry Vyukov Cc: Jens Axboe , Jan Kara , syzbot , syzkaller-bugs , linux-fsdevel , LKML , Al Viro , Tejun Heo , Dave Chinner , linux-block@vger.kernel.org, Linus Torvalds References: <95865cab-e12f-d45b-b6e3-465b624862ba@i-love.sakura.ne.jp> <201806080231.w582VIRn021009@www262.sakura.ne.jp> From: Tetsuo Handa Message-ID: <2b437c6f-3e10-3d83-bdf3-82075d3eaa1a@i-love.sakura.ne.jp> Date: Sat, 9 Jun 2018 14:30:41 +0900 User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Dmitry Vyukov wrote: > Here we go: Great. Thank you. > > [ 2853.033175] WARNING: wb_workfn: device is NULL > [ 2853.034709] wb->state=2 > It is surprising that wb->state == WB_shutting_down . WB_shutting_down is set by only wb_shutdown() and is always cleared before leaving wb_shutdown(). This means that someone was calling wb_shutdown() on this wb object. And bdi->dev == NULL means that bdi_unregister() already did bdi->dev = NULL while someone was still inside wb_shutdown(). Since we call wb_shutdown() from bdi_unregister() for each wb object on this bdi object, this should not happen. But since "INFO: task hung in wb_shutdown (2)" found that it is possible that wb_shutdown() is concurrently called on the same wb object, there might be something complicated concurrency. Well, is it really true that "we call wb_shutdown() from bdi_unregister() for each wb object on this bdi object"? It seems it is not always true... While cgwb_bdi_unregister() from bdi_unregister() calls wb_shutdown() on each wb object reachable from bdi->wb_list, wb_shutdown() firstly calls list_del_rcu(&wb->bdi_node) (which was added by list_add_tail_rcu(&wb->bdi_node, &bdi->wb_list) from cgwb_create()) and then starts waiting for that wb object by calling mod_delayed_work()/flush_delayed_work() and then clears WB_shutting_down. Then, it is possible that cgwb_bdi_unregister() from calls wb_shutdown() fails to find a wb object which already passed list_del_rcu() from wb_shutdown(), and cgwb_bdi_unregister() can return without waiting for somebody who is waiting inside wb_shutdown(). Hence, allows doing bdi->dev = NULL before a wb object which somebody is waiting inside wb_shutdown() completes wb_workfn(), and NULL pointer dereference...