Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3780500imm; Mon, 20 Aug 2018 04:45:01 -0700 (PDT) X-Google-Smtp-Source: AA+uWPzTzMjBNV9/mILrJmC9OwZtxJXOp8Icb8iwe+urNxmkpVoIhEMa9e6n+BzHI1YYpPRYxvJs X-Received: by 2002:a62:1756:: with SMTP id 83-v6mr48516834pfx.217.1534765501552; Mon, 20 Aug 2018 04:45:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534765501; cv=none; d=google.com; s=arc-20160816; b=uDjDd0tKQPUDOoDCAfzKUhmxhL28LoXILptVoZkcAy7WFRHi04GWoUPoI4+W37egpn 0DCaYDaOotQqoblitQO2QIKcC6txHaNkzz2uFTcXRpPpXlsUxarW+pOsnuaPUZnLTY09 +HtPY0utnPpphMy/HH3c5/d60kb205x2ixbHV95ucGqCBnoxMml8bdRFgYlyZ+uCp4Ue 69V2QxRFY9NTNH6uwAHkqBI5nfvHsACw/f0lFg1BkCjgDjod/y9a/0yI3yqiYGHn3v0j 3b970s6w34jwMXpClgpt2Th1LOy/t1qzbZTX+2t21yiNsrktbA8EiRFT1vtpmxNQ222a 2fBA== 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 :message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=Iun9iKLkriRSJZS1TokO8ENAazUqaQVi8hlmEjAFGIo=; b=Pc0M3B/ElZBhI+onTN5PBY3zPxF1Igr5PS76FUQkw/aMiATrk4Y6DW+6bXt+YiarxG NOBcOjQFOqF8pAo1tUZTzC5fD3pd1xBRmy6xRpe2r9T01I0GDfSQla1vsw0e2P51Nnla ySJr/53g07lDc4KWBpjnRNHwdJvH5fEcw8jMicqdOr4HyF/Vn76eBpCyd97OwXT96ejt kQkaHGQdOXu3LjZq3R+8njUtm9WFAfObMUqVbPvpr2lq7SYvYLWtkckuLYd1GJO7ciN3 FOHz41/qzaWiqVxX8wgUl2saX8aQBciH3WDprnTQFhL2EpI3/ycGPvKzoVipXrBbSaN9 oKvg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b="iNS4O6M/"; 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 f62-v6si9993035pfg.165.2018.08.20.04.44.46; Mon, 20 Aug 2018 04:45:01 -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="iNS4O6M/"; 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 S1726586AbeHTO64 (ORCPT + 99 others); Mon, 20 Aug 2018 10:58:56 -0400 Received: from mail-lf1-f67.google.com ([209.85.167.67]:36064 "EHLO mail-lf1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726221AbeHTO64 (ORCPT ); Mon, 20 Aug 2018 10:58:56 -0400 Received: by mail-lf1-f67.google.com with SMTP id c21-v6so860414lfh.3 for ; Mon, 20 Aug 2018 04:43:38 -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:mime-version :content-transfer-encoding; bh=Iun9iKLkriRSJZS1TokO8ENAazUqaQVi8hlmEjAFGIo=; b=iNS4O6M//MTbaQ9boaKAHC5eJnKyB2aTT+13OsfNNoJDPxSRh3vfewZGc5f65f1LZC p79/fQi/5C0fxggN5KC4tmaYOaBjhSK4e1ze/1nlunpte5+h8eIvLWo2dwr+J7fBGpRr lnCwh5w9VzTQdK6lkYcZImcxEUiv39Pnsu/L9RMv4bX0flPWDh+mW04aQ+v1nUVoMpH0 HBPIDYJKHPFLeh391OZV6xH6JtaEvG02R0B5IJISypg7OTNF0zhib4dpu8tMv5NG52dW sQF6sSHPXVACOTAWJ3XAdY43D578/YUcKw/6nDTWzFB/WGlmlBidg01jUVFBPw6s92pv thlQ== 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:mime-version :content-transfer-encoding; bh=Iun9iKLkriRSJZS1TokO8ENAazUqaQVi8hlmEjAFGIo=; b=bCuGwSuhtrp0vxllo2N2mrDnrti9ZcuV12uChGmvqfGaNiaqk0JrZvOTajgsGrOaug v5wLFLkRjPrnIo5uYybJJ+hGFidwboYKHmNn5mNtMB3i/d5fxhFCsq25Z/VPxnfolKF9 W9ZsyRbRPpjKYJJiTXWqCGZci7MUPcd/1IRMZskpT9Q/h0A/lwqNWAYq6vwlc9IH5ap4 716K6MsEbqoN4WB/gWaECk02gAJ6kLdjophtYi6wTVfir4Y1hpQWadlmIK0+2CwHkIg0 SKqxVkJTk6yPGgYE+0Yd0nLtPqkrxQrHFJxrnoxt+2V8yScPxxAoefcaTl1iMGlzLXcm 5bdg== X-Gm-Message-State: AOUpUlGZ2DjbEIg14IYDCGu72n2NmtVY4XbiuWVDylBFPVuSeUsL7vei e+SmoFkNgmiHPVHUOoRa4P+4YA== X-Received: by 2002:a19:7d84:: with SMTP id y126-v6mr4663685lfc.94.1534765417449; Mon, 20 Aug 2018 04:43:37 -0700 (PDT) Received: from localhost.localdomain (95-166-82-66-cable.dk.customer.tdc.net. [95.166.82.66]) by smtp.gmail.com with ESMTPSA id q73-v6sm1759529lfi.86.2018.08.20.04.43.35 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 20 Aug 2018 04:43:36 -0700 (PDT) From: =?UTF-8?q?Matias=20Bj=C3=B8rling?= To: igor.j.konopko@intel.com, marcin.dziegielewski@intel.com, javier@cnexlabs.com, hans.holmberg@cnexlabs.com, hlitz@ucsc.edu, youngtack.jin@circuitblvd.com Cc: linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, =?UTF-8?q?Matias=20Bj=C3=B8rling?= Subject: [PATCH] lightnvm: pblk: refactor put line fn on read completion Date: Mon, 20 Aug 2018 13:43:20 +0200 Message-Id: <20180820114320.3764-1-mb@lightnvm.io> X-Mailer: git-send-email 2.11.0 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 The read completion path uses the put_line variable to decide whether the reference on a line should be released. The function name used for that is pblk_read_put_rqd_kref, which could lead one to believe that it is the rqd that is releasing the reference, while it is the line reference that is put. Rename and also split the function in two to account for either rqd or single ppa callers. Signed-off-by: Matias Bjørling --- drivers/lightnvm/pblk-read.c | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/drivers/lightnvm/pblk-read.c b/drivers/lightnvm/pblk-read.c index cd2f61eed6a0..16858eaf694a 100644 --- a/drivers/lightnvm/pblk-read.c +++ b/drivers/lightnvm/pblk-read.c @@ -165,20 +165,23 @@ static void pblk_read_check_rand(struct pblk *pblk, struct nvm_rq *rqd, WARN_ONCE(j != rqd->nr_ppas, "pblk: corrupted random request\n"); } -static void pblk_read_put_rqd_kref(struct pblk *pblk, struct nvm_rq *rqd) +static void __pblk_read_put_line(struct pblk *pblk, struct ppa_addr ppa) { - struct ppa_addr *ppa_list; - int i; - - ppa_list = (rqd->nr_ppas > 1) ? rqd->ppa_list : &rqd->ppa_addr; - - for (i = 0; i < rqd->nr_ppas; i++) { - struct ppa_addr ppa = ppa_list[i]; struct pblk_line *line; line = &pblk->lines[pblk_ppa_to_line(ppa)]; kref_put(&line->ref, pblk_line_put_wq); - } +} + +static void pblk_read_put_line(struct pblk *pblk, struct nvm_rq *rqd) +{ + struct ppa_addr *ppa_list; + int i; + + ppa_list = (rqd->nr_ppas > 1) ? rqd->ppa_list : &rqd->ppa_addr; + + for (i = 0; i < rqd->nr_ppas; i++) + __pblk_read_put_line(pblk, ppa_list[i]); } static void pblk_end_user_read(struct bio *bio) @@ -208,7 +211,7 @@ static void __pblk_end_io_read(struct pblk *pblk, struct nvm_rq *rqd, bio_put(int_bio); if (put_line) - pblk_read_put_rqd_kref(pblk, rqd); + pblk_read_put_line(pblk, rqd); #ifdef CONFIG_NVM_PBLK_DEBUG atomic_long_add(rqd->nr_ppas, &pblk->sync_reads); -- 2.11.0