提交 b43da565 编写于 作者: S Scott Mayhew 提交者: Zheng Zengkai

NFS: Adjust fs_context error logging

stable inclusion
from stable-5.10.9
commit e6ae16467af19d2572a48af59946223bd089a06e
bugzilla: 47457

--------------------------------

commit c98e9daa upstream.

Several existing dprink()/dfprintk() calls were converted to use the new
mount API logging macros by commit ce8866f0 ("NFS: Attach
supplementary error information to fs_context").  If the fs_context was
not created using fsopen() then it will not have had a log buffer
allocated for it, and the new mount API logging macros will wind up
calling printk().

This can result in syslog messages being logged where previously there
were none... most notably "NFS4: Couldn't follow remote path", which can
happen if the client is auto-negotiating a protocol version with an NFS
server that doesn't support the higher v4.x versions.

Convert the nfs_errorf(), nfs_invalf(), and nfs_warnf() macros to check
for the existence of the fs_context's log buffer and call dprintk() if
it doesn't exist.  Add nfs_ferrorf(), nfs_finvalf(), and nfs_warnf(),
which do the same thing but take an NFS debug flag as an argument and
call dfprintk().  Finally, modify the "NFS4: Couldn't follow remote
path" message to use nfs_ferrorf().

Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=207385Signed-off-by: NScott Mayhew <smayhew@redhat.com>
Reviewed-by: NBenjamin Coddington <bcodding@redhat.com>
Fixes: ce8866f0 ("NFS: Attach supplementary error information to fs_context.")
Signed-off-by: NTrond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: NChen Jun <chenjun102@huawei.com>
Acked-by: NXie XiuQi <xiexiuqi@huawei.com>
上级 105b13bd
...@@ -142,9 +142,29 @@ struct nfs_fs_context { ...@@ -142,9 +142,29 @@ struct nfs_fs_context {
} clone_data; } clone_data;
}; };
#define nfs_errorf(fc, fmt, ...) errorf(fc, fmt, ## __VA_ARGS__) #define nfs_errorf(fc, fmt, ...) ((fc)->log.log ? \
#define nfs_invalf(fc, fmt, ...) invalf(fc, fmt, ## __VA_ARGS__) errorf(fc, fmt, ## __VA_ARGS__) : \
#define nfs_warnf(fc, fmt, ...) warnf(fc, fmt, ## __VA_ARGS__) ({ dprintk(fmt "\n", ## __VA_ARGS__); }))
#define nfs_ferrorf(fc, fac, fmt, ...) ((fc)->log.log ? \
errorf(fc, fmt, ## __VA_ARGS__) : \
({ dfprintk(fac, fmt "\n", ## __VA_ARGS__); }))
#define nfs_invalf(fc, fmt, ...) ((fc)->log.log ? \
invalf(fc, fmt, ## __VA_ARGS__) : \
({ dprintk(fmt "\n", ## __VA_ARGS__); -EINVAL; }))
#define nfs_finvalf(fc, fac, fmt, ...) ((fc)->log.log ? \
invalf(fc, fmt, ## __VA_ARGS__) : \
({ dfprintk(fac, fmt "\n", ## __VA_ARGS__); -EINVAL; }))
#define nfs_warnf(fc, fmt, ...) ((fc)->log.log ? \
warnf(fc, fmt, ## __VA_ARGS__) : \
({ dprintk(fmt "\n", ## __VA_ARGS__); }))
#define nfs_fwarnf(fc, fac, fmt, ...) ((fc)->log.log ? \
warnf(fc, fmt, ## __VA_ARGS__) : \
({ dfprintk(fac, fmt "\n", ## __VA_ARGS__); }))
static inline struct nfs_fs_context *nfs_fc2context(const struct fs_context *fc) static inline struct nfs_fs_context *nfs_fc2context(const struct fs_context *fc)
{ {
......
...@@ -227,7 +227,7 @@ int nfs4_try_get_tree(struct fs_context *fc) ...@@ -227,7 +227,7 @@ int nfs4_try_get_tree(struct fs_context *fc)
fc, ctx->nfs_server.hostname, fc, ctx->nfs_server.hostname,
ctx->nfs_server.export_path); ctx->nfs_server.export_path);
if (err) { if (err) {
nfs_errorf(fc, "NFS4: Couldn't follow remote path"); nfs_ferrorf(fc, MOUNT, "NFS4: Couldn't follow remote path");
dfprintk(MOUNT, "<-- nfs4_try_get_tree() = %d [error]\n", err); dfprintk(MOUNT, "<-- nfs4_try_get_tree() = %d [error]\n", err);
} else { } else {
dfprintk(MOUNT, "<-- nfs4_try_get_tree() = 0\n"); dfprintk(MOUNT, "<-- nfs4_try_get_tree() = 0\n");
...@@ -250,7 +250,7 @@ int nfs4_get_referral_tree(struct fs_context *fc) ...@@ -250,7 +250,7 @@ int nfs4_get_referral_tree(struct fs_context *fc)
fc, ctx->nfs_server.hostname, fc, ctx->nfs_server.hostname,
ctx->nfs_server.export_path); ctx->nfs_server.export_path);
if (err) { if (err) {
nfs_errorf(fc, "NFS4: Couldn't follow remote path"); nfs_ferrorf(fc, MOUNT, "NFS4: Couldn't follow remote path");
dfprintk(MOUNT, "<-- nfs4_get_referral_tree() = %d [error]\n", err); dfprintk(MOUNT, "<-- nfs4_get_referral_tree() = %d [error]\n", err);
} else { } else {
dfprintk(MOUNT, "<-- nfs4_get_referral_tree() = 0\n"); dfprintk(MOUNT, "<-- nfs4_get_referral_tree() = 0\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册