Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751641AbaK0QNv (ORCPT ); Thu, 27 Nov 2014 11:13:51 -0500 Received: from a.ns.miles-group.at ([95.130.255.143]:65275 "EHLO radon.swed.at" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751035AbaK0QNt (ORCPT ); Thu, 27 Nov 2014 11:13:49 -0500 Message-ID: <54774DB7.5090200@nod.at> Date: Thu, 27 Nov 2014 17:13:43 +0100 From: Richard Weinberger User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.1.0 MIME-Version: 1.0 To: dedekind1@gmail.com CC: linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/6] UBI: Fastmap: Ensure that only one fastmap work is scheduled References: <1416835236-25185-1-git-send-email-richard@nod.at> <1416835236-25185-3-git-send-email-richard@nod.at> <1417102042.5858.102.camel@sauron.fi.intel.com> In-Reply-To: <1417102042.5858.102.camel@sauron.fi.intel.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am 27.11.2014 um 16:27 schrieb Artem Bityutskiy: > On Mon, 2014-11-24 at 14:20 +0100, Richard Weinberger wrote: >> If the WL pool runs out of PEBs we schedule a fastmap write >> to refill it as soon as possible. >> Ensure that only one at a time is scheduled otherwise we might end in >> a fastmap write storm because writing the fastmap can schedule another >> write if bitflips are detected. > > Could you please provide some more details about the "write storm". Does > it happen when there are 2 fastmap works in the queue? Or if they run > simultaneously? Why the storm happens and white kind of "writes" it > consists of? If UBI needs to write a new fastmap while wear leveling (by using get_peb_for_wl()) a fastmap work is scheduled. We cannot write a fastmap in this context because we're in atomic context. At this point one fastmap write is scheduled. If now get_peb_for_wl() is executed a second time it will schedule another fastmap work because the pools are still not refilled. This will go on until finally a fastmap got written. Either by the the kworker or ubi_wl_get_peb(). As now a lot of fastmap works are scheduled they all will be issues in series. Hence, a write storm. :) Thanks, //richard -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/