Commit af887e43 authored by Trond Myklebust's avatar Trond Myklebust

NFS: Improve write error tracing

Don't leak request pointers, but use the "device:inode" labelling that
is used by all the other trace points. Furthermore, replace use of page
indexes with an offset, again in order to align behaviour with other
NFS trace points.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent 3c59366c
...@@ -1447,44 +1447,50 @@ TRACE_EVENT(nfs_writeback_done, ...@@ -1447,44 +1447,50 @@ TRACE_EVENT(nfs_writeback_done,
DECLARE_EVENT_CLASS(nfs_page_error_class, DECLARE_EVENT_CLASS(nfs_page_error_class,
TP_PROTO( TP_PROTO(
const struct inode *inode,
const struct nfs_page *req, const struct nfs_page *req,
int error int error
), ),
TP_ARGS(req, error), TP_ARGS(inode, req, error),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(const void *, req) __field(dev_t, dev)
__field(pgoff_t, index) __field(u32, fhandle)
__field(unsigned int, offset) __field(u64, fileid)
__field(unsigned int, pgbase) __field(loff_t, offset)
__field(unsigned int, bytes) __field(unsigned int, count)
__field(int, error) __field(int, error)
), ),
TP_fast_assign( TP_fast_assign(
__entry->req = req; const struct nfs_inode *nfsi = NFS_I(inode);
__entry->index = req->wb_index; __entry->dev = inode->i_sb->s_dev;
__entry->offset = req->wb_offset; __entry->fileid = nfsi->fileid;
__entry->pgbase = req->wb_pgbase; __entry->fhandle = nfs_fhandle_hash(&nfsi->fh);
__entry->bytes = req->wb_bytes; __entry->offset = req_offset(req);
__entry->count = req->wb_bytes;
__entry->error = error; __entry->error = error;
), ),
TP_printk( TP_printk(
"req=%p index=%lu offset=%u pgbase=%u bytes=%u error=%d", "error=%d fileid=%02x:%02x:%llu fhandle=0x%08x "
__entry->req, __entry->index, __entry->offset, "offset=%lld count=%u", __entry->error,
__entry->pgbase, __entry->bytes, __entry->error MAJOR(__entry->dev), MINOR(__entry->dev),
(unsigned long long)__entry->fileid,
__entry->fhandle, __entry->offset,
__entry->count
) )
); );
#define DEFINE_NFS_PAGEERR_EVENT(name) \ #define DEFINE_NFS_PAGEERR_EVENT(name) \
DEFINE_EVENT(nfs_page_error_class, name, \ DEFINE_EVENT(nfs_page_error_class, name, \
TP_PROTO( \ TP_PROTO( \
const struct inode *inode, \
const struct nfs_page *req, \ const struct nfs_page *req, \
int error \ int error \
), \ ), \
TP_ARGS(req, error)) TP_ARGS(inode, req, error))
DEFINE_NFS_PAGEERR_EVENT(nfs_write_error); DEFINE_NFS_PAGEERR_EVENT(nfs_write_error);
DEFINE_NFS_PAGEERR_EVENT(nfs_comp_error); DEFINE_NFS_PAGEERR_EVENT(nfs_comp_error);
......
...@@ -592,7 +592,8 @@ nfs_lock_and_join_requests(struct page *page) ...@@ -592,7 +592,8 @@ nfs_lock_and_join_requests(struct page *page)
static void nfs_write_error(struct nfs_page *req, int error) static void nfs_write_error(struct nfs_page *req, int error)
{ {
trace_nfs_write_error(req, error); trace_nfs_write_error(page_file_mapping(req->wb_page)->host, req,
error);
nfs_mapping_set_error(req->wb_page, error); nfs_mapping_set_error(req->wb_page, error);
nfs_inode_remove_request(req); nfs_inode_remove_request(req);
nfs_end_page_writeback(req); nfs_end_page_writeback(req);
...@@ -1000,7 +1001,7 @@ static void nfs_write_completion(struct nfs_pgio_header *hdr) ...@@ -1000,7 +1001,7 @@ static void nfs_write_completion(struct nfs_pgio_header *hdr)
nfs_list_remove_request(req); nfs_list_remove_request(req);
if (test_bit(NFS_IOHDR_ERROR, &hdr->flags) && if (test_bit(NFS_IOHDR_ERROR, &hdr->flags) &&
(hdr->good_bytes < bytes)) { (hdr->good_bytes < bytes)) {
trace_nfs_comp_error(req, hdr->error); trace_nfs_comp_error(hdr->inode, req, hdr->error);
nfs_mapping_set_error(req->wb_page, hdr->error); nfs_mapping_set_error(req->wb_page, hdr->error);
goto remove_req; goto remove_req;
} }
...@@ -1882,7 +1883,8 @@ static void nfs_commit_release_pages(struct nfs_commit_data *data) ...@@ -1882,7 +1883,8 @@ static void nfs_commit_release_pages(struct nfs_commit_data *data)
(long long)req_offset(req)); (long long)req_offset(req));
if (status < 0) { if (status < 0) {
if (req->wb_page) { if (req->wb_page) {
trace_nfs_commit_error(req, status); trace_nfs_commit_error(data->inode, req,
status);
nfs_mapping_set_error(req->wb_page, status); nfs_mapping_set_error(req->wb_page, status);
nfs_inode_remove_request(req); nfs_inode_remove_request(req);
} }
......
...@@ -202,8 +202,7 @@ nfs_list_entry(struct list_head *head) ...@@ -202,8 +202,7 @@ nfs_list_entry(struct list_head *head)
return list_entry(head, struct nfs_page, wb_list); return list_entry(head, struct nfs_page, wb_list);
} }
static inline static inline loff_t req_offset(const struct nfs_page *req)
loff_t req_offset(struct nfs_page *req)
{ {
return (((loff_t)req->wb_index) << PAGE_SHIFT) + req->wb_offset; return (((loff_t)req->wb_index) << PAGE_SHIFT) + req->wb_offset;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment