Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp4715770imm; Tue, 9 Oct 2018 04:15:34 -0700 (PDT) X-Google-Smtp-Source: ACcGV63G3+YowqCxrTLlAiEPs6drQK1K5gm5ToGOnemINKoBNm+IXbClE0PlApm7WXGEJYDZcig1 X-Received: by 2002:a63:682:: with SMTP id 124-v6mr19857826pgg.52.1539083734008; Tue, 09 Oct 2018 04:15:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539083733; cv=none; d=google.com; s=arc-20160816; b=PJluEvWlAhWhrHkKzsqTLSrNiZn3AT3pvA3gdUIgKdSezUNT9XQ8CbrDQM2Sa0mSW2 fTMY1vmo+R74E/zaXsJiARj/1HBc50jFppSCRWgX40f5Z2bFi8jptg/aYdBSIC5G9eD1 xz7t84vEyuceKRxGi5nR86a8v94i3AkvqXibzaperB6TqoPcKqZJKDfrTTLfD4raKt7/ RZA2tvrXcRdr9j22fXa5Btq+0DAOndSb/1GquixtttIFO5OGabhkNHgNWOqWIgk2HgiY tBvXpFIIS9Z0f8mJowcFrgFGBVzex1hteQ1/Z82tthrqqQCWq7NWr/Up9t1RdS/8HP8V SwKg== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=AYVRZNNBiLGoGN7ee6jJBIiPOJAQ8oCo8VOfejch4uU=; b=eTWHigB4qu/cBydgQ2CIM1/85JfxxrphJ8HeaSTI/Kkm1JLdOuETQOiuFF8R2jy9zI 5rZlpxFONF1ylSMAXTWrw41OK6G4dX+zESBjtlfFVgD9s+FNpPviRB3zTgKDlkf9+Ugn RKob+JVYJM7abLsJC9zpE6ggzn7tnRv/rY0e+/syb9qW/PWxNoJr8iOPhAcY8gwxKp3G 5tlCykIIjY8WySpwVlYieA1Lt3kxqmuopHghywT8NfNQZvFj7wTnihnbstnhqqTSFD79 jk9NK8TAKQU4LnUy79UU3MB3V4FYHJCJcdpOFoQXuNgZZers1e5Hwe4ktp0DoyOx6/J/ zBKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=bUIxXt4N; 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 k22-v6si20290262pgh.340.2018.10.09.04.15.19; Tue, 09 Oct 2018 04:15:33 -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; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=bUIxXt4N; 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 S1726990AbeJIS35 (ORCPT + 99 others); Tue, 9 Oct 2018 14:29:57 -0400 Received: from mail-pl1-f195.google.com ([209.85.214.195]:40718 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726923AbeJIS35 (ORCPT ); Tue, 9 Oct 2018 14:29:57 -0400 Received: by mail-pl1-f195.google.com with SMTP id 1-v6so667644plv.7 for ; Tue, 09 Oct 2018 04:13:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lightnvm-io.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=AYVRZNNBiLGoGN7ee6jJBIiPOJAQ8oCo8VOfejch4uU=; b=bUIxXt4Nz+3DxXDiFwyHugI/mcQCkIzFhOAj3gLrGA6nGNDITCnTgQJjJ7DMFCD71M U5e8s4xN08HS/glgGE9tc0MgYF6QYoksFNM/U1yScZJbS+ikUuZUfakfbXDhe8uxKZ8P QcWFlaiVs4+bdeaTWNCS3xrfdK6v7qoxAPya/6TJKEp59u17LPjgioyffxwxitAsOVd5 xhv4+oYv04L+7kJHM+1aeX+6sYtlTcv0XDDF7aBFCLztaX/azlEn47KVIpkivBP0unAd alZTV/AVe9oVyrf9h/qP0oxVxUrudXN39Mf2qXBXmgtdYS2j5n398Bh79Qp8g16rtCHJ CyeA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=AYVRZNNBiLGoGN7ee6jJBIiPOJAQ8oCo8VOfejch4uU=; b=c621XBy61YrKUqhD6JlLfq4P5cXaqWqUNESdzB1VKMVfQJiMnPaQou7h2Nc0Rywuu1 gog7KD/JuYNAQ8xmefAQqEKvIr2XHezOoJXk9n3x+6WChHZ5sTL+VsUc9iS7XYyIiI7h MQwZTreucHCJIAOjjJvvFWDPXzVPTsSE35WdHVxrrJKRK/dCECCksqT8V3T3n+UQa1qE YiKL8CmVlgV0ChNc4V5XIEe+9VK6/haqOOcxQzQYer8lA1+Lj1JjfLElYPIWtjJw9MuL ZTRtHY4Bmkp/hRqX8c52vDHyQu8kr1J+Ia9zG2TFLSBep1STRgZmu/231BhINfEwlHo0 YfKQ== X-Gm-Message-State: ABuFfoienc71QoWZEPXKYv3kBeV5IKaHGsgGV9+iZIQ9CK8xNX1z0A5m W8AeIdqhHERi06rtSxv4oQiSVw== X-Received: by 2002:a17:902:5590:: with SMTP id g16-v6mr27914511pli.46.1539083610996; Tue, 09 Oct 2018 04:13:30 -0700 (PDT) Received: from skyninja.hgst.com (rap-us.hgst.com. [199.255.44.250]) by smtp.gmail.com with ESMTPSA id p1-v6sm25342380pff.128.2018.10.09.04.13.27 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 09 Oct 2018 04:13:29 -0700 (PDT) From: =?UTF-8?q?Matias=20Bj=C3=B8rling?= To: axboe@fb.com Cc: linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, =?UTF-8?q?Javier=20Gonz=C3=A1lez?= , =?UTF-8?q?Javier=20Gonz=C3=A1lez?= , =?UTF-8?q?Matias=20Bj=C3=B8rling?= Subject: [GIT PULL 05/45] lightnvm: pblk: fix race condition on metadata I/O Date: Tue, 9 Oct 2018 13:11:35 +0200 Message-Id: <20181009111215.7653-6-mb@lightnvm.io> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181009111215.7653-1-mb@lightnvm.io> References: <20181009111215.7653-1-mb@lightnvm.io> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Javier González In pblk, when a new line is allocated, metadata for the previously written line is scheduled. This is done through a fixed memory region that is shared through time and contexts across different lines and therefore protected by a lock. Unfortunately, this lock is not properly covering all the metadata used for sharing this memory regions, resulting in a race condition. This patch fixes this race condition by protecting this metadata properly. Fixes: dd2a43437337 ("lightnvm: pblk: sched. metadata on write thread") Signed-off-by: Javier González Signed-off-by: Matias Bjørling --- drivers/lightnvm/pblk-write.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/drivers/lightnvm/pblk-write.c b/drivers/lightnvm/pblk-write.c index 508c63701eda..df99c45778d4 100644 --- a/drivers/lightnvm/pblk-write.c +++ b/drivers/lightnvm/pblk-write.c @@ -417,12 +417,11 @@ int pblk_submit_meta_io(struct pblk *pblk, struct pblk_line *meta_line) rqd->ppa_list[i] = addr_to_gen_ppa(pblk, paddr, id); } + spin_lock(&l_mg->close_lock); emeta->mem += rq_len; - if (emeta->mem >= lm->emeta_len[0]) { - spin_lock(&l_mg->close_lock); + if (emeta->mem >= lm->emeta_len[0]) list_del(&meta_line->list); - spin_unlock(&l_mg->close_lock); - } + spin_unlock(&l_mg->close_lock); pblk_down_page(pblk, rqd->ppa_list, rqd->nr_ppas); @@ -491,14 +490,15 @@ static struct pblk_line *pblk_should_submit_meta_io(struct pblk *pblk, struct pblk_line *meta_line; spin_lock(&l_mg->close_lock); -retry: if (list_empty(&l_mg->emeta_list)) { spin_unlock(&l_mg->close_lock); return NULL; } meta_line = list_first_entry(&l_mg->emeta_list, struct pblk_line, list); - if (meta_line->emeta->mem >= lm->emeta_len[0]) - goto retry; + if (meta_line->emeta->mem >= lm->emeta_len[0]) { + spin_unlock(&l_mg->close_lock); + return NULL; + } spin_unlock(&l_mg->close_lock); if (!pblk_valid_meta_ppa(pblk, meta_line, data_rqd)) -- 2.17.1