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