• S
    NFS: Adjust fs_context error logging · b43da565
    Scott Mayhew 提交于
    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>
    b43da565
nfs4super.c 6.9 KB