1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* 3 * Copyright (C) 2017-2023 Oracle. All Rights Reserved. 4 * Author: Darrick J. Wong <djwong@kernel.org> 5 * 6 * NOTE: none of these tracepoints shall be considered a stable kernel ABI 7 * as they can change at any time. See xfs_trace.h for documentation of 8 * specific units found in tracepoint output. 9 */ 10 #undef TRACE_SYSTEM 11 #define TRACE_SYSTEM xfs_scrub 12 13 #if !defined(_TRACE_XFS_SCRUB_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) 14 #define _TRACE_XFS_SCRUB_TRACE_H 15 16 #include <linux/tracepoint.h> 17 #include "xfs_bit.h" 18 #include "xfs_quota_defs.h" 19 20 struct xfs_scrub; 21 struct xfile; 22 struct xfarray; 23 struct xfarray_sortinfo; 24 struct xchk_dqiter; 25 struct xchk_iscan; 26 struct xchk_nlink; 27 struct xchk_fscounters; 28 struct xfs_rmap_update_params; 29 struct xfs_parent_rec; 30 enum xchk_dirpath_outcome; 31 struct xchk_dirtree; 32 struct xchk_dirtree_outcomes; 33 34 /* 35 * ftrace's __print_symbolic requires that all enum values be wrapped in the 36 * TRACE_DEFINE_ENUM macro so that the enum value can be encoded in the ftrace 37 * ring buffer. Somehow this was only worth mentioning in the ftrace sample 38 * code. 39 */ 40 TRACE_DEFINE_ENUM(XFS_REFC_DOMAIN_SHARED); 41 TRACE_DEFINE_ENUM(XFS_REFC_DOMAIN_COW); 42 43 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_PROBE); 44 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_SB); 45 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_AGF); 46 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_AGFL); 47 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_AGI); 48 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_BNOBT); 49 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_CNTBT); 50 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_INOBT); 51 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_FINOBT); 52 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_RMAPBT); 53 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_REFCNTBT); 54 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_INODE); 55 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_BMBTD); 56 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_BMBTA); 57 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_BMBTC); 58 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_DIR); 59 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_XATTR); 60 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_SYMLINK); 61 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_PARENT); 62 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_RTBITMAP); 63 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_RTSUM); 64 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_UQUOTA); 65 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_GQUOTA); 66 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_PQUOTA); 67 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_FSCOUNTERS); 68 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_QUOTACHECK); 69 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_NLINKS); 70 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_HEALTHY); 71 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_DIRTREE); 72 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_BARRIER); 73 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_METAPATH); 74 TRACE_DEFINE_ENUM(XFS_SCRUB_TYPE_RGSUPER); 75 76 #define XFS_SCRUB_TYPE_STRINGS \ 77 { XFS_SCRUB_TYPE_PROBE, "probe" }, \ 78 { XFS_SCRUB_TYPE_SB, "sb" }, \ 79 { XFS_SCRUB_TYPE_AGF, "agf" }, \ 80 { XFS_SCRUB_TYPE_AGFL, "agfl" }, \ 81 { XFS_SCRUB_TYPE_AGI, "agi" }, \ 82 { XFS_SCRUB_TYPE_BNOBT, "bnobt" }, \ 83 { XFS_SCRUB_TYPE_CNTBT, "cntbt" }, \ 84 { XFS_SCRUB_TYPE_INOBT, "inobt" }, \ 85 { XFS_SCRUB_TYPE_FINOBT, "finobt" }, \ 86 { XFS_SCRUB_TYPE_RMAPBT, "rmapbt" }, \ 87 { XFS_SCRUB_TYPE_REFCNTBT, "refcountbt" }, \ 88 { XFS_SCRUB_TYPE_INODE, "inode" }, \ 89 { XFS_SCRUB_TYPE_BMBTD, "bmapbtd" }, \ 90 { XFS_SCRUB_TYPE_BMBTA, "bmapbta" }, \ 91 { XFS_SCRUB_TYPE_BMBTC, "bmapbtc" }, \ 92 { XFS_SCRUB_TYPE_DIR, "directory" }, \ 93 { XFS_SCRUB_TYPE_XATTR, "xattr" }, \ 94 { XFS_SCRUB_TYPE_SYMLINK, "symlink" }, \ 95 { XFS_SCRUB_TYPE_PARENT, "parent" }, \ 96 { XFS_SCRUB_TYPE_RTBITMAP, "rtbitmap" }, \ 97 { XFS_SCRUB_TYPE_RTSUM, "rtsummary" }, \ 98 { XFS_SCRUB_TYPE_UQUOTA, "usrquota" }, \ 99 { XFS_SCRUB_TYPE_GQUOTA, "grpquota" }, \ 100 { XFS_SCRUB_TYPE_PQUOTA, "prjquota" }, \ 101 { XFS_SCRUB_TYPE_FSCOUNTERS, "fscounters" }, \ 102 { XFS_SCRUB_TYPE_QUOTACHECK, "quotacheck" }, \ 103 { XFS_SCRUB_TYPE_NLINKS, "nlinks" }, \ 104 { XFS_SCRUB_TYPE_HEALTHY, "healthy" }, \ 105 { XFS_SCRUB_TYPE_DIRTREE, "dirtree" }, \ 106 { XFS_SCRUB_TYPE_BARRIER, "barrier" }, \ 107 { XFS_SCRUB_TYPE_METAPATH, "metapath" }, \ 108 { XFS_SCRUB_TYPE_RGSUPER, "rgsuper" } 109 110 #define XFS_SCRUB_FLAG_STRINGS \ 111 { XFS_SCRUB_IFLAG_REPAIR, "repair" }, \ 112 { XFS_SCRUB_OFLAG_CORRUPT, "corrupt" }, \ 113 { XFS_SCRUB_OFLAG_PREEN, "preen" }, \ 114 { XFS_SCRUB_OFLAG_XFAIL, "xfail" }, \ 115 { XFS_SCRUB_OFLAG_XCORRUPT, "xcorrupt" }, \ 116 { XFS_SCRUB_OFLAG_INCOMPLETE, "incomplete" }, \ 117 { XFS_SCRUB_OFLAG_WARNING, "warning" }, \ 118 { XFS_SCRUB_OFLAG_NO_REPAIR_NEEDED, "norepair" }, \ 119 { XFS_SCRUB_IFLAG_FORCE_REBUILD, "rebuild" } 120 121 #define XFS_SCRUB_STATE_STRINGS \ 122 { XCHK_TRY_HARDER, "try_harder" }, \ 123 { XCHK_HAVE_FREEZE_PROT, "nofreeze" }, \ 124 { XCHK_FSGATES_DRAIN, "fsgates_drain" }, \ 125 { XCHK_NEED_DRAIN, "need_drain" }, \ 126 { XCHK_FSGATES_QUOTA, "fsgates_quota" }, \ 127 { XCHK_FSGATES_DIRENTS, "fsgates_dirents" }, \ 128 { XCHK_FSGATES_RMAP, "fsgates_rmap" }, \ 129 { XREP_RESET_PERAG_RESV, "reset_perag_resv" }, \ 130 { XREP_ALREADY_FIXED, "already_fixed" } 131 132 TRACE_DEFINE_ENUM(XFS_RMAP_MAP); 133 TRACE_DEFINE_ENUM(XFS_RMAP_MAP_SHARED); 134 TRACE_DEFINE_ENUM(XFS_RMAP_UNMAP); 135 TRACE_DEFINE_ENUM(XFS_RMAP_UNMAP_SHARED); 136 TRACE_DEFINE_ENUM(XFS_RMAP_CONVERT); 137 TRACE_DEFINE_ENUM(XFS_RMAP_CONVERT_SHARED); 138 TRACE_DEFINE_ENUM(XFS_RMAP_ALLOC); 139 TRACE_DEFINE_ENUM(XFS_RMAP_FREE); 140 141 DECLARE_EVENT_CLASS(xchk_class, 142 TP_PROTO(struct xfs_inode *ip, struct xfs_scrub_metadata *sm, 143 int error), 144 TP_ARGS(ip, sm, error), 145 TP_STRUCT__entry( 146 __field(dev_t, dev) 147 __field(xfs_ino_t, ino) 148 __field(unsigned int, type) 149 __field(xfs_agnumber_t, agno) 150 __field(xfs_ino_t, inum) 151 __field(unsigned int, gen) 152 __field(unsigned int, flags) 153 __field(int, error) 154 ), 155 TP_fast_assign( 156 __entry->dev = ip->i_mount->m_super->s_dev; 157 __entry->ino = ip->i_ino; 158 __entry->type = sm->sm_type; 159 __entry->agno = sm->sm_agno; 160 __entry->inum = sm->sm_ino; 161 __entry->gen = sm->sm_gen; 162 __entry->flags = sm->sm_flags; 163 __entry->error = error; 164 ), 165 TP_printk("dev %d:%d ino 0x%llx type %s agno 0x%x inum 0x%llx gen 0x%x flags (%s) error %d", 166 MAJOR(__entry->dev), MINOR(__entry->dev), 167 __entry->ino, 168 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 169 __entry->agno, 170 __entry->inum, 171 __entry->gen, 172 __print_flags(__entry->flags, "|", XFS_SCRUB_FLAG_STRINGS), 173 __entry->error) 174 ) 175 #define DEFINE_SCRUB_EVENT(name) \ 176 DEFINE_EVENT(xchk_class, name, \ 177 TP_PROTO(struct xfs_inode *ip, struct xfs_scrub_metadata *sm, \ 178 int error), \ 179 TP_ARGS(ip, sm, error)) 180 181 DEFINE_SCRUB_EVENT(xchk_start); 182 DEFINE_SCRUB_EVENT(xchk_done); 183 DEFINE_SCRUB_EVENT(xchk_deadlock_retry); 184 DEFINE_SCRUB_EVENT(xchk_dirtree_start); 185 DEFINE_SCRUB_EVENT(xchk_dirtree_done); 186 DEFINE_SCRUB_EVENT(xrep_attempt); 187 DEFINE_SCRUB_EVENT(xrep_done); 188 189 DECLARE_EVENT_CLASS(xchk_fsgate_class, 190 TP_PROTO(struct xfs_scrub *sc, unsigned int fsgate_flags), 191 TP_ARGS(sc, fsgate_flags), 192 TP_STRUCT__entry( 193 __field(dev_t, dev) 194 __field(unsigned int, type) 195 __field(unsigned int, fsgate_flags) 196 ), 197 TP_fast_assign( 198 __entry->dev = sc->mp->m_super->s_dev; 199 __entry->type = sc->sm->sm_type; 200 __entry->fsgate_flags = fsgate_flags; 201 ), 202 TP_printk("dev %d:%d type %s fsgates '%s'", 203 MAJOR(__entry->dev), MINOR(__entry->dev), 204 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 205 __print_flags(__entry->fsgate_flags, "|", XFS_SCRUB_STATE_STRINGS)) 206 ) 207 208 #define DEFINE_SCRUB_FSHOOK_EVENT(name) \ 209 DEFINE_EVENT(xchk_fsgate_class, name, \ 210 TP_PROTO(struct xfs_scrub *sc, unsigned int fsgates_flags), \ 211 TP_ARGS(sc, fsgates_flags)) 212 213 DEFINE_SCRUB_FSHOOK_EVENT(xchk_fsgates_enable); 214 DEFINE_SCRUB_FSHOOK_EVENT(xchk_fsgates_disable); 215 216 DECLARE_EVENT_CLASS(xchk_vector_head_class, 217 TP_PROTO(struct xfs_inode *ip, struct xfs_scrub_vec_head *vhead), 218 TP_ARGS(ip, vhead), 219 TP_STRUCT__entry( 220 __field(dev_t, dev) 221 __field(xfs_ino_t, ino) 222 __field(xfs_agnumber_t, agno) 223 __field(xfs_ino_t, inum) 224 __field(unsigned int, gen) 225 __field(unsigned int, flags) 226 __field(unsigned short, rest_us) 227 __field(unsigned short, nr_vecs) 228 ), 229 TP_fast_assign( 230 __entry->dev = ip->i_mount->m_super->s_dev; 231 __entry->ino = ip->i_ino; 232 __entry->agno = vhead->svh_agno; 233 __entry->inum = vhead->svh_ino; 234 __entry->gen = vhead->svh_gen; 235 __entry->flags = vhead->svh_flags; 236 __entry->rest_us = vhead->svh_rest_us; 237 __entry->nr_vecs = vhead->svh_nr; 238 ), 239 TP_printk("dev %d:%d ino 0x%llx agno 0x%x inum 0x%llx gen 0x%x flags 0x%x rest_us %u nr_vecs %u", 240 MAJOR(__entry->dev), MINOR(__entry->dev), 241 __entry->ino, 242 __entry->agno, 243 __entry->inum, 244 __entry->gen, 245 __entry->flags, 246 __entry->rest_us, 247 __entry->nr_vecs) 248 ) 249 #define DEFINE_SCRUBV_HEAD_EVENT(name) \ 250 DEFINE_EVENT(xchk_vector_head_class, name, \ 251 TP_PROTO(struct xfs_inode *ip, struct xfs_scrub_vec_head *vhead), \ 252 TP_ARGS(ip, vhead)) 253 254 DEFINE_SCRUBV_HEAD_EVENT(xchk_scrubv_start); 255 256 DECLARE_EVENT_CLASS(xchk_vector_class, 257 TP_PROTO(struct xfs_mount *mp, struct xfs_scrub_vec_head *vhead, 258 unsigned int vec_nr, struct xfs_scrub_vec *v), 259 TP_ARGS(mp, vhead, vec_nr, v), 260 TP_STRUCT__entry( 261 __field(dev_t, dev) 262 __field(unsigned int, vec_nr) 263 __field(unsigned int, vec_type) 264 __field(unsigned int, vec_flags) 265 __field(int, vec_ret) 266 ), 267 TP_fast_assign( 268 __entry->dev = mp->m_super->s_dev; 269 __entry->vec_nr = vec_nr; 270 __entry->vec_type = v->sv_type; 271 __entry->vec_flags = v->sv_flags; 272 __entry->vec_ret = v->sv_ret; 273 ), 274 TP_printk("dev %d:%d vec[%u] type %s flags %s ret %d", 275 MAJOR(__entry->dev), MINOR(__entry->dev), 276 __entry->vec_nr, 277 __print_symbolic(__entry->vec_type, XFS_SCRUB_TYPE_STRINGS), 278 __print_flags(__entry->vec_flags, "|", XFS_SCRUB_FLAG_STRINGS), 279 __entry->vec_ret) 280 ) 281 #define DEFINE_SCRUBV_EVENT(name) \ 282 DEFINE_EVENT(xchk_vector_class, name, \ 283 TP_PROTO(struct xfs_mount *mp, struct xfs_scrub_vec_head *vhead, \ 284 unsigned int vec_nr, struct xfs_scrub_vec *v), \ 285 TP_ARGS(mp, vhead, vec_nr, v)) 286 287 DEFINE_SCRUBV_EVENT(xchk_scrubv_barrier_fail); 288 DEFINE_SCRUBV_EVENT(xchk_scrubv_item); 289 DEFINE_SCRUBV_EVENT(xchk_scrubv_outcome); 290 291 TRACE_EVENT(xchk_op_error, 292 TP_PROTO(struct xfs_scrub *sc, xfs_agnumber_t agno, 293 xfs_agblock_t bno, int error, void *ret_ip), 294 TP_ARGS(sc, agno, bno, error, ret_ip), 295 TP_STRUCT__entry( 296 __field(dev_t, dev) 297 __field(unsigned int, type) 298 __field(xfs_agnumber_t, agno) 299 __field(xfs_agblock_t, bno) 300 __field(int, error) 301 __field(void *, ret_ip) 302 ), 303 TP_fast_assign( 304 __entry->dev = sc->mp->m_super->s_dev; 305 __entry->type = sc->sm->sm_type; 306 __entry->agno = agno; 307 __entry->bno = bno; 308 __entry->error = error; 309 __entry->ret_ip = ret_ip; 310 ), 311 TP_printk("dev %d:%d type %s agno 0x%x agbno 0x%x error %d ret_ip %pS", 312 MAJOR(__entry->dev), MINOR(__entry->dev), 313 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 314 __entry->agno, 315 __entry->bno, 316 __entry->error, 317 __entry->ret_ip) 318 ); 319 320 TRACE_EVENT(xchk_file_op_error, 321 TP_PROTO(struct xfs_scrub *sc, int whichfork, 322 xfs_fileoff_t offset, int error, void *ret_ip), 323 TP_ARGS(sc, whichfork, offset, error, ret_ip), 324 TP_STRUCT__entry( 325 __field(dev_t, dev) 326 __field(xfs_ino_t, ino) 327 __field(int, whichfork) 328 __field(unsigned int, type) 329 __field(xfs_fileoff_t, offset) 330 __field(int, error) 331 __field(void *, ret_ip) 332 ), 333 TP_fast_assign( 334 __entry->dev = sc->ip->i_mount->m_super->s_dev; 335 __entry->ino = sc->ip->i_ino; 336 __entry->whichfork = whichfork; 337 __entry->type = sc->sm->sm_type; 338 __entry->offset = offset; 339 __entry->error = error; 340 __entry->ret_ip = ret_ip; 341 ), 342 TP_printk("dev %d:%d ino 0x%llx fork %s type %s fileoff 0x%llx error %d ret_ip %pS", 343 MAJOR(__entry->dev), MINOR(__entry->dev), 344 __entry->ino, 345 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 346 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 347 __entry->offset, 348 __entry->error, 349 __entry->ret_ip) 350 ); 351 352 DECLARE_EVENT_CLASS(xchk_block_error_class, 353 TP_PROTO(struct xfs_scrub *sc, xfs_daddr_t daddr, void *ret_ip), 354 TP_ARGS(sc, daddr, ret_ip), 355 TP_STRUCT__entry( 356 __field(dev_t, dev) 357 __field(unsigned int, type) 358 __field(xfs_agnumber_t, agno) 359 __field(xfs_agblock_t, agbno) 360 __field(void *, ret_ip) 361 ), 362 TP_fast_assign( 363 __entry->dev = sc->mp->m_super->s_dev; 364 __entry->type = sc->sm->sm_type; 365 __entry->agno = xfs_daddr_to_agno(sc->mp, daddr); 366 __entry->agbno = xfs_daddr_to_agbno(sc->mp, daddr); 367 __entry->ret_ip = ret_ip; 368 ), 369 TP_printk("dev %d:%d type %s agno 0x%x agbno 0x%x ret_ip %pS", 370 MAJOR(__entry->dev), MINOR(__entry->dev), 371 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 372 __entry->agno, 373 __entry->agbno, 374 __entry->ret_ip) 375 ) 376 377 #define DEFINE_SCRUB_BLOCK_ERROR_EVENT(name) \ 378 DEFINE_EVENT(xchk_block_error_class, name, \ 379 TP_PROTO(struct xfs_scrub *sc, xfs_daddr_t daddr, \ 380 void *ret_ip), \ 381 TP_ARGS(sc, daddr, ret_ip)) 382 383 DEFINE_SCRUB_BLOCK_ERROR_EVENT(xchk_fs_error); 384 DEFINE_SCRUB_BLOCK_ERROR_EVENT(xchk_block_error); 385 DEFINE_SCRUB_BLOCK_ERROR_EVENT(xchk_block_preen); 386 387 DECLARE_EVENT_CLASS(xchk_ino_error_class, 388 TP_PROTO(struct xfs_scrub *sc, xfs_ino_t ino, void *ret_ip), 389 TP_ARGS(sc, ino, ret_ip), 390 TP_STRUCT__entry( 391 __field(dev_t, dev) 392 __field(xfs_ino_t, ino) 393 __field(unsigned int, type) 394 __field(void *, ret_ip) 395 ), 396 TP_fast_assign( 397 __entry->dev = sc->mp->m_super->s_dev; 398 __entry->ino = ino; 399 __entry->type = sc->sm->sm_type; 400 __entry->ret_ip = ret_ip; 401 ), 402 TP_printk("dev %d:%d ino 0x%llx type %s ret_ip %pS", 403 MAJOR(__entry->dev), MINOR(__entry->dev), 404 __entry->ino, 405 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 406 __entry->ret_ip) 407 ) 408 409 #define DEFINE_SCRUB_INO_ERROR_EVENT(name) \ 410 DEFINE_EVENT(xchk_ino_error_class, name, \ 411 TP_PROTO(struct xfs_scrub *sc, xfs_ino_t ino, \ 412 void *ret_ip), \ 413 TP_ARGS(sc, ino, ret_ip)) 414 415 DEFINE_SCRUB_INO_ERROR_EVENT(xchk_ino_error); 416 DEFINE_SCRUB_INO_ERROR_EVENT(xchk_ino_preen); 417 DEFINE_SCRUB_INO_ERROR_EVENT(xchk_ino_warning); 418 419 DECLARE_EVENT_CLASS(xchk_fblock_error_class, 420 TP_PROTO(struct xfs_scrub *sc, int whichfork, 421 xfs_fileoff_t offset, void *ret_ip), 422 TP_ARGS(sc, whichfork, offset, ret_ip), 423 TP_STRUCT__entry( 424 __field(dev_t, dev) 425 __field(xfs_ino_t, ino) 426 __field(int, whichfork) 427 __field(unsigned int, type) 428 __field(xfs_fileoff_t, offset) 429 __field(void *, ret_ip) 430 ), 431 TP_fast_assign( 432 __entry->dev = sc->ip->i_mount->m_super->s_dev; 433 __entry->ino = sc->ip->i_ino; 434 __entry->whichfork = whichfork; 435 __entry->type = sc->sm->sm_type; 436 __entry->offset = offset; 437 __entry->ret_ip = ret_ip; 438 ), 439 TP_printk("dev %d:%d ino 0x%llx fork %s type %s fileoff 0x%llx ret_ip %pS", 440 MAJOR(__entry->dev), MINOR(__entry->dev), 441 __entry->ino, 442 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 443 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 444 __entry->offset, 445 __entry->ret_ip) 446 ); 447 448 #define DEFINE_SCRUB_FBLOCK_ERROR_EVENT(name) \ 449 DEFINE_EVENT(xchk_fblock_error_class, name, \ 450 TP_PROTO(struct xfs_scrub *sc, int whichfork, \ 451 xfs_fileoff_t offset, void *ret_ip), \ 452 TP_ARGS(sc, whichfork, offset, ret_ip)) 453 454 DEFINE_SCRUB_FBLOCK_ERROR_EVENT(xchk_fblock_error); 455 DEFINE_SCRUB_FBLOCK_ERROR_EVENT(xchk_fblock_warning); 456 DEFINE_SCRUB_FBLOCK_ERROR_EVENT(xchk_fblock_preen); 457 458 #ifdef CONFIG_XFS_QUOTA 459 DECLARE_EVENT_CLASS(xchk_dqiter_class, 460 TP_PROTO(struct xchk_dqiter *cursor, uint64_t id), 461 TP_ARGS(cursor, id), 462 TP_STRUCT__entry( 463 __field(dev_t, dev) 464 __field(xfs_dqtype_t, dqtype) 465 __field(xfs_ino_t, ino) 466 __field(unsigned long long, cur_id) 467 __field(unsigned long long, id) 468 __field(xfs_fileoff_t, startoff) 469 __field(xfs_fsblock_t, startblock) 470 __field(xfs_filblks_t, blockcount) 471 __field(xfs_exntst_t, state) 472 ), 473 TP_fast_assign( 474 __entry->dev = cursor->sc->ip->i_mount->m_super->s_dev; 475 __entry->dqtype = cursor->dqtype; 476 __entry->ino = cursor->quota_ip->i_ino; 477 __entry->cur_id = cursor->id; 478 __entry->startoff = cursor->bmap.br_startoff; 479 __entry->startblock = cursor->bmap.br_startblock; 480 __entry->blockcount = cursor->bmap.br_blockcount; 481 __entry->state = cursor->bmap.br_state; 482 __entry->id = id; 483 ), 484 TP_printk("dev %d:%d dquot type %s ino 0x%llx cursor_id 0x%llx startoff 0x%llx startblock 0x%llx blockcount 0x%llx state %u id 0x%llx", 485 MAJOR(__entry->dev), MINOR(__entry->dev), 486 __print_symbolic(__entry->dqtype, XFS_DQTYPE_STRINGS), 487 __entry->ino, 488 __entry->cur_id, 489 __entry->startoff, 490 __entry->startblock, 491 __entry->blockcount, 492 __entry->state, 493 __entry->id) 494 ); 495 496 #define DEFINE_SCRUB_DQITER_EVENT(name) \ 497 DEFINE_EVENT(xchk_dqiter_class, name, \ 498 TP_PROTO(struct xchk_dqiter *cursor, uint64_t id), \ 499 TP_ARGS(cursor, id)) 500 DEFINE_SCRUB_DQITER_EVENT(xchk_dquot_iter_revalidate_bmap); 501 DEFINE_SCRUB_DQITER_EVENT(xchk_dquot_iter_advance_bmap); 502 DEFINE_SCRUB_DQITER_EVENT(xchk_dquot_iter_advance_incore); 503 DEFINE_SCRUB_DQITER_EVENT(xchk_dquot_iter); 504 505 TRACE_EVENT(xchk_qcheck_error, 506 TP_PROTO(struct xfs_scrub *sc, xfs_dqtype_t dqtype, xfs_dqid_t id, 507 void *ret_ip), 508 TP_ARGS(sc, dqtype, id, ret_ip), 509 TP_STRUCT__entry( 510 __field(dev_t, dev) 511 __field(xfs_dqtype_t, dqtype) 512 __field(xfs_dqid_t, id) 513 __field(void *, ret_ip) 514 ), 515 TP_fast_assign( 516 __entry->dev = sc->mp->m_super->s_dev; 517 __entry->dqtype = dqtype; 518 __entry->id = id; 519 __entry->ret_ip = ret_ip; 520 ), 521 TP_printk("dev %d:%d dquot type %s id 0x%x ret_ip %pS", 522 MAJOR(__entry->dev), MINOR(__entry->dev), 523 __print_symbolic(__entry->dqtype, XFS_DQTYPE_STRINGS), 524 __entry->id, 525 __entry->ret_ip) 526 ); 527 #endif /* CONFIG_XFS_QUOTA */ 528 529 TRACE_EVENT(xchk_incomplete, 530 TP_PROTO(struct xfs_scrub *sc, void *ret_ip), 531 TP_ARGS(sc, ret_ip), 532 TP_STRUCT__entry( 533 __field(dev_t, dev) 534 __field(unsigned int, type) 535 __field(void *, ret_ip) 536 ), 537 TP_fast_assign( 538 __entry->dev = sc->mp->m_super->s_dev; 539 __entry->type = sc->sm->sm_type; 540 __entry->ret_ip = ret_ip; 541 ), 542 TP_printk("dev %d:%d type %s ret_ip %pS", 543 MAJOR(__entry->dev), MINOR(__entry->dev), 544 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 545 __entry->ret_ip) 546 ); 547 548 TRACE_EVENT(xchk_btree_op_error, 549 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, 550 int level, int error, void *ret_ip), 551 TP_ARGS(sc, cur, level, error, ret_ip), 552 TP_STRUCT__entry( 553 __field(dev_t, dev) 554 __field(unsigned int, type) 555 __string(name, cur->bc_ops->name) 556 __field(int, level) 557 __field(xfs_agnumber_t, agno) 558 __field(xfs_agblock_t, bno) 559 __field(int, ptr) 560 __field(int, error) 561 __field(void *, ret_ip) 562 ), 563 TP_fast_assign( 564 xfs_fsblock_t fsbno = xchk_btree_cur_fsbno(cur, level); 565 566 __entry->dev = sc->mp->m_super->s_dev; 567 __entry->type = sc->sm->sm_type; 568 __assign_str(name); 569 __entry->level = level; 570 __entry->agno = XFS_FSB_TO_AGNO(cur->bc_mp, fsbno); 571 __entry->bno = XFS_FSB_TO_AGBNO(cur->bc_mp, fsbno); 572 __entry->ptr = cur->bc_levels[level].ptr; 573 __entry->error = error; 574 __entry->ret_ip = ret_ip; 575 ), 576 TP_printk("dev %d:%d type %s %sbt level %d ptr %d agno 0x%x agbno 0x%x error %d ret_ip %pS", 577 MAJOR(__entry->dev), MINOR(__entry->dev), 578 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 579 __get_str(name), 580 __entry->level, 581 __entry->ptr, 582 __entry->agno, 583 __entry->bno, 584 __entry->error, 585 __entry->ret_ip) 586 ); 587 588 TRACE_EVENT(xchk_ifork_btree_op_error, 589 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, 590 int level, int error, void *ret_ip), 591 TP_ARGS(sc, cur, level, error, ret_ip), 592 TP_STRUCT__entry( 593 __field(dev_t, dev) 594 __field(xfs_ino_t, ino) 595 __field(int, whichfork) 596 __field(unsigned int, type) 597 __string(name, cur->bc_ops->name) 598 __field(int, level) 599 __field(int, ptr) 600 __field(xfs_agnumber_t, agno) 601 __field(xfs_agblock_t, bno) 602 __field(int, error) 603 __field(void *, ret_ip) 604 ), 605 TP_fast_assign( 606 xfs_fsblock_t fsbno = xchk_btree_cur_fsbno(cur, level); 607 __entry->dev = sc->mp->m_super->s_dev; 608 __entry->ino = cur->bc_ino.ip->i_ino; 609 __entry->whichfork = cur->bc_ino.whichfork; 610 __entry->type = sc->sm->sm_type; 611 __assign_str(name); 612 __entry->level = level; 613 __entry->ptr = cur->bc_levels[level].ptr; 614 __entry->agno = XFS_FSB_TO_AGNO(cur->bc_mp, fsbno); 615 __entry->bno = XFS_FSB_TO_AGBNO(cur->bc_mp, fsbno); 616 __entry->error = error; 617 __entry->ret_ip = ret_ip; 618 ), 619 TP_printk("dev %d:%d ino 0x%llx fork %s type %s %sbt level %d ptr %d agno 0x%x agbno 0x%x error %d ret_ip %pS", 620 MAJOR(__entry->dev), MINOR(__entry->dev), 621 __entry->ino, 622 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 623 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 624 __get_str(name), 625 __entry->level, 626 __entry->ptr, 627 __entry->agno, 628 __entry->bno, 629 __entry->error, 630 __entry->ret_ip) 631 ); 632 633 TRACE_EVENT(xchk_btree_error, 634 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, 635 int level, void *ret_ip), 636 TP_ARGS(sc, cur, level, ret_ip), 637 TP_STRUCT__entry( 638 __field(dev_t, dev) 639 __field(unsigned int, type) 640 __string(name, cur->bc_ops->name) 641 __field(int, level) 642 __field(xfs_agnumber_t, agno) 643 __field(xfs_agblock_t, bno) 644 __field(int, ptr) 645 __field(void *, ret_ip) 646 ), 647 TP_fast_assign( 648 xfs_fsblock_t fsbno = xchk_btree_cur_fsbno(cur, level); 649 __entry->dev = sc->mp->m_super->s_dev; 650 __entry->type = sc->sm->sm_type; 651 __assign_str(name); 652 __entry->level = level; 653 __entry->agno = XFS_FSB_TO_AGNO(cur->bc_mp, fsbno); 654 __entry->bno = XFS_FSB_TO_AGBNO(cur->bc_mp, fsbno); 655 __entry->ptr = cur->bc_levels[level].ptr; 656 __entry->ret_ip = ret_ip; 657 ), 658 TP_printk("dev %d:%d type %s %sbt level %d ptr %d agno 0x%x agbno 0x%x ret_ip %pS", 659 MAJOR(__entry->dev), MINOR(__entry->dev), 660 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 661 __get_str(name), 662 __entry->level, 663 __entry->ptr, 664 __entry->agno, 665 __entry->bno, 666 __entry->ret_ip) 667 ); 668 669 TRACE_EVENT(xchk_ifork_btree_error, 670 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, 671 int level, void *ret_ip), 672 TP_ARGS(sc, cur, level, ret_ip), 673 TP_STRUCT__entry( 674 __field(dev_t, dev) 675 __field(xfs_ino_t, ino) 676 __field(int, whichfork) 677 __field(unsigned int, type) 678 __string(name, cur->bc_ops->name) 679 __field(int, level) 680 __field(xfs_agnumber_t, agno) 681 __field(xfs_agblock_t, bno) 682 __field(int, ptr) 683 __field(void *, ret_ip) 684 ), 685 TP_fast_assign( 686 xfs_fsblock_t fsbno = xchk_btree_cur_fsbno(cur, level); 687 __entry->dev = sc->mp->m_super->s_dev; 688 __entry->ino = sc->ip->i_ino; 689 __entry->whichfork = cur->bc_ino.whichfork; 690 __entry->type = sc->sm->sm_type; 691 __assign_str(name); 692 __entry->level = level; 693 __entry->agno = XFS_FSB_TO_AGNO(cur->bc_mp, fsbno); 694 __entry->bno = XFS_FSB_TO_AGBNO(cur->bc_mp, fsbno); 695 __entry->ptr = cur->bc_levels[level].ptr; 696 __entry->ret_ip = ret_ip; 697 ), 698 TP_printk("dev %d:%d ino 0x%llx fork %s type %s %sbt level %d ptr %d agno 0x%x agbno 0x%x ret_ip %pS", 699 MAJOR(__entry->dev), MINOR(__entry->dev), 700 __entry->ino, 701 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 702 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 703 __get_str(name), 704 __entry->level, 705 __entry->ptr, 706 __entry->agno, 707 __entry->bno, 708 __entry->ret_ip) 709 ); 710 711 DECLARE_EVENT_CLASS(xchk_sbtree_class, 712 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, 713 int level), 714 TP_ARGS(sc, cur, level), 715 TP_STRUCT__entry( 716 __field(dev_t, dev) 717 __field(int, type) 718 __string(name, cur->bc_ops->name) 719 __field(xfs_agnumber_t, agno) 720 __field(xfs_agblock_t, bno) 721 __field(int, level) 722 __field(int, nlevels) 723 __field(int, ptr) 724 ), 725 TP_fast_assign( 726 xfs_fsblock_t fsbno = xchk_btree_cur_fsbno(cur, level); 727 728 __entry->dev = sc->mp->m_super->s_dev; 729 __entry->type = sc->sm->sm_type; 730 __assign_str(name); 731 __entry->agno = XFS_FSB_TO_AGNO(cur->bc_mp, fsbno); 732 __entry->bno = XFS_FSB_TO_AGBNO(cur->bc_mp, fsbno); 733 __entry->level = level; 734 __entry->nlevels = cur->bc_nlevels; 735 __entry->ptr = cur->bc_levels[level].ptr; 736 ), 737 TP_printk("dev %d:%d type %s %sbt agno 0x%x agbno 0x%x level %d nlevels %d ptr %d", 738 MAJOR(__entry->dev), MINOR(__entry->dev), 739 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 740 __get_str(name), 741 __entry->agno, 742 __entry->bno, 743 __entry->level, 744 __entry->nlevels, 745 __entry->ptr) 746 ) 747 #define DEFINE_SCRUB_SBTREE_EVENT(name) \ 748 DEFINE_EVENT(xchk_sbtree_class, name, \ 749 TP_PROTO(struct xfs_scrub *sc, struct xfs_btree_cur *cur, \ 750 int level), \ 751 TP_ARGS(sc, cur, level)) 752 753 DEFINE_SCRUB_SBTREE_EVENT(xchk_btree_rec); 754 DEFINE_SCRUB_SBTREE_EVENT(xchk_btree_key); 755 756 TRACE_EVENT(xchk_xref_error, 757 TP_PROTO(struct xfs_scrub *sc, int error, void *ret_ip), 758 TP_ARGS(sc, error, ret_ip), 759 TP_STRUCT__entry( 760 __field(dev_t, dev) 761 __field(int, type) 762 __field(int, error) 763 __field(void *, ret_ip) 764 ), 765 TP_fast_assign( 766 __entry->dev = sc->mp->m_super->s_dev; 767 __entry->type = sc->sm->sm_type; 768 __entry->error = error; 769 __entry->ret_ip = ret_ip; 770 ), 771 TP_printk("dev %d:%d type %s xref error %d ret_ip %pS", 772 MAJOR(__entry->dev), MINOR(__entry->dev), 773 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 774 __entry->error, 775 __entry->ret_ip) 776 ); 777 778 TRACE_EVENT(xchk_iallocbt_check_cluster, 779 TP_PROTO(const struct xfs_perag *pag, xfs_agino_t startino, 780 xfs_daddr_t map_daddr, unsigned short map_len, 781 unsigned int chunk_ino, unsigned int nr_inodes, 782 uint16_t cluster_mask, uint16_t holemask, 783 unsigned int cluster_ino), 784 TP_ARGS(pag, startino, map_daddr, map_len, chunk_ino, nr_inodes, 785 cluster_mask, holemask, cluster_ino), 786 TP_STRUCT__entry( 787 __field(dev_t, dev) 788 __field(xfs_agnumber_t, agno) 789 __field(xfs_agino_t, startino) 790 __field(xfs_daddr_t, map_daddr) 791 __field(unsigned short, map_len) 792 __field(unsigned int, chunk_ino) 793 __field(unsigned int, nr_inodes) 794 __field(unsigned int, cluster_ino) 795 __field(uint16_t, cluster_mask) 796 __field(uint16_t, holemask) 797 ), 798 TP_fast_assign( 799 __entry->dev = pag_mount(pag)->m_super->s_dev; 800 __entry->agno = pag_agno(pag); 801 __entry->startino = startino; 802 __entry->map_daddr = map_daddr; 803 __entry->map_len = map_len; 804 __entry->chunk_ino = chunk_ino; 805 __entry->nr_inodes = nr_inodes; 806 __entry->cluster_mask = cluster_mask; 807 __entry->holemask = holemask; 808 __entry->cluster_ino = cluster_ino; 809 ), 810 TP_printk("dev %d:%d agno 0x%x startino 0x%x daddr 0x%llx bbcount 0x%x chunkino 0x%x nr_inodes %u cluster_mask 0x%x holemask 0x%x cluster_ino 0x%x", 811 MAJOR(__entry->dev), MINOR(__entry->dev), 812 __entry->agno, 813 __entry->startino, 814 __entry->map_daddr, 815 __entry->map_len, 816 __entry->chunk_ino, 817 __entry->nr_inodes, 818 __entry->cluster_mask, 819 __entry->holemask, 820 __entry->cluster_ino) 821 ) 822 823 TRACE_EVENT(xchk_inode_is_allocated, 824 TP_PROTO(struct xfs_inode *ip), 825 TP_ARGS(ip), 826 TP_STRUCT__entry( 827 __field(dev_t, dev) 828 __field(xfs_ino_t, ino) 829 __field(unsigned long, iflags) 830 __field(umode_t, mode) 831 ), 832 TP_fast_assign( 833 __entry->dev = VFS_I(ip)->i_sb->s_dev; 834 __entry->ino = ip->i_ino; 835 __entry->iflags = ip->i_flags; 836 __entry->mode = VFS_I(ip)->i_mode; 837 ), 838 TP_printk("dev %d:%d ino 0x%llx iflags 0x%lx mode 0x%x", 839 MAJOR(__entry->dev), MINOR(__entry->dev), 840 __entry->ino, 841 __entry->iflags, 842 __entry->mode) 843 ); 844 845 TRACE_EVENT(xchk_fscounters_calc, 846 TP_PROTO(struct xfs_mount *mp, uint64_t icount, uint64_t ifree, 847 uint64_t fdblocks, uint64_t delalloc), 848 TP_ARGS(mp, icount, ifree, fdblocks, delalloc), 849 TP_STRUCT__entry( 850 __field(dev_t, dev) 851 __field(int64_t, icount_sb) 852 __field(uint64_t, icount_calculated) 853 __field(int64_t, ifree_sb) 854 __field(uint64_t, ifree_calculated) 855 __field(int64_t, fdblocks_sb) 856 __field(uint64_t, fdblocks_calculated) 857 __field(uint64_t, delalloc) 858 ), 859 TP_fast_assign( 860 __entry->dev = mp->m_super->s_dev; 861 __entry->icount_sb = mp->m_sb.sb_icount; 862 __entry->icount_calculated = icount; 863 __entry->ifree_sb = mp->m_sb.sb_ifree; 864 __entry->ifree_calculated = ifree; 865 __entry->fdblocks_sb = mp->m_sb.sb_fdblocks; 866 __entry->fdblocks_calculated = fdblocks; 867 __entry->delalloc = delalloc; 868 ), 869 TP_printk("dev %d:%d icount %lld:%llu ifree %lld::%llu fdblocks %lld::%llu delalloc %llu", 870 MAJOR(__entry->dev), MINOR(__entry->dev), 871 __entry->icount_sb, 872 __entry->icount_calculated, 873 __entry->ifree_sb, 874 __entry->ifree_calculated, 875 __entry->fdblocks_sb, 876 __entry->fdblocks_calculated, 877 __entry->delalloc) 878 ) 879 880 TRACE_EVENT(xchk_fscounters_within_range, 881 TP_PROTO(struct xfs_mount *mp, uint64_t expected, int64_t curr_value, 882 int64_t old_value), 883 TP_ARGS(mp, expected, curr_value, old_value), 884 TP_STRUCT__entry( 885 __field(dev_t, dev) 886 __field(uint64_t, expected) 887 __field(int64_t, curr_value) 888 __field(int64_t, old_value) 889 ), 890 TP_fast_assign( 891 __entry->dev = mp->m_super->s_dev; 892 __entry->expected = expected; 893 __entry->curr_value = curr_value; 894 __entry->old_value = old_value; 895 ), 896 TP_printk("dev %d:%d expected %llu curr_value %lld old_value %lld", 897 MAJOR(__entry->dev), MINOR(__entry->dev), 898 __entry->expected, 899 __entry->curr_value, 900 __entry->old_value) 901 ) 902 903 DECLARE_EVENT_CLASS(xchk_fsfreeze_class, 904 TP_PROTO(struct xfs_scrub *sc, int error), 905 TP_ARGS(sc, error), 906 TP_STRUCT__entry( 907 __field(dev_t, dev) 908 __field(unsigned int, type) 909 __field(int, error) 910 ), 911 TP_fast_assign( 912 __entry->dev = sc->mp->m_super->s_dev; 913 __entry->type = sc->sm->sm_type; 914 __entry->error = error; 915 ), 916 TP_printk("dev %d:%d type %s error %d", 917 MAJOR(__entry->dev), MINOR(__entry->dev), 918 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 919 __entry->error) 920 ); 921 #define DEFINE_XCHK_FSFREEZE_EVENT(name) \ 922 DEFINE_EVENT(xchk_fsfreeze_class, name, \ 923 TP_PROTO(struct xfs_scrub *sc, int error), \ 924 TP_ARGS(sc, error)) 925 DEFINE_XCHK_FSFREEZE_EVENT(xchk_fsfreeze); 926 DEFINE_XCHK_FSFREEZE_EVENT(xchk_fsthaw); 927 928 TRACE_EVENT(xchk_refcount_incorrect, 929 TP_PROTO(const struct xfs_perag *pag, 930 const struct xfs_refcount_irec *irec, 931 xfs_nlink_t seen), 932 TP_ARGS(pag, irec, seen), 933 TP_STRUCT__entry( 934 __field(dev_t, dev) 935 __field(xfs_agnumber_t, agno) 936 __field(enum xfs_refc_domain, domain) 937 __field(xfs_agblock_t, startblock) 938 __field(xfs_extlen_t, blockcount) 939 __field(xfs_nlink_t, refcount) 940 __field(xfs_nlink_t, seen) 941 ), 942 TP_fast_assign( 943 __entry->dev = pag_mount(pag)->m_super->s_dev; 944 __entry->agno = pag_agno(pag); 945 __entry->domain = irec->rc_domain; 946 __entry->startblock = irec->rc_startblock; 947 __entry->blockcount = irec->rc_blockcount; 948 __entry->refcount = irec->rc_refcount; 949 __entry->seen = seen; 950 ), 951 TP_printk("dev %d:%d agno 0x%x dom %s agbno 0x%x fsbcount 0x%x refcount %u seen %u", 952 MAJOR(__entry->dev), MINOR(__entry->dev), 953 __entry->agno, 954 __print_symbolic(__entry->domain, XFS_REFC_DOMAIN_STRINGS), 955 __entry->startblock, 956 __entry->blockcount, 957 __entry->refcount, 958 __entry->seen) 959 ) 960 961 TRACE_EVENT(xfile_create, 962 TP_PROTO(struct xfile *xf), 963 TP_ARGS(xf), 964 TP_STRUCT__entry( 965 __field(dev_t, dev) 966 __field(unsigned long, ino) 967 __array(char, pathname, MAXNAMELEN) 968 ), 969 TP_fast_assign( 970 char *path; 971 972 __entry->ino = file_inode(xf->file)->i_ino; 973 path = file_path(xf->file, __entry->pathname, MAXNAMELEN); 974 if (IS_ERR(path)) 975 strncpy(__entry->pathname, "(unknown)", 976 sizeof(__entry->pathname)); 977 ), 978 TP_printk("xfino 0x%lx path '%s'", 979 __entry->ino, 980 __entry->pathname) 981 ); 982 983 TRACE_EVENT(xfile_destroy, 984 TP_PROTO(struct xfile *xf), 985 TP_ARGS(xf), 986 TP_STRUCT__entry( 987 __field(unsigned long, ino) 988 __field(unsigned long long, bytes) 989 __field(loff_t, size) 990 ), 991 TP_fast_assign( 992 struct inode *inode = file_inode(xf->file); 993 994 __entry->ino = inode->i_ino; 995 __entry->bytes = inode->i_blocks << SECTOR_SHIFT; 996 __entry->size = i_size_read(inode); 997 ), 998 TP_printk("xfino 0x%lx mem_bytes 0x%llx isize 0x%llx", 999 __entry->ino, 1000 __entry->bytes, 1001 __entry->size) 1002 ); 1003 1004 DECLARE_EVENT_CLASS(xfile_class, 1005 TP_PROTO(struct xfile *xf, loff_t pos, unsigned long long bytecount), 1006 TP_ARGS(xf, pos, bytecount), 1007 TP_STRUCT__entry( 1008 __field(unsigned long, ino) 1009 __field(unsigned long long, bytes_used) 1010 __field(loff_t, pos) 1011 __field(loff_t, size) 1012 __field(unsigned long long, bytecount) 1013 ), 1014 TP_fast_assign( 1015 struct inode *inode = file_inode(xf->file); 1016 1017 __entry->ino = inode->i_ino; 1018 __entry->bytes_used = inode->i_blocks << SECTOR_SHIFT; 1019 __entry->pos = pos; 1020 __entry->size = i_size_read(inode); 1021 __entry->bytecount = bytecount; 1022 ), 1023 TP_printk("xfino 0x%lx mem_bytes 0x%llx pos 0x%llx bytecount 0x%llx isize 0x%llx", 1024 __entry->ino, 1025 __entry->bytes_used, 1026 __entry->pos, 1027 __entry->bytecount, 1028 __entry->size) 1029 ); 1030 #define DEFINE_XFILE_EVENT(name) \ 1031 DEFINE_EVENT(xfile_class, name, \ 1032 TP_PROTO(struct xfile *xf, loff_t pos, unsigned long long bytecount), \ 1033 TP_ARGS(xf, pos, bytecount)) 1034 DEFINE_XFILE_EVENT(xfile_load); 1035 DEFINE_XFILE_EVENT(xfile_store); 1036 DEFINE_XFILE_EVENT(xfile_seek_data); 1037 DEFINE_XFILE_EVENT(xfile_get_folio); 1038 DEFINE_XFILE_EVENT(xfile_put_folio); 1039 DEFINE_XFILE_EVENT(xfile_discard); 1040 1041 TRACE_EVENT(xfarray_create, 1042 TP_PROTO(struct xfarray *xfa, unsigned long long required_capacity), 1043 TP_ARGS(xfa, required_capacity), 1044 TP_STRUCT__entry( 1045 __field(unsigned long, ino) 1046 __field(uint64_t, max_nr) 1047 __field(size_t, obj_size) 1048 __field(int, obj_size_log) 1049 __field(unsigned long long, required_capacity) 1050 ), 1051 TP_fast_assign( 1052 __entry->max_nr = xfa->max_nr; 1053 __entry->obj_size = xfa->obj_size; 1054 __entry->obj_size_log = xfa->obj_size_log; 1055 __entry->ino = file_inode(xfa->xfile->file)->i_ino; 1056 __entry->required_capacity = required_capacity; 1057 ), 1058 TP_printk("xfino 0x%lx max_nr %llu reqd_nr %llu objsz %zu objszlog %d", 1059 __entry->ino, 1060 __entry->max_nr, 1061 __entry->required_capacity, 1062 __entry->obj_size, 1063 __entry->obj_size_log) 1064 ); 1065 1066 TRACE_EVENT(xfarray_isort, 1067 TP_PROTO(struct xfarray_sortinfo *si, uint64_t lo, uint64_t hi), 1068 TP_ARGS(si, lo, hi), 1069 TP_STRUCT__entry( 1070 __field(unsigned long, ino) 1071 __field(unsigned long long, lo) 1072 __field(unsigned long long, hi) 1073 ), 1074 TP_fast_assign( 1075 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1076 __entry->lo = lo; 1077 __entry->hi = hi; 1078 ), 1079 TP_printk("xfino 0x%lx lo %llu hi %llu elts %llu", 1080 __entry->ino, 1081 __entry->lo, 1082 __entry->hi, 1083 __entry->hi - __entry->lo) 1084 ); 1085 1086 TRACE_EVENT(xfarray_foliosort, 1087 TP_PROTO(struct xfarray_sortinfo *si, uint64_t lo, uint64_t hi), 1088 TP_ARGS(si, lo, hi), 1089 TP_STRUCT__entry( 1090 __field(unsigned long, ino) 1091 __field(unsigned long long, lo) 1092 __field(unsigned long long, hi) 1093 ), 1094 TP_fast_assign( 1095 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1096 __entry->lo = lo; 1097 __entry->hi = hi; 1098 ), 1099 TP_printk("xfino 0x%lx lo %llu hi %llu elts %llu", 1100 __entry->ino, 1101 __entry->lo, 1102 __entry->hi, 1103 __entry->hi - __entry->lo) 1104 ); 1105 1106 TRACE_EVENT(xfarray_qsort, 1107 TP_PROTO(struct xfarray_sortinfo *si, uint64_t lo, uint64_t hi), 1108 TP_ARGS(si, lo, hi), 1109 TP_STRUCT__entry( 1110 __field(unsigned long, ino) 1111 __field(unsigned long long, lo) 1112 __field(unsigned long long, hi) 1113 __field(int, stack_depth) 1114 __field(int, max_stack_depth) 1115 ), 1116 TP_fast_assign( 1117 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1118 __entry->lo = lo; 1119 __entry->hi = hi; 1120 __entry->stack_depth = si->stack_depth; 1121 __entry->max_stack_depth = si->max_stack_depth; 1122 ), 1123 TP_printk("xfino 0x%lx lo %llu hi %llu elts %llu stack %d/%d", 1124 __entry->ino, 1125 __entry->lo, 1126 __entry->hi, 1127 __entry->hi - __entry->lo, 1128 __entry->stack_depth, 1129 __entry->max_stack_depth) 1130 ); 1131 1132 TRACE_EVENT(xfarray_sort, 1133 TP_PROTO(struct xfarray_sortinfo *si, size_t bytes), 1134 TP_ARGS(si, bytes), 1135 TP_STRUCT__entry( 1136 __field(unsigned long, ino) 1137 __field(unsigned long long, nr) 1138 __field(size_t, obj_size) 1139 __field(size_t, bytes) 1140 __field(unsigned int, max_stack_depth) 1141 ), 1142 TP_fast_assign( 1143 __entry->nr = si->array->nr; 1144 __entry->obj_size = si->array->obj_size; 1145 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1146 __entry->bytes = bytes; 1147 __entry->max_stack_depth = si->max_stack_depth; 1148 ), 1149 TP_printk("xfino 0x%lx nr %llu objsz %zu stack %u bytes %zu", 1150 __entry->ino, 1151 __entry->nr, 1152 __entry->obj_size, 1153 __entry->max_stack_depth, 1154 __entry->bytes) 1155 ); 1156 1157 TRACE_EVENT(xfarray_sort_scan, 1158 TP_PROTO(struct xfarray_sortinfo *si, unsigned long long idx), 1159 TP_ARGS(si, idx), 1160 TP_STRUCT__entry( 1161 __field(unsigned long, ino) 1162 __field(unsigned long long, nr) 1163 __field(size_t, obj_size) 1164 __field(unsigned long long, idx) 1165 __field(unsigned long long, folio_pos) 1166 __field(unsigned long, folio_bytes) 1167 __field(unsigned long long, first_idx) 1168 __field(unsigned long long, last_idx) 1169 ), 1170 TP_fast_assign( 1171 __entry->nr = si->array->nr; 1172 __entry->obj_size = si->array->obj_size; 1173 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1174 __entry->idx = idx; 1175 if (si->folio) { 1176 __entry->folio_pos = folio_pos(si->folio); 1177 __entry->folio_bytes = folio_size(si->folio); 1178 __entry->first_idx = si->first_folio_idx; 1179 __entry->last_idx = si->last_folio_idx; 1180 } else { 1181 __entry->folio_pos = 0; 1182 __entry->folio_bytes = 0; 1183 __entry->first_idx = 0; 1184 __entry->last_idx = 0; 1185 } 1186 ), 1187 TP_printk("xfino 0x%lx nr %llu objsz %zu idx %llu folio_pos 0x%llx folio_bytes 0x%lx first_idx %llu last_idx %llu", 1188 __entry->ino, 1189 __entry->nr, 1190 __entry->obj_size, 1191 __entry->idx, 1192 __entry->folio_pos, 1193 __entry->folio_bytes, 1194 __entry->first_idx, 1195 __entry->last_idx) 1196 ); 1197 1198 TRACE_EVENT(xfarray_sort_stats, 1199 TP_PROTO(struct xfarray_sortinfo *si, int error), 1200 TP_ARGS(si, error), 1201 TP_STRUCT__entry( 1202 __field(unsigned long, ino) 1203 #ifdef DEBUG 1204 __field(unsigned long long, loads) 1205 __field(unsigned long long, stores) 1206 __field(unsigned long long, compares) 1207 __field(unsigned long long, heapsorts) 1208 #endif 1209 __field(unsigned int, max_stack_depth) 1210 __field(unsigned int, max_stack_used) 1211 __field(int, error) 1212 ), 1213 TP_fast_assign( 1214 __entry->ino = file_inode(si->array->xfile->file)->i_ino; 1215 #ifdef DEBUG 1216 __entry->loads = si->loads; 1217 __entry->stores = si->stores; 1218 __entry->compares = si->compares; 1219 __entry->heapsorts = si->heapsorts; 1220 #endif 1221 __entry->max_stack_depth = si->max_stack_depth; 1222 __entry->max_stack_used = si->max_stack_used; 1223 __entry->error = error; 1224 ), 1225 TP_printk( 1226 #ifdef DEBUG 1227 "xfino 0x%lx loads %llu stores %llu compares %llu heapsorts %llu stack_depth %u/%u error %d", 1228 #else 1229 "xfino 0x%lx stack_depth %u/%u error %d", 1230 #endif 1231 __entry->ino, 1232 #ifdef DEBUG 1233 __entry->loads, 1234 __entry->stores, 1235 __entry->compares, 1236 __entry->heapsorts, 1237 #endif 1238 __entry->max_stack_used, 1239 __entry->max_stack_depth, 1240 __entry->error) 1241 ); 1242 1243 #ifdef CONFIG_XFS_RT 1244 TRACE_EVENT(xchk_rtsum_record_free, 1245 TP_PROTO(struct xfs_mount *mp, xfs_rtxnum_t start, 1246 xfs_rtbxlen_t len, unsigned int log, loff_t pos, 1247 xfs_suminfo_t value), 1248 TP_ARGS(mp, start, len, log, pos, value), 1249 TP_STRUCT__entry( 1250 __field(dev_t, dev) 1251 __field(dev_t, rtdev) 1252 __field(xfs_rtxnum_t, start) 1253 __field(unsigned long long, len) 1254 __field(unsigned int, log) 1255 __field(loff_t, pos) 1256 __field(xfs_suminfo_t, value) 1257 ), 1258 TP_fast_assign( 1259 __entry->dev = mp->m_super->s_dev; 1260 __entry->rtdev = mp->m_rtdev_targp->bt_dev; 1261 __entry->start = start; 1262 __entry->len = len; 1263 __entry->log = log; 1264 __entry->pos = pos; 1265 __entry->value = value; 1266 ), 1267 TP_printk("dev %d:%d rtdev %d:%d rtx 0x%llx rtxcount 0x%llx log %u rsumpos 0x%llx sumcount %u", 1268 MAJOR(__entry->dev), MINOR(__entry->dev), 1269 MAJOR(__entry->rtdev), MINOR(__entry->rtdev), 1270 __entry->start, 1271 __entry->len, 1272 __entry->log, 1273 __entry->pos, 1274 __entry->value) 1275 ); 1276 #endif /* CONFIG_XFS_RT */ 1277 1278 DECLARE_EVENT_CLASS(xchk_iscan_class, 1279 TP_PROTO(struct xchk_iscan *iscan), 1280 TP_ARGS(iscan), 1281 TP_STRUCT__entry( 1282 __field(dev_t, dev) 1283 __field(xfs_ino_t, cursor) 1284 __field(xfs_ino_t, visited) 1285 ), 1286 TP_fast_assign( 1287 __entry->dev = iscan->sc->mp->m_super->s_dev; 1288 __entry->cursor = iscan->cursor_ino; 1289 __entry->visited = iscan->__visited_ino; 1290 ), 1291 TP_printk("dev %d:%d iscan cursor 0x%llx visited 0x%llx", 1292 MAJOR(__entry->dev), MINOR(__entry->dev), 1293 __entry->cursor, 1294 __entry->visited) 1295 ) 1296 #define DEFINE_ISCAN_EVENT(name) \ 1297 DEFINE_EVENT(xchk_iscan_class, name, \ 1298 TP_PROTO(struct xchk_iscan *iscan), \ 1299 TP_ARGS(iscan)) 1300 DEFINE_ISCAN_EVENT(xchk_iscan_move_cursor); 1301 DEFINE_ISCAN_EVENT(xchk_iscan_visit); 1302 DEFINE_ISCAN_EVENT(xchk_iscan_skip); 1303 DEFINE_ISCAN_EVENT(xchk_iscan_advance_ag); 1304 1305 DECLARE_EVENT_CLASS(xchk_iscan_ino_class, 1306 TP_PROTO(struct xchk_iscan *iscan, xfs_ino_t ino), 1307 TP_ARGS(iscan, ino), 1308 TP_STRUCT__entry( 1309 __field(dev_t, dev) 1310 __field(xfs_ino_t, startino) 1311 __field(xfs_ino_t, cursor) 1312 __field(xfs_ino_t, visited) 1313 __field(xfs_ino_t, ino) 1314 ), 1315 TP_fast_assign( 1316 __entry->dev = iscan->sc->mp->m_super->s_dev; 1317 __entry->startino = iscan->scan_start_ino; 1318 __entry->cursor = iscan->cursor_ino; 1319 __entry->visited = iscan->__visited_ino; 1320 __entry->ino = ino; 1321 ), 1322 TP_printk("dev %d:%d iscan start 0x%llx cursor 0x%llx visited 0x%llx ino 0x%llx", 1323 MAJOR(__entry->dev), MINOR(__entry->dev), 1324 __entry->startino, 1325 __entry->cursor, 1326 __entry->visited, 1327 __entry->ino) 1328 ) 1329 #define DEFINE_ISCAN_INO_EVENT(name) \ 1330 DEFINE_EVENT(xchk_iscan_ino_class, name, \ 1331 TP_PROTO(struct xchk_iscan *iscan, xfs_ino_t ino), \ 1332 TP_ARGS(iscan, ino)) 1333 DEFINE_ISCAN_INO_EVENT(xchk_iscan_want_live_update); 1334 DEFINE_ISCAN_INO_EVENT(xchk_iscan_start); 1335 1336 TRACE_EVENT(xchk_iscan_iget, 1337 TP_PROTO(struct xchk_iscan *iscan, int error), 1338 TP_ARGS(iscan, error), 1339 TP_STRUCT__entry( 1340 __field(dev_t, dev) 1341 __field(xfs_ino_t, cursor) 1342 __field(xfs_ino_t, visited) 1343 __field(int, error) 1344 ), 1345 TP_fast_assign( 1346 __entry->dev = iscan->sc->mp->m_super->s_dev; 1347 __entry->cursor = iscan->cursor_ino; 1348 __entry->visited = iscan->__visited_ino; 1349 __entry->error = error; 1350 ), 1351 TP_printk("dev %d:%d iscan cursor 0x%llx visited 0x%llx error %d", 1352 MAJOR(__entry->dev), MINOR(__entry->dev), 1353 __entry->cursor, 1354 __entry->visited, 1355 __entry->error) 1356 ); 1357 1358 TRACE_EVENT(xchk_iscan_iget_batch, 1359 TP_PROTO(struct xfs_mount *mp, struct xchk_iscan *iscan, 1360 unsigned int nr, unsigned int avail), 1361 TP_ARGS(mp, iscan, nr, avail), 1362 TP_STRUCT__entry( 1363 __field(dev_t, dev) 1364 __field(xfs_ino_t, cursor) 1365 __field(xfs_ino_t, visited) 1366 __field(unsigned int, nr) 1367 __field(unsigned int, avail) 1368 __field(unsigned int, unavail) 1369 __field(xfs_ino_t, batch_ino) 1370 __field(unsigned long long, skipmask) 1371 ), 1372 TP_fast_assign( 1373 __entry->dev = mp->m_super->s_dev; 1374 __entry->cursor = iscan->cursor_ino; 1375 __entry->visited = iscan->__visited_ino; 1376 __entry->nr = nr; 1377 __entry->avail = avail; 1378 __entry->unavail = hweight64(iscan->__skipped_inomask); 1379 __entry->batch_ino = iscan->__batch_ino; 1380 __entry->skipmask = iscan->__skipped_inomask; 1381 ), 1382 TP_printk("dev %d:%d iscan cursor 0x%llx visited 0x%llx batchino 0x%llx skipmask 0x%llx nr %u avail %u unavail %u", 1383 MAJOR(__entry->dev), MINOR(__entry->dev), 1384 __entry->cursor, 1385 __entry->visited, 1386 __entry->batch_ino, 1387 __entry->skipmask, 1388 __entry->nr, 1389 __entry->avail, 1390 __entry->unavail) 1391 ); 1392 1393 DECLARE_EVENT_CLASS(xchk_iscan_retry_wait_class, 1394 TP_PROTO(struct xchk_iscan *iscan), 1395 TP_ARGS(iscan), 1396 TP_STRUCT__entry( 1397 __field(dev_t, dev) 1398 __field(xfs_ino_t, cursor) 1399 __field(xfs_ino_t, visited) 1400 __field(unsigned int, retry_delay) 1401 __field(unsigned long, remaining) 1402 __field(unsigned int, iget_timeout) 1403 ), 1404 TP_fast_assign( 1405 __entry->dev = iscan->sc->mp->m_super->s_dev; 1406 __entry->cursor = iscan->cursor_ino; 1407 __entry->visited = iscan->__visited_ino; 1408 __entry->retry_delay = iscan->iget_retry_delay; 1409 __entry->remaining = jiffies_to_msecs(iscan->__iget_deadline - jiffies); 1410 __entry->iget_timeout = iscan->iget_timeout; 1411 ), 1412 TP_printk("dev %d:%d iscan cursor 0x%llx visited 0x%llx remaining %lu timeout %u delay %u", 1413 MAJOR(__entry->dev), MINOR(__entry->dev), 1414 __entry->cursor, 1415 __entry->visited, 1416 __entry->remaining, 1417 __entry->iget_timeout, 1418 __entry->retry_delay) 1419 ) 1420 #define DEFINE_ISCAN_RETRY_WAIT_EVENT(name) \ 1421 DEFINE_EVENT(xchk_iscan_retry_wait_class, name, \ 1422 TP_PROTO(struct xchk_iscan *iscan), \ 1423 TP_ARGS(iscan)) 1424 DEFINE_ISCAN_RETRY_WAIT_EVENT(xchk_iscan_iget_retry_wait); 1425 DEFINE_ISCAN_RETRY_WAIT_EVENT(xchk_iscan_agi_retry_wait); 1426 1427 TRACE_EVENT(xchk_nlinks_collect_dirent, 1428 TP_PROTO(struct xfs_mount *mp, struct xfs_inode *dp, 1429 xfs_ino_t ino, const struct xfs_name *name), 1430 TP_ARGS(mp, dp, ino, name), 1431 TP_STRUCT__entry( 1432 __field(dev_t, dev) 1433 __field(xfs_ino_t, dir) 1434 __field(xfs_ino_t, ino) 1435 __field(unsigned int, namelen) 1436 __dynamic_array(char, name, name->len) 1437 ), 1438 TP_fast_assign( 1439 __entry->dev = mp->m_super->s_dev; 1440 __entry->dir = dp->i_ino; 1441 __entry->ino = ino; 1442 __entry->namelen = name->len; 1443 memcpy(__get_str(name), name->name, name->len); 1444 ), 1445 TP_printk("dev %d:%d dir 0x%llx -> ino 0x%llx name '%.*s'", 1446 MAJOR(__entry->dev), MINOR(__entry->dev), 1447 __entry->dir, 1448 __entry->ino, 1449 __entry->namelen, 1450 __get_str(name)) 1451 ); 1452 1453 TRACE_EVENT(xchk_nlinks_collect_pptr, 1454 TP_PROTO(struct xfs_mount *mp, struct xfs_inode *dp, 1455 const struct xfs_name *name, 1456 const struct xfs_parent_rec *pptr), 1457 TP_ARGS(mp, dp, name, pptr), 1458 TP_STRUCT__entry( 1459 __field(dev_t, dev) 1460 __field(xfs_ino_t, dir) 1461 __field(xfs_ino_t, ino) 1462 __field(unsigned int, namelen) 1463 __dynamic_array(char, name, name->len) 1464 ), 1465 TP_fast_assign( 1466 __entry->dev = mp->m_super->s_dev; 1467 __entry->dir = dp->i_ino; 1468 __entry->ino = be64_to_cpu(pptr->p_ino); 1469 __entry->namelen = name->len; 1470 memcpy(__get_str(name), name->name, name->len); 1471 ), 1472 TP_printk("dev %d:%d dir 0x%llx -> ino 0x%llx name '%.*s'", 1473 MAJOR(__entry->dev), MINOR(__entry->dev), 1474 __entry->dir, 1475 __entry->ino, 1476 __entry->namelen, 1477 __get_str(name)) 1478 ); 1479 1480 TRACE_EVENT(xchk_nlinks_collect_metafile, 1481 TP_PROTO(struct xfs_mount *mp, xfs_ino_t ino), 1482 TP_ARGS(mp, ino), 1483 TP_STRUCT__entry( 1484 __field(dev_t, dev) 1485 __field(xfs_ino_t, ino) 1486 ), 1487 TP_fast_assign( 1488 __entry->dev = mp->m_super->s_dev; 1489 __entry->ino = ino; 1490 ), 1491 TP_printk("dev %d:%d ino 0x%llx", 1492 MAJOR(__entry->dev), MINOR(__entry->dev), 1493 __entry->ino) 1494 ); 1495 1496 TRACE_EVENT(xchk_nlinks_live_update, 1497 TP_PROTO(struct xfs_mount *mp, const struct xfs_inode *dp, 1498 int action, xfs_ino_t ino, int delta, 1499 const char *name, unsigned int namelen), 1500 TP_ARGS(mp, dp, action, ino, delta, name, namelen), 1501 TP_STRUCT__entry( 1502 __field(dev_t, dev) 1503 __field(xfs_ino_t, dir) 1504 __field(int, action) 1505 __field(xfs_ino_t, ino) 1506 __field(int, delta) 1507 __field(unsigned int, namelen) 1508 __dynamic_array(char, name, namelen) 1509 ), 1510 TP_fast_assign( 1511 __entry->dev = mp->m_super->s_dev; 1512 __entry->dir = dp ? dp->i_ino : NULLFSINO; 1513 __entry->action = action; 1514 __entry->ino = ino; 1515 __entry->delta = delta; 1516 __entry->namelen = namelen; 1517 memcpy(__get_str(name), name, namelen); 1518 ), 1519 TP_printk("dev %d:%d dir 0x%llx ino 0x%llx nlink_delta %d name '%.*s'", 1520 MAJOR(__entry->dev), MINOR(__entry->dev), 1521 __entry->dir, 1522 __entry->ino, 1523 __entry->delta, 1524 __entry->namelen, 1525 __get_str(name)) 1526 ); 1527 1528 TRACE_EVENT(xchk_nlinks_check_zero, 1529 TP_PROTO(struct xfs_mount *mp, xfs_ino_t ino, 1530 const struct xchk_nlink *live), 1531 TP_ARGS(mp, ino, live), 1532 TP_STRUCT__entry( 1533 __field(dev_t, dev) 1534 __field(xfs_ino_t, ino) 1535 __field(xfs_nlink_t, parents) 1536 __field(xfs_nlink_t, backrefs) 1537 __field(xfs_nlink_t, children) 1538 ), 1539 TP_fast_assign( 1540 __entry->dev = mp->m_super->s_dev; 1541 __entry->ino = ino; 1542 __entry->parents = live->parents; 1543 __entry->backrefs = live->backrefs; 1544 __entry->children = live->children; 1545 ), 1546 TP_printk("dev %d:%d ino 0x%llx parents %u backrefs %u children %u", 1547 MAJOR(__entry->dev), MINOR(__entry->dev), 1548 __entry->ino, 1549 __entry->parents, 1550 __entry->backrefs, 1551 __entry->children) 1552 ); 1553 1554 TRACE_EVENT(xchk_nlinks_update_incore, 1555 TP_PROTO(struct xfs_mount *mp, xfs_ino_t ino, 1556 const struct xchk_nlink *live, int parents_delta, 1557 int backrefs_delta, int children_delta), 1558 TP_ARGS(mp, ino, live, parents_delta, backrefs_delta, children_delta), 1559 TP_STRUCT__entry( 1560 __field(dev_t, dev) 1561 __field(xfs_ino_t, ino) 1562 __field(xfs_nlink_t, parents) 1563 __field(xfs_nlink_t, backrefs) 1564 __field(xfs_nlink_t, children) 1565 __field(int, parents_delta) 1566 __field(int, backrefs_delta) 1567 __field(int, children_delta) 1568 ), 1569 TP_fast_assign( 1570 __entry->dev = mp->m_super->s_dev; 1571 __entry->ino = ino; 1572 __entry->parents = live->parents; 1573 __entry->backrefs = live->backrefs; 1574 __entry->children = live->children; 1575 __entry->parents_delta = parents_delta; 1576 __entry->backrefs_delta = backrefs_delta; 1577 __entry->children_delta = children_delta; 1578 ), 1579 TP_printk("dev %d:%d ino 0x%llx parents %d:%u backrefs %d:%u children %d:%u", 1580 MAJOR(__entry->dev), MINOR(__entry->dev), 1581 __entry->ino, 1582 __entry->parents_delta, 1583 __entry->parents, 1584 __entry->backrefs_delta, 1585 __entry->backrefs, 1586 __entry->children_delta, 1587 __entry->children) 1588 ); 1589 1590 DECLARE_EVENT_CLASS(xchk_nlinks_diff_class, 1591 TP_PROTO(struct xfs_mount *mp, struct xfs_inode *ip, 1592 const struct xchk_nlink *live), 1593 TP_ARGS(mp, ip, live), 1594 TP_STRUCT__entry( 1595 __field(dev_t, dev) 1596 __field(xfs_ino_t, ino) 1597 __field(uint8_t, ftype) 1598 __field(xfs_nlink_t, nlink) 1599 __field(xfs_nlink_t, parents) 1600 __field(xfs_nlink_t, backrefs) 1601 __field(xfs_nlink_t, children) 1602 ), 1603 TP_fast_assign( 1604 __entry->dev = mp->m_super->s_dev; 1605 __entry->ino = ip->i_ino; 1606 __entry->ftype = xfs_mode_to_ftype(VFS_I(ip)->i_mode); 1607 __entry->nlink = VFS_I(ip)->i_nlink; 1608 __entry->parents = live->parents; 1609 __entry->backrefs = live->backrefs; 1610 __entry->children = live->children; 1611 ), 1612 TP_printk("dev %d:%d ino 0x%llx ftype %s nlink %u parents %u backrefs %u children %u", 1613 MAJOR(__entry->dev), MINOR(__entry->dev), 1614 __entry->ino, 1615 __print_symbolic(__entry->ftype, XFS_DIR3_FTYPE_STR), 1616 __entry->nlink, 1617 __entry->parents, 1618 __entry->backrefs, 1619 __entry->children) 1620 ); 1621 #define DEFINE_SCRUB_NLINKS_DIFF_EVENT(name) \ 1622 DEFINE_EVENT(xchk_nlinks_diff_class, name, \ 1623 TP_PROTO(struct xfs_mount *mp, struct xfs_inode *ip, \ 1624 const struct xchk_nlink *live), \ 1625 TP_ARGS(mp, ip, live)) 1626 DEFINE_SCRUB_NLINKS_DIFF_EVENT(xchk_nlinks_compare_inode); 1627 1628 DECLARE_EVENT_CLASS(xchk_pptr_class, 1629 TP_PROTO(struct xfs_inode *ip, const struct xfs_name *name, 1630 xfs_ino_t far_ino), 1631 TP_ARGS(ip, name, far_ino), 1632 TP_STRUCT__entry( 1633 __field(dev_t, dev) 1634 __field(xfs_ino_t, ino) 1635 __field(unsigned int, namelen) 1636 __dynamic_array(char, name, name->len) 1637 __field(xfs_ino_t, far_ino) 1638 ), 1639 TP_fast_assign( 1640 __entry->dev = ip->i_mount->m_super->s_dev; 1641 __entry->ino = ip->i_ino; 1642 __entry->namelen = name->len; 1643 memcpy(__get_str(name), name, name->len); 1644 __entry->far_ino = far_ino; 1645 ), 1646 TP_printk("dev %d:%d ino 0x%llx name '%.*s' far_ino 0x%llx", 1647 MAJOR(__entry->dev), MINOR(__entry->dev), 1648 __entry->ino, 1649 __entry->namelen, 1650 __get_str(name), 1651 __entry->far_ino) 1652 ) 1653 #define DEFINE_XCHK_PPTR_EVENT(name) \ 1654 DEFINE_EVENT(xchk_pptr_class, name, \ 1655 TP_PROTO(struct xfs_inode *ip, const struct xfs_name *name, \ 1656 xfs_ino_t far_ino), \ 1657 TP_ARGS(ip, name, far_ino)) 1658 DEFINE_XCHK_PPTR_EVENT(xchk_dir_defer); 1659 DEFINE_XCHK_PPTR_EVENT(xchk_dir_slowpath); 1660 DEFINE_XCHK_PPTR_EVENT(xchk_dir_ultraslowpath); 1661 DEFINE_XCHK_PPTR_EVENT(xchk_parent_defer); 1662 DEFINE_XCHK_PPTR_EVENT(xchk_parent_slowpath); 1663 DEFINE_XCHK_PPTR_EVENT(xchk_parent_ultraslowpath); 1664 1665 DECLARE_EVENT_CLASS(xchk_dirtree_class, 1666 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *ip, 1667 unsigned int path_nr, const struct xfs_name *name, 1668 const struct xfs_parent_rec *pptr), 1669 TP_ARGS(sc, ip, path_nr, name, pptr), 1670 TP_STRUCT__entry( 1671 __field(dev_t, dev) 1672 __field(unsigned int, path_nr) 1673 __field(xfs_ino_t, child_ino) 1674 __field(unsigned int, child_gen) 1675 __field(xfs_ino_t, parent_ino) 1676 __field(unsigned int, parent_gen) 1677 __field(unsigned int, namelen) 1678 __dynamic_array(char, name, name->len) 1679 ), 1680 TP_fast_assign( 1681 __entry->dev = sc->mp->m_super->s_dev; 1682 __entry->path_nr = path_nr; 1683 __entry->child_ino = ip->i_ino; 1684 __entry->child_gen = VFS_I(ip)->i_generation; 1685 __entry->parent_ino = be64_to_cpu(pptr->p_ino); 1686 __entry->parent_gen = be32_to_cpu(pptr->p_gen); 1687 __entry->namelen = name->len; 1688 memcpy(__get_str(name), name->name, name->len); 1689 ), 1690 TP_printk("dev %d:%d path %u child_ino 0x%llx child_gen 0x%x parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 1691 MAJOR(__entry->dev), MINOR(__entry->dev), 1692 __entry->path_nr, 1693 __entry->child_ino, 1694 __entry->child_gen, 1695 __entry->parent_ino, 1696 __entry->parent_gen, 1697 __entry->namelen, 1698 __get_str(name)) 1699 ); 1700 #define DEFINE_XCHK_DIRTREE_EVENT(name) \ 1701 DEFINE_EVENT(xchk_dirtree_class, name, \ 1702 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *ip, \ 1703 unsigned int path_nr, const struct xfs_name *name, \ 1704 const struct xfs_parent_rec *pptr), \ 1705 TP_ARGS(sc, ip, path_nr, name, pptr)) 1706 DEFINE_XCHK_DIRTREE_EVENT(xchk_dirtree_create_path); 1707 DEFINE_XCHK_DIRTREE_EVENT(xchk_dirpath_walk_upwards); 1708 1709 DECLARE_EVENT_CLASS(xchk_dirpath_class, 1710 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *ip, 1711 unsigned int path_nr, unsigned int step_nr, 1712 const struct xfs_name *name, 1713 const struct xfs_parent_rec *pptr), 1714 TP_ARGS(sc, ip, path_nr, step_nr, name, pptr), 1715 TP_STRUCT__entry( 1716 __field(dev_t, dev) 1717 __field(unsigned int, path_nr) 1718 __field(unsigned int, step_nr) 1719 __field(xfs_ino_t, child_ino) 1720 __field(unsigned int, child_gen) 1721 __field(xfs_ino_t, parent_ino) 1722 __field(unsigned int, parent_gen) 1723 __field(unsigned int, namelen) 1724 __dynamic_array(char, name, name->len) 1725 ), 1726 TP_fast_assign( 1727 __entry->dev = sc->mp->m_super->s_dev; 1728 __entry->path_nr = path_nr; 1729 __entry->step_nr = step_nr; 1730 __entry->child_ino = ip->i_ino; 1731 __entry->child_gen = VFS_I(ip)->i_generation; 1732 __entry->parent_ino = be64_to_cpu(pptr->p_ino); 1733 __entry->parent_gen = be32_to_cpu(pptr->p_gen); 1734 __entry->namelen = name->len; 1735 memcpy(__get_str(name), name->name, name->len); 1736 ), 1737 TP_printk("dev %d:%d path %u step %u child_ino 0x%llx child_gen 0x%x parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 1738 MAJOR(__entry->dev), MINOR(__entry->dev), 1739 __entry->path_nr, 1740 __entry->step_nr, 1741 __entry->child_ino, 1742 __entry->child_gen, 1743 __entry->parent_ino, 1744 __entry->parent_gen, 1745 __entry->namelen, 1746 __get_str(name)) 1747 ); 1748 #define DEFINE_XCHK_DIRPATH_EVENT(name) \ 1749 DEFINE_EVENT(xchk_dirpath_class, name, \ 1750 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *ip, \ 1751 unsigned int path_nr, unsigned int step_nr, \ 1752 const struct xfs_name *name, \ 1753 const struct xfs_parent_rec *pptr), \ 1754 TP_ARGS(sc, ip, path_nr, step_nr, name, pptr)) 1755 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_disappeared); 1756 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_badgen); 1757 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_nondir_parent); 1758 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_unlinked_parent); 1759 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_found_next_step); 1760 DEFINE_XCHK_DIRPATH_EVENT(xchk_dirpath_crosses_tree); 1761 1762 TRACE_DEFINE_ENUM(XCHK_DIRPATH_SCANNING); 1763 TRACE_DEFINE_ENUM(XCHK_DIRPATH_DELETE); 1764 TRACE_DEFINE_ENUM(XCHK_DIRPATH_CORRUPT); 1765 TRACE_DEFINE_ENUM(XCHK_DIRPATH_LOOP); 1766 TRACE_DEFINE_ENUM(XCHK_DIRPATH_STALE); 1767 TRACE_DEFINE_ENUM(XCHK_DIRPATH_OK); 1768 TRACE_DEFINE_ENUM(XREP_DIRPATH_DELETING); 1769 TRACE_DEFINE_ENUM(XREP_DIRPATH_DELETED); 1770 TRACE_DEFINE_ENUM(XREP_DIRPATH_ADOPTING); 1771 TRACE_DEFINE_ENUM(XREP_DIRPATH_ADOPTED); 1772 1773 #define XCHK_DIRPATH_OUTCOME_STRINGS \ 1774 { XCHK_DIRPATH_SCANNING, "scanning" }, \ 1775 { XCHK_DIRPATH_DELETE, "delete" }, \ 1776 { XCHK_DIRPATH_CORRUPT, "corrupt" }, \ 1777 { XCHK_DIRPATH_LOOP, "loop" }, \ 1778 { XCHK_DIRPATH_STALE, "stale" }, \ 1779 { XCHK_DIRPATH_OK, "ok" }, \ 1780 { XREP_DIRPATH_DELETING, "deleting" }, \ 1781 { XREP_DIRPATH_DELETED, "deleted" }, \ 1782 { XREP_DIRPATH_ADOPTING, "adopting" }, \ 1783 { XREP_DIRPATH_ADOPTED, "adopted" } 1784 1785 DECLARE_EVENT_CLASS(xchk_dirpath_outcome_class, 1786 TP_PROTO(struct xfs_scrub *sc, unsigned long long path_nr, 1787 unsigned int nr_steps, \ 1788 unsigned int outcome), 1789 TP_ARGS(sc, path_nr, nr_steps, outcome), 1790 TP_STRUCT__entry( 1791 __field(dev_t, dev) 1792 __field(unsigned long long, path_nr) 1793 __field(unsigned int, nr_steps) 1794 __field(unsigned int, outcome) 1795 ), 1796 TP_fast_assign( 1797 __entry->dev = sc->mp->m_super->s_dev; 1798 __entry->path_nr = path_nr; 1799 __entry->nr_steps = nr_steps; 1800 __entry->outcome = outcome; 1801 ), 1802 TP_printk("dev %d:%d path %llu steps %u outcome %s", 1803 MAJOR(__entry->dev), MINOR(__entry->dev), 1804 __entry->path_nr, 1805 __entry->nr_steps, 1806 __print_symbolic(__entry->outcome, XCHK_DIRPATH_OUTCOME_STRINGS)) 1807 ); 1808 #define DEFINE_XCHK_DIRPATH_OUTCOME_EVENT(name) \ 1809 DEFINE_EVENT(xchk_dirpath_outcome_class, name, \ 1810 TP_PROTO(struct xfs_scrub *sc, unsigned long long path_nr, \ 1811 unsigned int nr_steps, \ 1812 unsigned int outcome), \ 1813 TP_ARGS(sc, path_nr, nr_steps, outcome)) 1814 DEFINE_XCHK_DIRPATH_OUTCOME_EVENT(xchk_dirpath_set_outcome); 1815 DEFINE_XCHK_DIRPATH_OUTCOME_EVENT(xchk_dirpath_evaluate_path); 1816 1817 DECLARE_EVENT_CLASS(xchk_dirtree_evaluate_class, 1818 TP_PROTO(const struct xchk_dirtree *dl, 1819 const struct xchk_dirtree_outcomes *oc), 1820 TP_ARGS(dl, oc), 1821 TP_STRUCT__entry( 1822 __field(dev_t, dev) 1823 __field(xfs_ino_t, ino) 1824 __field(xfs_ino_t, rootino) 1825 __field(unsigned int, nr_paths) 1826 __field(unsigned int, bad) 1827 __field(unsigned int, suspect) 1828 __field(unsigned int, good) 1829 __field(bool, needs_adoption) 1830 ), 1831 TP_fast_assign( 1832 __entry->dev = dl->sc->mp->m_super->s_dev; 1833 __entry->ino = dl->sc->ip->i_ino; 1834 __entry->rootino = dl->root_ino; 1835 __entry->nr_paths = dl->nr_paths; 1836 __entry->bad = oc->bad; 1837 __entry->suspect = oc->suspect; 1838 __entry->good = oc->good; 1839 __entry->needs_adoption = oc->needs_adoption ? 1 : 0; 1840 ), 1841 TP_printk("dev %d:%d ino 0x%llx rootino 0x%llx nr_paths %u bad %u suspect %u good %u adopt? %d", 1842 MAJOR(__entry->dev), MINOR(__entry->dev), 1843 __entry->ino, 1844 __entry->rootino, 1845 __entry->nr_paths, 1846 __entry->bad, 1847 __entry->suspect, 1848 __entry->good, 1849 __entry->needs_adoption) 1850 ); 1851 #define DEFINE_XCHK_DIRTREE_EVALUATE_EVENT(name) \ 1852 DEFINE_EVENT(xchk_dirtree_evaluate_class, name, \ 1853 TP_PROTO(const struct xchk_dirtree *dl, \ 1854 const struct xchk_dirtree_outcomes *oc), \ 1855 TP_ARGS(dl, oc)) 1856 DEFINE_XCHK_DIRTREE_EVALUATE_EVENT(xchk_dirtree_evaluate); 1857 1858 TRACE_EVENT(xchk_dirpath_changed, 1859 TP_PROTO(struct xfs_scrub *sc, unsigned int path_nr, 1860 unsigned int step_nr, const struct xfs_inode *dp, 1861 const struct xfs_inode *ip, const struct xfs_name *xname), 1862 TP_ARGS(sc, path_nr, step_nr, dp, ip, xname), 1863 TP_STRUCT__entry( 1864 __field(dev_t, dev) 1865 __field(unsigned int, path_nr) 1866 __field(unsigned int, step_nr) 1867 __field(xfs_ino_t, child_ino) 1868 __field(xfs_ino_t, parent_ino) 1869 __field(unsigned int, namelen) 1870 __dynamic_array(char, name, xname->len) 1871 ), 1872 TP_fast_assign( 1873 __entry->dev = sc->mp->m_super->s_dev; 1874 __entry->path_nr = path_nr; 1875 __entry->step_nr = step_nr; 1876 __entry->child_ino = ip->i_ino; 1877 __entry->parent_ino = dp->i_ino; 1878 __entry->namelen = xname->len; 1879 memcpy(__get_str(name), xname->name, xname->len); 1880 ), 1881 TP_printk("dev %d:%d path %u step %u child_ino 0x%llx parent_ino 0x%llx name '%.*s'", 1882 MAJOR(__entry->dev), MINOR(__entry->dev), 1883 __entry->path_nr, 1884 __entry->step_nr, 1885 __entry->child_ino, 1886 __entry->parent_ino, 1887 __entry->namelen, 1888 __get_str(name)) 1889 ); 1890 1891 TRACE_EVENT(xchk_dirtree_live_update, 1892 TP_PROTO(struct xfs_scrub *sc, const struct xfs_inode *dp, 1893 int action, const struct xfs_inode *ip, int delta, 1894 const struct xfs_name *xname), 1895 TP_ARGS(sc, dp, action, ip, delta, xname), 1896 TP_STRUCT__entry( 1897 __field(dev_t, dev) 1898 __field(xfs_ino_t, parent_ino) 1899 __field(int, action) 1900 __field(xfs_ino_t, child_ino) 1901 __field(int, delta) 1902 __field(unsigned int, namelen) 1903 __dynamic_array(char, name, xname->len) 1904 ), 1905 TP_fast_assign( 1906 __entry->dev = sc->mp->m_super->s_dev; 1907 __entry->parent_ino = dp->i_ino; 1908 __entry->action = action; 1909 __entry->child_ino = ip->i_ino; 1910 __entry->delta = delta; 1911 __entry->namelen = xname->len; 1912 memcpy(__get_str(name), xname->name, xname->len); 1913 ), 1914 TP_printk("dev %d:%d parent_ino 0x%llx child_ino 0x%llx nlink_delta %d name '%.*s'", 1915 MAJOR(__entry->dev), MINOR(__entry->dev), 1916 __entry->parent_ino, 1917 __entry->child_ino, 1918 __entry->delta, 1919 __entry->namelen, 1920 __get_str(name)) 1921 ); 1922 1923 DECLARE_EVENT_CLASS(xchk_metapath_class, 1924 TP_PROTO(struct xfs_scrub *sc, const char *path, 1925 struct xfs_inode *dp, xfs_ino_t ino), 1926 TP_ARGS(sc, path, dp, ino), 1927 TP_STRUCT__entry( 1928 __field(dev_t, dev) 1929 __field(xfs_ino_t, scrub_ino) 1930 __field(xfs_ino_t, parent_ino) 1931 __field(xfs_ino_t, ino) 1932 __string(name, path) 1933 ), 1934 TP_fast_assign( 1935 __entry->dev = sc->mp->m_super->s_dev; 1936 __entry->scrub_ino = sc->ip ? sc->ip->i_ino : NULLFSINO; 1937 __entry->parent_ino = dp ? dp->i_ino : NULLFSINO; 1938 __entry->ino = ino; 1939 __assign_str(name); 1940 ), 1941 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx name '%s' ino 0x%llx", 1942 MAJOR(__entry->dev), MINOR(__entry->dev), 1943 __entry->scrub_ino, 1944 __entry->parent_ino, 1945 __get_str(name), 1946 __entry->ino) 1947 ); 1948 #define DEFINE_XCHK_METAPATH_EVENT(name) \ 1949 DEFINE_EVENT(xchk_metapath_class, name, \ 1950 TP_PROTO(struct xfs_scrub *sc, const char *path, \ 1951 struct xfs_inode *dp, xfs_ino_t ino), \ 1952 TP_ARGS(sc, path, dp, ino)) 1953 DEFINE_XCHK_METAPATH_EVENT(xchk_metapath_lookup); 1954 1955 /* repair tracepoints */ 1956 #if IS_ENABLED(CONFIG_XFS_ONLINE_REPAIR) 1957 1958 DECLARE_EVENT_CLASS(xrep_extent_class, 1959 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, 1960 xfs_extlen_t len), 1961 TP_ARGS(pag, agbno, len), 1962 TP_STRUCT__entry( 1963 __field(dev_t, dev) 1964 __field(xfs_agnumber_t, agno) 1965 __field(xfs_agblock_t, agbno) 1966 __field(xfs_extlen_t, len) 1967 ), 1968 TP_fast_assign( 1969 __entry->dev = pag_mount(pag)->m_super->s_dev; 1970 __entry->agno = pag_agno(pag); 1971 __entry->agbno = agbno; 1972 __entry->len = len; 1973 ), 1974 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x", 1975 MAJOR(__entry->dev), MINOR(__entry->dev), 1976 __entry->agno, 1977 __entry->agbno, 1978 __entry->len) 1979 ); 1980 #define DEFINE_REPAIR_EXTENT_EVENT(name) \ 1981 DEFINE_EVENT(xrep_extent_class, name, \ 1982 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, \ 1983 xfs_extlen_t len), \ 1984 TP_ARGS(pag, agbno, len)) 1985 DEFINE_REPAIR_EXTENT_EVENT(xreap_dispose_unmap_extent); 1986 DEFINE_REPAIR_EXTENT_EVENT(xreap_dispose_free_extent); 1987 DEFINE_REPAIR_EXTENT_EVENT(xreap_agextent_binval); 1988 DEFINE_REPAIR_EXTENT_EVENT(xreap_bmapi_binval); 1989 DEFINE_REPAIR_EXTENT_EVENT(xrep_agfl_insert); 1990 1991 DECLARE_EVENT_CLASS(xrep_reap_find_class, 1992 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, 1993 xfs_extlen_t len, bool crosslinked), 1994 TP_ARGS(pag, agbno, len, crosslinked), 1995 TP_STRUCT__entry( 1996 __field(dev_t, dev) 1997 __field(xfs_agnumber_t, agno) 1998 __field(xfs_agblock_t, agbno) 1999 __field(xfs_extlen_t, len) 2000 __field(bool, crosslinked) 2001 ), 2002 TP_fast_assign( 2003 __entry->dev = pag_mount(pag)->m_super->s_dev; 2004 __entry->agno = pag_agno(pag); 2005 __entry->agbno = agbno; 2006 __entry->len = len; 2007 __entry->crosslinked = crosslinked; 2008 ), 2009 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x crosslinked %d", 2010 MAJOR(__entry->dev), MINOR(__entry->dev), 2011 __entry->agno, 2012 __entry->agbno, 2013 __entry->len, 2014 __entry->crosslinked ? 1 : 0) 2015 ); 2016 #define DEFINE_REPAIR_REAP_FIND_EVENT(name) \ 2017 DEFINE_EVENT(xrep_reap_find_class, name, \ 2018 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, \ 2019 xfs_extlen_t len, bool crosslinked), \ 2020 TP_ARGS(pag, agbno, len, crosslinked)) 2021 DEFINE_REPAIR_REAP_FIND_EVENT(xreap_agextent_select); 2022 DEFINE_REPAIR_REAP_FIND_EVENT(xreap_bmapi_select); 2023 2024 TRACE_EVENT(xrep_ibt_walk_rmap, 2025 TP_PROTO(const struct xfs_perag *pag, const struct xfs_rmap_irec *rec), 2026 TP_ARGS(pag, rec), 2027 TP_STRUCT__entry( 2028 __field(dev_t, dev) 2029 __field(xfs_agnumber_t, agno) 2030 __field(xfs_agblock_t, agbno) 2031 __field(xfs_extlen_t, len) 2032 __field(uint64_t, owner) 2033 __field(uint64_t, offset) 2034 __field(unsigned int, flags) 2035 ), 2036 TP_fast_assign( 2037 __entry->dev = pag_mount(pag)->m_super->s_dev; 2038 __entry->agno = pag_agno(pag); 2039 __entry->agbno = rec->rm_startblock; 2040 __entry->len = rec->rm_blockcount; 2041 __entry->owner = rec->rm_owner; 2042 __entry->offset = rec->rm_offset; 2043 __entry->flags = rec->rm_flags; 2044 ), 2045 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x owner 0x%llx fileoff 0x%llx flags 0x%x", 2046 MAJOR(__entry->dev), MINOR(__entry->dev), 2047 __entry->agno, 2048 __entry->agbno, 2049 __entry->len, 2050 __entry->owner, 2051 __entry->offset, 2052 __entry->flags) 2053 ); 2054 2055 TRACE_EVENT(xrep_abt_found, 2056 TP_PROTO(const struct xfs_perag *pag, 2057 const struct xfs_alloc_rec_incore *rec), 2058 TP_ARGS(pag, rec), 2059 TP_STRUCT__entry( 2060 __field(dev_t, dev) 2061 __field(xfs_agnumber_t, agno) 2062 __field(xfs_agblock_t, startblock) 2063 __field(xfs_extlen_t, blockcount) 2064 ), 2065 TP_fast_assign( 2066 __entry->dev = pag_mount(pag)->m_super->s_dev; 2067 __entry->agno = pag_agno(pag); 2068 __entry->startblock = rec->ar_startblock; 2069 __entry->blockcount = rec->ar_blockcount; 2070 ), 2071 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x", 2072 MAJOR(__entry->dev), MINOR(__entry->dev), 2073 __entry->agno, 2074 __entry->startblock, 2075 __entry->blockcount) 2076 ) 2077 2078 TRACE_EVENT(xrep_ibt_found, 2079 TP_PROTO(const struct xfs_perag *pag, 2080 const struct xfs_inobt_rec_incore *rec), 2081 TP_ARGS(pag, rec), 2082 TP_STRUCT__entry( 2083 __field(dev_t, dev) 2084 __field(xfs_agnumber_t, agno) 2085 __field(xfs_agino_t, startino) 2086 __field(uint16_t, holemask) 2087 __field(uint8_t, count) 2088 __field(uint8_t, freecount) 2089 __field(uint64_t, freemask) 2090 ), 2091 TP_fast_assign( 2092 __entry->dev = pag_mount(pag)->m_super->s_dev; 2093 __entry->agno = pag_agno(pag); 2094 __entry->startino = rec->ir_startino; 2095 __entry->holemask = rec->ir_holemask; 2096 __entry->count = rec->ir_count; 2097 __entry->freecount = rec->ir_freecount; 2098 __entry->freemask = rec->ir_free; 2099 ), 2100 TP_printk("dev %d:%d agno 0x%x agino 0x%x holemask 0x%x count 0x%x freecount 0x%x freemask 0x%llx", 2101 MAJOR(__entry->dev), MINOR(__entry->dev), 2102 __entry->agno, 2103 __entry->startino, 2104 __entry->holemask, 2105 __entry->count, 2106 __entry->freecount, 2107 __entry->freemask) 2108 ) 2109 2110 TRACE_EVENT(xrep_refc_found, 2111 TP_PROTO(const struct xfs_perag *pag, 2112 const struct xfs_refcount_irec *rec), 2113 TP_ARGS(pag, rec), 2114 TP_STRUCT__entry( 2115 __field(dev_t, dev) 2116 __field(xfs_agnumber_t, agno) 2117 __field(enum xfs_refc_domain, domain) 2118 __field(xfs_agblock_t, startblock) 2119 __field(xfs_extlen_t, blockcount) 2120 __field(xfs_nlink_t, refcount) 2121 ), 2122 TP_fast_assign( 2123 __entry->dev = pag_mount(pag)->m_super->s_dev; 2124 __entry->agno = pag_agno(pag); 2125 __entry->domain = rec->rc_domain; 2126 __entry->startblock = rec->rc_startblock; 2127 __entry->blockcount = rec->rc_blockcount; 2128 __entry->refcount = rec->rc_refcount; 2129 ), 2130 TP_printk("dev %d:%d agno 0x%x dom %s agbno 0x%x fsbcount 0x%x refcount %u", 2131 MAJOR(__entry->dev), MINOR(__entry->dev), 2132 __entry->agno, 2133 __print_symbolic(__entry->domain, XFS_REFC_DOMAIN_STRINGS), 2134 __entry->startblock, 2135 __entry->blockcount, 2136 __entry->refcount) 2137 ) 2138 2139 TRACE_EVENT(xrep_bmap_found, 2140 TP_PROTO(struct xfs_inode *ip, int whichfork, 2141 struct xfs_bmbt_irec *irec), 2142 TP_ARGS(ip, whichfork, irec), 2143 TP_STRUCT__entry( 2144 __field(dev_t, dev) 2145 __field(xfs_ino_t, ino) 2146 __field(int, whichfork) 2147 __field(xfs_fileoff_t, lblk) 2148 __field(xfs_filblks_t, len) 2149 __field(xfs_fsblock_t, pblk) 2150 __field(int, state) 2151 ), 2152 TP_fast_assign( 2153 __entry->dev = VFS_I(ip)->i_sb->s_dev; 2154 __entry->ino = ip->i_ino; 2155 __entry->whichfork = whichfork; 2156 __entry->lblk = irec->br_startoff; 2157 __entry->len = irec->br_blockcount; 2158 __entry->pblk = irec->br_startblock; 2159 __entry->state = irec->br_state; 2160 ), 2161 TP_printk("dev %d:%d ino 0x%llx whichfork %s fileoff 0x%llx fsbcount 0x%llx startblock 0x%llx state %d", 2162 MAJOR(__entry->dev), MINOR(__entry->dev), 2163 __entry->ino, 2164 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 2165 __entry->lblk, 2166 __entry->len, 2167 __entry->pblk, 2168 __entry->state) 2169 ); 2170 2171 TRACE_EVENT(xrep_rmap_found, 2172 TP_PROTO(const struct xfs_perag *pag, const struct xfs_rmap_irec *rec), 2173 TP_ARGS(pag, rec), 2174 TP_STRUCT__entry( 2175 __field(dev_t, dev) 2176 __field(xfs_agnumber_t, agno) 2177 __field(xfs_agblock_t, agbno) 2178 __field(xfs_extlen_t, len) 2179 __field(uint64_t, owner) 2180 __field(uint64_t, offset) 2181 __field(unsigned int, flags) 2182 ), 2183 TP_fast_assign( 2184 __entry->dev = pag_mount(pag)->m_super->s_dev; 2185 __entry->agno = pag_agno(pag); 2186 __entry->agbno = rec->rm_startblock; 2187 __entry->len = rec->rm_blockcount; 2188 __entry->owner = rec->rm_owner; 2189 __entry->offset = rec->rm_offset; 2190 __entry->flags = rec->rm_flags; 2191 ), 2192 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x owner 0x%llx fileoff 0x%llx flags 0x%x", 2193 MAJOR(__entry->dev), MINOR(__entry->dev), 2194 __entry->agno, 2195 __entry->agbno, 2196 __entry->len, 2197 __entry->owner, 2198 __entry->offset, 2199 __entry->flags) 2200 ); 2201 2202 TRACE_EVENT(xrep_findroot_block, 2203 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, 2204 uint32_t magic, uint16_t level), 2205 TP_ARGS(pag, agbno, magic, level), 2206 TP_STRUCT__entry( 2207 __field(dev_t, dev) 2208 __field(xfs_agnumber_t, agno) 2209 __field(xfs_agblock_t, agbno) 2210 __field(uint32_t, magic) 2211 __field(uint16_t, level) 2212 ), 2213 TP_fast_assign( 2214 __entry->dev = pag_mount(pag)->m_super->s_dev; 2215 __entry->agno = pag_agno(pag); 2216 __entry->agbno = agbno; 2217 __entry->magic = magic; 2218 __entry->level = level; 2219 ), 2220 TP_printk("dev %d:%d agno 0x%x agbno 0x%x magic 0x%x level %u", 2221 MAJOR(__entry->dev), MINOR(__entry->dev), 2222 __entry->agno, 2223 __entry->agbno, 2224 __entry->magic, 2225 __entry->level) 2226 ) 2227 TRACE_EVENT(xrep_calc_ag_resblks, 2228 TP_PROTO(const struct xfs_perag *pag, xfs_agino_t icount, 2229 xfs_agblock_t aglen, xfs_agblock_t freelen, 2230 xfs_agblock_t usedlen), 2231 TP_ARGS(pag, icount, aglen, freelen, usedlen), 2232 TP_STRUCT__entry( 2233 __field(dev_t, dev) 2234 __field(xfs_agnumber_t, agno) 2235 __field(xfs_agino_t, icount) 2236 __field(xfs_agblock_t, aglen) 2237 __field(xfs_agblock_t, freelen) 2238 __field(xfs_agblock_t, usedlen) 2239 ), 2240 TP_fast_assign( 2241 __entry->dev = pag_mount(pag)->m_super->s_dev; 2242 __entry->agno = pag_agno(pag); 2243 __entry->icount = icount; 2244 __entry->aglen = aglen; 2245 __entry->freelen = freelen; 2246 __entry->usedlen = usedlen; 2247 ), 2248 TP_printk("dev %d:%d agno 0x%x icount %u aglen %u freelen %u usedlen %u", 2249 MAJOR(__entry->dev), MINOR(__entry->dev), 2250 __entry->agno, 2251 __entry->icount, 2252 __entry->aglen, 2253 __entry->freelen, 2254 __entry->usedlen) 2255 ) 2256 TRACE_EVENT(xrep_calc_ag_resblks_btsize, 2257 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t bnobt_sz, 2258 xfs_agblock_t inobt_sz, xfs_agblock_t rmapbt_sz, 2259 xfs_agblock_t refcbt_sz), 2260 TP_ARGS(pag, bnobt_sz, inobt_sz, rmapbt_sz, refcbt_sz), 2261 TP_STRUCT__entry( 2262 __field(dev_t, dev) 2263 __field(xfs_agnumber_t, agno) 2264 __field(xfs_agblock_t, bnobt_sz) 2265 __field(xfs_agblock_t, inobt_sz) 2266 __field(xfs_agblock_t, rmapbt_sz) 2267 __field(xfs_agblock_t, refcbt_sz) 2268 ), 2269 TP_fast_assign( 2270 __entry->dev = pag_mount(pag)->m_super->s_dev; 2271 __entry->agno = pag_agno(pag); 2272 __entry->bnobt_sz = bnobt_sz; 2273 __entry->inobt_sz = inobt_sz; 2274 __entry->rmapbt_sz = rmapbt_sz; 2275 __entry->refcbt_sz = refcbt_sz; 2276 ), 2277 TP_printk("dev %d:%d agno 0x%x bnobt %u inobt %u rmapbt %u refcountbt %u", 2278 MAJOR(__entry->dev), MINOR(__entry->dev), 2279 __entry->agno, 2280 __entry->bnobt_sz, 2281 __entry->inobt_sz, 2282 __entry->rmapbt_sz, 2283 __entry->refcbt_sz) 2284 ) 2285 TRACE_EVENT(xrep_reset_counters, 2286 TP_PROTO(struct xfs_mount *mp, struct xchk_fscounters *fsc), 2287 TP_ARGS(mp, fsc), 2288 TP_STRUCT__entry( 2289 __field(dev_t, dev) 2290 __field(uint64_t, icount) 2291 __field(uint64_t, ifree) 2292 __field(uint64_t, fdblocks) 2293 __field(uint64_t, frextents) 2294 ), 2295 TP_fast_assign( 2296 __entry->dev = mp->m_super->s_dev; 2297 __entry->icount = fsc->icount; 2298 __entry->ifree = fsc->ifree; 2299 __entry->fdblocks = fsc->fdblocks; 2300 __entry->frextents = fsc->frextents; 2301 ), 2302 TP_printk("dev %d:%d icount %llu ifree %llu fdblocks %llu frextents %llu", 2303 MAJOR(__entry->dev), MINOR(__entry->dev), 2304 __entry->icount, 2305 __entry->ifree, 2306 __entry->fdblocks, 2307 __entry->frextents) 2308 ) 2309 2310 DECLARE_EVENT_CLASS(xrep_newbt_extent_class, 2311 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, 2312 xfs_extlen_t len, int64_t owner), 2313 TP_ARGS(pag, agbno, len, owner), 2314 TP_STRUCT__entry( 2315 __field(dev_t, dev) 2316 __field(xfs_agnumber_t, agno) 2317 __field(xfs_agblock_t, agbno) 2318 __field(xfs_extlen_t, len) 2319 __field(int64_t, owner) 2320 ), 2321 TP_fast_assign( 2322 __entry->dev = pag_mount(pag)->m_super->s_dev; 2323 __entry->agno = pag_agno(pag); 2324 __entry->agbno = agbno; 2325 __entry->len = len; 2326 __entry->owner = owner; 2327 ), 2328 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x owner 0x%llx", 2329 MAJOR(__entry->dev), MINOR(__entry->dev), 2330 __entry->agno, 2331 __entry->agbno, 2332 __entry->len, 2333 __entry->owner) 2334 ); 2335 #define DEFINE_NEWBT_EXTENT_EVENT(name) \ 2336 DEFINE_EVENT(xrep_newbt_extent_class, name, \ 2337 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, \ 2338 xfs_extlen_t len, int64_t owner), \ 2339 TP_ARGS(pag, agbno, len, owner)) 2340 DEFINE_NEWBT_EXTENT_EVENT(xrep_newbt_alloc_ag_blocks); 2341 DEFINE_NEWBT_EXTENT_EVENT(xrep_newbt_alloc_file_blocks); 2342 DEFINE_NEWBT_EXTENT_EVENT(xrep_newbt_free_blocks); 2343 DEFINE_NEWBT_EXTENT_EVENT(xrep_newbt_claim_block); 2344 2345 DECLARE_EVENT_CLASS(xrep_dinode_class, 2346 TP_PROTO(struct xfs_scrub *sc, struct xfs_dinode *dip), 2347 TP_ARGS(sc, dip), 2348 TP_STRUCT__entry( 2349 __field(dev_t, dev) 2350 __field(xfs_ino_t, ino) 2351 __field(uint16_t, mode) 2352 __field(uint8_t, version) 2353 __field(uint8_t, format) 2354 __field(uint32_t, uid) 2355 __field(uint32_t, gid) 2356 __field(uint64_t, size) 2357 __field(uint64_t, nblocks) 2358 __field(uint32_t, extsize) 2359 __field(uint32_t, nextents) 2360 __field(uint16_t, anextents) 2361 __field(uint8_t, forkoff) 2362 __field(uint8_t, aformat) 2363 __field(uint16_t, flags) 2364 __field(uint32_t, gen) 2365 __field(uint64_t, flags2) 2366 __field(uint32_t, cowextsize) 2367 ), 2368 TP_fast_assign( 2369 __entry->dev = sc->mp->m_super->s_dev; 2370 __entry->ino = sc->sm->sm_ino; 2371 __entry->mode = be16_to_cpu(dip->di_mode); 2372 __entry->version = dip->di_version; 2373 __entry->format = dip->di_format; 2374 __entry->uid = be32_to_cpu(dip->di_uid); 2375 __entry->gid = be32_to_cpu(dip->di_gid); 2376 __entry->size = be64_to_cpu(dip->di_size); 2377 __entry->nblocks = be64_to_cpu(dip->di_nblocks); 2378 __entry->extsize = be32_to_cpu(dip->di_extsize); 2379 __entry->nextents = be32_to_cpu(dip->di_nextents); 2380 __entry->anextents = be16_to_cpu(dip->di_anextents); 2381 __entry->forkoff = dip->di_forkoff; 2382 __entry->aformat = dip->di_aformat; 2383 __entry->flags = be16_to_cpu(dip->di_flags); 2384 __entry->gen = be32_to_cpu(dip->di_gen); 2385 __entry->flags2 = be64_to_cpu(dip->di_flags2); 2386 __entry->cowextsize = be32_to_cpu(dip->di_cowextsize); 2387 ), 2388 TP_printk("dev %d:%d ino 0x%llx mode 0x%x version %u format %u uid %u gid %u disize 0x%llx nblocks 0x%llx extsize %u nextents %u anextents %u forkoff 0x%x aformat %u flags 0x%x gen 0x%x flags2 0x%llx cowextsize %u", 2389 MAJOR(__entry->dev), MINOR(__entry->dev), 2390 __entry->ino, 2391 __entry->mode, 2392 __entry->version, 2393 __entry->format, 2394 __entry->uid, 2395 __entry->gid, 2396 __entry->size, 2397 __entry->nblocks, 2398 __entry->extsize, 2399 __entry->nextents, 2400 __entry->anextents, 2401 __entry->forkoff, 2402 __entry->aformat, 2403 __entry->flags, 2404 __entry->gen, 2405 __entry->flags2, 2406 __entry->cowextsize) 2407 ) 2408 2409 #define DEFINE_REPAIR_DINODE_EVENT(name) \ 2410 DEFINE_EVENT(xrep_dinode_class, name, \ 2411 TP_PROTO(struct xfs_scrub *sc, struct xfs_dinode *dip), \ 2412 TP_ARGS(sc, dip)) 2413 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_header); 2414 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_mode); 2415 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_flags); 2416 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_size); 2417 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_extsize_hints); 2418 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_zap_symlink); 2419 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_zap_dir); 2420 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_fixed); 2421 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_zap_forks); 2422 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_zap_dfork); 2423 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_zap_afork); 2424 DEFINE_REPAIR_DINODE_EVENT(xrep_dinode_ensure_forkoff); 2425 2426 DECLARE_EVENT_CLASS(xrep_inode_class, 2427 TP_PROTO(struct xfs_scrub *sc), 2428 TP_ARGS(sc), 2429 TP_STRUCT__entry( 2430 __field(dev_t, dev) 2431 __field(xfs_ino_t, ino) 2432 __field(xfs_fsize_t, size) 2433 __field(xfs_rfsblock_t, nblocks) 2434 __field(uint16_t, flags) 2435 __field(uint64_t, flags2) 2436 __field(uint32_t, nextents) 2437 __field(uint8_t, format) 2438 __field(uint32_t, anextents) 2439 __field(uint8_t, aformat) 2440 ), 2441 TP_fast_assign( 2442 __entry->dev = sc->mp->m_super->s_dev; 2443 __entry->ino = sc->sm->sm_ino; 2444 __entry->size = sc->ip->i_disk_size; 2445 __entry->nblocks = sc->ip->i_nblocks; 2446 __entry->flags = sc->ip->i_diflags; 2447 __entry->flags2 = sc->ip->i_diflags2; 2448 __entry->nextents = sc->ip->i_df.if_nextents; 2449 __entry->format = sc->ip->i_df.if_format; 2450 __entry->anextents = sc->ip->i_af.if_nextents; 2451 __entry->aformat = sc->ip->i_af.if_format; 2452 ), 2453 TP_printk("dev %d:%d ino 0x%llx disize 0x%llx nblocks 0x%llx flags 0x%x flags2 0x%llx nextents %u format %u anextents %u aformat %u", 2454 MAJOR(__entry->dev), MINOR(__entry->dev), 2455 __entry->ino, 2456 __entry->size, 2457 __entry->nblocks, 2458 __entry->flags, 2459 __entry->flags2, 2460 __entry->nextents, 2461 __entry->format, 2462 __entry->anextents, 2463 __entry->aformat) 2464 ) 2465 2466 #define DEFINE_REPAIR_INODE_EVENT(name) \ 2467 DEFINE_EVENT(xrep_inode_class, name, \ 2468 TP_PROTO(struct xfs_scrub *sc), \ 2469 TP_ARGS(sc)) 2470 DEFINE_REPAIR_INODE_EVENT(xrep_inode_blockcounts); 2471 DEFINE_REPAIR_INODE_EVENT(xrep_inode_ids); 2472 DEFINE_REPAIR_INODE_EVENT(xrep_inode_flags); 2473 DEFINE_REPAIR_INODE_EVENT(xrep_inode_blockdir_size); 2474 DEFINE_REPAIR_INODE_EVENT(xrep_inode_sfdir_size); 2475 DEFINE_REPAIR_INODE_EVENT(xrep_inode_dir_size); 2476 DEFINE_REPAIR_INODE_EVENT(xrep_inode_fixed); 2477 2478 TRACE_EVENT(xrep_dinode_count_rmaps, 2479 TP_PROTO(struct xfs_scrub *sc, xfs_rfsblock_t data_blocks, 2480 xfs_rfsblock_t rt_blocks, xfs_rfsblock_t attr_blocks, 2481 xfs_extnum_t data_extents, xfs_extnum_t rt_extents, 2482 xfs_aextnum_t attr_extents), 2483 TP_ARGS(sc, data_blocks, rt_blocks, attr_blocks, data_extents, 2484 rt_extents, attr_extents), 2485 TP_STRUCT__entry( 2486 __field(dev_t, dev) 2487 __field(xfs_ino_t, ino) 2488 __field(xfs_rfsblock_t, data_blocks) 2489 __field(xfs_rfsblock_t, rt_blocks) 2490 __field(xfs_rfsblock_t, attr_blocks) 2491 __field(xfs_extnum_t, data_extents) 2492 __field(xfs_extnum_t, rt_extents) 2493 __field(xfs_aextnum_t, attr_extents) 2494 ), 2495 TP_fast_assign( 2496 __entry->dev = sc->mp->m_super->s_dev; 2497 __entry->ino = sc->sm->sm_ino; 2498 __entry->data_blocks = data_blocks; 2499 __entry->rt_blocks = rt_blocks; 2500 __entry->attr_blocks = attr_blocks; 2501 __entry->data_extents = data_extents; 2502 __entry->rt_extents = rt_extents; 2503 __entry->attr_extents = attr_extents; 2504 ), 2505 TP_printk("dev %d:%d ino 0x%llx dblocks 0x%llx rtblocks 0x%llx ablocks 0x%llx dextents %llu rtextents %llu aextents %u", 2506 MAJOR(__entry->dev), MINOR(__entry->dev), 2507 __entry->ino, 2508 __entry->data_blocks, 2509 __entry->rt_blocks, 2510 __entry->attr_blocks, 2511 __entry->data_extents, 2512 __entry->rt_extents, 2513 __entry->attr_extents) 2514 ); 2515 2516 TRACE_EVENT(xrep_dinode_findmode_dirent, 2517 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *dp, 2518 unsigned int ftype), 2519 TP_ARGS(sc, dp, ftype), 2520 TP_STRUCT__entry( 2521 __field(dev_t, dev) 2522 __field(xfs_ino_t, ino) 2523 __field(xfs_ino_t, parent_ino) 2524 __field(unsigned int, ftype) 2525 ), 2526 TP_fast_assign( 2527 __entry->dev = sc->mp->m_super->s_dev; 2528 __entry->ino = sc->sm->sm_ino; 2529 __entry->parent_ino = dp->i_ino; 2530 __entry->ftype = ftype; 2531 ), 2532 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx ftype '%s'", 2533 MAJOR(__entry->dev), MINOR(__entry->dev), 2534 __entry->ino, 2535 __entry->parent_ino, 2536 __print_symbolic(__entry->ftype, XFS_DIR3_FTYPE_STR)) 2537 ); 2538 2539 TRACE_EVENT(xrep_dinode_findmode_dirent_inval, 2540 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *dp, 2541 unsigned int ftype, unsigned int found_ftype), 2542 TP_ARGS(sc, dp, ftype, found_ftype), 2543 TP_STRUCT__entry( 2544 __field(dev_t, dev) 2545 __field(xfs_ino_t, ino) 2546 __field(xfs_ino_t, parent_ino) 2547 __field(unsigned int, ftype) 2548 __field(unsigned int, found_ftype) 2549 ), 2550 TP_fast_assign( 2551 __entry->dev = sc->mp->m_super->s_dev; 2552 __entry->ino = sc->sm->sm_ino; 2553 __entry->parent_ino = dp->i_ino; 2554 __entry->ftype = ftype; 2555 __entry->found_ftype = found_ftype; 2556 ), 2557 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx ftype '%s' found_ftype '%s'", 2558 MAJOR(__entry->dev), MINOR(__entry->dev), 2559 __entry->ino, 2560 __entry->parent_ino, 2561 __print_symbolic(__entry->ftype, XFS_DIR3_FTYPE_STR), 2562 __print_symbolic(__entry->found_ftype, XFS_DIR3_FTYPE_STR)) 2563 ); 2564 2565 TRACE_EVENT(xrep_cow_mark_file_range, 2566 TP_PROTO(struct xfs_inode *ip, xfs_fsblock_t startblock, 2567 xfs_fileoff_t startoff, xfs_filblks_t blockcount), 2568 TP_ARGS(ip, startblock, startoff, blockcount), 2569 TP_STRUCT__entry( 2570 __field(dev_t, dev) 2571 __field(xfs_ino_t, ino) 2572 __field(xfs_fsblock_t, startblock) 2573 __field(xfs_fileoff_t, startoff) 2574 __field(xfs_filblks_t, blockcount) 2575 ), 2576 TP_fast_assign( 2577 __entry->dev = ip->i_mount->m_super->s_dev; 2578 __entry->ino = ip->i_ino; 2579 __entry->startoff = startoff; 2580 __entry->startblock = startblock; 2581 __entry->blockcount = blockcount; 2582 ), 2583 TP_printk("dev %d:%d ino 0x%llx fileoff 0x%llx startblock 0x%llx fsbcount 0x%llx", 2584 MAJOR(__entry->dev), MINOR(__entry->dev), 2585 __entry->ino, 2586 __entry->startoff, 2587 __entry->startblock, 2588 __entry->blockcount) 2589 ); 2590 2591 TRACE_EVENT(xrep_cow_replace_mapping, 2592 TP_PROTO(struct xfs_inode *ip, const struct xfs_bmbt_irec *irec, 2593 xfs_fsblock_t new_startblock, xfs_extlen_t new_blockcount), 2594 TP_ARGS(ip, irec, new_startblock, new_blockcount), 2595 TP_STRUCT__entry( 2596 __field(dev_t, dev) 2597 __field(xfs_ino_t, ino) 2598 __field(xfs_fsblock_t, startblock) 2599 __field(xfs_fileoff_t, startoff) 2600 __field(xfs_filblks_t, blockcount) 2601 __field(xfs_exntst_t, state) 2602 __field(xfs_fsblock_t, new_startblock) 2603 __field(xfs_extlen_t, new_blockcount) 2604 ), 2605 TP_fast_assign( 2606 __entry->dev = ip->i_mount->m_super->s_dev; 2607 __entry->ino = ip->i_ino; 2608 __entry->startoff = irec->br_startoff; 2609 __entry->startblock = irec->br_startblock; 2610 __entry->blockcount = irec->br_blockcount; 2611 __entry->state = irec->br_state; 2612 __entry->new_startblock = new_startblock; 2613 __entry->new_blockcount = new_blockcount; 2614 ), 2615 TP_printk("dev %d:%d ino 0x%llx startoff 0x%llx startblock 0x%llx fsbcount 0x%llx state 0x%x new_startblock 0x%llx new_fsbcount 0x%x", 2616 MAJOR(__entry->dev), MINOR(__entry->dev), 2617 __entry->ino, 2618 __entry->startoff, 2619 __entry->startblock, 2620 __entry->blockcount, 2621 __entry->state, 2622 __entry->new_startblock, 2623 __entry->new_blockcount) 2624 ); 2625 2626 TRACE_EVENT(xrep_cow_free_staging, 2627 TP_PROTO(const struct xfs_perag *pag, xfs_agblock_t agbno, 2628 xfs_extlen_t blockcount), 2629 TP_ARGS(pag, agbno, blockcount), 2630 TP_STRUCT__entry( 2631 __field(dev_t, dev) 2632 __field(xfs_agnumber_t, agno) 2633 __field(xfs_agblock_t, agbno) 2634 __field(xfs_extlen_t, blockcount) 2635 ), 2636 TP_fast_assign( 2637 __entry->dev = pag_mount(pag)->m_super->s_dev; 2638 __entry->agno = pag_agno(pag); 2639 __entry->agbno = agbno; 2640 __entry->blockcount = blockcount; 2641 ), 2642 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%x", 2643 MAJOR(__entry->dev), MINOR(__entry->dev), 2644 __entry->agno, 2645 __entry->agbno, 2646 __entry->blockcount) 2647 ); 2648 2649 #ifdef CONFIG_XFS_QUOTA 2650 DECLARE_EVENT_CLASS(xrep_dquot_class, 2651 TP_PROTO(struct xfs_mount *mp, uint8_t type, uint32_t id), 2652 TP_ARGS(mp, type, id), 2653 TP_STRUCT__entry( 2654 __field(dev_t, dev) 2655 __field(uint8_t, type) 2656 __field(uint32_t, id) 2657 ), 2658 TP_fast_assign( 2659 __entry->dev = mp->m_super->s_dev; 2660 __entry->id = id; 2661 __entry->type = type; 2662 ), 2663 TP_printk("dev %d:%d type %s id 0x%x", 2664 MAJOR(__entry->dev), MINOR(__entry->dev), 2665 __print_flags(__entry->type, "|", XFS_DQTYPE_STRINGS), 2666 __entry->id) 2667 ); 2668 2669 #define DEFINE_XREP_DQUOT_EVENT(name) \ 2670 DEFINE_EVENT(xrep_dquot_class, name, \ 2671 TP_PROTO(struct xfs_mount *mp, uint8_t type, uint32_t id), \ 2672 TP_ARGS(mp, type, id)) 2673 DEFINE_XREP_DQUOT_EVENT(xrep_dquot_item); 2674 DEFINE_XREP_DQUOT_EVENT(xrep_disk_dquot); 2675 DEFINE_XREP_DQUOT_EVENT(xrep_dquot_item_fill_bmap_hole); 2676 DEFINE_XREP_DQUOT_EVENT(xrep_quotacheck_dquot); 2677 #endif /* CONFIG_XFS_QUOTA */ 2678 2679 DEFINE_SCRUB_NLINKS_DIFF_EVENT(xrep_nlinks_update_inode); 2680 DEFINE_SCRUB_NLINKS_DIFF_EVENT(xrep_nlinks_unfixable_inode); 2681 2682 TRACE_EVENT(xrep_rmap_live_update, 2683 TP_PROTO(const struct xfs_perag *pag, unsigned int op, 2684 const struct xfs_rmap_update_params *p), 2685 TP_ARGS(pag, op, p), 2686 TP_STRUCT__entry( 2687 __field(dev_t, dev) 2688 __field(xfs_agnumber_t, agno) 2689 __field(unsigned int, op) 2690 __field(xfs_agblock_t, agbno) 2691 __field(xfs_extlen_t, len) 2692 __field(uint64_t, owner) 2693 __field(uint64_t, offset) 2694 __field(unsigned int, flags) 2695 ), 2696 TP_fast_assign( 2697 __entry->dev = pag_mount(pag)->m_super->s_dev; 2698 __entry->agno = pag_agno(pag); 2699 __entry->op = op; 2700 __entry->agbno = p->startblock; 2701 __entry->len = p->blockcount; 2702 xfs_owner_info_unpack(&p->oinfo, &__entry->owner, 2703 &__entry->offset, &__entry->flags); 2704 if (p->unwritten) 2705 __entry->flags |= XFS_RMAP_UNWRITTEN; 2706 ), 2707 TP_printk("dev %d:%d agno 0x%x op %d agbno 0x%x fsbcount 0x%x owner 0x%llx fileoff 0x%llx flags 0x%x", 2708 MAJOR(__entry->dev), MINOR(__entry->dev), 2709 __entry->agno, 2710 __entry->op, 2711 __entry->agbno, 2712 __entry->len, 2713 __entry->owner, 2714 __entry->offset, 2715 __entry->flags) 2716 ); 2717 2718 TRACE_EVENT(xrep_tempfile_create, 2719 TP_PROTO(struct xfs_scrub *sc), 2720 TP_ARGS(sc), 2721 TP_STRUCT__entry( 2722 __field(dev_t, dev) 2723 __field(xfs_ino_t, ino) 2724 __field(unsigned int, type) 2725 __field(xfs_agnumber_t, agno) 2726 __field(xfs_ino_t, inum) 2727 __field(unsigned int, gen) 2728 __field(unsigned int, flags) 2729 __field(xfs_ino_t, temp_inum) 2730 ), 2731 TP_fast_assign( 2732 __entry->dev = sc->mp->m_super->s_dev; 2733 __entry->ino = sc->file ? XFS_I(file_inode(sc->file))->i_ino : 0; 2734 __entry->type = sc->sm->sm_type; 2735 __entry->agno = sc->sm->sm_agno; 2736 __entry->inum = sc->sm->sm_ino; 2737 __entry->gen = sc->sm->sm_gen; 2738 __entry->flags = sc->sm->sm_flags; 2739 __entry->temp_inum = sc->tempip->i_ino; 2740 ), 2741 TP_printk("dev %d:%d ino 0x%llx type %s inum 0x%llx gen 0x%x flags 0x%x temp_inum 0x%llx", 2742 MAJOR(__entry->dev), MINOR(__entry->dev), 2743 __entry->ino, 2744 __print_symbolic(__entry->type, XFS_SCRUB_TYPE_STRINGS), 2745 __entry->inum, 2746 __entry->gen, 2747 __entry->flags, 2748 __entry->temp_inum) 2749 ); 2750 2751 DECLARE_EVENT_CLASS(xrep_tempfile_class, 2752 TP_PROTO(struct xfs_scrub *sc, int whichfork, 2753 struct xfs_bmbt_irec *irec), 2754 TP_ARGS(sc, whichfork, irec), 2755 TP_STRUCT__entry( 2756 __field(dev_t, dev) 2757 __field(xfs_ino_t, ino) 2758 __field(int, whichfork) 2759 __field(xfs_fileoff_t, lblk) 2760 __field(xfs_filblks_t, len) 2761 __field(xfs_fsblock_t, pblk) 2762 __field(int, state) 2763 ), 2764 TP_fast_assign( 2765 __entry->dev = sc->mp->m_super->s_dev; 2766 __entry->ino = sc->tempip->i_ino; 2767 __entry->whichfork = whichfork; 2768 __entry->lblk = irec->br_startoff; 2769 __entry->len = irec->br_blockcount; 2770 __entry->pblk = irec->br_startblock; 2771 __entry->state = irec->br_state; 2772 ), 2773 TP_printk("dev %d:%d ino 0x%llx whichfork %s fileoff 0x%llx fsbcount 0x%llx startblock 0x%llx state %d", 2774 MAJOR(__entry->dev), MINOR(__entry->dev), 2775 __entry->ino, 2776 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 2777 __entry->lblk, 2778 __entry->len, 2779 __entry->pblk, 2780 __entry->state) 2781 ); 2782 #define DEFINE_XREP_TEMPFILE_EVENT(name) \ 2783 DEFINE_EVENT(xrep_tempfile_class, name, \ 2784 TP_PROTO(struct xfs_scrub *sc, int whichfork, \ 2785 struct xfs_bmbt_irec *irec), \ 2786 TP_ARGS(sc, whichfork, irec)) 2787 DEFINE_XREP_TEMPFILE_EVENT(xrep_tempfile_prealloc); 2788 DEFINE_XREP_TEMPFILE_EVENT(xrep_tempfile_copyin); 2789 2790 TRACE_EVENT(xreap_ifork_extent, 2791 TP_PROTO(struct xfs_scrub *sc, struct xfs_inode *ip, int whichfork, 2792 const struct xfs_bmbt_irec *irec), 2793 TP_ARGS(sc, ip, whichfork, irec), 2794 TP_STRUCT__entry( 2795 __field(dev_t, dev) 2796 __field(xfs_ino_t, ino) 2797 __field(int, whichfork) 2798 __field(xfs_fileoff_t, fileoff) 2799 __field(xfs_filblks_t, len) 2800 __field(xfs_agnumber_t, agno) 2801 __field(xfs_agblock_t, agbno) 2802 __field(int, state) 2803 ), 2804 TP_fast_assign( 2805 __entry->dev = sc->mp->m_super->s_dev; 2806 __entry->ino = ip->i_ino; 2807 __entry->whichfork = whichfork; 2808 __entry->fileoff = irec->br_startoff; 2809 __entry->len = irec->br_blockcount; 2810 __entry->agno = XFS_FSB_TO_AGNO(sc->mp, irec->br_startblock); 2811 __entry->agbno = XFS_FSB_TO_AGBNO(sc->mp, irec->br_startblock); 2812 __entry->state = irec->br_state; 2813 ), 2814 TP_printk("dev %d:%d ip 0x%llx whichfork %s agno 0x%x agbno 0x%x fileoff 0x%llx fsbcount 0x%llx state 0x%x", 2815 MAJOR(__entry->dev), MINOR(__entry->dev), 2816 __entry->ino, 2817 __print_symbolic(__entry->whichfork, XFS_WHICHFORK_STRINGS), 2818 __entry->agno, 2819 __entry->agbno, 2820 __entry->fileoff, 2821 __entry->len, 2822 __entry->state) 2823 ); 2824 2825 TRACE_EVENT(xreap_bmapi_binval_scan, 2826 TP_PROTO(struct xfs_scrub *sc, const struct xfs_bmbt_irec *irec, 2827 xfs_extlen_t scan_blocks), 2828 TP_ARGS(sc, irec, scan_blocks), 2829 TP_STRUCT__entry( 2830 __field(dev_t, dev) 2831 __field(xfs_filblks_t, len) 2832 __field(xfs_agnumber_t, agno) 2833 __field(xfs_agblock_t, agbno) 2834 __field(xfs_extlen_t, scan_blocks) 2835 ), 2836 TP_fast_assign( 2837 __entry->dev = sc->mp->m_super->s_dev; 2838 __entry->len = irec->br_blockcount; 2839 __entry->agno = XFS_FSB_TO_AGNO(sc->mp, irec->br_startblock); 2840 __entry->agbno = XFS_FSB_TO_AGBNO(sc->mp, irec->br_startblock); 2841 __entry->scan_blocks = scan_blocks; 2842 ), 2843 TP_printk("dev %d:%d agno 0x%x agbno 0x%x fsbcount 0x%llx scan_blocks 0x%x", 2844 MAJOR(__entry->dev), MINOR(__entry->dev), 2845 __entry->agno, 2846 __entry->agbno, 2847 __entry->len, 2848 __entry->scan_blocks) 2849 ); 2850 2851 TRACE_EVENT(xrep_xattr_recover_leafblock, 2852 TP_PROTO(struct xfs_inode *ip, xfs_dablk_t dabno, uint16_t magic), 2853 TP_ARGS(ip, dabno, magic), 2854 TP_STRUCT__entry( 2855 __field(dev_t, dev) 2856 __field(xfs_ino_t, ino) 2857 __field(xfs_dablk_t, dabno) 2858 __field(uint16_t, magic) 2859 ), 2860 TP_fast_assign( 2861 __entry->dev = ip->i_mount->m_super->s_dev; 2862 __entry->ino = ip->i_ino; 2863 __entry->dabno = dabno; 2864 __entry->magic = magic; 2865 ), 2866 TP_printk("dev %d:%d ino 0x%llx dablk 0x%x magic 0x%x", 2867 MAJOR(__entry->dev), MINOR(__entry->dev), 2868 __entry->ino, 2869 __entry->dabno, 2870 __entry->magic) 2871 ); 2872 2873 DECLARE_EVENT_CLASS(xrep_xattr_salvage_class, 2874 TP_PROTO(struct xfs_inode *ip, unsigned int flags, char *name, 2875 unsigned int namelen, unsigned int valuelen), 2876 TP_ARGS(ip, flags, name, namelen, valuelen), 2877 TP_STRUCT__entry( 2878 __field(dev_t, dev) 2879 __field(xfs_ino_t, ino) 2880 __field(unsigned int, flags) 2881 __field(unsigned int, namelen) 2882 __dynamic_array(char, name, namelen) 2883 __field(unsigned int, valuelen) 2884 ), 2885 TP_fast_assign( 2886 __entry->dev = ip->i_mount->m_super->s_dev; 2887 __entry->ino = ip->i_ino; 2888 __entry->flags = flags; 2889 __entry->namelen = namelen; 2890 memcpy(__get_str(name), name, namelen); 2891 __entry->valuelen = valuelen; 2892 ), 2893 TP_printk("dev %d:%d ino 0x%llx flags %s name '%.*s' valuelen 0x%x", 2894 MAJOR(__entry->dev), MINOR(__entry->dev), 2895 __entry->ino, 2896 __print_flags(__entry->flags, "|", XFS_ATTR_NAMESPACE_STR), 2897 __entry->namelen, 2898 __get_str(name), 2899 __entry->valuelen) 2900 ); 2901 #define DEFINE_XREP_XATTR_SALVAGE_EVENT(name) \ 2902 DEFINE_EVENT(xrep_xattr_salvage_class, name, \ 2903 TP_PROTO(struct xfs_inode *ip, unsigned int flags, char *name, \ 2904 unsigned int namelen, unsigned int valuelen), \ 2905 TP_ARGS(ip, flags, name, namelen, valuelen)) 2906 DEFINE_XREP_XATTR_SALVAGE_EVENT(xrep_xattr_salvage_rec); 2907 DEFINE_XREP_XATTR_SALVAGE_EVENT(xrep_xattr_insert_rec); 2908 DEFINE_XREP_XATTR_SALVAGE_EVENT(xrep_parent_stash_xattr); 2909 DEFINE_XREP_XATTR_SALVAGE_EVENT(xrep_parent_insert_xattr); 2910 2911 DECLARE_EVENT_CLASS(xrep_pptr_salvage_class, 2912 TP_PROTO(struct xfs_inode *ip, unsigned int flags, const void *name, 2913 unsigned int namelen, const void *value, unsigned int valuelen), 2914 TP_ARGS(ip, flags, name, namelen, value, valuelen), 2915 TP_STRUCT__entry( 2916 __field(dev_t, dev) 2917 __field(xfs_ino_t, ino) 2918 __field(xfs_ino_t, parent_ino) 2919 __field(unsigned int, parent_gen) 2920 __field(unsigned int, namelen) 2921 __dynamic_array(char, name, namelen) 2922 ), 2923 TP_fast_assign( 2924 const struct xfs_parent_rec *rec = value; 2925 2926 __entry->dev = ip->i_mount->m_super->s_dev; 2927 __entry->ino = ip->i_ino; 2928 __entry->parent_ino = be64_to_cpu(rec->p_ino); 2929 __entry->parent_gen = be32_to_cpu(rec->p_gen); 2930 __entry->namelen = namelen; 2931 memcpy(__get_str(name), name, namelen); 2932 ), 2933 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 2934 MAJOR(__entry->dev), MINOR(__entry->dev), 2935 __entry->ino, 2936 __entry->parent_ino, 2937 __entry->parent_gen, 2938 __entry->namelen, 2939 __get_str(name)) 2940 ) 2941 #define DEFINE_XREP_PPTR_SALVAGE_EVENT(name) \ 2942 DEFINE_EVENT(xrep_pptr_salvage_class, name, \ 2943 TP_PROTO(struct xfs_inode *ip, unsigned int flags, const void *name, \ 2944 unsigned int namelen, const void *value, unsigned int valuelen), \ 2945 TP_ARGS(ip, flags, name, namelen, value, valuelen)) 2946 DEFINE_XREP_PPTR_SALVAGE_EVENT(xrep_xattr_salvage_pptr); 2947 DEFINE_XREP_PPTR_SALVAGE_EVENT(xrep_xattr_insert_pptr); 2948 2949 TRACE_EVENT(xrep_xattr_class, 2950 TP_PROTO(struct xfs_inode *ip, struct xfs_inode *arg_ip), 2951 TP_ARGS(ip, arg_ip), 2952 TP_STRUCT__entry( 2953 __field(dev_t, dev) 2954 __field(xfs_ino_t, ino) 2955 __field(xfs_ino_t, src_ino) 2956 ), 2957 TP_fast_assign( 2958 __entry->dev = ip->i_mount->m_super->s_dev; 2959 __entry->ino = ip->i_ino; 2960 __entry->src_ino = arg_ip->i_ino; 2961 ), 2962 TP_printk("dev %d:%d ino 0x%llx src 0x%llx", 2963 MAJOR(__entry->dev), MINOR(__entry->dev), 2964 __entry->ino, 2965 __entry->src_ino) 2966 ) 2967 #define DEFINE_XREP_XATTR_EVENT(name) \ 2968 DEFINE_EVENT(xrep_xattr_class, name, \ 2969 TP_PROTO(struct xfs_inode *ip, struct xfs_inode *arg_ip), \ 2970 TP_ARGS(ip, arg_ip)) 2971 DEFINE_XREP_XATTR_EVENT(xrep_xattr_rebuild_tree); 2972 DEFINE_XREP_XATTR_EVENT(xrep_xattr_reset_fork); 2973 DEFINE_XREP_XATTR_EVENT(xrep_xattr_full_reset); 2974 2975 DECLARE_EVENT_CLASS(xrep_xattr_pptr_scan_class, 2976 TP_PROTO(struct xfs_inode *ip, const struct xfs_inode *dp, 2977 const struct xfs_name *name), 2978 TP_ARGS(ip, dp, name), 2979 TP_STRUCT__entry( 2980 __field(dev_t, dev) 2981 __field(xfs_ino_t, ino) 2982 __field(xfs_ino_t, parent_ino) 2983 __field(unsigned int, parent_gen) 2984 __field(unsigned int, namelen) 2985 __dynamic_array(char, name, name->len) 2986 ), 2987 TP_fast_assign( 2988 __entry->dev = ip->i_mount->m_super->s_dev; 2989 __entry->ino = ip->i_ino; 2990 __entry->parent_ino = dp->i_ino; 2991 __entry->parent_gen = VFS_IC(dp)->i_generation; 2992 __entry->namelen = name->len; 2993 memcpy(__get_str(name), name->name, name->len); 2994 ), 2995 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 2996 MAJOR(__entry->dev), MINOR(__entry->dev), 2997 __entry->ino, 2998 __entry->parent_ino, 2999 __entry->parent_gen, 3000 __entry->namelen, 3001 __get_str(name)) 3002 ) 3003 #define DEFINE_XREP_XATTR_PPTR_SCAN_EVENT(name) \ 3004 DEFINE_EVENT(xrep_xattr_pptr_scan_class, name, \ 3005 TP_PROTO(struct xfs_inode *ip, const struct xfs_inode *dp, \ 3006 const struct xfs_name *name), \ 3007 TP_ARGS(ip, dp, name)) 3008 DEFINE_XREP_XATTR_PPTR_SCAN_EVENT(xrep_xattr_stash_parentadd); 3009 DEFINE_XREP_XATTR_PPTR_SCAN_EVENT(xrep_xattr_stash_parentremove); 3010 3011 TRACE_EVENT(xrep_dir_recover_dirblock, 3012 TP_PROTO(struct xfs_inode *dp, xfs_dablk_t dabno, uint32_t magic, 3013 uint32_t magic_guess), 3014 TP_ARGS(dp, dabno, magic, magic_guess), 3015 TP_STRUCT__entry( 3016 __field(dev_t, dev) 3017 __field(xfs_ino_t, dir_ino) 3018 __field(xfs_dablk_t, dabno) 3019 __field(uint32_t, magic) 3020 __field(uint32_t, magic_guess) 3021 ), 3022 TP_fast_assign( 3023 __entry->dev = dp->i_mount->m_super->s_dev; 3024 __entry->dir_ino = dp->i_ino; 3025 __entry->dabno = dabno; 3026 __entry->magic = magic; 3027 __entry->magic_guess = magic_guess; 3028 ), 3029 TP_printk("dev %d:%d dir 0x%llx dablk 0x%x magic 0x%x magic_guess 0x%x", 3030 MAJOR(__entry->dev), MINOR(__entry->dev), 3031 __entry->dir_ino, 3032 __entry->dabno, 3033 __entry->magic, 3034 __entry->magic_guess) 3035 ); 3036 3037 DECLARE_EVENT_CLASS(xrep_dir_class, 3038 TP_PROTO(struct xfs_inode *dp, xfs_ino_t parent_ino), 3039 TP_ARGS(dp, parent_ino), 3040 TP_STRUCT__entry( 3041 __field(dev_t, dev) 3042 __field(xfs_ino_t, dir_ino) 3043 __field(xfs_ino_t, parent_ino) 3044 ), 3045 TP_fast_assign( 3046 __entry->dev = dp->i_mount->m_super->s_dev; 3047 __entry->dir_ino = dp->i_ino; 3048 __entry->parent_ino = parent_ino; 3049 ), 3050 TP_printk("dev %d:%d dir 0x%llx parent 0x%llx", 3051 MAJOR(__entry->dev), MINOR(__entry->dev), 3052 __entry->dir_ino, 3053 __entry->parent_ino) 3054 ) 3055 #define DEFINE_XREP_DIR_EVENT(name) \ 3056 DEFINE_EVENT(xrep_dir_class, name, \ 3057 TP_PROTO(struct xfs_inode *dp, xfs_ino_t parent_ino), \ 3058 TP_ARGS(dp, parent_ino)) 3059 DEFINE_XREP_DIR_EVENT(xrep_dir_rebuild_tree); 3060 DEFINE_XREP_DIR_EVENT(xrep_dir_reset_fork); 3061 DEFINE_XREP_DIR_EVENT(xrep_parent_reset_dotdot); 3062 3063 DECLARE_EVENT_CLASS(xrep_dirent_class, 3064 TP_PROTO(struct xfs_inode *dp, const struct xfs_name *name, 3065 xfs_ino_t ino), 3066 TP_ARGS(dp, name, ino), 3067 TP_STRUCT__entry( 3068 __field(dev_t, dev) 3069 __field(xfs_ino_t, dir_ino) 3070 __field(unsigned int, namelen) 3071 __dynamic_array(char, name, name->len) 3072 __field(xfs_ino_t, ino) 3073 __field(uint8_t, ftype) 3074 ), 3075 TP_fast_assign( 3076 __entry->dev = dp->i_mount->m_super->s_dev; 3077 __entry->dir_ino = dp->i_ino; 3078 __entry->namelen = name->len; 3079 memcpy(__get_str(name), name->name, name->len); 3080 __entry->ino = ino; 3081 __entry->ftype = name->type; 3082 ), 3083 TP_printk("dev %d:%d dir 0x%llx ftype %s name '%.*s' ino 0x%llx", 3084 MAJOR(__entry->dev), MINOR(__entry->dev), 3085 __entry->dir_ino, 3086 __print_symbolic(__entry->ftype, XFS_DIR3_FTYPE_STR), 3087 __entry->namelen, 3088 __get_str(name), 3089 __entry->ino) 3090 ) 3091 #define DEFINE_XREP_DIRENT_EVENT(name) \ 3092 DEFINE_EVENT(xrep_dirent_class, name, \ 3093 TP_PROTO(struct xfs_inode *dp, const struct xfs_name *name, \ 3094 xfs_ino_t ino), \ 3095 TP_ARGS(dp, name, ino)) 3096 DEFINE_XREP_DIRENT_EVENT(xrep_dir_salvage_entry); 3097 DEFINE_XREP_DIRENT_EVENT(xrep_dir_stash_createname); 3098 DEFINE_XREP_DIRENT_EVENT(xrep_dir_replay_createname); 3099 DEFINE_XREP_DIRENT_EVENT(xrep_adoption_reparent); 3100 DEFINE_XREP_DIRENT_EVENT(xrep_dir_stash_removename); 3101 DEFINE_XREP_DIRENT_EVENT(xrep_dir_replay_removename); 3102 3103 DECLARE_EVENT_CLASS(xrep_adoption_class, 3104 TP_PROTO(struct xfs_inode *dp, struct xfs_inode *ip, bool moved), 3105 TP_ARGS(dp, ip, moved), 3106 TP_STRUCT__entry( 3107 __field(dev_t, dev) 3108 __field(xfs_ino_t, dir_ino) 3109 __field(xfs_ino_t, child_ino) 3110 __field(bool, moved) 3111 ), 3112 TP_fast_assign( 3113 __entry->dev = dp->i_mount->m_super->s_dev; 3114 __entry->dir_ino = dp->i_ino; 3115 __entry->child_ino = ip->i_ino; 3116 __entry->moved = moved; 3117 ), 3118 TP_printk("dev %d:%d dir 0x%llx child 0x%llx moved? %d", 3119 MAJOR(__entry->dev), MINOR(__entry->dev), 3120 __entry->dir_ino, 3121 __entry->child_ino, 3122 __entry->moved) 3123 ); 3124 #define DEFINE_XREP_ADOPTION_EVENT(name) \ 3125 DEFINE_EVENT(xrep_adoption_class, name, \ 3126 TP_PROTO(struct xfs_inode *dp, struct xfs_inode *ip, bool moved), \ 3127 TP_ARGS(dp, ip, moved)) 3128 DEFINE_XREP_ADOPTION_EVENT(xrep_adoption_trans_roll); 3129 3130 DECLARE_EVENT_CLASS(xrep_parent_salvage_class, 3131 TP_PROTO(struct xfs_inode *dp, xfs_ino_t ino), 3132 TP_ARGS(dp, ino), 3133 TP_STRUCT__entry( 3134 __field(dev_t, dev) 3135 __field(xfs_ino_t, dir_ino) 3136 __field(xfs_ino_t, ino) 3137 ), 3138 TP_fast_assign( 3139 __entry->dev = dp->i_mount->m_super->s_dev; 3140 __entry->dir_ino = dp->i_ino; 3141 __entry->ino = ino; 3142 ), 3143 TP_printk("dev %d:%d dir 0x%llx parent 0x%llx", 3144 MAJOR(__entry->dev), MINOR(__entry->dev), 3145 __entry->dir_ino, 3146 __entry->ino) 3147 ) 3148 #define DEFINE_XREP_PARENT_SALVAGE_EVENT(name) \ 3149 DEFINE_EVENT(xrep_parent_salvage_class, name, \ 3150 TP_PROTO(struct xfs_inode *dp, xfs_ino_t ino), \ 3151 TP_ARGS(dp, ino)) 3152 DEFINE_XREP_PARENT_SALVAGE_EVENT(xrep_dir_salvaged_parent); 3153 DEFINE_XREP_PARENT_SALVAGE_EVENT(xrep_findparent_dirent); 3154 DEFINE_XREP_PARENT_SALVAGE_EVENT(xrep_findparent_from_dcache); 3155 3156 DECLARE_EVENT_CLASS(xrep_pptr_class, 3157 TP_PROTO(struct xfs_inode *ip, const struct xfs_name *name, 3158 const struct xfs_parent_rec *pptr), 3159 TP_ARGS(ip, name, pptr), 3160 TP_STRUCT__entry( 3161 __field(dev_t, dev) 3162 __field(xfs_ino_t, ino) 3163 __field(xfs_ino_t, parent_ino) 3164 __field(unsigned int, parent_gen) 3165 __field(unsigned int, namelen) 3166 __dynamic_array(char, name, name->len) 3167 ), 3168 TP_fast_assign( 3169 __entry->dev = ip->i_mount->m_super->s_dev; 3170 __entry->ino = ip->i_ino; 3171 __entry->parent_ino = be64_to_cpu(pptr->p_ino); 3172 __entry->parent_gen = be32_to_cpu(pptr->p_gen); 3173 __entry->namelen = name->len; 3174 memcpy(__get_str(name), name->name, name->len); 3175 ), 3176 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 3177 MAJOR(__entry->dev), MINOR(__entry->dev), 3178 __entry->ino, 3179 __entry->parent_ino, 3180 __entry->parent_gen, 3181 __entry->namelen, 3182 __get_str(name)) 3183 ) 3184 #define DEFINE_XREP_PPTR_EVENT(name) \ 3185 DEFINE_EVENT(xrep_pptr_class, name, \ 3186 TP_PROTO(struct xfs_inode *ip, const struct xfs_name *name, \ 3187 const struct xfs_parent_rec *pptr), \ 3188 TP_ARGS(ip, name, pptr)) 3189 DEFINE_XREP_PPTR_EVENT(xrep_xattr_replay_parentadd); 3190 DEFINE_XREP_PPTR_EVENT(xrep_xattr_replay_parentremove); 3191 DEFINE_XREP_PPTR_EVENT(xrep_parent_replay_parentadd); 3192 DEFINE_XREP_PPTR_EVENT(xrep_parent_replay_parentremove); 3193 3194 DECLARE_EVENT_CLASS(xrep_pptr_scan_class, 3195 TP_PROTO(struct xfs_inode *ip, const struct xfs_inode *dp, 3196 const struct xfs_name *name), 3197 TP_ARGS(ip, dp, name), 3198 TP_STRUCT__entry( 3199 __field(dev_t, dev) 3200 __field(xfs_ino_t, ino) 3201 __field(xfs_ino_t, parent_ino) 3202 __field(unsigned int, parent_gen) 3203 __field(unsigned int, namelen) 3204 __dynamic_array(char, name, name->len) 3205 ), 3206 TP_fast_assign( 3207 __entry->dev = ip->i_mount->m_super->s_dev; 3208 __entry->ino = ip->i_ino; 3209 __entry->parent_ino = dp->i_ino; 3210 __entry->parent_gen = VFS_IC(dp)->i_generation; 3211 __entry->namelen = name->len; 3212 memcpy(__get_str(name), name->name, name->len); 3213 ), 3214 TP_printk("dev %d:%d ino 0x%llx parent_ino 0x%llx parent_gen 0x%x name '%.*s'", 3215 MAJOR(__entry->dev), MINOR(__entry->dev), 3216 __entry->ino, 3217 __entry->parent_ino, 3218 __entry->parent_gen, 3219 __entry->namelen, 3220 __get_str(name)) 3221 ) 3222 #define DEFINE_XREP_PPTR_SCAN_EVENT(name) \ 3223 DEFINE_EVENT(xrep_pptr_scan_class, name, \ 3224 TP_PROTO(struct xfs_inode *ip, const struct xfs_inode *dp, \ 3225 const struct xfs_name *name), \ 3226 TP_ARGS(ip, dp, name)) 3227 DEFINE_XREP_PPTR_SCAN_EVENT(xrep_parent_stash_parentadd); 3228 DEFINE_XREP_PPTR_SCAN_EVENT(xrep_parent_stash_parentremove); 3229 3230 TRACE_EVENT(xrep_nlinks_set_record, 3231 TP_PROTO(struct xfs_mount *mp, xfs_ino_t ino, 3232 const struct xchk_nlink *obs), 3233 TP_ARGS(mp, ino, obs), 3234 TP_STRUCT__entry( 3235 __field(dev_t, dev) 3236 __field(xfs_ino_t, ino) 3237 __field(xfs_nlink_t, parents) 3238 __field(xfs_nlink_t, backrefs) 3239 __field(xfs_nlink_t, children) 3240 ), 3241 TP_fast_assign( 3242 __entry->dev = mp->m_super->s_dev; 3243 __entry->ino = ino; 3244 __entry->parents = obs->parents; 3245 __entry->backrefs = obs->backrefs; 3246 __entry->children = obs->children; 3247 ), 3248 TP_printk("dev %d:%d ino 0x%llx parents %u backrefs %u children %u", 3249 MAJOR(__entry->dev), MINOR(__entry->dev), 3250 __entry->ino, 3251 __entry->parents, 3252 __entry->backrefs, 3253 __entry->children) 3254 ); 3255 3256 DECLARE_EVENT_CLASS(xrep_dentry_class, 3257 TP_PROTO(struct xfs_mount *mp, const struct dentry *dentry), 3258 TP_ARGS(mp, dentry), 3259 TP_STRUCT__entry( 3260 __field(dev_t, dev) 3261 __field(unsigned int, flags) 3262 __field(unsigned long, ino) 3263 __field(bool, positive) 3264 __field(unsigned long, parent_ino) 3265 __field(unsigned int, namelen) 3266 __dynamic_array(char, name, dentry->d_name.len) 3267 ), 3268 TP_fast_assign( 3269 __entry->dev = mp->m_super->s_dev; 3270 __entry->flags = dentry->d_flags; 3271 __entry->positive = d_is_positive(dentry); 3272 if (dentry->d_parent && d_inode(dentry->d_parent)) 3273 __entry->parent_ino = d_inode(dentry->d_parent)->i_ino; 3274 else 3275 __entry->parent_ino = -1UL; 3276 __entry->ino = d_inode(dentry) ? d_inode(dentry)->i_ino : 0; 3277 __entry->namelen = dentry->d_name.len; 3278 memcpy(__get_str(name), dentry->d_name.name, dentry->d_name.len); 3279 ), 3280 TP_printk("dev %d:%d flags 0x%x positive? %d parent_ino 0x%lx ino 0x%lx name '%.*s'", 3281 MAJOR(__entry->dev), MINOR(__entry->dev), 3282 __entry->flags, 3283 __entry->positive, 3284 __entry->parent_ino, 3285 __entry->ino, 3286 __entry->namelen, 3287 __get_str(name)) 3288 ); 3289 #define DEFINE_REPAIR_DENTRY_EVENT(name) \ 3290 DEFINE_EVENT(xrep_dentry_class, name, \ 3291 TP_PROTO(struct xfs_mount *mp, const struct dentry *dentry), \ 3292 TP_ARGS(mp, dentry)) 3293 DEFINE_REPAIR_DENTRY_EVENT(xrep_adoption_check_child); 3294 DEFINE_REPAIR_DENTRY_EVENT(xrep_adoption_invalidate_child); 3295 DEFINE_REPAIR_DENTRY_EVENT(xrep_dirtree_delete_child); 3296 3297 TRACE_EVENT(xrep_symlink_salvage_target, 3298 TP_PROTO(struct xfs_inode *ip, char *target, unsigned int targetlen), 3299 TP_ARGS(ip, target, targetlen), 3300 TP_STRUCT__entry( 3301 __field(dev_t, dev) 3302 __field(xfs_ino_t, ino) 3303 __field(unsigned int, targetlen) 3304 __dynamic_array(char, target, targetlen + 1) 3305 ), 3306 TP_fast_assign( 3307 __entry->dev = ip->i_mount->m_super->s_dev; 3308 __entry->ino = ip->i_ino; 3309 __entry->targetlen = targetlen; 3310 memcpy(__get_str(target), target, targetlen); 3311 __get_str(target)[targetlen] = 0; 3312 ), 3313 TP_printk("dev %d:%d ip 0x%llx target '%.*s'", 3314 MAJOR(__entry->dev), MINOR(__entry->dev), 3315 __entry->ino, 3316 __entry->targetlen, 3317 __get_str(target)) 3318 ); 3319 3320 DECLARE_EVENT_CLASS(xrep_symlink_class, 3321 TP_PROTO(struct xfs_inode *ip), 3322 TP_ARGS(ip), 3323 TP_STRUCT__entry( 3324 __field(dev_t, dev) 3325 __field(xfs_ino_t, ino) 3326 ), 3327 TP_fast_assign( 3328 __entry->dev = ip->i_mount->m_super->s_dev; 3329 __entry->ino = ip->i_ino; 3330 ), 3331 TP_printk("dev %d:%d ip 0x%llx", 3332 MAJOR(__entry->dev), MINOR(__entry->dev), 3333 __entry->ino) 3334 ); 3335 3336 #define DEFINE_XREP_SYMLINK_EVENT(name) \ 3337 DEFINE_EVENT(xrep_symlink_class, name, \ 3338 TP_PROTO(struct xfs_inode *ip), \ 3339 TP_ARGS(ip)) 3340 DEFINE_XREP_SYMLINK_EVENT(xrep_symlink_rebuild); 3341 DEFINE_XREP_SYMLINK_EVENT(xrep_symlink_reset_fork); 3342 3343 TRACE_EVENT(xrep_iunlink_visit, 3344 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, 3345 xfs_agino_t bucket_agino, struct xfs_inode *ip), 3346 TP_ARGS(pag, bucket, bucket_agino, ip), 3347 TP_STRUCT__entry( 3348 __field(dev_t, dev) 3349 __field(xfs_agnumber_t, agno) 3350 __field(xfs_agino_t, agino) 3351 __field(unsigned int, bucket) 3352 __field(xfs_agino_t, bucket_agino) 3353 __field(xfs_agino_t, prev_agino) 3354 __field(xfs_agino_t, next_agino) 3355 ), 3356 TP_fast_assign( 3357 __entry->dev = pag_mount(pag)->m_super->s_dev; 3358 __entry->agno = pag_agno(pag); 3359 __entry->agino = XFS_INO_TO_AGINO(pag_mount(pag), ip->i_ino); 3360 __entry->bucket = bucket; 3361 __entry->bucket_agino = bucket_agino; 3362 __entry->prev_agino = ip->i_prev_unlinked; 3363 __entry->next_agino = ip->i_next_unlinked; 3364 ), 3365 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x bucket_agino 0x%x prev_agino 0x%x next_agino 0x%x", 3366 MAJOR(__entry->dev), MINOR(__entry->dev), 3367 __entry->agno, 3368 __entry->bucket, 3369 __entry->agino, 3370 __entry->bucket_agino, 3371 __entry->prev_agino, 3372 __entry->next_agino) 3373 ); 3374 3375 TRACE_EVENT(xrep_iunlink_reload_next, 3376 TP_PROTO(struct xfs_inode *ip, xfs_agino_t prev_agino), 3377 TP_ARGS(ip, prev_agino), 3378 TP_STRUCT__entry( 3379 __field(dev_t, dev) 3380 __field(xfs_agnumber_t, agno) 3381 __field(xfs_agino_t, agino) 3382 __field(xfs_agino_t, old_prev_agino) 3383 __field(xfs_agino_t, prev_agino) 3384 __field(xfs_agino_t, next_agino) 3385 __field(unsigned int, nlink) 3386 ), 3387 TP_fast_assign( 3388 __entry->dev = ip->i_mount->m_super->s_dev; 3389 __entry->agno = XFS_INO_TO_AGNO(ip->i_mount, ip->i_ino); 3390 __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino); 3391 __entry->old_prev_agino = ip->i_prev_unlinked; 3392 __entry->prev_agino = prev_agino; 3393 __entry->next_agino = ip->i_next_unlinked; 3394 __entry->nlink = VFS_I(ip)->i_nlink; 3395 ), 3396 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x nlink %u old_prev_agino %u prev_agino 0x%x next_agino 0x%x", 3397 MAJOR(__entry->dev), MINOR(__entry->dev), 3398 __entry->agno, 3399 __entry->agino % XFS_AGI_UNLINKED_BUCKETS, 3400 __entry->agino, 3401 __entry->nlink, 3402 __entry->old_prev_agino, 3403 __entry->prev_agino, 3404 __entry->next_agino) 3405 ); 3406 3407 TRACE_EVENT(xrep_iunlink_reload_ondisk, 3408 TP_PROTO(struct xfs_inode *ip), 3409 TP_ARGS(ip), 3410 TP_STRUCT__entry( 3411 __field(dev_t, dev) 3412 __field(xfs_agnumber_t, agno) 3413 __field(xfs_agino_t, agino) 3414 __field(unsigned int, nlink) 3415 __field(xfs_agino_t, next_agino) 3416 ), 3417 TP_fast_assign( 3418 __entry->dev = ip->i_mount->m_super->s_dev; 3419 __entry->agno = XFS_INO_TO_AGNO(ip->i_mount, ip->i_ino); 3420 __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino); 3421 __entry->nlink = VFS_I(ip)->i_nlink; 3422 __entry->next_agino = ip->i_next_unlinked; 3423 ), 3424 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x nlink %u next_agino 0x%x", 3425 MAJOR(__entry->dev), MINOR(__entry->dev), 3426 __entry->agno, 3427 __entry->agino % XFS_AGI_UNLINKED_BUCKETS, 3428 __entry->agino, 3429 __entry->nlink, 3430 __entry->next_agino) 3431 ); 3432 3433 TRACE_EVENT(xrep_iunlink_walk_ondisk_bucket, 3434 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, 3435 xfs_agino_t prev_agino, xfs_agino_t next_agino), 3436 TP_ARGS(pag, bucket, prev_agino, next_agino), 3437 TP_STRUCT__entry( 3438 __field(dev_t, dev) 3439 __field(xfs_agnumber_t, agno) 3440 __field(unsigned int, bucket) 3441 __field(xfs_agino_t, prev_agino) 3442 __field(xfs_agino_t, next_agino) 3443 ), 3444 TP_fast_assign( 3445 __entry->dev = pag_mount(pag)->m_super->s_dev; 3446 __entry->agno = pag_agno(pag); 3447 __entry->bucket = bucket; 3448 __entry->prev_agino = prev_agino; 3449 __entry->next_agino = next_agino; 3450 ), 3451 TP_printk("dev %d:%d agno 0x%x bucket %u prev_agino 0x%x next_agino 0x%x", 3452 MAJOR(__entry->dev), MINOR(__entry->dev), 3453 __entry->agno, 3454 __entry->bucket, 3455 __entry->prev_agino, 3456 __entry->next_agino) 3457 ); 3458 3459 DECLARE_EVENT_CLASS(xrep_iunlink_resolve_class, 3460 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, 3461 xfs_agino_t prev_agino, xfs_agino_t next_agino), 3462 TP_ARGS(pag, bucket, prev_agino, next_agino), 3463 TP_STRUCT__entry( 3464 __field(dev_t, dev) 3465 __field(xfs_agnumber_t, agno) 3466 __field(unsigned int, bucket) 3467 __field(xfs_agino_t, prev_agino) 3468 __field(xfs_agino_t, next_agino) 3469 ), 3470 TP_fast_assign( 3471 __entry->dev = pag_mount(pag)->m_super->s_dev; 3472 __entry->agno = pag_agno(pag); 3473 __entry->bucket = bucket; 3474 __entry->prev_agino = prev_agino; 3475 __entry->next_agino = next_agino; 3476 ), 3477 TP_printk("dev %d:%d agno 0x%x bucket %u prev_agino 0x%x next_agino 0x%x", 3478 MAJOR(__entry->dev), MINOR(__entry->dev), 3479 __entry->agno, 3480 __entry->bucket, 3481 __entry->prev_agino, 3482 __entry->next_agino) 3483 ); 3484 #define DEFINE_REPAIR_IUNLINK_RESOLVE_EVENT(name) \ 3485 DEFINE_EVENT(xrep_iunlink_resolve_class, name, \ 3486 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, \ 3487 xfs_agino_t prev_agino, xfs_agino_t next_agino), \ 3488 TP_ARGS(pag, bucket, prev_agino, next_agino)) 3489 DEFINE_REPAIR_IUNLINK_RESOLVE_EVENT(xrep_iunlink_resolve_uncached); 3490 DEFINE_REPAIR_IUNLINK_RESOLVE_EVENT(xrep_iunlink_resolve_wronglist); 3491 DEFINE_REPAIR_IUNLINK_RESOLVE_EVENT(xrep_iunlink_resolve_nolist); 3492 DEFINE_REPAIR_IUNLINK_RESOLVE_EVENT(xrep_iunlink_resolve_ok); 3493 3494 TRACE_EVENT(xrep_iunlink_relink_next, 3495 TP_PROTO(struct xfs_inode *ip, xfs_agino_t next_agino), 3496 TP_ARGS(ip, next_agino), 3497 TP_STRUCT__entry( 3498 __field(dev_t, dev) 3499 __field(xfs_agnumber_t, agno) 3500 __field(xfs_agino_t, agino) 3501 __field(xfs_agino_t, next_agino) 3502 __field(xfs_agino_t, new_next_agino) 3503 ), 3504 TP_fast_assign( 3505 __entry->dev = ip->i_mount->m_super->s_dev; 3506 __entry->agno = XFS_INO_TO_AGNO(ip->i_mount, ip->i_ino); 3507 __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino); 3508 __entry->next_agino = ip->i_next_unlinked; 3509 __entry->new_next_agino = next_agino; 3510 ), 3511 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x next_agino 0x%x -> 0x%x", 3512 MAJOR(__entry->dev), MINOR(__entry->dev), 3513 __entry->agno, 3514 __entry->agino % XFS_AGI_UNLINKED_BUCKETS, 3515 __entry->agino, 3516 __entry->next_agino, 3517 __entry->new_next_agino) 3518 ); 3519 3520 TRACE_EVENT(xrep_iunlink_relink_prev, 3521 TP_PROTO(struct xfs_inode *ip, xfs_agino_t prev_agino), 3522 TP_ARGS(ip, prev_agino), 3523 TP_STRUCT__entry( 3524 __field(dev_t, dev) 3525 __field(xfs_agnumber_t, agno) 3526 __field(xfs_agino_t, agino) 3527 __field(xfs_agino_t, prev_agino) 3528 __field(xfs_agino_t, new_prev_agino) 3529 ), 3530 TP_fast_assign( 3531 __entry->dev = ip->i_mount->m_super->s_dev; 3532 __entry->agno = XFS_INO_TO_AGNO(ip->i_mount, ip->i_ino); 3533 __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino); 3534 __entry->prev_agino = ip->i_prev_unlinked; 3535 __entry->new_prev_agino = prev_agino; 3536 ), 3537 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x prev_agino 0x%x -> 0x%x", 3538 MAJOR(__entry->dev), MINOR(__entry->dev), 3539 __entry->agno, 3540 __entry->agino % XFS_AGI_UNLINKED_BUCKETS, 3541 __entry->agino, 3542 __entry->prev_agino, 3543 __entry->new_prev_agino) 3544 ); 3545 3546 TRACE_EVENT(xrep_iunlink_add_to_bucket, 3547 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, 3548 xfs_agino_t agino, xfs_agino_t curr_head), 3549 TP_ARGS(pag, bucket, agino, curr_head), 3550 TP_STRUCT__entry( 3551 __field(dev_t, dev) 3552 __field(xfs_agnumber_t, agno) 3553 __field(unsigned int, bucket) 3554 __field(xfs_agino_t, agino) 3555 __field(xfs_agino_t, next_agino) 3556 ), 3557 TP_fast_assign( 3558 __entry->dev = pag_mount(pag)->m_super->s_dev; 3559 __entry->agno = pag_agno(pag); 3560 __entry->bucket = bucket; 3561 __entry->agino = agino; 3562 __entry->next_agino = curr_head; 3563 ), 3564 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x next_agino 0x%x", 3565 MAJOR(__entry->dev), MINOR(__entry->dev), 3566 __entry->agno, 3567 __entry->bucket, 3568 __entry->agino, 3569 __entry->next_agino) 3570 ); 3571 3572 TRACE_EVENT(xrep_iunlink_commit_bucket, 3573 TP_PROTO(const struct xfs_perag *pag, unsigned int bucket, 3574 xfs_agino_t old_agino, xfs_agino_t agino), 3575 TP_ARGS(pag, bucket, old_agino, agino), 3576 TP_STRUCT__entry( 3577 __field(dev_t, dev) 3578 __field(xfs_agnumber_t, agno) 3579 __field(unsigned int, bucket) 3580 __field(xfs_agino_t, old_agino) 3581 __field(xfs_agino_t, agino) 3582 ), 3583 TP_fast_assign( 3584 __entry->dev = pag_mount(pag)->m_super->s_dev; 3585 __entry->agno = pag_agno(pag); 3586 __entry->bucket = bucket; 3587 __entry->old_agino = old_agino; 3588 __entry->agino = agino; 3589 ), 3590 TP_printk("dev %d:%d agno 0x%x bucket %u agino 0x%x -> 0x%x", 3591 MAJOR(__entry->dev), MINOR(__entry->dev), 3592 __entry->agno, 3593 __entry->bucket, 3594 __entry->old_agino, 3595 __entry->agino) 3596 ); 3597 3598 DEFINE_XCHK_DIRPATH_OUTCOME_EVENT(xrep_dirpath_set_outcome); 3599 DEFINE_XCHK_DIRTREE_EVENT(xrep_dirtree_delete_path); 3600 DEFINE_XCHK_DIRTREE_EVENT(xrep_dirtree_create_adoption); 3601 DEFINE_XCHK_DIRTREE_EVALUATE_EVENT(xrep_dirtree_decided_fate); 3602 3603 DEFINE_XCHK_METAPATH_EVENT(xrep_metapath_lookup); 3604 DEFINE_XCHK_METAPATH_EVENT(xrep_metapath_try_unlink); 3605 DEFINE_XCHK_METAPATH_EVENT(xrep_metapath_unlink); 3606 DEFINE_XCHK_METAPATH_EVENT(xrep_metapath_link); 3607 3608 #endif /* IS_ENABLED(CONFIG_XFS_ONLINE_REPAIR) */ 3609 3610 #endif /* _TRACE_XFS_SCRUB_TRACE_H */ 3611 3612 #undef TRACE_INCLUDE_PATH 3613 #define TRACE_INCLUDE_PATH . 3614 #define TRACE_INCLUDE_FILE scrub/trace 3615 #include <trace/define_trace.h> 3616