Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp575307imm; Fri, 1 Jun 2018 06:10:33 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLnK8SivVatX4LeLreoCTdbB4pVVDCnVdh22K6F5v4WiE3fhA11yCM+WXHeGskBAYIpbx+1 X-Received: by 2002:a63:7905:: with SMTP id u5-v6mr8788695pgc.411.1527858633831; Fri, 01 Jun 2018 06:10:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527858633; cv=none; d=google.com; s=arc-20160816; b=qbB7QDBM/AE0k/8It5pXm3gFB76Ty0p0dBxoaIRi9Wz0jzCASNLiq9slf099lkTnM5 e9jxl1EFTJzgStT1XHOC+QhT23RG6ZR/1nrsEhRD+NmLT9u4NSUTh3np2EU5+YvR4yWJ n8rBu5Sv7bF6+AtdrsbkiFjBNiBmhTvix701vR3NDEmr8vs4mi0L3OvlpnonpLEU2rEC /jUNwkBVfeCJ23HwRoWiPtLX4UdjaREd7T3vF9EAVT6xp7fDEKPLCFZUtqZkoD+I5jiC 2XBC3XJSksIwPFx+8ZgFDp3MVg2enGrntJ1+yi4A/tx6V1LbvJYb+00Rs4NtnR9IsXnQ ntzw== 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:arc-authentication-results; bh=j1jR/yf4TRDpRH7GZG8hOJoJU1FY5n4rWM2R2vC+j3w=; b=w7rpdL049V5pGwWpl+O5e8ILS2VJw/eh5EzeLTzeqxH0jLd8DD/cVvLL1t7raY32Jh Ojo2hwADMoCT9+RkpuoJKthl4wRF52Zd/VkJSe/cSQsqW2/C65pQVZ++s6ox2s9Rb7sX PaXCRqWO2mtgzfUsmz1IafhSxuRvoK8s8v/AdPG7YQvxOgwHFyLCs3TC9anIBSidMl+K 8tRGJbcbgs0hpfadBwBzAI1FDA9ynkKEiFR3nCdh6pVX6i18xI3x0S2zWJ8tQeHH9Nm3 NHEq1kp+bZ2zVs9dV2nUKvDUMjOoVL7IdE0JNvHeOXo7pXJDWSbYNGJAzDzcVHls5MtN 1xQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=ggPfcrTV; 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 f26-v6si16681327pgn.247.2018.06.01.06.10.19; Fri, 01 Jun 2018 06:10: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=ggPfcrTV; 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 S1752444AbeFANJP (ORCPT + 99 others); Fri, 1 Jun 2018 09:09:15 -0400 Received: from mail-lf0-f54.google.com ([209.85.215.54]:41140 "EHLO mail-lf0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751733AbeFANEp (ORCPT ); Fri, 1 Jun 2018 09:04:45 -0400 Received: by mail-lf0-f54.google.com with SMTP id d24-v6so14741230lfa.8 for ; Fri, 01 Jun 2018 06:04:45 -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=j1jR/yf4TRDpRH7GZG8hOJoJU1FY5n4rWM2R2vC+j3w=; b=ggPfcrTVT+cKCtb0w65ZOqFyg697cwAUsZ9hasjoJO/luTV3O65rmNPksMvo6zSiKz AnEDMQb/DG3O87OjdA3rneBNG+vO/tq6emT4or2lL2xqjtHQUNg57reOEJJWbV81OHNK NV5ZGEq2QK0CyVg5ZXAHZcOfOGXZ7pd3Y3NRmYkUDRU4g2OKDDbJKUr7jQFyZihOGoBS 20ktwcw78zBg2mz2ZC3huJjY+2zPYMztArQVxApuUGwjpNlp/92tsQrPRusGL7rvqTYX LYjDcrc3+dq81Mngb+KWvNyBj1h6hD0yv04HYNx92z5iUncBMr4sp7yXsd3f2iRgJBby TyoA== 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=j1jR/yf4TRDpRH7GZG8hOJoJU1FY5n4rWM2R2vC+j3w=; b=WY5cg24LSYOSVh1/VJYD3Wyp4XXW3NCqEVds8Uxjb/mMR90sStsH66EqA/MgP9l1WA ilUXYktCUC/IQ935pIsyKFtJyPQNcHX/JMgRSIgyMYuvWMjYZIV6p1u0hYFVY3lStH/s OA13Mf6b6U6AyDDcPOvoG0obI57AmYKCDao2r3xieDtO18mZV3EiqDZ+Z4M+Ea19pOz1 jxq487SipHa0NQC8+2U5rIa9gNvIT0fxmeRMY+Y+a6aNRqlixINyhMsmfXEofnkjrkvS YgaHL2/VPjyv6NZABUuyyrxTGnqSKr7LWh1NoUupR6nepVJAqDwphVYlduntW+70qg6I oQ9A== X-Gm-Message-State: ALKqPwel0ZpGu16csrQ6/DQ0mTcHUo0pBxkND+2yC8AVvfLK2mLOEC+Z uaCAxmgrym19r5WRc+GLawkX+w== X-Received: by 2002:a2e:9cd8:: with SMTP id g24-v6mr8464473ljj.141.1527858284307; Fri, 01 Jun 2018 06:04:44 -0700 (PDT) Received: from Macroninja.cnexlabs.com (95-166-82-66-cable.dk.customer.tdc.net. [95.166.82.66]) by smtp.gmail.com with ESMTPSA id g5-v6sm303161lje.21.2018.06.01.06.04.43 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 01 Jun 2018 06:04:43 -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, javier@cnexlabs.com, igor.j.konopko@intel.com, marcin.dziegielewski@intel.com, =?UTF-8?q?Javier=20Gonz=C3=A1lez?= , =?UTF-8?q?Matias=20Bj=C3=B8rling?= Subject: [GIT PULL 01/18] lightnvm: pblk: fail gracefully on line alloc. failure Date: Fri, 1 Jun 2018 15:04:15 +0200 Message-Id: <20180601130432.30866-2-mb@lightnvm.io> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20180601130432.30866-1-mb@lightnvm.io> References: <20180601130432.30866-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 the event of a line failing to allocate, fail gracefully and stop the pipeline to avoid more write failing in the same place. Signed-off-by: Javier González Signed-off-by: Matias Bjørling --- drivers/lightnvm/pblk-init.c | 5 +++++ drivers/lightnvm/pblk-map.c | 33 ++++++++++++++++++++++++--------- 2 files changed, 29 insertions(+), 9 deletions(-) diff --git a/drivers/lightnvm/pblk-init.c b/drivers/lightnvm/pblk-init.c index 91a5bc2556a3..dee64f91227d 100644 --- a/drivers/lightnvm/pblk-init.c +++ b/drivers/lightnvm/pblk-init.c @@ -1047,6 +1047,11 @@ static int pblk_lines_init(struct pblk *pblk) nr_free_chks += pblk_setup_line_meta(pblk, line, chunk_meta, i); } + if (!nr_free_chks) { + pr_err("pblk: too many bad blocks prevent for sane instance\n"); + return -EINTR; + } + pblk_set_provision(pblk, nr_free_chks); kfree(chunk_meta); diff --git a/drivers/lightnvm/pblk-map.c b/drivers/lightnvm/pblk-map.c index 20dbaa89c9df..953ca31dda68 100644 --- a/drivers/lightnvm/pblk-map.c +++ b/drivers/lightnvm/pblk-map.c @@ -18,11 +18,11 @@ #include "pblk.h" -static void pblk_map_page_data(struct pblk *pblk, unsigned int sentry, - struct ppa_addr *ppa_list, - unsigned long *lun_bitmap, - struct pblk_sec_meta *meta_list, - unsigned int valid_secs) +static int pblk_map_page_data(struct pblk *pblk, unsigned int sentry, + struct ppa_addr *ppa_list, + unsigned long *lun_bitmap, + struct pblk_sec_meta *meta_list, + unsigned int valid_secs) { struct pblk_line *line = pblk_line_get_data(pblk); struct pblk_emeta *emeta; @@ -35,8 +35,14 @@ static void pblk_map_page_data(struct pblk *pblk, unsigned int sentry, if (pblk_line_is_full(line)) { struct pblk_line *prev_line = line; + /* If we cannot allocate a new line, make sure to store metadata + * on current line and then fail + */ line = pblk_line_replace_data(pblk); pblk_line_close_meta(pblk, prev_line); + + if (!line) + return -EINTR; } emeta = line->emeta; @@ -74,6 +80,7 @@ static void pblk_map_page_data(struct pblk *pblk, unsigned int sentry, } pblk_down_rq(pblk, ppa_list, nr_secs, lun_bitmap); + return 0; } void pblk_map_rq(struct pblk *pblk, struct nvm_rq *rqd, unsigned int sentry, @@ -87,8 +94,12 @@ void pblk_map_rq(struct pblk *pblk, struct nvm_rq *rqd, unsigned int sentry, for (i = off; i < rqd->nr_ppas; i += min) { map_secs = (i + min > valid_secs) ? (valid_secs % min) : min; - pblk_map_page_data(pblk, sentry + i, &rqd->ppa_list[i], - lun_bitmap, &meta_list[i], map_secs); + if (pblk_map_page_data(pblk, sentry + i, &rqd->ppa_list[i], + lun_bitmap, &meta_list[i], map_secs)) { + bio_put(rqd->bio); + pblk_free_rqd(pblk, rqd, PBLK_WRITE); + pblk_pipeline_stop(pblk); + } } } @@ -108,8 +119,12 @@ void pblk_map_erase_rq(struct pblk *pblk, struct nvm_rq *rqd, for (i = 0; i < rqd->nr_ppas; i += min) { map_secs = (i + min > valid_secs) ? (valid_secs % min) : min; - pblk_map_page_data(pblk, sentry + i, &rqd->ppa_list[i], - lun_bitmap, &meta_list[i], map_secs); + if (pblk_map_page_data(pblk, sentry + i, &rqd->ppa_list[i], + lun_bitmap, &meta_list[i], map_secs)) { + bio_put(rqd->bio); + pblk_free_rqd(pblk, rqd, PBLK_WRITE); + pblk_pipeline_stop(pblk); + } erase_lun = pblk_ppa_to_pos(geo, rqd->ppa_list[i]); -- 2.11.0