ocfs2_trace.h 50 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM ocfs2
  3. #if !defined(_TRACE_OCFS2_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_OCFS2_H
  5. #include <linux/tracepoint.h>
  6. DECLARE_EVENT_CLASS(ocfs2__int,
  7. TP_PROTO(int num),
  8. TP_ARGS(num),
  9. TP_STRUCT__entry(
  10. __field(int, num)
  11. ),
  12. TP_fast_assign(
  13. __entry->num = num;
  14. ),
  15. TP_printk("%d", __entry->num)
  16. );
  17. #define DEFINE_OCFS2_INT_EVENT(name) \
  18. DEFINE_EVENT(ocfs2__int, name, \
  19. TP_PROTO(int num), \
  20. TP_ARGS(num))
  21. DECLARE_EVENT_CLASS(ocfs2__uint,
  22. TP_PROTO(unsigned int num),
  23. TP_ARGS(num),
  24. TP_STRUCT__entry(
  25. __field( unsigned int, num )
  26. ),
  27. TP_fast_assign(
  28. __entry->num = num;
  29. ),
  30. TP_printk("%u", __entry->num)
  31. );
  32. #define DEFINE_OCFS2_UINT_EVENT(name) \
  33. DEFINE_EVENT(ocfs2__uint, name, \
  34. TP_PROTO(unsigned int num), \
  35. TP_ARGS(num))
  36. DECLARE_EVENT_CLASS(ocfs2__ull,
  37. TP_PROTO(unsigned long long blkno),
  38. TP_ARGS(blkno),
  39. TP_STRUCT__entry(
  40. __field(unsigned long long, blkno)
  41. ),
  42. TP_fast_assign(
  43. __entry->blkno = blkno;
  44. ),
  45. TP_printk("%llu", __entry->blkno)
  46. );
  47. #define DEFINE_OCFS2_ULL_EVENT(name) \
  48. DEFINE_EVENT(ocfs2__ull, name, \
  49. TP_PROTO(unsigned long long num), \
  50. TP_ARGS(num))
  51. DECLARE_EVENT_CLASS(ocfs2__pointer,
  52. TP_PROTO(void *pointer),
  53. TP_ARGS(pointer),
  54. TP_STRUCT__entry(
  55. __field(void *, pointer)
  56. ),
  57. TP_fast_assign(
  58. __entry->pointer = pointer;
  59. ),
  60. TP_printk("%p", __entry->pointer)
  61. );
  62. #define DEFINE_OCFS2_POINTER_EVENT(name) \
  63. DEFINE_EVENT(ocfs2__pointer, name, \
  64. TP_PROTO(void *pointer), \
  65. TP_ARGS(pointer))
  66. DECLARE_EVENT_CLASS(ocfs2__string,
  67. TP_PROTO(const char *name),
  68. TP_ARGS(name),
  69. TP_STRUCT__entry(
  70. __string(name,name)
  71. ),
  72. TP_fast_assign(
  73. __assign_str(name, name);
  74. ),
  75. TP_printk("%s", __get_str(name))
  76. );
  77. #define DEFINE_OCFS2_STRING_EVENT(name) \
  78. DEFINE_EVENT(ocfs2__string, name, \
  79. TP_PROTO(const char *name), \
  80. TP_ARGS(name))
  81. DECLARE_EVENT_CLASS(ocfs2__int_int,
  82. TP_PROTO(int value1, int value2),
  83. TP_ARGS(value1, value2),
  84. TP_STRUCT__entry(
  85. __field(int, value1)
  86. __field(int, value2)
  87. ),
  88. TP_fast_assign(
  89. __entry->value1 = value1;
  90. __entry->value2 = value2;
  91. ),
  92. TP_printk("%d %d", __entry->value1, __entry->value2)
  93. );
  94. #define DEFINE_OCFS2_INT_INT_EVENT(name) \
  95. DEFINE_EVENT(ocfs2__int_int, name, \
  96. TP_PROTO(int val1, int val2), \
  97. TP_ARGS(val1, val2))
  98. DECLARE_EVENT_CLASS(ocfs2__uint_uint,
  99. TP_PROTO(unsigned int value1, unsigned int value2),
  100. TP_ARGS(value1, value2),
  101. TP_STRUCT__entry(
  102. __field(unsigned int, value1)
  103. __field(unsigned int, value2)
  104. ),
  105. TP_fast_assign(
  106. __entry->value1 = value1;
  107. __entry->value2 = value2;
  108. ),
  109. TP_printk("%u %u", __entry->value1, __entry->value2)
  110. );
  111. #define DEFINE_OCFS2_UINT_UINT_EVENT(name) \
  112. DEFINE_EVENT(ocfs2__uint_uint, name, \
  113. TP_PROTO(unsigned int val1, unsigned int val2), \
  114. TP_ARGS(val1, val2))
  115. DECLARE_EVENT_CLASS(ocfs2__ull_uint,
  116. TP_PROTO(unsigned long long value1, unsigned int value2),
  117. TP_ARGS(value1, value2),
  118. TP_STRUCT__entry(
  119. __field(unsigned long long, value1)
  120. __field(unsigned int, value2)
  121. ),
  122. TP_fast_assign(
  123. __entry->value1 = value1;
  124. __entry->value2 = value2;
  125. ),
  126. TP_printk("%llu %u", __entry->value1, __entry->value2)
  127. );
  128. #define DEFINE_OCFS2_ULL_UINT_EVENT(name) \
  129. DEFINE_EVENT(ocfs2__ull_uint, name, \
  130. TP_PROTO(unsigned long long val1, unsigned int val2), \
  131. TP_ARGS(val1, val2))
  132. DECLARE_EVENT_CLASS(ocfs2__ull_int,
  133. TP_PROTO(unsigned long long value1, int value2),
  134. TP_ARGS(value1, value2),
  135. TP_STRUCT__entry(
  136. __field(unsigned long long, value1)
  137. __field(int, value2)
  138. ),
  139. TP_fast_assign(
  140. __entry->value1 = value1;
  141. __entry->value2 = value2;
  142. ),
  143. TP_printk("%llu %d", __entry->value1, __entry->value2)
  144. );
  145. #define DEFINE_OCFS2_ULL_INT_EVENT(name) \
  146. DEFINE_EVENT(ocfs2__ull_int, name, \
  147. TP_PROTO(unsigned long long val1, int val2), \
  148. TP_ARGS(val1, val2))
  149. DECLARE_EVENT_CLASS(ocfs2__ull_ull,
  150. TP_PROTO(unsigned long long value1, unsigned long long value2),
  151. TP_ARGS(value1, value2),
  152. TP_STRUCT__entry(
  153. __field(unsigned long long, value1)
  154. __field(unsigned long long, value2)
  155. ),
  156. TP_fast_assign(
  157. __entry->value1 = value1;
  158. __entry->value2 = value2;
  159. ),
  160. TP_printk("%llu %llu", __entry->value1, __entry->value2)
  161. );
  162. #define DEFINE_OCFS2_ULL_ULL_EVENT(name) \
  163. DEFINE_EVENT(ocfs2__ull_ull, name, \
  164. TP_PROTO(unsigned long long val1, unsigned long long val2), \
  165. TP_ARGS(val1, val2))
  166. DECLARE_EVENT_CLASS(ocfs2__ull_ull_uint,
  167. TP_PROTO(unsigned long long value1,
  168. unsigned long long value2, unsigned int value3),
  169. TP_ARGS(value1, value2, value3),
  170. TP_STRUCT__entry(
  171. __field(unsigned long long, value1)
  172. __field(unsigned long long, value2)
  173. __field(unsigned int, value3)
  174. ),
  175. TP_fast_assign(
  176. __entry->value1 = value1;
  177. __entry->value2 = value2;
  178. __entry->value3 = value3;
  179. ),
  180. TP_printk("%llu %llu %u",
  181. __entry->value1, __entry->value2, __entry->value3)
  182. );
  183. #define DEFINE_OCFS2_ULL_ULL_UINT_EVENT(name) \
  184. DEFINE_EVENT(ocfs2__ull_ull_uint, name, \
  185. TP_PROTO(unsigned long long val1, \
  186. unsigned long long val2, unsigned int val3), \
  187. TP_ARGS(val1, val2, val3))
  188. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint,
  189. TP_PROTO(unsigned long long value1,
  190. unsigned int value2, unsigned int value3),
  191. TP_ARGS(value1, value2, value3),
  192. TP_STRUCT__entry(
  193. __field(unsigned long long, value1)
  194. __field(unsigned int, value2)
  195. __field(unsigned int, value3)
  196. ),
  197. TP_fast_assign(
  198. __entry->value1 = value1;
  199. __entry->value2 = value2;
  200. __entry->value3 = value3;
  201. ),
  202. TP_printk("%llu %u %u", __entry->value1,
  203. __entry->value2, __entry->value3)
  204. );
  205. #define DEFINE_OCFS2_ULL_UINT_UINT_EVENT(name) \
  206. DEFINE_EVENT(ocfs2__ull_uint_uint, name, \
  207. TP_PROTO(unsigned long long val1, \
  208. unsigned int val2, unsigned int val3), \
  209. TP_ARGS(val1, val2, val3))
  210. DECLARE_EVENT_CLASS(ocfs2__uint_uint_uint,
  211. TP_PROTO(unsigned int value1, unsigned int value2,
  212. unsigned int value3),
  213. TP_ARGS(value1, value2, value3),
  214. TP_STRUCT__entry(
  215. __field( unsigned int, value1 )
  216. __field( unsigned int, value2 )
  217. __field( unsigned int, value3 )
  218. ),
  219. TP_fast_assign(
  220. __entry->value1 = value1;
  221. __entry->value2 = value2;
  222. __entry->value3 = value3;
  223. ),
  224. TP_printk("%u %u %u", __entry->value1, __entry->value2, __entry->value3)
  225. );
  226. #define DEFINE_OCFS2_UINT_UINT_UINT_EVENT(name) \
  227. DEFINE_EVENT(ocfs2__uint_uint_uint, name, \
  228. TP_PROTO(unsigned int value1, unsigned int value2, \
  229. unsigned int value3), \
  230. TP_ARGS(value1, value2, value3))
  231. DECLARE_EVENT_CLASS(ocfs2__ull_ull_ull,
  232. TP_PROTO(unsigned long long value1,
  233. unsigned long long value2, unsigned long long value3),
  234. TP_ARGS(value1, value2, value3),
  235. TP_STRUCT__entry(
  236. __field(unsigned long long, value1)
  237. __field(unsigned long long, value2)
  238. __field(unsigned long long, value3)
  239. ),
  240. TP_fast_assign(
  241. __entry->value1 = value1;
  242. __entry->value2 = value2;
  243. __entry->value3 = value3;
  244. ),
  245. TP_printk("%llu %llu %llu",
  246. __entry->value1, __entry->value2, __entry->value3)
  247. );
  248. #define DEFINE_OCFS2_ULL_ULL_ULL_EVENT(name) \
  249. DEFINE_EVENT(ocfs2__ull_ull_ull, name, \
  250. TP_PROTO(unsigned long long value1, unsigned long long value2, \
  251. unsigned long long value3), \
  252. TP_ARGS(value1, value2, value3))
  253. DECLARE_EVENT_CLASS(ocfs2__ull_int_int_int,
  254. TP_PROTO(unsigned long long ull, int value1, int value2, int value3),
  255. TP_ARGS(ull, value1, value2, value3),
  256. TP_STRUCT__entry(
  257. __field( unsigned long long, ull )
  258. __field( int, value1 )
  259. __field( int, value2 )
  260. __field( int, value3 )
  261. ),
  262. TP_fast_assign(
  263. __entry->ull = ull;
  264. __entry->value1 = value1;
  265. __entry->value2 = value2;
  266. __entry->value3 = value3;
  267. ),
  268. TP_printk("%llu %d %d %d",
  269. __entry->ull, __entry->value1,
  270. __entry->value2, __entry->value3)
  271. );
  272. #define DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(name) \
  273. DEFINE_EVENT(ocfs2__ull_int_int_int, name, \
  274. TP_PROTO(unsigned long long ull, int value1, \
  275. int value2, int value3), \
  276. TP_ARGS(ull, value1, value2, value3))
  277. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint_uint,
  278. TP_PROTO(unsigned long long ull, unsigned int value1,
  279. unsigned int value2, unsigned int value3),
  280. TP_ARGS(ull, value1, value2, value3),
  281. TP_STRUCT__entry(
  282. __field(unsigned long long, ull)
  283. __field(unsigned int, value1)
  284. __field(unsigned int, value2)
  285. __field(unsigned int, value3)
  286. ),
  287. TP_fast_assign(
  288. __entry->ull = ull;
  289. __entry->value1 = value1;
  290. __entry->value2 = value2;
  291. __entry->value3 = value3;
  292. ),
  293. TP_printk("%llu %u %u %u",
  294. __entry->ull, __entry->value1,
  295. __entry->value2, __entry->value3)
  296. );
  297. #define DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(name) \
  298. DEFINE_EVENT(ocfs2__ull_uint_uint_uint, name, \
  299. TP_PROTO(unsigned long long ull, unsigned int value1, \
  300. unsigned int value2, unsigned int value3), \
  301. TP_ARGS(ull, value1, value2, value3))
  302. DECLARE_EVENT_CLASS(ocfs2__ull_ull_uint_uint,
  303. TP_PROTO(unsigned long long value1, unsigned long long value2,
  304. unsigned int value3, unsigned int value4),
  305. TP_ARGS(value1, value2, value3, value4),
  306. TP_STRUCT__entry(
  307. __field(unsigned long long, value1)
  308. __field(unsigned long long, value2)
  309. __field(unsigned int, value3)
  310. __field(unsigned int, value4)
  311. ),
  312. TP_fast_assign(
  313. __entry->value1 = value1;
  314. __entry->value2 = value2;
  315. __entry->value3 = value3;
  316. __entry->value4 = value4;
  317. ),
  318. TP_printk("%llu %llu %u %u",
  319. __entry->value1, __entry->value2,
  320. __entry->value3, __entry->value4)
  321. );
  322. #define DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(name) \
  323. DEFINE_EVENT(ocfs2__ull_ull_uint_uint, name, \
  324. TP_PROTO(unsigned long long ull, unsigned long long ull1, \
  325. unsigned int value2, unsigned int value3), \
  326. TP_ARGS(ull, ull1, value2, value3))
  327. /* Trace events for fs/ocfs2/alloc.c. */
  328. DECLARE_EVENT_CLASS(ocfs2__btree_ops,
  329. TP_PROTO(unsigned long long owner,\
  330. unsigned int value1, unsigned int value2),
  331. TP_ARGS(owner, value1, value2),
  332. TP_STRUCT__entry(
  333. __field(unsigned long long, owner)
  334. __field(unsigned int, value1)
  335. __field(unsigned int, value2)
  336. ),
  337. TP_fast_assign(
  338. __entry->owner = owner;
  339. __entry->value1 = value1;
  340. __entry->value2 = value2;
  341. ),
  342. TP_printk("%llu %u %u",
  343. __entry->owner, __entry->value1, __entry->value2)
  344. );
  345. #define DEFINE_OCFS2_BTREE_EVENT(name) \
  346. DEFINE_EVENT(ocfs2__btree_ops, name, \
  347. TP_PROTO(unsigned long long owner, \
  348. unsigned int value1, unsigned int value2), \
  349. TP_ARGS(owner, value1, value2))
  350. DEFINE_OCFS2_BTREE_EVENT(ocfs2_adjust_rightmost_branch);
  351. DEFINE_OCFS2_BTREE_EVENT(ocfs2_rotate_tree_right);
  352. DEFINE_OCFS2_BTREE_EVENT(ocfs2_append_rec_to_path);
  353. DEFINE_OCFS2_BTREE_EVENT(ocfs2_insert_extent_start);
  354. DEFINE_OCFS2_BTREE_EVENT(ocfs2_add_clusters_in_btree);
  355. DEFINE_OCFS2_INT_EVENT(ocfs2_num_free_extents);
  356. DEFINE_OCFS2_INT_EVENT(ocfs2_complete_edge_insert);
  357. TRACE_EVENT(ocfs2_grow_tree,
  358. TP_PROTO(unsigned long long owner, int depth),
  359. TP_ARGS(owner, depth),
  360. TP_STRUCT__entry(
  361. __field(unsigned long long, owner)
  362. __field(int, depth)
  363. ),
  364. TP_fast_assign(
  365. __entry->owner = owner;
  366. __entry->depth = depth;
  367. ),
  368. TP_printk("%llu %d", __entry->owner, __entry->depth)
  369. );
  370. TRACE_EVENT(ocfs2_rotate_subtree,
  371. TP_PROTO(int subtree_root, unsigned long long blkno,
  372. int depth),
  373. TP_ARGS(subtree_root, blkno, depth),
  374. TP_STRUCT__entry(
  375. __field(int, subtree_root)
  376. __field(unsigned long long, blkno)
  377. __field(int, depth)
  378. ),
  379. TP_fast_assign(
  380. __entry->subtree_root = subtree_root;
  381. __entry->blkno = blkno;
  382. __entry->depth = depth;
  383. ),
  384. TP_printk("%d %llu %d", __entry->subtree_root,
  385. __entry->blkno, __entry->depth)
  386. );
  387. TRACE_EVENT(ocfs2_insert_extent,
  388. TP_PROTO(unsigned int ins_appending, unsigned int ins_contig,
  389. int ins_contig_index, int free_records, int ins_tree_depth),
  390. TP_ARGS(ins_appending, ins_contig, ins_contig_index, free_records,
  391. ins_tree_depth),
  392. TP_STRUCT__entry(
  393. __field(unsigned int, ins_appending)
  394. __field(unsigned int, ins_contig)
  395. __field(int, ins_contig_index)
  396. __field(int, free_records)
  397. __field(int, ins_tree_depth)
  398. ),
  399. TP_fast_assign(
  400. __entry->ins_appending = ins_appending;
  401. __entry->ins_contig = ins_contig;
  402. __entry->ins_contig_index = ins_contig_index;
  403. __entry->free_records = free_records;
  404. __entry->ins_tree_depth = ins_tree_depth;
  405. ),
  406. TP_printk("%u %u %d %d %d",
  407. __entry->ins_appending, __entry->ins_contig,
  408. __entry->ins_contig_index, __entry->free_records,
  409. __entry->ins_tree_depth)
  410. );
  411. TRACE_EVENT(ocfs2_split_extent,
  412. TP_PROTO(int split_index, unsigned int c_contig_type,
  413. unsigned int c_has_empty_extent,
  414. unsigned int c_split_covers_rec),
  415. TP_ARGS(split_index, c_contig_type,
  416. c_has_empty_extent, c_split_covers_rec),
  417. TP_STRUCT__entry(
  418. __field(int, split_index)
  419. __field(unsigned int, c_contig_type)
  420. __field(unsigned int, c_has_empty_extent)
  421. __field(unsigned int, c_split_covers_rec)
  422. ),
  423. TP_fast_assign(
  424. __entry->split_index = split_index;
  425. __entry->c_contig_type = c_contig_type;
  426. __entry->c_has_empty_extent = c_has_empty_extent;
  427. __entry->c_split_covers_rec = c_split_covers_rec;
  428. ),
  429. TP_printk("%d %u %u %u", __entry->split_index, __entry->c_contig_type,
  430. __entry->c_has_empty_extent, __entry->c_split_covers_rec)
  431. );
  432. TRACE_EVENT(ocfs2_remove_extent,
  433. TP_PROTO(unsigned long long owner, unsigned int cpos,
  434. unsigned int len, int index,
  435. unsigned int e_cpos, unsigned int clusters),
  436. TP_ARGS(owner, cpos, len, index, e_cpos, clusters),
  437. TP_STRUCT__entry(
  438. __field(unsigned long long, owner)
  439. __field(unsigned int, cpos)
  440. __field(unsigned int, len)
  441. __field(int, index)
  442. __field(unsigned int, e_cpos)
  443. __field(unsigned int, clusters)
  444. ),
  445. TP_fast_assign(
  446. __entry->owner = owner;
  447. __entry->cpos = cpos;
  448. __entry->len = len;
  449. __entry->index = index;
  450. __entry->e_cpos = e_cpos;
  451. __entry->clusters = clusters;
  452. ),
  453. TP_printk("%llu %u %u %d %u %u",
  454. __entry->owner, __entry->cpos, __entry->len, __entry->index,
  455. __entry->e_cpos, __entry->clusters)
  456. );
  457. TRACE_EVENT(ocfs2_commit_truncate,
  458. TP_PROTO(unsigned long long ino, unsigned int new_cpos,
  459. unsigned int clusters, unsigned int depth),
  460. TP_ARGS(ino, new_cpos, clusters, depth),
  461. TP_STRUCT__entry(
  462. __field(unsigned long long, ino)
  463. __field(unsigned int, new_cpos)
  464. __field(unsigned int, clusters)
  465. __field(unsigned int, depth)
  466. ),
  467. TP_fast_assign(
  468. __entry->ino = ino;
  469. __entry->new_cpos = new_cpos;
  470. __entry->clusters = clusters;
  471. __entry->depth = depth;
  472. ),
  473. TP_printk("%llu %u %u %u",
  474. __entry->ino, __entry->new_cpos,
  475. __entry->clusters, __entry->depth)
  476. );
  477. TRACE_EVENT(ocfs2_validate_extent_block,
  478. TP_PROTO(unsigned long long blkno),
  479. TP_ARGS(blkno),
  480. TP_STRUCT__entry(
  481. __field(unsigned long long, blkno)
  482. ),
  483. TP_fast_assign(
  484. __entry->blkno = blkno;
  485. ),
  486. TP_printk("%llu ", __entry->blkno)
  487. );
  488. TRACE_EVENT(ocfs2_rotate_leaf,
  489. TP_PROTO(unsigned int insert_cpos, int insert_index,
  490. int has_empty, int next_free,
  491. unsigned int l_count),
  492. TP_ARGS(insert_cpos, insert_index, has_empty,
  493. next_free, l_count),
  494. TP_STRUCT__entry(
  495. __field(unsigned int, insert_cpos)
  496. __field(int, insert_index)
  497. __field(int, has_empty)
  498. __field(int, next_free)
  499. __field(unsigned int, l_count)
  500. ),
  501. TP_fast_assign(
  502. __entry->insert_cpos = insert_cpos;
  503. __entry->insert_index = insert_index;
  504. __entry->has_empty = has_empty;
  505. __entry->next_free = next_free;
  506. __entry->l_count = l_count;
  507. ),
  508. TP_printk("%u %d %d %d %u", __entry->insert_cpos,
  509. __entry->insert_index, __entry->has_empty,
  510. __entry->next_free, __entry->l_count)
  511. );
  512. TRACE_EVENT(ocfs2_add_clusters_in_btree_ret,
  513. TP_PROTO(int status, int reason, int err),
  514. TP_ARGS(status, reason, err),
  515. TP_STRUCT__entry(
  516. __field(int, status)
  517. __field(int, reason)
  518. __field(int, err)
  519. ),
  520. TP_fast_assign(
  521. __entry->status = status;
  522. __entry->reason = reason;
  523. __entry->err = err;
  524. ),
  525. TP_printk("%d %d %d", __entry->status,
  526. __entry->reason, __entry->err)
  527. );
  528. TRACE_EVENT(ocfs2_mark_extent_written,
  529. TP_PROTO(unsigned long long owner, unsigned int cpos,
  530. unsigned int len, unsigned int phys),
  531. TP_ARGS(owner, cpos, len, phys),
  532. TP_STRUCT__entry(
  533. __field(unsigned long long, owner)
  534. __field(unsigned int, cpos)
  535. __field(unsigned int, len)
  536. __field(unsigned int, phys)
  537. ),
  538. TP_fast_assign(
  539. __entry->owner = owner;
  540. __entry->cpos = cpos;
  541. __entry->len = len;
  542. __entry->phys = phys;
  543. ),
  544. TP_printk("%llu %u %u %u",
  545. __entry->owner, __entry->cpos,
  546. __entry->len, __entry->phys)
  547. );
  548. DECLARE_EVENT_CLASS(ocfs2__truncate_log_ops,
  549. TP_PROTO(unsigned long long blkno, int index,
  550. unsigned int start, unsigned int num),
  551. TP_ARGS(blkno, index, start, num),
  552. TP_STRUCT__entry(
  553. __field(unsigned long long, blkno)
  554. __field(int, index)
  555. __field(unsigned int, start)
  556. __field(unsigned int, num)
  557. ),
  558. TP_fast_assign(
  559. __entry->blkno = blkno;
  560. __entry->index = index;
  561. __entry->start = start;
  562. __entry->num = num;
  563. ),
  564. TP_printk("%llu %d %u %u",
  565. __entry->blkno, __entry->index,
  566. __entry->start, __entry->num)
  567. );
  568. #define DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(name) \
  569. DEFINE_EVENT(ocfs2__truncate_log_ops, name, \
  570. TP_PROTO(unsigned long long blkno, int index, \
  571. unsigned int start, unsigned int num), \
  572. TP_ARGS(blkno, index, start, num))
  573. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_truncate_log_append);
  574. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_replay_truncate_records);
  575. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_flush_truncate_log);
  576. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_truncate_log_recovery);
  577. DEFINE_OCFS2_INT_EVENT(ocfs2_truncate_log_recovery_num);
  578. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_complete_truncate_log_recovery);
  579. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_free_cached_blocks);
  580. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_cache_cluster_dealloc);
  581. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_run_deallocs);
  582. TRACE_EVENT(ocfs2_cache_block_dealloc,
  583. TP_PROTO(int type, int slot, unsigned long long suballoc,
  584. unsigned long long blkno, unsigned int bit),
  585. TP_ARGS(type, slot, suballoc, blkno, bit),
  586. TP_STRUCT__entry(
  587. __field(int, type)
  588. __field(int, slot)
  589. __field(unsigned long long, suballoc)
  590. __field(unsigned long long, blkno)
  591. __field(unsigned int, bit)
  592. ),
  593. TP_fast_assign(
  594. __entry->type = type;
  595. __entry->slot = slot;
  596. __entry->suballoc = suballoc;
  597. __entry->blkno = blkno;
  598. __entry->bit = bit;
  599. ),
  600. TP_printk("%d %d %llu %llu %u",
  601. __entry->type, __entry->slot, __entry->suballoc,
  602. __entry->blkno, __entry->bit)
  603. );
  604. /* End of trace events for fs/ocfs2/alloc.c. */
  605. /* Trace events for fs/ocfs2/localalloc.c. */
  606. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_la_set_sizes);
  607. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_alloc_should_use_local);
  608. DEFINE_OCFS2_INT_EVENT(ocfs2_load_local_alloc);
  609. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_local_alloc_recovery);
  610. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_reserve_local_alloc_bits);
  611. DEFINE_OCFS2_UINT_EVENT(ocfs2_local_alloc_count_bits);
  612. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits_search_bitmap);
  613. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits);
  614. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_sync_local_to_main);
  615. TRACE_EVENT(ocfs2_sync_local_to_main_free,
  616. TP_PROTO(int count, int bit, unsigned long long start_blk,
  617. unsigned long long blkno),
  618. TP_ARGS(count, bit, start_blk, blkno),
  619. TP_STRUCT__entry(
  620. __field(int, count)
  621. __field(int, bit)
  622. __field(unsigned long long, start_blk)
  623. __field(unsigned long long, blkno)
  624. ),
  625. TP_fast_assign(
  626. __entry->count = count;
  627. __entry->bit = bit;
  628. __entry->start_blk = start_blk;
  629. __entry->blkno = blkno;
  630. ),
  631. TP_printk("%d %d %llu %llu",
  632. __entry->count, __entry->bit, __entry->start_blk,
  633. __entry->blkno)
  634. );
  635. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_new_window);
  636. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_local_alloc_new_window_result);
  637. /* End of trace events for fs/ocfs2/localalloc.c. */
  638. /* Trace events for fs/ocfs2/resize.c. */
  639. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_update_last_group_and_inode);
  640. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_group_extend);
  641. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_group_add);
  642. /* End of trace events for fs/ocfs2/resize.c. */
  643. /* Trace events for fs/ocfs2/suballoc.c. */
  644. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_group_descriptor);
  645. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_contig);
  646. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_discontig);
  647. DEFINE_OCFS2_ULL_EVENT(ocfs2_block_group_alloc);
  648. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_nospc);
  649. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_no_new_group);
  650. DEFINE_OCFS2_ULL_EVENT(ocfs2_reserve_new_inode_new_group);
  651. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_set_bits);
  652. TRACE_EVENT(ocfs2_relink_block_group,
  653. TP_PROTO(unsigned long long i_blkno, unsigned int chain,
  654. unsigned long long bg_blkno,
  655. unsigned long long prev_blkno),
  656. TP_ARGS(i_blkno, chain, bg_blkno, prev_blkno),
  657. TP_STRUCT__entry(
  658. __field(unsigned long long, i_blkno)
  659. __field(unsigned int, chain)
  660. __field(unsigned long long, bg_blkno)
  661. __field(unsigned long long, prev_blkno)
  662. ),
  663. TP_fast_assign(
  664. __entry->i_blkno = i_blkno;
  665. __entry->chain = chain;
  666. __entry->bg_blkno = bg_blkno;
  667. __entry->prev_blkno = prev_blkno;
  668. ),
  669. TP_printk("%llu %u %llu %llu",
  670. __entry->i_blkno, __entry->chain, __entry->bg_blkno,
  671. __entry->prev_blkno)
  672. );
  673. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_cluster_group_search_wrong_max_bits);
  674. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cluster_group_search_max_block);
  675. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_block_group_search_max_block);
  676. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_search_chain_begin);
  677. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_succ);
  678. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_end);
  679. DEFINE_OCFS2_UINT_EVENT(ocfs2_claim_suballoc_bits);
  680. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_claim_new_inode_at_loc);
  681. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_clear_bits);
  682. TRACE_EVENT(ocfs2_free_suballoc_bits,
  683. TP_PROTO(unsigned long long inode, unsigned long long group,
  684. unsigned int start_bit, unsigned int count),
  685. TP_ARGS(inode, group, start_bit, count),
  686. TP_STRUCT__entry(
  687. __field(unsigned long long, inode)
  688. __field(unsigned long long, group)
  689. __field(unsigned int, start_bit)
  690. __field(unsigned int, count)
  691. ),
  692. TP_fast_assign(
  693. __entry->inode = inode;
  694. __entry->group = group;
  695. __entry->start_bit = start_bit;
  696. __entry->count = count;
  697. ),
  698. TP_printk("%llu %llu %u %u", __entry->inode, __entry->group,
  699. __entry->start_bit, __entry->count)
  700. );
  701. TRACE_EVENT(ocfs2_free_clusters,
  702. TP_PROTO(unsigned long long bg_blkno, unsigned long long start_blk,
  703. unsigned int start_bit, unsigned int count),
  704. TP_ARGS(bg_blkno, start_blk, start_bit, count),
  705. TP_STRUCT__entry(
  706. __field(unsigned long long, bg_blkno)
  707. __field(unsigned long long, start_blk)
  708. __field(unsigned int, start_bit)
  709. __field(unsigned int, count)
  710. ),
  711. TP_fast_assign(
  712. __entry->bg_blkno = bg_blkno;
  713. __entry->start_blk = start_blk;
  714. __entry->start_bit = start_bit;
  715. __entry->count = count;
  716. ),
  717. TP_printk("%llu %llu %u %u", __entry->bg_blkno, __entry->start_blk,
  718. __entry->start_bit, __entry->count)
  719. );
  720. DEFINE_OCFS2_ULL_EVENT(ocfs2_get_suballoc_slot_bit);
  721. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_test_suballoc_bit);
  722. DEFINE_OCFS2_ULL_EVENT(ocfs2_test_inode_bit);
  723. /* End of trace events for fs/ocfs2/suballoc.c. */
  724. /* Trace events for fs/ocfs2/refcounttree.c. */
  725. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_refcount_block);
  726. DEFINE_OCFS2_ULL_EVENT(ocfs2_purge_refcount_trees);
  727. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree);
  728. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree_blkno);
  729. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_change_refcount_rec);
  730. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_expand_inline_ref_root);
  731. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_divide_leaf_refcount_block);
  732. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_new_leaf_refcount_block);
  733. DECLARE_EVENT_CLASS(ocfs2__refcount_tree_ops,
  734. TP_PROTO(unsigned long long blkno, int index,
  735. unsigned long long cpos,
  736. unsigned int clusters, unsigned int refcount),
  737. TP_ARGS(blkno, index, cpos, clusters, refcount),
  738. TP_STRUCT__entry(
  739. __field(unsigned long long, blkno)
  740. __field(int, index)
  741. __field(unsigned long long, cpos)
  742. __field(unsigned int, clusters)
  743. __field(unsigned int, refcount)
  744. ),
  745. TP_fast_assign(
  746. __entry->blkno = blkno;
  747. __entry->index = index;
  748. __entry->cpos = cpos;
  749. __entry->clusters = clusters;
  750. __entry->refcount = refcount;
  751. ),
  752. TP_printk("%llu %d %llu %u %u", __entry->blkno, __entry->index,
  753. __entry->cpos, __entry->clusters, __entry->refcount)
  754. );
  755. #define DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(name) \
  756. DEFINE_EVENT(ocfs2__refcount_tree_ops, name, \
  757. TP_PROTO(unsigned long long blkno, int index, \
  758. unsigned long long cpos, \
  759. unsigned int count, unsigned int refcount), \
  760. TP_ARGS(blkno, index, cpos, count, refcount))
  761. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_insert_refcount_rec);
  762. TRACE_EVENT(ocfs2_split_refcount_rec,
  763. TP_PROTO(unsigned long long cpos,
  764. unsigned int clusters, unsigned int refcount,
  765. unsigned long long split_cpos,
  766. unsigned int split_clusters, unsigned int split_refcount),
  767. TP_ARGS(cpos, clusters, refcount,
  768. split_cpos, split_clusters, split_refcount),
  769. TP_STRUCT__entry(
  770. __field(unsigned long long, cpos)
  771. __field(unsigned int, clusters)
  772. __field(unsigned int, refcount)
  773. __field(unsigned long long, split_cpos)
  774. __field(unsigned int, split_clusters)
  775. __field(unsigned int, split_refcount)
  776. ),
  777. TP_fast_assign(
  778. __entry->cpos = cpos;
  779. __entry->clusters = clusters;
  780. __entry->refcount = refcount;
  781. __entry->split_cpos = split_cpos;
  782. __entry->split_clusters = split_clusters;
  783. __entry->split_refcount = split_refcount;
  784. ),
  785. TP_printk("%llu %u %u %llu %u %u",
  786. __entry->cpos, __entry->clusters, __entry->refcount,
  787. __entry->split_cpos, __entry->split_clusters,
  788. __entry->split_refcount)
  789. );
  790. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_split_refcount_rec_insert);
  791. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_increase_refcount_begin);
  792. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_change);
  793. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_increase_refcount_insert);
  794. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_split);
  795. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_remove_refcount_extent);
  796. DEFINE_OCFS2_ULL_EVENT(ocfs2_restore_refcount_block);
  797. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_decrease_refcount_rec);
  798. TRACE_EVENT(ocfs2_decrease_refcount,
  799. TP_PROTO(unsigned long long owner,
  800. unsigned long long cpos,
  801. unsigned int len, int delete),
  802. TP_ARGS(owner, cpos, len, delete),
  803. TP_STRUCT__entry(
  804. __field(unsigned long long, owner)
  805. __field(unsigned long long, cpos)
  806. __field(unsigned int, len)
  807. __field(int, delete)
  808. ),
  809. TP_fast_assign(
  810. __entry->owner = owner;
  811. __entry->cpos = cpos;
  812. __entry->len = len;
  813. __entry->delete = delete;
  814. ),
  815. TP_printk("%llu %llu %u %d",
  816. __entry->owner, __entry->cpos, __entry->len, __entry->delete)
  817. );
  818. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_mark_extent_refcounted);
  819. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_calc_refcount_meta_credits);
  820. TRACE_EVENT(ocfs2_calc_refcount_meta_credits_iterate,
  821. TP_PROTO(int recs_add, unsigned long long cpos,
  822. unsigned int clusters, unsigned long long r_cpos,
  823. unsigned int r_clusters, unsigned int refcount, int index),
  824. TP_ARGS(recs_add, cpos, clusters, r_cpos, r_clusters, refcount, index),
  825. TP_STRUCT__entry(
  826. __field(int, recs_add)
  827. __field(unsigned long long, cpos)
  828. __field(unsigned int, clusters)
  829. __field(unsigned long long, r_cpos)
  830. __field(unsigned int, r_clusters)
  831. __field(unsigned int, refcount)
  832. __field(int, index)
  833. ),
  834. TP_fast_assign(
  835. __entry->recs_add = recs_add;
  836. __entry->cpos = cpos;
  837. __entry->clusters = clusters;
  838. __entry->r_cpos = r_cpos;
  839. __entry->r_clusters = r_clusters;
  840. __entry->refcount = refcount;
  841. __entry->index = index;
  842. ),
  843. TP_printk("%d %llu %u %llu %u %u %d",
  844. __entry->recs_add, __entry->cpos, __entry->clusters,
  845. __entry->r_cpos, __entry->r_clusters,
  846. __entry->refcount, __entry->index)
  847. );
  848. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_add_refcount_flag);
  849. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_prepare_refcount_change_for_del);
  850. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_lock_refcount_allocators);
  851. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_page);
  852. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_jbd);
  853. TRACE_EVENT(ocfs2_clear_ext_refcount,
  854. TP_PROTO(unsigned long long ino, unsigned int cpos,
  855. unsigned int len, unsigned int p_cluster,
  856. unsigned int ext_flags),
  857. TP_ARGS(ino, cpos, len, p_cluster, ext_flags),
  858. TP_STRUCT__entry(
  859. __field(unsigned long long, ino)
  860. __field(unsigned int, cpos)
  861. __field(unsigned int, len)
  862. __field(unsigned int, p_cluster)
  863. __field(unsigned int, ext_flags)
  864. ),
  865. TP_fast_assign(
  866. __entry->ino = ino;
  867. __entry->cpos = cpos;
  868. __entry->len = len;
  869. __entry->p_cluster = p_cluster;
  870. __entry->ext_flags = ext_flags;
  871. ),
  872. TP_printk("%llu %u %u %u %u",
  873. __entry->ino, __entry->cpos, __entry->len,
  874. __entry->p_cluster, __entry->ext_flags)
  875. );
  876. TRACE_EVENT(ocfs2_replace_clusters,
  877. TP_PROTO(unsigned long long ino, unsigned int cpos,
  878. unsigned int old, unsigned int new, unsigned int len,
  879. unsigned int ext_flags),
  880. TP_ARGS(ino, cpos, old, new, len, ext_flags),
  881. TP_STRUCT__entry(
  882. __field(unsigned long long, ino)
  883. __field(unsigned int, cpos)
  884. __field(unsigned int, old)
  885. __field(unsigned int, new)
  886. __field(unsigned int, len)
  887. __field(unsigned int, ext_flags)
  888. ),
  889. TP_fast_assign(
  890. __entry->ino = ino;
  891. __entry->cpos = cpos;
  892. __entry->old = old;
  893. __entry->new = new;
  894. __entry->len = len;
  895. __entry->ext_flags = ext_flags;
  896. ),
  897. TP_printk("%llu %u %u %u %u %u",
  898. __entry->ino, __entry->cpos, __entry->old, __entry->new,
  899. __entry->len, __entry->ext_flags)
  900. );
  901. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_make_clusters_writable);
  902. TRACE_EVENT(ocfs2_refcount_cow_hunk,
  903. TP_PROTO(unsigned long long ino, unsigned int cpos,
  904. unsigned int write_len, unsigned int max_cpos,
  905. unsigned int cow_start, unsigned int cow_len),
  906. TP_ARGS(ino, cpos, write_len, max_cpos, cow_start, cow_len),
  907. TP_STRUCT__entry(
  908. __field(unsigned long long, ino)
  909. __field(unsigned int, cpos)
  910. __field(unsigned int, write_len)
  911. __field(unsigned int, max_cpos)
  912. __field(unsigned int, cow_start)
  913. __field(unsigned int, cow_len)
  914. ),
  915. TP_fast_assign(
  916. __entry->ino = ino;
  917. __entry->cpos = cpos;
  918. __entry->write_len = write_len;
  919. __entry->max_cpos = max_cpos;
  920. __entry->cow_start = cow_start;
  921. __entry->cow_len = cow_len;
  922. ),
  923. TP_printk("%llu %u %u %u %u %u",
  924. __entry->ino, __entry->cpos, __entry->write_len,
  925. __entry->max_cpos, __entry->cow_start, __entry->cow_len)
  926. );
  927. /* End of trace events for fs/ocfs2/refcounttree.c. */
  928. /* Trace events for fs/ocfs2/aops.c. */
  929. DECLARE_EVENT_CLASS(ocfs2__get_block,
  930. TP_PROTO(unsigned long long ino, unsigned long long iblock,
  931. void *bh_result, int create),
  932. TP_ARGS(ino, iblock, bh_result, create),
  933. TP_STRUCT__entry(
  934. __field(unsigned long long, ino)
  935. __field(unsigned long long, iblock)
  936. __field(void *, bh_result)
  937. __field(int, create)
  938. ),
  939. TP_fast_assign(
  940. __entry->ino = ino;
  941. __entry->iblock = iblock;
  942. __entry->bh_result = bh_result;
  943. __entry->create = create;
  944. ),
  945. TP_printk("%llu %llu %p %d",
  946. __entry->ino, __entry->iblock,
  947. __entry->bh_result, __entry->create)
  948. );
  949. #define DEFINE_OCFS2_GET_BLOCK_EVENT(name) \
  950. DEFINE_EVENT(ocfs2__get_block, name, \
  951. TP_PROTO(unsigned long long ino, unsigned long long iblock, \
  952. void *bh_result, int create), \
  953. TP_ARGS(ino, iblock, bh_result, create))
  954. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_symlink_get_block);
  955. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_get_block);
  956. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_get_block_end);
  957. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_readpage);
  958. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_writepage);
  959. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_bmap);
  960. TRACE_EVENT(ocfs2_try_to_write_inline_data,
  961. TP_PROTO(unsigned long long ino, unsigned int len,
  962. unsigned long long pos, unsigned int flags),
  963. TP_ARGS(ino, len, pos, flags),
  964. TP_STRUCT__entry(
  965. __field(unsigned long long, ino)
  966. __field(unsigned int, len)
  967. __field(unsigned long long, pos)
  968. __field(unsigned int, flags)
  969. ),
  970. TP_fast_assign(
  971. __entry->ino = ino;
  972. __entry->len = len;
  973. __entry->pos = pos;
  974. __entry->flags = flags;
  975. ),
  976. TP_printk("%llu %u %llu 0x%x",
  977. __entry->ino, __entry->len, __entry->pos, __entry->flags)
  978. );
  979. TRACE_EVENT(ocfs2_write_begin_nolock,
  980. TP_PROTO(unsigned long long ino,
  981. long long i_size, unsigned int i_clusters,
  982. unsigned long long pos, unsigned int len,
  983. unsigned int flags, void *page,
  984. unsigned int clusters, unsigned int extents_to_split),
  985. TP_ARGS(ino, i_size, i_clusters, pos, len, flags,
  986. page, clusters, extents_to_split),
  987. TP_STRUCT__entry(
  988. __field(unsigned long long, ino)
  989. __field(long long, i_size)
  990. __field(unsigned int, i_clusters)
  991. __field(unsigned long long, pos)
  992. __field(unsigned int, len)
  993. __field(unsigned int, flags)
  994. __field(void *, page)
  995. __field(unsigned int, clusters)
  996. __field(unsigned int, extents_to_split)
  997. ),
  998. TP_fast_assign(
  999. __entry->ino = ino;
  1000. __entry->i_size = i_size;
  1001. __entry->i_clusters = i_clusters;
  1002. __entry->pos = pos;
  1003. __entry->len = len;
  1004. __entry->flags = flags;
  1005. __entry->page = page;
  1006. __entry->clusters = clusters;
  1007. __entry->extents_to_split = extents_to_split;
  1008. ),
  1009. TP_printk("%llu %lld %u %llu %u %u %p %u %u",
  1010. __entry->ino, __entry->i_size, __entry->i_clusters,
  1011. __entry->pos, __entry->len,
  1012. __entry->flags, __entry->page, __entry->clusters,
  1013. __entry->extents_to_split)
  1014. );
  1015. TRACE_EVENT(ocfs2_write_end_inline,
  1016. TP_PROTO(unsigned long long ino,
  1017. unsigned long long pos, unsigned int copied,
  1018. unsigned int id_count, unsigned int features),
  1019. TP_ARGS(ino, pos, copied, id_count, features),
  1020. TP_STRUCT__entry(
  1021. __field(unsigned long long, ino)
  1022. __field(unsigned long long, pos)
  1023. __field(unsigned int, copied)
  1024. __field(unsigned int, id_count)
  1025. __field(unsigned int, features)
  1026. ),
  1027. TP_fast_assign(
  1028. __entry->ino = ino;
  1029. __entry->pos = pos;
  1030. __entry->copied = copied;
  1031. __entry->id_count = id_count;
  1032. __entry->features = features;
  1033. ),
  1034. TP_printk("%llu %llu %u %u %u",
  1035. __entry->ino, __entry->pos, __entry->copied,
  1036. __entry->id_count, __entry->features)
  1037. );
  1038. /* End of trace events for fs/ocfs2/aops.c. */
  1039. /* Trace events for fs/ocfs2/mmap.c. */
  1040. TRACE_EVENT(ocfs2_fault,
  1041. TP_PROTO(unsigned long long ino,
  1042. void *area, void *page, unsigned long pgoff),
  1043. TP_ARGS(ino, area, page, pgoff),
  1044. TP_STRUCT__entry(
  1045. __field(unsigned long long, ino)
  1046. __field(void *, area)
  1047. __field(void *, page)
  1048. __field(unsigned long, pgoff)
  1049. ),
  1050. TP_fast_assign(
  1051. __entry->ino = ino;
  1052. __entry->area = area;
  1053. __entry->page = page;
  1054. __entry->pgoff = pgoff;
  1055. ),
  1056. TP_printk("%llu %p %p %lu",
  1057. __entry->ino, __entry->area, __entry->page, __entry->pgoff)
  1058. );
  1059. /* End of trace events for fs/ocfs2/mmap.c. */
  1060. /* Trace events for fs/ocfs2/file.c. */
  1061. DECLARE_EVENT_CLASS(ocfs2__file_ops,
  1062. TP_PROTO(void *inode, void *file, void *dentry,
  1063. unsigned long long ino,
  1064. unsigned int d_len, const unsigned char *d_name,
  1065. unsigned long long para),
  1066. TP_ARGS(inode, file, dentry, ino, d_len, d_name, para),
  1067. TP_STRUCT__entry(
  1068. __field(void *, inode)
  1069. __field(void *, file)
  1070. __field(void *, dentry)
  1071. __field(unsigned long long, ino)
  1072. __field(unsigned int, d_len)
  1073. __string(d_name, d_name)
  1074. __field(unsigned long long, para)
  1075. ),
  1076. TP_fast_assign(
  1077. __entry->inode = inode;
  1078. __entry->file = file;
  1079. __entry->dentry = dentry;
  1080. __entry->ino = ino;
  1081. __entry->d_len = d_len;
  1082. __assign_str(d_name, d_name);
  1083. __entry->para = para;
  1084. ),
  1085. TP_printk("%p %p %p %llu %llu %.*s", __entry->inode, __entry->file,
  1086. __entry->dentry, __entry->ino, __entry->para,
  1087. __entry->d_len, __get_str(d_name))
  1088. );
  1089. #define DEFINE_OCFS2_FILE_OPS(name) \
  1090. DEFINE_EVENT(ocfs2__file_ops, name, \
  1091. TP_PROTO(void *inode, void *file, void *dentry, \
  1092. unsigned long long ino, \
  1093. unsigned int d_len, const unsigned char *d_name, \
  1094. unsigned long long mode), \
  1095. TP_ARGS(inode, file, dentry, ino, d_len, d_name, mode))
  1096. DEFINE_OCFS2_FILE_OPS(ocfs2_file_open);
  1097. DEFINE_OCFS2_FILE_OPS(ocfs2_file_release);
  1098. DEFINE_OCFS2_FILE_OPS(ocfs2_sync_file);
  1099. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_write);
  1100. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_write);
  1101. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_read);
  1102. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_read);
  1103. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_truncate_file);
  1104. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_truncate_file_error);
  1105. TRACE_EVENT(ocfs2_extend_allocation,
  1106. TP_PROTO(unsigned long long ip_blkno, unsigned long long size,
  1107. unsigned int clusters, unsigned int clusters_to_add,
  1108. int why, int restart_func),
  1109. TP_ARGS(ip_blkno, size, clusters, clusters_to_add, why, restart_func),
  1110. TP_STRUCT__entry(
  1111. __field(unsigned long long, ip_blkno)
  1112. __field(unsigned long long, size)
  1113. __field(unsigned int, clusters)
  1114. __field(unsigned int, clusters_to_add)
  1115. __field(int, why)
  1116. __field(int, restart_func)
  1117. ),
  1118. TP_fast_assign(
  1119. __entry->ip_blkno = ip_blkno;
  1120. __entry->size = size;
  1121. __entry->clusters = clusters;
  1122. __entry->clusters_to_add = clusters_to_add;
  1123. __entry->why = why;
  1124. __entry->restart_func = restart_func;
  1125. ),
  1126. TP_printk("%llu %llu %u %u %d %d",
  1127. __entry->ip_blkno, __entry->size, __entry->clusters,
  1128. __entry->clusters_to_add, __entry->why, __entry->restart_func)
  1129. );
  1130. TRACE_EVENT(ocfs2_extend_allocation_end,
  1131. TP_PROTO(unsigned long long ino,
  1132. unsigned int di_clusters, unsigned long long di_size,
  1133. unsigned int ip_clusters, unsigned long long i_size),
  1134. TP_ARGS(ino, di_clusters, di_size, ip_clusters, i_size),
  1135. TP_STRUCT__entry(
  1136. __field(unsigned long long, ino)
  1137. __field(unsigned int, di_clusters)
  1138. __field(unsigned long long, di_size)
  1139. __field(unsigned int, ip_clusters)
  1140. __field(unsigned long long, i_size)
  1141. ),
  1142. TP_fast_assign(
  1143. __entry->ino = ino;
  1144. __entry->di_clusters = di_clusters;
  1145. __entry->di_size = di_size;
  1146. __entry->ip_clusters = ip_clusters;
  1147. __entry->i_size = i_size;
  1148. ),
  1149. TP_printk("%llu %u %llu %u %llu", __entry->ino, __entry->di_clusters,
  1150. __entry->di_size, __entry->ip_clusters, __entry->i_size)
  1151. );
  1152. TRACE_EVENT(ocfs2_write_zero_page,
  1153. TP_PROTO(unsigned long long ino,
  1154. unsigned long long abs_from, unsigned long long abs_to,
  1155. unsigned long index, unsigned int zero_from,
  1156. unsigned int zero_to),
  1157. TP_ARGS(ino, abs_from, abs_to, index, zero_from, zero_to),
  1158. TP_STRUCT__entry(
  1159. __field(unsigned long long, ino)
  1160. __field(unsigned long long, abs_from)
  1161. __field(unsigned long long, abs_to)
  1162. __field(unsigned long, index)
  1163. __field(unsigned int, zero_from)
  1164. __field(unsigned int, zero_to)
  1165. ),
  1166. TP_fast_assign(
  1167. __entry->ino = ino;
  1168. __entry->abs_from = abs_from;
  1169. __entry->abs_to = abs_to;
  1170. __entry->index = index;
  1171. __entry->zero_from = zero_from;
  1172. __entry->zero_to = zero_to;
  1173. ),
  1174. TP_printk("%llu %llu %llu %lu %u %u", __entry->ino,
  1175. __entry->abs_from, __entry->abs_to,
  1176. __entry->index, __entry->zero_from, __entry->zero_to)
  1177. );
  1178. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend_range);
  1179. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend);
  1180. TRACE_EVENT(ocfs2_setattr,
  1181. TP_PROTO(void *inode, void *dentry,
  1182. unsigned long long ino,
  1183. unsigned int d_len, const unsigned char *d_name,
  1184. unsigned int ia_valid, unsigned int ia_mode,
  1185. unsigned int ia_uid, unsigned int ia_gid),
  1186. TP_ARGS(inode, dentry, ino, d_len, d_name,
  1187. ia_valid, ia_mode, ia_uid, ia_gid),
  1188. TP_STRUCT__entry(
  1189. __field(void *, inode)
  1190. __field(void *, dentry)
  1191. __field(unsigned long long, ino)
  1192. __field(unsigned int, d_len)
  1193. __string(d_name, d_name)
  1194. __field(unsigned int, ia_valid)
  1195. __field(unsigned int, ia_mode)
  1196. __field(unsigned int, ia_uid)
  1197. __field(unsigned int, ia_gid)
  1198. ),
  1199. TP_fast_assign(
  1200. __entry->inode = inode;
  1201. __entry->dentry = dentry;
  1202. __entry->ino = ino;
  1203. __entry->d_len = d_len;
  1204. __assign_str(d_name, d_name);
  1205. __entry->ia_valid = ia_valid;
  1206. __entry->ia_mode = ia_mode;
  1207. __entry->ia_uid = ia_uid;
  1208. __entry->ia_gid = ia_gid;
  1209. ),
  1210. TP_printk("%p %p %llu %.*s %u %u %u %u", __entry->inode,
  1211. __entry->dentry, __entry->ino, __entry->d_len,
  1212. __get_str(d_name), __entry->ia_valid, __entry->ia_mode,
  1213. __entry->ia_uid, __entry->ia_gid)
  1214. );
  1215. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_write_remove_suid);
  1216. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_partial_clusters);
  1217. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range1);
  1218. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range2);
  1219. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_remove_inode_range);
  1220. TRACE_EVENT(ocfs2_prepare_inode_for_write,
  1221. TP_PROTO(unsigned long long ino, unsigned long long saved_pos,
  1222. int appending, unsigned long count,
  1223. int *direct_io, int *has_refcount),
  1224. TP_ARGS(ino, saved_pos, appending, count, direct_io, has_refcount),
  1225. TP_STRUCT__entry(
  1226. __field(unsigned long long, ino)
  1227. __field(unsigned long long, saved_pos)
  1228. __field(int, appending)
  1229. __field(unsigned long, count)
  1230. __field(int, direct_io)
  1231. __field(int, has_refcount)
  1232. ),
  1233. TP_fast_assign(
  1234. __entry->ino = ino;
  1235. __entry->saved_pos = saved_pos;
  1236. __entry->appending = appending;
  1237. __entry->count = count;
  1238. __entry->direct_io = direct_io ? *direct_io : -1;
  1239. __entry->has_refcount = has_refcount ? *has_refcount : -1;
  1240. ),
  1241. TP_printk("%llu %llu %d %lu %d %d", __entry->ino,
  1242. __entry->saved_pos, __entry->appending, __entry->count,
  1243. __entry->direct_io, __entry->has_refcount)
  1244. );
  1245. DEFINE_OCFS2_INT_EVENT(generic_file_aio_read_ret);
  1246. /* End of trace events for fs/ocfs2/file.c. */
  1247. /* Trace events for fs/ocfs2/inode.c. */
  1248. TRACE_EVENT(ocfs2_iget_begin,
  1249. TP_PROTO(unsigned long long ino, unsigned int flags, int sysfile_type),
  1250. TP_ARGS(ino, flags, sysfile_type),
  1251. TP_STRUCT__entry(
  1252. __field(unsigned long long, ino)
  1253. __field(unsigned int, flags)
  1254. __field(int, sysfile_type)
  1255. ),
  1256. TP_fast_assign(
  1257. __entry->ino = ino;
  1258. __entry->flags = flags;
  1259. __entry->sysfile_type = sysfile_type;
  1260. ),
  1261. TP_printk("%llu %u %d", __entry->ino,
  1262. __entry->flags, __entry->sysfile_type)
  1263. );
  1264. DEFINE_OCFS2_ULL_EVENT(ocfs2_iget5_locked);
  1265. TRACE_EVENT(ocfs2_iget_end,
  1266. TP_PROTO(void *inode, unsigned long long ino),
  1267. TP_ARGS(inode, ino),
  1268. TP_STRUCT__entry(
  1269. __field(void *, inode)
  1270. __field(unsigned long long, ino)
  1271. ),
  1272. TP_fast_assign(
  1273. __entry->inode = inode;
  1274. __entry->ino = ino;
  1275. ),
  1276. TP_printk("%p %llu", __entry->inode, __entry->ino)
  1277. );
  1278. TRACE_EVENT(ocfs2_find_actor,
  1279. TP_PROTO(void *inode, unsigned long long ino,
  1280. void *args, unsigned long long fi_blkno),
  1281. TP_ARGS(inode, ino, args, fi_blkno),
  1282. TP_STRUCT__entry(
  1283. __field(void *, inode)
  1284. __field(unsigned long long, ino)
  1285. __field(void *, args)
  1286. __field(unsigned long long, fi_blkno)
  1287. ),
  1288. TP_fast_assign(
  1289. __entry->inode = inode;
  1290. __entry->ino = ino;
  1291. __entry->args = args;
  1292. __entry->fi_blkno = fi_blkno;
  1293. ),
  1294. TP_printk("%p %llu %p %llu", __entry->inode, __entry->ino,
  1295. __entry->args, __entry->fi_blkno)
  1296. );
  1297. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_populate_inode);
  1298. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_read_locked_inode);
  1299. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_check_orphan_recovery_state);
  1300. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_inode_block);
  1301. TRACE_EVENT(ocfs2_inode_is_valid_to_delete,
  1302. TP_PROTO(void *task, void *dc_task, unsigned long long ino,
  1303. unsigned int flags),
  1304. TP_ARGS(task, dc_task, ino, flags),
  1305. TP_STRUCT__entry(
  1306. __field(void *, task)
  1307. __field(void *, dc_task)
  1308. __field(unsigned long long, ino)
  1309. __field(unsigned int, flags)
  1310. ),
  1311. TP_fast_assign(
  1312. __entry->task = task;
  1313. __entry->dc_task = dc_task;
  1314. __entry->ino = ino;
  1315. __entry->flags = flags;
  1316. ),
  1317. TP_printk("%p %p %llu %u", __entry->task, __entry->dc_task,
  1318. __entry->ino, __entry->flags)
  1319. );
  1320. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_query_inode_wipe_begin);
  1321. DEFINE_OCFS2_UINT_EVENT(ocfs2_query_inode_wipe_succ);
  1322. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_query_inode_wipe_end);
  1323. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_cleanup_delete_inode);
  1324. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_delete_inode);
  1325. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_clear_inode);
  1326. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_drop_inode);
  1327. TRACE_EVENT(ocfs2_inode_revalidate,
  1328. TP_PROTO(void *inode, unsigned long long ino,
  1329. unsigned int flags),
  1330. TP_ARGS(inode, ino, flags),
  1331. TP_STRUCT__entry(
  1332. __field(void *, inode)
  1333. __field(unsigned long long, ino)
  1334. __field(unsigned int, flags)
  1335. ),
  1336. TP_fast_assign(
  1337. __entry->inode = inode;
  1338. __entry->ino = ino;
  1339. __entry->flags = flags;
  1340. ),
  1341. TP_printk("%p %llu %u", __entry->inode, __entry->ino, __entry->flags)
  1342. );
  1343. DEFINE_OCFS2_ULL_EVENT(ocfs2_mark_inode_dirty);
  1344. /* End of trace events for fs/ocfs2/inode.c. */
  1345. /* Trace events for fs/ocfs2/extent_map.c. */
  1346. TRACE_EVENT(ocfs2_read_virt_blocks,
  1347. TP_PROTO(void *inode, unsigned long long vblock, int nr,
  1348. void *bhs, unsigned int flags, void *validate),
  1349. TP_ARGS(inode, vblock, nr, bhs, flags, validate),
  1350. TP_STRUCT__entry(
  1351. __field(void *, inode)
  1352. __field(unsigned long long, vblock)
  1353. __field(int, nr)
  1354. __field(void *, bhs)
  1355. __field(unsigned int, flags)
  1356. __field(void *, validate)
  1357. ),
  1358. TP_fast_assign(
  1359. __entry->inode = inode;
  1360. __entry->vblock = vblock;
  1361. __entry->nr = nr;
  1362. __entry->bhs = bhs;
  1363. __entry->flags = flags;
  1364. __entry->validate = validate;
  1365. ),
  1366. TP_printk("%p %llu %d %p %x %p", __entry->inode, __entry->vblock,
  1367. __entry->nr, __entry->bhs, __entry->flags, __entry->validate)
  1368. );
  1369. /* End of trace events for fs/ocfs2/extent_map.c. */
  1370. /* Trace events for fs/ocfs2/slot_map.c. */
  1371. DEFINE_OCFS2_UINT_EVENT(ocfs2_refresh_slot_info);
  1372. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_map_slot_buffers);
  1373. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_map_slot_buffers_block);
  1374. DEFINE_OCFS2_INT_EVENT(ocfs2_find_slot);
  1375. /* End of trace events for fs/ocfs2/slot_map.c. */
  1376. /* Trace events for fs/ocfs2/heartbeat.c. */
  1377. DEFINE_OCFS2_INT_EVENT(ocfs2_do_node_down);
  1378. /* End of trace events for fs/ocfs2/heartbeat.c. */
  1379. /* Trace events for fs/ocfs2/super.c. */
  1380. TRACE_EVENT(ocfs2_remount,
  1381. TP_PROTO(unsigned long s_flags, unsigned long osb_flags, int flags),
  1382. TP_ARGS(s_flags, osb_flags, flags),
  1383. TP_STRUCT__entry(
  1384. __field(unsigned long, s_flags)
  1385. __field(unsigned long, osb_flags)
  1386. __field(int, flags)
  1387. ),
  1388. TP_fast_assign(
  1389. __entry->s_flags = s_flags;
  1390. __entry->osb_flags = osb_flags;
  1391. __entry->flags = flags;
  1392. ),
  1393. TP_printk("%lu %lu %d", __entry->s_flags,
  1394. __entry->osb_flags, __entry->flags)
  1395. );
  1396. TRACE_EVENT(ocfs2_fill_super,
  1397. TP_PROTO(void *sb, void *data, int silent),
  1398. TP_ARGS(sb, data, silent),
  1399. TP_STRUCT__entry(
  1400. __field(void *, sb)
  1401. __field(void *, data)
  1402. __field(int, silent)
  1403. ),
  1404. TP_fast_assign(
  1405. __entry->sb = sb;
  1406. __entry->data = data;
  1407. __entry->silent = silent;
  1408. ),
  1409. TP_printk("%p %p %d", __entry->sb,
  1410. __entry->data, __entry->silent)
  1411. );
  1412. TRACE_EVENT(ocfs2_parse_options,
  1413. TP_PROTO(int is_remount, char *options),
  1414. TP_ARGS(is_remount, options),
  1415. TP_STRUCT__entry(
  1416. __field(int, is_remount)
  1417. __string(options, options)
  1418. ),
  1419. TP_fast_assign(
  1420. __entry->is_remount = is_remount;
  1421. __assign_str(options, options);
  1422. ),
  1423. TP_printk("%d %s", __entry->is_remount, __get_str(options))
  1424. );
  1425. DEFINE_OCFS2_POINTER_EVENT(ocfs2_put_super);
  1426. TRACE_EVENT(ocfs2_statfs,
  1427. TP_PROTO(void *sb, void *buf),
  1428. TP_ARGS(sb, buf),
  1429. TP_STRUCT__entry(
  1430. __field(void *, sb)
  1431. __field(void *, buf)
  1432. ),
  1433. TP_fast_assign(
  1434. __entry->sb = sb;
  1435. __entry->buf = buf;
  1436. ),
  1437. TP_printk("%p %p", __entry->sb, __entry->buf)
  1438. );
  1439. DEFINE_OCFS2_POINTER_EVENT(ocfs2_dismount_volume);
  1440. TRACE_EVENT(ocfs2_initialize_super,
  1441. TP_PROTO(char *label, char *uuid_str, unsigned long long root_dir,
  1442. unsigned long long system_dir, int cluster_bits),
  1443. TP_ARGS(label, uuid_str, root_dir, system_dir, cluster_bits),
  1444. TP_STRUCT__entry(
  1445. __string(label, label)
  1446. __string(uuid_str, uuid_str)
  1447. __field(unsigned long long, root_dir)
  1448. __field(unsigned long long, system_dir)
  1449. __field(int, cluster_bits)
  1450. ),
  1451. TP_fast_assign(
  1452. __assign_str(label, label);
  1453. __assign_str(uuid_str, uuid_str);
  1454. __entry->root_dir = root_dir;
  1455. __entry->system_dir = system_dir;
  1456. __entry->cluster_bits = cluster_bits;
  1457. ),
  1458. TP_printk("%s %s %llu %llu %d", __get_str(label), __get_str(uuid_str),
  1459. __entry->root_dir, __entry->system_dir, __entry->cluster_bits)
  1460. );
  1461. /* End of trace events for fs/ocfs2/super.c. */
  1462. /* Trace events for fs/ocfs2/xattr.c. */
  1463. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_xattr_block);
  1464. DEFINE_OCFS2_UINT_EVENT(ocfs2_xattr_extend_allocation);
  1465. TRACE_EVENT(ocfs2_init_xattr_set_ctxt,
  1466. TP_PROTO(const char *name, int meta, int clusters, int credits),
  1467. TP_ARGS(name, meta, clusters, credits),
  1468. TP_STRUCT__entry(
  1469. __string(name, name)
  1470. __field(int, meta)
  1471. __field(int, clusters)
  1472. __field(int, credits)
  1473. ),
  1474. TP_fast_assign(
  1475. __assign_str(name, name);
  1476. __entry->meta = meta;
  1477. __entry->clusters = clusters;
  1478. __entry->credits = credits;
  1479. ),
  1480. TP_printk("%s %d %d %d", __get_str(name), __entry->meta,
  1481. __entry->clusters, __entry->credits)
  1482. );
  1483. DECLARE_EVENT_CLASS(ocfs2__xattr_find,
  1484. TP_PROTO(unsigned long long ino, const char *name, int name_index,
  1485. unsigned int hash, unsigned long long location,
  1486. int xe_index),
  1487. TP_ARGS(ino, name, name_index, hash, location, xe_index),
  1488. TP_STRUCT__entry(
  1489. __field(unsigned long long, ino)
  1490. __string(name, name)
  1491. __field(int, name_index)
  1492. __field(unsigned int, hash)
  1493. __field(unsigned long long, location)
  1494. __field(int, xe_index)
  1495. ),
  1496. TP_fast_assign(
  1497. __entry->ino = ino;
  1498. __assign_str(name, name);
  1499. __entry->name_index = name_index;
  1500. __entry->hash = hash;
  1501. __entry->location = location;
  1502. __entry->xe_index = xe_index;
  1503. ),
  1504. TP_printk("%llu %s %d %u %llu %d", __entry->ino, __get_str(name),
  1505. __entry->name_index, __entry->hash, __entry->location,
  1506. __entry->xe_index)
  1507. );
  1508. #define DEFINE_OCFS2_XATTR_FIND_EVENT(name) \
  1509. DEFINE_EVENT(ocfs2__xattr_find, name, \
  1510. TP_PROTO(unsigned long long ino, const char *name, int name_index, \
  1511. unsigned int hash, unsigned long long bucket, \
  1512. int xe_index), \
  1513. TP_ARGS(ino, name, name_index, hash, bucket, xe_index))
  1514. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_bucket_find);
  1515. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_index_block_find);
  1516. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_index_block_find_rec);
  1517. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_iterate_xattr_buckets);
  1518. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_iterate_xattr_bucket);
  1519. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cp_xattr_block_to_bucket_begin);
  1520. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_cp_xattr_block_to_bucket_end);
  1521. DEFINE_OCFS2_ULL_EVENT(ocfs2_xattr_create_index_block_begin);
  1522. DEFINE_OCFS2_ULL_EVENT(ocfs2_xattr_create_index_block);
  1523. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_defrag_xattr_bucket);
  1524. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_mv_xattr_bucket_cross_cluster);
  1525. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_divide_xattr_bucket_begin);
  1526. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_divide_xattr_bucket_move);
  1527. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_cp_xattr_bucket);
  1528. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_mv_xattr_buckets);
  1529. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_adjust_xattr_cross_cluster);
  1530. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_add_new_xattr_cluster_begin);
  1531. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_add_new_xattr_cluster);
  1532. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_add_new_xattr_cluster_insert);
  1533. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_extend_xattr_bucket);
  1534. DEFINE_OCFS2_ULL_EVENT(ocfs2_add_new_xattr_bucket);
  1535. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_xattr_bucket_value_truncate);
  1536. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_rm_xattr_cluster);
  1537. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_reflink_xattr_header);
  1538. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_create_empty_xattr_block);
  1539. DEFINE_OCFS2_STRING_EVENT(ocfs2_xattr_set_entry_bucket);
  1540. DEFINE_OCFS2_STRING_EVENT(ocfs2_xattr_set_entry_index_block);
  1541. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_xattr_bucket_value_refcount);
  1542. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_reflink_xattr_buckets);
  1543. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_reflink_xattr_rec);
  1544. /* End of trace events for fs/ocfs2/xattr.c. */
  1545. #endif /* _TRACE_OCFS2_H */
  1546. /* This part must be outside protection */
  1547. #undef TRACE_INCLUDE_PATH
  1548. #define TRACE_INCLUDE_PATH .
  1549. #define TRACE_INCLUDE_FILE ocfs2_trace
  1550. #include <trace/define_trace.h>