Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751795AbdFEIl6 (ORCPT ); Mon, 5 Jun 2017 04:41:58 -0400 Received: from m12-16.163.com ([220.181.12.16]:48624 "EHLO m12-16.163.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751634AbdFEIl5 (ORCPT ); Mon, 5 Jun 2017 04:41:57 -0400 Message-ID: <593519AD.4070901@163.com> Date: Mon, 05 Jun 2017 16:43:25 +0800 From: Jia-Ju Bai User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:11.0) Gecko/20120410 Thunderbird/11.0.1 MIME-Version: 1.0 To: Richard Weinberger CC: dedekind1@gmail.com, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] ubifs: Fix a sleep-in-atomic bug in ubifs_read_nnode References: <1496633916-32362-1-git-send-email-baijiaju1990@163.com> <0687ba2f-f7d5-4632-eebb-50bbadd8a4b0@nod.at> In-Reply-To: <0687ba2f-f7d5-4632-eebb-50bbadd8a4b0@nod.at> Content-Type: text/plain; charset=ISO-8859-15; format=flowed Content-Transfer-Encoding: 7bit X-CM-TRANSID: EMCowACXTywYGTVZ2xlBIA--.40331S2 X-Coremail-Antispam: 1Uf129KBjDUn29KB7ZKAUJUUUUU529EdanIXcx71UUUUU7v73 VFW2AGmfu7bjvjm3AaLaJ3UbIYCTnIWIevJa73UjIFyTuYvjxU6DGOUUUUU X-Originating-IP: [166.111.70.19] X-CM-SenderInfo: xedlyx5dmximizq6il2tof0z/1tbiHhjtelSIVaaKuQAAsN Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 648 Lines: 23 On 06/05/2017 04:25 PM, Richard Weinberger wrote: > Jia-Ju Bai, > > Am 05.06.2017 um 05:38 schrieb Jia-Ju Bai: >> The driver may sleep under a spin lock, and the function call path is: >> ubifs_change_lp (acquire the lock by spin_lock) >> change_category >> ubifs_remove_from_cat >> remove_from_lpt_heap >> dbg_check_heap >> ubifs_lpt_lookup >> ubifs_read_nnode >> kzalloc(GFP_NOFS) --> may sleep >> >> To fix it, "GFP_NOFS" is replaced with "GFP_ATOMIC". > So, this happens only when dbg_check_heap() is activated, right? > > Thanks, > //richard Yes, I think so. Thanks, Jia-Ju Bai