Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp346844pxj; Fri, 28 May 2021 05:32:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwRWTTuvxjiWq9GvlILHdO+OQYObgKKgyDeDmgARfDdMUCjv55oYolZKRrz69MdmDryHyIR X-Received: by 2002:a17:906:b191:: with SMTP id w17mr8814315ejy.200.1622205143606; Fri, 28 May 2021 05:32:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622205143; cv=none; d=google.com; s=arc-20160816; b=ujxRzHw7gvJHrw2kqvaNuoP9R1iCx6rxOfKkuAGFqlmfCsgz4SzF+ZtcAxCGYRhGq1 24IiLLGf+uYZ6ndE8xqsLA/UhtjQWJQK7UUHOsnlsbJ8YoNhyI2WQvuiu/PGPJ6B2us9 X39E+vvr9SXnIslFiSgSjzcDQlJ3t9SrkLgcPVZcsCVhrc1D4ySCXJ0Idjwn/7AOOfpJ uVZBEq75FK70GJub6r+lt+a3nY8+OHTeNwn29A0o1N40yvRqj2ymhnR7DpwGG0trwnVV b9XrPAJy+elghw4YwiTkqSczmd6Swg8kZh7U4O6/Eq1mySLK53U2FpDDp6XlJLCWzOKd 8+oA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=JVweKyGZbmvQGtm/+2AfPRRClEkg6JoF73VnWA8CxCY=; b=zgJJU+3hQ5wUPFywnIBwo3xwGi5IbDKtrHqTSivKbkOCE26nCQt2d2SJ6AlZ9EeNzh GP4bVmi6RPQL7NLKUvQW8bI+R9lQNhNsl+QFNY6x/8Lh1qLTU//ydZ1pkj56i+VKzfWt UakX5f7bFhxRjNPcWybdoIURYxdNbEDiXWBZ2BZUXl6ZZ43C6D9QFAIUgmnyWEBDuEX6 ce8bhZXmwA6scODeAJX2h34O20eYAdif541VJ1Rm99U+gF+yzT88QpPzMoi4WArCtZ/l WTz5YrzUNsFakoSdsWuTGuaM9cSlsn/cyIR9Lg/tH76/5Iw2CU6wmZeLezpKt7MjJu1Z WOYg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l16si4415393eds.512.2021.05.28.05.32.00; Fri, 28 May 2021 05:32:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235523AbhE1Llw (ORCPT + 99 others); Fri, 28 May 2021 07:41:52 -0400 Received: from foss.arm.com ([217.140.110.172]:39654 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233583AbhE1Llu (ORCPT ); Fri, 28 May 2021 07:41:50 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0A0241516; Fri, 28 May 2021 04:40:16 -0700 (PDT) Received: from entos-ampere-02.shanghai.arm.com (entos-ampere-02.shanghai.arm.com [10.169.214.103]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id CA0963F73B; Fri, 28 May 2021 04:40:09 -0700 (PDT) From: Jia He To: Linus Torvalds , Petr Mladek , Steven Rostedt , Sergey Senozhatsky , Andy Shevchenko , Rasmus Villemoes , Jonathan Corbet , Alexander Viro , Luca Coelho , Kalle Valo , "David S. Miller" , Jakub Kicinski , Heiko Carstens , Vasily Gorbik Cc: Christian Borntraeger , Johannes Berg , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-s390@vger.kernel.org, Jia He Subject: [PATCH RFCv2 1/3] fs: introduce helper d_path_fast() Date: Fri, 28 May 2021 19:39:49 +0800 Message-Id: <20210528113951.6225-2-justin.he@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210528113951.6225-1-justin.he@arm.com> References: <20210528113951.6225-1-justin.he@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org This helper is similar to d_path except that it doesn't take any seqlock/spinlock. It is typical for debugging purpose. Signed-off-by: Jia He --- fs/d_path.c | 21 +++++++++++++++++++++ include/linux/dcache.h | 1 + 2 files changed, 22 insertions(+) diff --git a/fs/d_path.c b/fs/d_path.c index 23a53f7b5c71..f9df68d62786 100644 --- a/fs/d_path.c +++ b/fs/d_path.c @@ -263,6 +263,27 @@ char *d_path(const struct path *path, char *buf, int buflen) } EXPORT_SYMBOL(d_path); +/** + * d_path_fast - fast return the full path of a dentry without taking + * any seqlock/spinlock. This helper is typical for debugging purpose + */ +char *d_path_fast(const struct path *path, char *buf, int buflen) +{ + struct path root; + struct mount *mnt = real_mount(path->mnt); + DECLARE_BUFFER(b, buf, buflen); + + rcu_read_lock(); + get_fs_root_rcu(current->fs, &root); + + prepend(&b, "", 1); + __prepend_path(path->dentry, mnt, &root, &b); + rcu_read_unlock(); + + return extract_string(&b); +} +EXPORT_SYMBOL(d_path_fast); + /* * Helper function for dentry_operations.d_dname() members */ diff --git a/include/linux/dcache.h b/include/linux/dcache.h index 9e23d33bb6f1..c4483fc887a5 100644 --- a/include/linux/dcache.h +++ b/include/linux/dcache.h @@ -301,6 +301,7 @@ char *dynamic_dname(struct dentry *, char *, int, const char *, ...); extern char *__d_path(const struct path *, const struct path *, char *, int); extern char *d_absolute_path(const struct path *, char *, int); extern char *d_path(const struct path *, char *, int); +extern char *d_path_fast(const struct path *, char *, int); extern char *dentry_path_raw(const struct dentry *, char *, int); extern char *dentry_path(const struct dentry *, char *, int); -- 2.17.1