ocfs2_trace.h 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499
  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__int_int,
  52. TP_PROTO(int value1, int value2),
  53. TP_ARGS(value1, value2),
  54. TP_STRUCT__entry(
  55. __field(int, value1)
  56. __field(int, value2)
  57. ),
  58. TP_fast_assign(
  59. __entry->value1 = value1;
  60. __entry->value2 = value2;
  61. ),
  62. TP_printk("%d %d", __entry->value1, __entry->value2)
  63. );
  64. #define DEFINE_OCFS2_INT_INT_EVENT(name) \
  65. DEFINE_EVENT(ocfs2__int_int, name, \
  66. TP_PROTO(int val1, int val2), \
  67. TP_ARGS(val1, val2))
  68. DECLARE_EVENT_CLASS(ocfs2__uint_uint,
  69. TP_PROTO(unsigned int value1, unsigned int value2),
  70. TP_ARGS(value1, value2),
  71. TP_STRUCT__entry(
  72. __field(unsigned int, value1)
  73. __field(unsigned int, value2)
  74. ),
  75. TP_fast_assign(
  76. __entry->value1 = value1;
  77. __entry->value2 = value2;
  78. ),
  79. TP_printk("%u %u", __entry->value1, __entry->value2)
  80. );
  81. #define DEFINE_OCFS2_UINT_UINT_EVENT(name) \
  82. DEFINE_EVENT(ocfs2__uint_uint, name, \
  83. TP_PROTO(unsigned int val1, unsigned int val2), \
  84. TP_ARGS(val1, val2))
  85. DECLARE_EVENT_CLASS(ocfs2__ull_uint,
  86. TP_PROTO(unsigned long long value1, unsigned int value2),
  87. TP_ARGS(value1, value2),
  88. TP_STRUCT__entry(
  89. __field(unsigned long long, value1)
  90. __field(unsigned int, value2)
  91. ),
  92. TP_fast_assign(
  93. __entry->value1 = value1;
  94. __entry->value2 = value2;
  95. ),
  96. TP_printk("%llu %u", __entry->value1, __entry->value2)
  97. );
  98. #define DEFINE_OCFS2_ULL_UINT_EVENT(name) \
  99. DEFINE_EVENT(ocfs2__ull_uint, name, \
  100. TP_PROTO(unsigned long long val1, unsigned int val2), \
  101. TP_ARGS(val1, val2))
  102. DECLARE_EVENT_CLASS(ocfs2__ull_int,
  103. TP_PROTO(unsigned long long value1, int value2),
  104. TP_ARGS(value1, value2),
  105. TP_STRUCT__entry(
  106. __field(unsigned long long, value1)
  107. __field(int, value2)
  108. ),
  109. TP_fast_assign(
  110. __entry->value1 = value1;
  111. __entry->value2 = value2;
  112. ),
  113. TP_printk("%llu %d", __entry->value1, __entry->value2)
  114. );
  115. #define DEFINE_OCFS2_ULL_INT_EVENT(name) \
  116. DEFINE_EVENT(ocfs2__ull_int, name, \
  117. TP_PROTO(unsigned long long val1, int val2), \
  118. TP_ARGS(val1, val2))
  119. DECLARE_EVENT_CLASS(ocfs2__ull_ull,
  120. TP_PROTO(unsigned long long value1, unsigned long long value2),
  121. TP_ARGS(value1, value2),
  122. TP_STRUCT__entry(
  123. __field(unsigned long long, value1)
  124. __field(unsigned long long, value2)
  125. ),
  126. TP_fast_assign(
  127. __entry->value1 = value1;
  128. __entry->value2 = value2;
  129. ),
  130. TP_printk("%llu %llu", __entry->value1, __entry->value2)
  131. );
  132. #define DEFINE_OCFS2_ULL_ULL_EVENT(name) \
  133. DEFINE_EVENT(ocfs2__ull_ull, name, \
  134. TP_PROTO(unsigned long long val1, unsigned long long val2), \
  135. TP_ARGS(val1, val2))
  136. DECLARE_EVENT_CLASS(ocfs2__ull_ull_uint,
  137. TP_PROTO(unsigned long long value1,
  138. unsigned long long value2, unsigned int value3),
  139. TP_ARGS(value1, value2, value3),
  140. TP_STRUCT__entry(
  141. __field(unsigned long long, value1)
  142. __field(unsigned long long, value2)
  143. __field(unsigned int, value3)
  144. ),
  145. TP_fast_assign(
  146. __entry->value1 = value1;
  147. __entry->value2 = value2;
  148. __entry->value3 = value3;
  149. ),
  150. TP_printk("%llu %llu %u",
  151. __entry->value1, __entry->value2, __entry->value3)
  152. );
  153. #define DEFINE_OCFS2_ULL_ULL_UINT_EVENT(name) \
  154. DEFINE_EVENT(ocfs2__ull_ull_uint, name, \
  155. TP_PROTO(unsigned long long val1, \
  156. unsigned long long val2, unsigned int val3), \
  157. TP_ARGS(val1, val2, val3))
  158. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint,
  159. TP_PROTO(unsigned long long value1,
  160. unsigned int value2, unsigned int value3),
  161. TP_ARGS(value1, value2, value3),
  162. TP_STRUCT__entry(
  163. __field(unsigned long long, value1)
  164. __field(unsigned int, value2)
  165. __field(unsigned int, value3)
  166. ),
  167. TP_fast_assign(
  168. __entry->value1 = value1;
  169. __entry->value2 = value2;
  170. __entry->value3 = value3;
  171. ),
  172. TP_printk("%llu %u %u", __entry->value1,
  173. __entry->value2, __entry->value3)
  174. );
  175. #define DEFINE_OCFS2_ULL_UINT_UINT_EVENT(name) \
  176. DEFINE_EVENT(ocfs2__ull_uint_uint, name, \
  177. TP_PROTO(unsigned long long val1, \
  178. unsigned int val2, unsigned int val3), \
  179. TP_ARGS(val1, val2, val3))
  180. DECLARE_EVENT_CLASS(ocfs2__uint_uint_uint,
  181. TP_PROTO(unsigned int value1, unsigned int value2,
  182. unsigned int value3),
  183. TP_ARGS(value1, value2, value3),
  184. TP_STRUCT__entry(
  185. __field( unsigned int, value1 )
  186. __field( unsigned int, value2 )
  187. __field( unsigned int, value3 )
  188. ),
  189. TP_fast_assign(
  190. __entry->value1 = value1;
  191. __entry->value2 = value2;
  192. __entry->value3 = value3;
  193. ),
  194. TP_printk("%u %u %u", __entry->value1, __entry->value2, __entry->value3)
  195. );
  196. #define DEFINE_OCFS2_UINT_UINT_UINT_EVENT(name) \
  197. DEFINE_EVENT(ocfs2__uint_uint_uint, name, \
  198. TP_PROTO(unsigned int value1, unsigned int value2, \
  199. unsigned int value3), \
  200. TP_ARGS(value1, value2, value3))
  201. DECLARE_EVENT_CLASS(ocfs2__ull_ull_ull,
  202. TP_PROTO(unsigned long long value1,
  203. unsigned long long value2, unsigned long long value3),
  204. TP_ARGS(value1, value2, value3),
  205. TP_STRUCT__entry(
  206. __field(unsigned long long, value1)
  207. __field(unsigned long long, value2)
  208. __field(unsigned long long, value3)
  209. ),
  210. TP_fast_assign(
  211. __entry->value1 = value1;
  212. __entry->value2 = value2;
  213. __entry->value3 = value3;
  214. ),
  215. TP_printk("%llu %llu %llu",
  216. __entry->value1, __entry->value2, __entry->value3)
  217. );
  218. #define DEFINE_OCFS2_ULL_ULL_ULL_EVENT(name) \
  219. DEFINE_EVENT(ocfs2__ull_ull_ull, name, \
  220. TP_PROTO(unsigned long long value1, unsigned long long value2, \
  221. unsigned long long value3), \
  222. TP_ARGS(value1, value2, value3))
  223. DECLARE_EVENT_CLASS(ocfs2__ull_int_int_int,
  224. TP_PROTO(unsigned long long ull, int value1, int value2, int value3),
  225. TP_ARGS(ull, value1, value2, value3),
  226. TP_STRUCT__entry(
  227. __field( unsigned long long, ull )
  228. __field( int, value1 )
  229. __field( int, value2 )
  230. __field( int, value3 )
  231. ),
  232. TP_fast_assign(
  233. __entry->ull = ull;
  234. __entry->value1 = value1;
  235. __entry->value2 = value2;
  236. __entry->value3 = value3;
  237. ),
  238. TP_printk("%llu %d %d %d",
  239. __entry->ull, __entry->value1,
  240. __entry->value2, __entry->value3)
  241. );
  242. #define DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(name) \
  243. DEFINE_EVENT(ocfs2__ull_int_int_int, name, \
  244. TP_PROTO(unsigned long long ull, int value1, \
  245. int value2, int value3), \
  246. TP_ARGS(ull, value1, value2, value3))
  247. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint_uint,
  248. TP_PROTO(unsigned long long ull, unsigned int value1,
  249. unsigned int value2, unsigned int value3),
  250. TP_ARGS(ull, value1, value2, value3),
  251. TP_STRUCT__entry(
  252. __field(unsigned long long, ull)
  253. __field(unsigned int, value1)
  254. __field(unsigned int, value2)
  255. __field(unsigned int, value3)
  256. ),
  257. TP_fast_assign(
  258. __entry->ull = ull;
  259. __entry->value1 = value1;
  260. __entry->value2 = value2;
  261. __entry->value3 = value3;
  262. ),
  263. TP_printk("%llu %u %u %u",
  264. __entry->ull, __entry->value1,
  265. __entry->value2, __entry->value3)
  266. );
  267. #define DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(name) \
  268. DEFINE_EVENT(ocfs2__ull_uint_uint_uint, name, \
  269. TP_PROTO(unsigned long long ull, unsigned int value1, \
  270. unsigned int value2, unsigned int value3), \
  271. TP_ARGS(ull, value1, value2, value3))
  272. /* Trace events for fs/ocfs2/alloc.c. */
  273. DECLARE_EVENT_CLASS(ocfs2__btree_ops,
  274. TP_PROTO(unsigned long long owner,\
  275. unsigned int value1, unsigned int value2),
  276. TP_ARGS(owner, value1, value2),
  277. TP_STRUCT__entry(
  278. __field(unsigned long long, owner)
  279. __field(unsigned int, value1)
  280. __field(unsigned int, value2)
  281. ),
  282. TP_fast_assign(
  283. __entry->owner = owner;
  284. __entry->value1 = value1;
  285. __entry->value2 = value2;
  286. ),
  287. TP_printk("%llu %u %u",
  288. __entry->owner, __entry->value1, __entry->value2)
  289. );
  290. #define DEFINE_OCFS2_BTREE_EVENT(name) \
  291. DEFINE_EVENT(ocfs2__btree_ops, name, \
  292. TP_PROTO(unsigned long long owner, \
  293. unsigned int value1, unsigned int value2), \
  294. TP_ARGS(owner, value1, value2))
  295. DEFINE_OCFS2_BTREE_EVENT(ocfs2_adjust_rightmost_branch);
  296. DEFINE_OCFS2_BTREE_EVENT(ocfs2_rotate_tree_right);
  297. DEFINE_OCFS2_BTREE_EVENT(ocfs2_append_rec_to_path);
  298. DEFINE_OCFS2_BTREE_EVENT(ocfs2_insert_extent_start);
  299. DEFINE_OCFS2_BTREE_EVENT(ocfs2_add_clusters_in_btree);
  300. DEFINE_OCFS2_INT_EVENT(ocfs2_num_free_extents);
  301. DEFINE_OCFS2_INT_EVENT(ocfs2_complete_edge_insert);
  302. TRACE_EVENT(ocfs2_grow_tree,
  303. TP_PROTO(unsigned long long owner, int depth),
  304. TP_ARGS(owner, depth),
  305. TP_STRUCT__entry(
  306. __field(unsigned long long, owner)
  307. __field(int, depth)
  308. ),
  309. TP_fast_assign(
  310. __entry->owner = owner;
  311. __entry->depth = depth;
  312. ),
  313. TP_printk("%llu %d", __entry->owner, __entry->depth)
  314. );
  315. TRACE_EVENT(ocfs2_rotate_subtree,
  316. TP_PROTO(int subtree_root, unsigned long long blkno,
  317. int depth),
  318. TP_ARGS(subtree_root, blkno, depth),
  319. TP_STRUCT__entry(
  320. __field(int, subtree_root)
  321. __field(unsigned long long, blkno)
  322. __field(int, depth)
  323. ),
  324. TP_fast_assign(
  325. __entry->subtree_root = subtree_root;
  326. __entry->blkno = blkno;
  327. __entry->depth = depth;
  328. ),
  329. TP_printk("%d %llu %d", __entry->subtree_root,
  330. __entry->blkno, __entry->depth)
  331. );
  332. TRACE_EVENT(ocfs2_insert_extent,
  333. TP_PROTO(unsigned int ins_appending, unsigned int ins_contig,
  334. int ins_contig_index, int free_records, int ins_tree_depth),
  335. TP_ARGS(ins_appending, ins_contig, ins_contig_index, free_records,
  336. ins_tree_depth),
  337. TP_STRUCT__entry(
  338. __field(unsigned int, ins_appending)
  339. __field(unsigned int, ins_contig)
  340. __field(int, ins_contig_index)
  341. __field(int, free_records)
  342. __field(int, ins_tree_depth)
  343. ),
  344. TP_fast_assign(
  345. __entry->ins_appending = ins_appending;
  346. __entry->ins_contig = ins_contig;
  347. __entry->ins_contig_index = ins_contig_index;
  348. __entry->free_records = free_records;
  349. __entry->ins_tree_depth = ins_tree_depth;
  350. ),
  351. TP_printk("%u %u %d %d %d",
  352. __entry->ins_appending, __entry->ins_contig,
  353. __entry->ins_contig_index, __entry->free_records,
  354. __entry->ins_tree_depth)
  355. );
  356. TRACE_EVENT(ocfs2_split_extent,
  357. TP_PROTO(int split_index, unsigned int c_contig_type,
  358. unsigned int c_has_empty_extent,
  359. unsigned int c_split_covers_rec),
  360. TP_ARGS(split_index, c_contig_type,
  361. c_has_empty_extent, c_split_covers_rec),
  362. TP_STRUCT__entry(
  363. __field(int, split_index)
  364. __field(unsigned int, c_contig_type)
  365. __field(unsigned int, c_has_empty_extent)
  366. __field(unsigned int, c_split_covers_rec)
  367. ),
  368. TP_fast_assign(
  369. __entry->split_index = split_index;
  370. __entry->c_contig_type = c_contig_type;
  371. __entry->c_has_empty_extent = c_has_empty_extent;
  372. __entry->c_split_covers_rec = c_split_covers_rec;
  373. ),
  374. TP_printk("%d %u %u %u", __entry->split_index, __entry->c_contig_type,
  375. __entry->c_has_empty_extent, __entry->c_split_covers_rec)
  376. );
  377. TRACE_EVENT(ocfs2_remove_extent,
  378. TP_PROTO(unsigned long long owner, unsigned int cpos,
  379. unsigned int len, int index,
  380. unsigned int e_cpos, unsigned int clusters),
  381. TP_ARGS(owner, cpos, len, index, e_cpos, clusters),
  382. TP_STRUCT__entry(
  383. __field(unsigned long long, owner)
  384. __field(unsigned int, cpos)
  385. __field(unsigned int, len)
  386. __field(int, index)
  387. __field(unsigned int, e_cpos)
  388. __field(unsigned int, clusters)
  389. ),
  390. TP_fast_assign(
  391. __entry->owner = owner;
  392. __entry->cpos = cpos;
  393. __entry->len = len;
  394. __entry->index = index;
  395. __entry->e_cpos = e_cpos;
  396. __entry->clusters = clusters;
  397. ),
  398. TP_printk("%llu %u %u %d %u %u",
  399. __entry->owner, __entry->cpos, __entry->len, __entry->index,
  400. __entry->e_cpos, __entry->clusters)
  401. );
  402. TRACE_EVENT(ocfs2_commit_truncate,
  403. TP_PROTO(unsigned long long ino, unsigned int new_cpos,
  404. unsigned int clusters, unsigned int depth),
  405. TP_ARGS(ino, new_cpos, clusters, depth),
  406. TP_STRUCT__entry(
  407. __field(unsigned long long, ino)
  408. __field(unsigned int, new_cpos)
  409. __field(unsigned int, clusters)
  410. __field(unsigned int, depth)
  411. ),
  412. TP_fast_assign(
  413. __entry->ino = ino;
  414. __entry->new_cpos = new_cpos;
  415. __entry->clusters = clusters;
  416. __entry->depth = depth;
  417. ),
  418. TP_printk("%llu %u %u %u",
  419. __entry->ino, __entry->new_cpos,
  420. __entry->clusters, __entry->depth)
  421. );
  422. TRACE_EVENT(ocfs2_validate_extent_block,
  423. TP_PROTO(unsigned long long blkno),
  424. TP_ARGS(blkno),
  425. TP_STRUCT__entry(
  426. __field(unsigned long long, blkno)
  427. ),
  428. TP_fast_assign(
  429. __entry->blkno = blkno;
  430. ),
  431. TP_printk("%llu ", __entry->blkno)
  432. );
  433. TRACE_EVENT(ocfs2_rotate_leaf,
  434. TP_PROTO(unsigned int insert_cpos, int insert_index,
  435. int has_empty, int next_free,
  436. unsigned int l_count),
  437. TP_ARGS(insert_cpos, insert_index, has_empty,
  438. next_free, l_count),
  439. TP_STRUCT__entry(
  440. __field(unsigned int, insert_cpos)
  441. __field(int, insert_index)
  442. __field(int, has_empty)
  443. __field(int, next_free)
  444. __field(unsigned int, l_count)
  445. ),
  446. TP_fast_assign(
  447. __entry->insert_cpos = insert_cpos;
  448. __entry->insert_index = insert_index;
  449. __entry->has_empty = has_empty;
  450. __entry->next_free = next_free;
  451. __entry->l_count = l_count;
  452. ),
  453. TP_printk("%u %d %d %d %u", __entry->insert_cpos,
  454. __entry->insert_index, __entry->has_empty,
  455. __entry->next_free, __entry->l_count)
  456. );
  457. TRACE_EVENT(ocfs2_add_clusters_in_btree_ret,
  458. TP_PROTO(int status, int reason, int err),
  459. TP_ARGS(status, reason, err),
  460. TP_STRUCT__entry(
  461. __field(int, status)
  462. __field(int, reason)
  463. __field(int, err)
  464. ),
  465. TP_fast_assign(
  466. __entry->status = status;
  467. __entry->reason = reason;
  468. __entry->err = err;
  469. ),
  470. TP_printk("%d %d %d", __entry->status,
  471. __entry->reason, __entry->err)
  472. );
  473. TRACE_EVENT(ocfs2_mark_extent_written,
  474. TP_PROTO(unsigned long long owner, unsigned int cpos,
  475. unsigned int len, unsigned int phys),
  476. TP_ARGS(owner, cpos, len, phys),
  477. TP_STRUCT__entry(
  478. __field(unsigned long long, owner)
  479. __field(unsigned int, cpos)
  480. __field(unsigned int, len)
  481. __field(unsigned int, phys)
  482. ),
  483. TP_fast_assign(
  484. __entry->owner = owner;
  485. __entry->cpos = cpos;
  486. __entry->len = len;
  487. __entry->phys = phys;
  488. ),
  489. TP_printk("%llu %u %u %u",
  490. __entry->owner, __entry->cpos,
  491. __entry->len, __entry->phys)
  492. );
  493. DECLARE_EVENT_CLASS(ocfs2__truncate_log_ops,
  494. TP_PROTO(unsigned long long blkno, int index,
  495. unsigned int start, unsigned int num),
  496. TP_ARGS(blkno, index, start, num),
  497. TP_STRUCT__entry(
  498. __field(unsigned long long, blkno)
  499. __field(int, index)
  500. __field(unsigned int, start)
  501. __field(unsigned int, num)
  502. ),
  503. TP_fast_assign(
  504. __entry->blkno = blkno;
  505. __entry->index = index;
  506. __entry->start = start;
  507. __entry->num = num;
  508. ),
  509. TP_printk("%llu %d %u %u",
  510. __entry->blkno, __entry->index,
  511. __entry->start, __entry->num)
  512. );
  513. #define DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(name) \
  514. DEFINE_EVENT(ocfs2__truncate_log_ops, name, \
  515. TP_PROTO(unsigned long long blkno, int index, \
  516. unsigned int start, unsigned int num), \
  517. TP_ARGS(blkno, index, start, num))
  518. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_truncate_log_append);
  519. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_replay_truncate_records);
  520. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_flush_truncate_log);
  521. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_truncate_log_recovery);
  522. DEFINE_OCFS2_INT_EVENT(ocfs2_truncate_log_recovery_num);
  523. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_complete_truncate_log_recovery);
  524. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_free_cached_blocks);
  525. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_cache_cluster_dealloc);
  526. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_run_deallocs);
  527. TRACE_EVENT(ocfs2_cache_block_dealloc,
  528. TP_PROTO(int type, int slot, unsigned long long suballoc,
  529. unsigned long long blkno, unsigned int bit),
  530. TP_ARGS(type, slot, suballoc, blkno, bit),
  531. TP_STRUCT__entry(
  532. __field(int, type)
  533. __field(int, slot)
  534. __field(unsigned long long, suballoc)
  535. __field(unsigned long long, blkno)
  536. __field(unsigned int, bit)
  537. ),
  538. TP_fast_assign(
  539. __entry->type = type;
  540. __entry->slot = slot;
  541. __entry->suballoc = suballoc;
  542. __entry->blkno = blkno;
  543. __entry->bit = bit;
  544. ),
  545. TP_printk("%d %d %llu %llu %u",
  546. __entry->type, __entry->slot, __entry->suballoc,
  547. __entry->blkno, __entry->bit)
  548. );
  549. /* End of trace events for fs/ocfs2/alloc.c. */
  550. /* Trace events for fs/ocfs2/localalloc.c. */
  551. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_la_set_sizes);
  552. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_alloc_should_use_local);
  553. DEFINE_OCFS2_INT_EVENT(ocfs2_load_local_alloc);
  554. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_local_alloc_recovery);
  555. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_reserve_local_alloc_bits);
  556. DEFINE_OCFS2_UINT_EVENT(ocfs2_local_alloc_count_bits);
  557. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits_search_bitmap);
  558. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits);
  559. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_sync_local_to_main);
  560. TRACE_EVENT(ocfs2_sync_local_to_main_free,
  561. TP_PROTO(int count, int bit, unsigned long long start_blk,
  562. unsigned long long blkno),
  563. TP_ARGS(count, bit, start_blk, blkno),
  564. TP_STRUCT__entry(
  565. __field(int, count)
  566. __field(int, bit)
  567. __field(unsigned long long, start_blk)
  568. __field(unsigned long long, blkno)
  569. ),
  570. TP_fast_assign(
  571. __entry->count = count;
  572. __entry->bit = bit;
  573. __entry->start_blk = start_blk;
  574. __entry->blkno = blkno;
  575. ),
  576. TP_printk("%d %d %llu %llu",
  577. __entry->count, __entry->bit, __entry->start_blk,
  578. __entry->blkno)
  579. );
  580. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_new_window);
  581. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_local_alloc_new_window_result);
  582. /* End of trace events for fs/ocfs2/localalloc.c. */
  583. /* Trace events for fs/ocfs2/resize.c. */
  584. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_update_last_group_and_inode);
  585. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_group_extend);
  586. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_group_add);
  587. /* End of trace events for fs/ocfs2/resize.c. */
  588. /* Trace events for fs/ocfs2/suballoc.c. */
  589. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_group_descriptor);
  590. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_contig);
  591. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_discontig);
  592. DEFINE_OCFS2_ULL_EVENT(ocfs2_block_group_alloc);
  593. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_nospc);
  594. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_no_new_group);
  595. DEFINE_OCFS2_ULL_EVENT(ocfs2_reserve_new_inode_new_group);
  596. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_set_bits);
  597. TRACE_EVENT(ocfs2_relink_block_group,
  598. TP_PROTO(unsigned long long i_blkno, unsigned int chain,
  599. unsigned long long bg_blkno,
  600. unsigned long long prev_blkno),
  601. TP_ARGS(i_blkno, chain, bg_blkno, prev_blkno),
  602. TP_STRUCT__entry(
  603. __field(unsigned long long, i_blkno)
  604. __field(unsigned int, chain)
  605. __field(unsigned long long, bg_blkno)
  606. __field(unsigned long long, prev_blkno)
  607. ),
  608. TP_fast_assign(
  609. __entry->i_blkno = i_blkno;
  610. __entry->chain = chain;
  611. __entry->bg_blkno = bg_blkno;
  612. __entry->prev_blkno = prev_blkno;
  613. ),
  614. TP_printk("%llu %u %llu %llu",
  615. __entry->i_blkno, __entry->chain, __entry->bg_blkno,
  616. __entry->prev_blkno)
  617. );
  618. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_cluster_group_search_wrong_max_bits);
  619. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cluster_group_search_max_block);
  620. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_block_group_search_max_block);
  621. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_search_chain_begin);
  622. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_succ);
  623. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_end);
  624. DEFINE_OCFS2_UINT_EVENT(ocfs2_claim_suballoc_bits);
  625. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_claim_new_inode_at_loc);
  626. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_clear_bits);
  627. TRACE_EVENT(ocfs2_free_suballoc_bits,
  628. TP_PROTO(unsigned long long inode, unsigned long long group,
  629. unsigned int start_bit, unsigned int count),
  630. TP_ARGS(inode, group, start_bit, count),
  631. TP_STRUCT__entry(
  632. __field(unsigned long long, inode)
  633. __field(unsigned long long, group)
  634. __field(unsigned int, start_bit)
  635. __field(unsigned int, count)
  636. ),
  637. TP_fast_assign(
  638. __entry->inode = inode;
  639. __entry->group = group;
  640. __entry->start_bit = start_bit;
  641. __entry->count = count;
  642. ),
  643. TP_printk("%llu %llu %u %u", __entry->inode, __entry->group,
  644. __entry->start_bit, __entry->count)
  645. );
  646. TRACE_EVENT(ocfs2_free_clusters,
  647. TP_PROTO(unsigned long long bg_blkno, unsigned long long start_blk,
  648. unsigned int start_bit, unsigned int count),
  649. TP_ARGS(bg_blkno, start_blk, start_bit, count),
  650. TP_STRUCT__entry(
  651. __field(unsigned long long, bg_blkno)
  652. __field(unsigned long long, start_blk)
  653. __field(unsigned int, start_bit)
  654. __field(unsigned int, count)
  655. ),
  656. TP_fast_assign(
  657. __entry->bg_blkno = bg_blkno;
  658. __entry->start_blk = start_blk;
  659. __entry->start_bit = start_bit;
  660. __entry->count = count;
  661. ),
  662. TP_printk("%llu %llu %u %u", __entry->bg_blkno, __entry->start_blk,
  663. __entry->start_bit, __entry->count)
  664. );
  665. DEFINE_OCFS2_ULL_EVENT(ocfs2_get_suballoc_slot_bit);
  666. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_test_suballoc_bit);
  667. DEFINE_OCFS2_ULL_EVENT(ocfs2_test_inode_bit);
  668. /* End of trace events for fs/ocfs2/suballoc.c. */
  669. /* Trace events for fs/ocfs2/refcounttree.c. */
  670. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_refcount_block);
  671. DEFINE_OCFS2_ULL_EVENT(ocfs2_purge_refcount_trees);
  672. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree);
  673. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree_blkno);
  674. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_change_refcount_rec);
  675. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_expand_inline_ref_root);
  676. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_divide_leaf_refcount_block);
  677. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_new_leaf_refcount_block);
  678. DECLARE_EVENT_CLASS(ocfs2__refcount_tree_ops,
  679. TP_PROTO(unsigned long long blkno, int index,
  680. unsigned long long cpos,
  681. unsigned int clusters, unsigned int refcount),
  682. TP_ARGS(blkno, index, cpos, clusters, refcount),
  683. TP_STRUCT__entry(
  684. __field(unsigned long long, blkno)
  685. __field(int, index)
  686. __field(unsigned long long, cpos)
  687. __field(unsigned int, clusters)
  688. __field(unsigned int, refcount)
  689. ),
  690. TP_fast_assign(
  691. __entry->blkno = blkno;
  692. __entry->index = index;
  693. __entry->cpos = cpos;
  694. __entry->clusters = clusters;
  695. __entry->refcount = refcount;
  696. ),
  697. TP_printk("%llu %d %llu %u %u", __entry->blkno, __entry->index,
  698. __entry->cpos, __entry->clusters, __entry->refcount)
  699. );
  700. #define DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(name) \
  701. DEFINE_EVENT(ocfs2__refcount_tree_ops, name, \
  702. TP_PROTO(unsigned long long blkno, int index, \
  703. unsigned long long cpos, \
  704. unsigned int count, unsigned int refcount), \
  705. TP_ARGS(blkno, index, cpos, count, refcount))
  706. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_insert_refcount_rec);
  707. TRACE_EVENT(ocfs2_split_refcount_rec,
  708. TP_PROTO(unsigned long long cpos,
  709. unsigned int clusters, unsigned int refcount,
  710. unsigned long long split_cpos,
  711. unsigned int split_clusters, unsigned int split_refcount),
  712. TP_ARGS(cpos, clusters, refcount,
  713. split_cpos, split_clusters, split_refcount),
  714. TP_STRUCT__entry(
  715. __field(unsigned long long, cpos)
  716. __field(unsigned int, clusters)
  717. __field(unsigned int, refcount)
  718. __field(unsigned long long, split_cpos)
  719. __field(unsigned int, split_clusters)
  720. __field(unsigned int, split_refcount)
  721. ),
  722. TP_fast_assign(
  723. __entry->cpos = cpos;
  724. __entry->clusters = clusters;
  725. __entry->refcount = refcount;
  726. __entry->split_cpos = split_cpos;
  727. __entry->split_clusters = split_clusters;
  728. __entry->split_refcount = split_refcount;
  729. ),
  730. TP_printk("%llu %u %u %llu %u %u",
  731. __entry->cpos, __entry->clusters, __entry->refcount,
  732. __entry->split_cpos, __entry->split_clusters,
  733. __entry->split_refcount)
  734. );
  735. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_split_refcount_rec_insert);
  736. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_increase_refcount_begin);
  737. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_change);
  738. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_increase_refcount_insert);
  739. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_split);
  740. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_remove_refcount_extent);
  741. DEFINE_OCFS2_ULL_EVENT(ocfs2_restore_refcount_block);
  742. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_decrease_refcount_rec);
  743. TRACE_EVENT(ocfs2_decrease_refcount,
  744. TP_PROTO(unsigned long long owner,
  745. unsigned long long cpos,
  746. unsigned int len, int delete),
  747. TP_ARGS(owner, cpos, len, delete),
  748. TP_STRUCT__entry(
  749. __field(unsigned long long, owner)
  750. __field(unsigned long long, cpos)
  751. __field(unsigned int, len)
  752. __field(int, delete)
  753. ),
  754. TP_fast_assign(
  755. __entry->owner = owner;
  756. __entry->cpos = cpos;
  757. __entry->len = len;
  758. __entry->delete = delete;
  759. ),
  760. TP_printk("%llu %llu %u %d",
  761. __entry->owner, __entry->cpos, __entry->len, __entry->delete)
  762. );
  763. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_mark_extent_refcounted);
  764. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_calc_refcount_meta_credits);
  765. TRACE_EVENT(ocfs2_calc_refcount_meta_credits_iterate,
  766. TP_PROTO(int recs_add, unsigned long long cpos,
  767. unsigned int clusters, unsigned long long r_cpos,
  768. unsigned int r_clusters, unsigned int refcount, int index),
  769. TP_ARGS(recs_add, cpos, clusters, r_cpos, r_clusters, refcount, index),
  770. TP_STRUCT__entry(
  771. __field(int, recs_add)
  772. __field(unsigned long long, cpos)
  773. __field(unsigned int, clusters)
  774. __field(unsigned long long, r_cpos)
  775. __field(unsigned int, r_clusters)
  776. __field(unsigned int, refcount)
  777. __field(int, index)
  778. ),
  779. TP_fast_assign(
  780. __entry->recs_add = recs_add;
  781. __entry->cpos = cpos;
  782. __entry->clusters = clusters;
  783. __entry->r_cpos = r_cpos;
  784. __entry->r_clusters = r_clusters;
  785. __entry->refcount = refcount;
  786. __entry->index = index;
  787. ),
  788. TP_printk("%d %llu %u %llu %u %u %d",
  789. __entry->recs_add, __entry->cpos, __entry->clusters,
  790. __entry->r_cpos, __entry->r_clusters,
  791. __entry->refcount, __entry->index)
  792. );
  793. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_add_refcount_flag);
  794. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_prepare_refcount_change_for_del);
  795. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_lock_refcount_allocators);
  796. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_page);
  797. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_jbd);
  798. TRACE_EVENT(ocfs2_clear_ext_refcount,
  799. TP_PROTO(unsigned long long ino, unsigned int cpos,
  800. unsigned int len, unsigned int p_cluster,
  801. unsigned int ext_flags),
  802. TP_ARGS(ino, cpos, len, p_cluster, ext_flags),
  803. TP_STRUCT__entry(
  804. __field(unsigned long long, ino)
  805. __field(unsigned int, cpos)
  806. __field(unsigned int, len)
  807. __field(unsigned int, p_cluster)
  808. __field(unsigned int, ext_flags)
  809. ),
  810. TP_fast_assign(
  811. __entry->ino = ino;
  812. __entry->cpos = cpos;
  813. __entry->len = len;
  814. __entry->p_cluster = p_cluster;
  815. __entry->ext_flags = ext_flags;
  816. ),
  817. TP_printk("%llu %u %u %u %u",
  818. __entry->ino, __entry->cpos, __entry->len,
  819. __entry->p_cluster, __entry->ext_flags)
  820. );
  821. TRACE_EVENT(ocfs2_replace_clusters,
  822. TP_PROTO(unsigned long long ino, unsigned int cpos,
  823. unsigned int old, unsigned int new, unsigned int len,
  824. unsigned int ext_flags),
  825. TP_ARGS(ino, cpos, old, new, len, ext_flags),
  826. TP_STRUCT__entry(
  827. __field(unsigned long long, ino)
  828. __field(unsigned int, cpos)
  829. __field(unsigned int, old)
  830. __field(unsigned int, new)
  831. __field(unsigned int, len)
  832. __field(unsigned int, ext_flags)
  833. ),
  834. TP_fast_assign(
  835. __entry->ino = ino;
  836. __entry->cpos = cpos;
  837. __entry->old = old;
  838. __entry->new = new;
  839. __entry->len = len;
  840. __entry->ext_flags = ext_flags;
  841. ),
  842. TP_printk("%llu %u %u %u %u %u",
  843. __entry->ino, __entry->cpos, __entry->old, __entry->new,
  844. __entry->len, __entry->ext_flags)
  845. );
  846. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_make_clusters_writable);
  847. TRACE_EVENT(ocfs2_refcount_cow_hunk,
  848. TP_PROTO(unsigned long long ino, unsigned int cpos,
  849. unsigned int write_len, unsigned int max_cpos,
  850. unsigned int cow_start, unsigned int cow_len),
  851. TP_ARGS(ino, cpos, write_len, max_cpos, cow_start, cow_len),
  852. TP_STRUCT__entry(
  853. __field(unsigned long long, ino)
  854. __field(unsigned int, cpos)
  855. __field(unsigned int, write_len)
  856. __field(unsigned int, max_cpos)
  857. __field(unsigned int, cow_start)
  858. __field(unsigned int, cow_len)
  859. ),
  860. TP_fast_assign(
  861. __entry->ino = ino;
  862. __entry->cpos = cpos;
  863. __entry->write_len = write_len;
  864. __entry->max_cpos = max_cpos;
  865. __entry->cow_start = cow_start;
  866. __entry->cow_len = cow_len;
  867. ),
  868. TP_printk("%llu %u %u %u %u %u",
  869. __entry->ino, __entry->cpos, __entry->write_len,
  870. __entry->max_cpos, __entry->cow_start, __entry->cow_len)
  871. );
  872. /* End of trace events for fs/ocfs2/refcounttree.c. */
  873. /* Trace events for fs/ocfs2/aops.c. */
  874. DECLARE_EVENT_CLASS(ocfs2__get_block,
  875. TP_PROTO(unsigned long long ino, unsigned long long iblock,
  876. void *bh_result, int create),
  877. TP_ARGS(ino, iblock, bh_result, create),
  878. TP_STRUCT__entry(
  879. __field(unsigned long long, ino)
  880. __field(unsigned long long, iblock)
  881. __field(void *, bh_result)
  882. __field(int, create)
  883. ),
  884. TP_fast_assign(
  885. __entry->ino = ino;
  886. __entry->iblock = iblock;
  887. __entry->bh_result = bh_result;
  888. __entry->create = create;
  889. ),
  890. TP_printk("%llu %llu %p %d",
  891. __entry->ino, __entry->iblock,
  892. __entry->bh_result, __entry->create)
  893. );
  894. #define DEFINE_OCFS2_GET_BLOCK_EVENT(name) \
  895. DEFINE_EVENT(ocfs2__get_block, name, \
  896. TP_PROTO(unsigned long long ino, unsigned long long iblock, \
  897. void *bh_result, int create), \
  898. TP_ARGS(ino, iblock, bh_result, create))
  899. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_symlink_get_block);
  900. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_get_block);
  901. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_get_block_end);
  902. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_readpage);
  903. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_writepage);
  904. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_bmap);
  905. TRACE_EVENT(ocfs2_try_to_write_inline_data,
  906. TP_PROTO(unsigned long long ino, unsigned int len,
  907. unsigned long long pos, unsigned int flags),
  908. TP_ARGS(ino, len, pos, flags),
  909. TP_STRUCT__entry(
  910. __field(unsigned long long, ino)
  911. __field(unsigned int, len)
  912. __field(unsigned long long, pos)
  913. __field(unsigned int, flags)
  914. ),
  915. TP_fast_assign(
  916. __entry->ino = ino;
  917. __entry->len = len;
  918. __entry->pos = pos;
  919. __entry->flags = flags;
  920. ),
  921. TP_printk("%llu %u %llu 0x%x",
  922. __entry->ino, __entry->len, __entry->pos, __entry->flags)
  923. );
  924. TRACE_EVENT(ocfs2_write_begin_nolock,
  925. TP_PROTO(unsigned long long ino,
  926. long long i_size, unsigned int i_clusters,
  927. unsigned long long pos, unsigned int len,
  928. unsigned int flags, void *page,
  929. unsigned int clusters, unsigned int extents_to_split),
  930. TP_ARGS(ino, i_size, i_clusters, pos, len, flags,
  931. page, clusters, extents_to_split),
  932. TP_STRUCT__entry(
  933. __field(unsigned long long, ino)
  934. __field(long long, i_size)
  935. __field(unsigned int, i_clusters)
  936. __field(unsigned long long, pos)
  937. __field(unsigned int, len)
  938. __field(unsigned int, flags)
  939. __field(void *, page)
  940. __field(unsigned int, clusters)
  941. __field(unsigned int, extents_to_split)
  942. ),
  943. TP_fast_assign(
  944. __entry->ino = ino;
  945. __entry->i_size = i_size;
  946. __entry->i_clusters = i_clusters;
  947. __entry->pos = pos;
  948. __entry->len = len;
  949. __entry->flags = flags;
  950. __entry->page = page;
  951. __entry->clusters = clusters;
  952. __entry->extents_to_split = extents_to_split;
  953. ),
  954. TP_printk("%llu %lld %u %llu %u %u %p %u %u",
  955. __entry->ino, __entry->i_size, __entry->i_clusters,
  956. __entry->pos, __entry->len,
  957. __entry->flags, __entry->page, __entry->clusters,
  958. __entry->extents_to_split)
  959. );
  960. TRACE_EVENT(ocfs2_write_end_inline,
  961. TP_PROTO(unsigned long long ino,
  962. unsigned long long pos, unsigned int copied,
  963. unsigned int id_count, unsigned int features),
  964. TP_ARGS(ino, pos, copied, id_count, features),
  965. TP_STRUCT__entry(
  966. __field(unsigned long long, ino)
  967. __field(unsigned long long, pos)
  968. __field(unsigned int, copied)
  969. __field(unsigned int, id_count)
  970. __field(unsigned int, features)
  971. ),
  972. TP_fast_assign(
  973. __entry->ino = ino;
  974. __entry->pos = pos;
  975. __entry->copied = copied;
  976. __entry->id_count = id_count;
  977. __entry->features = features;
  978. ),
  979. TP_printk("%llu %llu %u %u %u",
  980. __entry->ino, __entry->pos, __entry->copied,
  981. __entry->id_count, __entry->features)
  982. );
  983. /* End of trace events for fs/ocfs2/aops.c. */
  984. /* Trace events for fs/ocfs2/mmap.c. */
  985. TRACE_EVENT(ocfs2_fault,
  986. TP_PROTO(unsigned long long ino,
  987. void *area, void *page, unsigned long pgoff),
  988. TP_ARGS(ino, area, page, pgoff),
  989. TP_STRUCT__entry(
  990. __field(unsigned long long, ino)
  991. __field(void *, area)
  992. __field(void *, page)
  993. __field(unsigned long, pgoff)
  994. ),
  995. TP_fast_assign(
  996. __entry->ino = ino;
  997. __entry->area = area;
  998. __entry->page = page;
  999. __entry->pgoff = pgoff;
  1000. ),
  1001. TP_printk("%llu %p %p %lu",
  1002. __entry->ino, __entry->area, __entry->page, __entry->pgoff)
  1003. );
  1004. /* End of trace events for fs/ocfs2/mmap.c. */
  1005. /* Trace events for fs/ocfs2/file.c. */
  1006. DECLARE_EVENT_CLASS(ocfs2__file_ops,
  1007. TP_PROTO(void *inode, void *file, void *dentry,
  1008. unsigned long long ino,
  1009. unsigned int d_len, const unsigned char *d_name,
  1010. unsigned long long para),
  1011. TP_ARGS(inode, file, dentry, ino, d_len, d_name, para),
  1012. TP_STRUCT__entry(
  1013. __field(void *, inode)
  1014. __field(void *, file)
  1015. __field(void *, dentry)
  1016. __field(unsigned long long, ino)
  1017. __field(unsigned int, d_len)
  1018. __string(d_name, d_name)
  1019. __field(unsigned long long, para)
  1020. ),
  1021. TP_fast_assign(
  1022. __entry->inode = inode;
  1023. __entry->file = file;
  1024. __entry->dentry = dentry;
  1025. __entry->ino = ino;
  1026. __entry->d_len = d_len;
  1027. __assign_str(d_name, d_name);
  1028. __entry->para = para;
  1029. ),
  1030. TP_printk("%p %p %p %llu %llu %.*s", __entry->inode, __entry->file,
  1031. __entry->dentry, __entry->ino, __entry->para,
  1032. __entry->d_len, __get_str(d_name))
  1033. );
  1034. #define DEFINE_OCFS2_FILE_OPS(name) \
  1035. DEFINE_EVENT(ocfs2__file_ops, name, \
  1036. TP_PROTO(void *inode, void *file, void *dentry, \
  1037. unsigned long long ino, \
  1038. unsigned int d_len, const unsigned char *d_name, \
  1039. unsigned long long mode), \
  1040. TP_ARGS(inode, file, dentry, ino, d_len, d_name, mode))
  1041. DEFINE_OCFS2_FILE_OPS(ocfs2_file_open);
  1042. DEFINE_OCFS2_FILE_OPS(ocfs2_file_release);
  1043. DEFINE_OCFS2_FILE_OPS(ocfs2_sync_file);
  1044. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_write);
  1045. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_write);
  1046. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_read);
  1047. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_read);
  1048. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_truncate_file);
  1049. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_truncate_file_error);
  1050. TRACE_EVENT(ocfs2_extend_allocation,
  1051. TP_PROTO(unsigned long long ip_blkno, unsigned long long size,
  1052. unsigned int clusters, unsigned int clusters_to_add,
  1053. int why, int restart_func),
  1054. TP_ARGS(ip_blkno, size, clusters, clusters_to_add, why, restart_func),
  1055. TP_STRUCT__entry(
  1056. __field(unsigned long long, ip_blkno)
  1057. __field(unsigned long long, size)
  1058. __field(unsigned int, clusters)
  1059. __field(unsigned int, clusters_to_add)
  1060. __field(int, why)
  1061. __field(int, restart_func)
  1062. ),
  1063. TP_fast_assign(
  1064. __entry->ip_blkno = ip_blkno;
  1065. __entry->size = size;
  1066. __entry->clusters = clusters;
  1067. __entry->clusters_to_add = clusters_to_add;
  1068. __entry->why = why;
  1069. __entry->restart_func = restart_func;
  1070. ),
  1071. TP_printk("%llu %llu %u %u %d %d",
  1072. __entry->ip_blkno, __entry->size, __entry->clusters,
  1073. __entry->clusters_to_add, __entry->why, __entry->restart_func)
  1074. );
  1075. TRACE_EVENT(ocfs2_extend_allocation_end,
  1076. TP_PROTO(unsigned long long ino,
  1077. unsigned int di_clusters, unsigned long long di_size,
  1078. unsigned int ip_clusters, unsigned long long i_size),
  1079. TP_ARGS(ino, di_clusters, di_size, ip_clusters, i_size),
  1080. TP_STRUCT__entry(
  1081. __field(unsigned long long, ino)
  1082. __field(unsigned int, di_clusters)
  1083. __field(unsigned long long, di_size)
  1084. __field(unsigned int, ip_clusters)
  1085. __field(unsigned long long, i_size)
  1086. ),
  1087. TP_fast_assign(
  1088. __entry->ino = ino;
  1089. __entry->di_clusters = di_clusters;
  1090. __entry->di_size = di_size;
  1091. __entry->ip_clusters = ip_clusters;
  1092. __entry->i_size = i_size;
  1093. ),
  1094. TP_printk("%llu %u %llu %u %llu", __entry->ino, __entry->di_clusters,
  1095. __entry->di_size, __entry->ip_clusters, __entry->i_size)
  1096. );
  1097. TRACE_EVENT(ocfs2_write_zero_page,
  1098. TP_PROTO(unsigned long long ino,
  1099. unsigned long long abs_from, unsigned long long abs_to,
  1100. unsigned long index, unsigned int zero_from,
  1101. unsigned int zero_to),
  1102. TP_ARGS(ino, abs_from, abs_to, index, zero_from, zero_to),
  1103. TP_STRUCT__entry(
  1104. __field(unsigned long long, ino)
  1105. __field(unsigned long long, abs_from)
  1106. __field(unsigned long long, abs_to)
  1107. __field(unsigned long, index)
  1108. __field(unsigned int, zero_from)
  1109. __field(unsigned int, zero_to)
  1110. ),
  1111. TP_fast_assign(
  1112. __entry->ino = ino;
  1113. __entry->abs_from = abs_from;
  1114. __entry->abs_to = abs_to;
  1115. __entry->index = index;
  1116. __entry->zero_from = zero_from;
  1117. __entry->zero_to = zero_to;
  1118. ),
  1119. TP_printk("%llu %llu %llu %lu %u %u", __entry->ino,
  1120. __entry->abs_from, __entry->abs_to,
  1121. __entry->index, __entry->zero_from, __entry->zero_to)
  1122. );
  1123. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend_range);
  1124. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend);
  1125. TRACE_EVENT(ocfs2_setattr,
  1126. TP_PROTO(void *inode, void *dentry,
  1127. unsigned long long ino,
  1128. unsigned int d_len, const unsigned char *d_name,
  1129. unsigned int ia_valid, unsigned int ia_mode,
  1130. unsigned int ia_uid, unsigned int ia_gid),
  1131. TP_ARGS(inode, dentry, ino, d_len, d_name,
  1132. ia_valid, ia_mode, ia_uid, ia_gid),
  1133. TP_STRUCT__entry(
  1134. __field(void *, inode)
  1135. __field(void *, dentry)
  1136. __field(unsigned long long, ino)
  1137. __field(unsigned int, d_len)
  1138. __string(d_name, d_name)
  1139. __field(unsigned int, ia_valid)
  1140. __field(unsigned int, ia_mode)
  1141. __field(unsigned int, ia_uid)
  1142. __field(unsigned int, ia_gid)
  1143. ),
  1144. TP_fast_assign(
  1145. __entry->inode = inode;
  1146. __entry->dentry = dentry;
  1147. __entry->ino = ino;
  1148. __entry->d_len = d_len;
  1149. __assign_str(d_name, d_name);
  1150. __entry->ia_valid = ia_valid;
  1151. __entry->ia_mode = ia_mode;
  1152. __entry->ia_uid = ia_uid;
  1153. __entry->ia_gid = ia_gid;
  1154. ),
  1155. TP_printk("%p %p %llu %.*s %u %u %u %u", __entry->inode,
  1156. __entry->dentry, __entry->ino, __entry->d_len,
  1157. __get_str(d_name), __entry->ia_valid, __entry->ia_mode,
  1158. __entry->ia_uid, __entry->ia_gid)
  1159. );
  1160. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_write_remove_suid);
  1161. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_partial_clusters);
  1162. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range1);
  1163. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range2);
  1164. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_remove_inode_range);
  1165. TRACE_EVENT(ocfs2_prepare_inode_for_write,
  1166. TP_PROTO(unsigned long long ino, unsigned long long saved_pos,
  1167. int appending, unsigned long count,
  1168. int *direct_io, int *has_refcount),
  1169. TP_ARGS(ino, saved_pos, appending, count, direct_io, has_refcount),
  1170. TP_STRUCT__entry(
  1171. __field(unsigned long long, ino)
  1172. __field(unsigned long long, saved_pos)
  1173. __field(int, appending)
  1174. __field(unsigned long, count)
  1175. __field(int, direct_io)
  1176. __field(int, has_refcount)
  1177. ),
  1178. TP_fast_assign(
  1179. __entry->ino = ino;
  1180. __entry->saved_pos = saved_pos;
  1181. __entry->appending = appending;
  1182. __entry->count = count;
  1183. __entry->direct_io = direct_io ? *direct_io : -1;
  1184. __entry->has_refcount = has_refcount ? *has_refcount : -1;
  1185. ),
  1186. TP_printk("%llu %llu %d %lu %d %d", __entry->ino,
  1187. __entry->saved_pos, __entry->appending, __entry->count,
  1188. __entry->direct_io, __entry->has_refcount)
  1189. );
  1190. DEFINE_OCFS2_INT_EVENT(generic_file_aio_read_ret);
  1191. /* End of trace events for fs/ocfs2/file.c. */
  1192. /* Trace events for fs/ocfs2/inode.c. */
  1193. TRACE_EVENT(ocfs2_iget_begin,
  1194. TP_PROTO(unsigned long long ino, unsigned int flags, int sysfile_type),
  1195. TP_ARGS(ino, flags, sysfile_type),
  1196. TP_STRUCT__entry(
  1197. __field(unsigned long long, ino)
  1198. __field(unsigned int, flags)
  1199. __field(int, sysfile_type)
  1200. ),
  1201. TP_fast_assign(
  1202. __entry->ino = ino;
  1203. __entry->flags = flags;
  1204. __entry->sysfile_type = sysfile_type;
  1205. ),
  1206. TP_printk("%llu %u %d", __entry->ino,
  1207. __entry->flags, __entry->sysfile_type)
  1208. );
  1209. DEFINE_OCFS2_ULL_EVENT(ocfs2_iget5_locked);
  1210. TRACE_EVENT(ocfs2_iget_end,
  1211. TP_PROTO(void *inode, unsigned long long ino),
  1212. TP_ARGS(inode, ino),
  1213. TP_STRUCT__entry(
  1214. __field(void *, inode)
  1215. __field(unsigned long long, ino)
  1216. ),
  1217. TP_fast_assign(
  1218. __entry->inode = inode;
  1219. __entry->ino = ino;
  1220. ),
  1221. TP_printk("%p %llu", __entry->inode, __entry->ino)
  1222. );
  1223. TRACE_EVENT(ocfs2_find_actor,
  1224. TP_PROTO(void *inode, unsigned long long ino,
  1225. void *args, unsigned long long fi_blkno),
  1226. TP_ARGS(inode, ino, args, fi_blkno),
  1227. TP_STRUCT__entry(
  1228. __field(void *, inode)
  1229. __field(unsigned long long, ino)
  1230. __field(void *, args)
  1231. __field(unsigned long long, fi_blkno)
  1232. ),
  1233. TP_fast_assign(
  1234. __entry->inode = inode;
  1235. __entry->ino = ino;
  1236. __entry->args = args;
  1237. __entry->fi_blkno = fi_blkno;
  1238. ),
  1239. TP_printk("%p %llu %p %llu", __entry->inode, __entry->ino,
  1240. __entry->args, __entry->fi_blkno)
  1241. );
  1242. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_populate_inode);
  1243. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_read_locked_inode);
  1244. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_check_orphan_recovery_state);
  1245. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_inode_block);
  1246. TRACE_EVENT(ocfs2_inode_is_valid_to_delete,
  1247. TP_PROTO(void *task, void *dc_task, unsigned long long ino,
  1248. unsigned int flags),
  1249. TP_ARGS(task, dc_task, ino, flags),
  1250. TP_STRUCT__entry(
  1251. __field(void *, task)
  1252. __field(void *, dc_task)
  1253. __field(unsigned long long, ino)
  1254. __field(unsigned int, flags)
  1255. ),
  1256. TP_fast_assign(
  1257. __entry->task = task;
  1258. __entry->dc_task = dc_task;
  1259. __entry->ino = ino;
  1260. __entry->flags = flags;
  1261. ),
  1262. TP_printk("%p %p %llu %u", __entry->task, __entry->dc_task,
  1263. __entry->ino, __entry->flags)
  1264. );
  1265. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_query_inode_wipe_begin);
  1266. DEFINE_OCFS2_UINT_EVENT(ocfs2_query_inode_wipe_succ);
  1267. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_query_inode_wipe_end);
  1268. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_cleanup_delete_inode);
  1269. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_delete_inode);
  1270. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_clear_inode);
  1271. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_drop_inode);
  1272. TRACE_EVENT(ocfs2_inode_revalidate,
  1273. TP_PROTO(void *inode, unsigned long long ino,
  1274. unsigned int flags),
  1275. TP_ARGS(inode, ino, flags),
  1276. TP_STRUCT__entry(
  1277. __field(void *, inode)
  1278. __field(unsigned long long, ino)
  1279. __field(unsigned int, flags)
  1280. ),
  1281. TP_fast_assign(
  1282. __entry->inode = inode;
  1283. __entry->ino = ino;
  1284. __entry->flags = flags;
  1285. ),
  1286. TP_printk("%p %llu %u", __entry->inode, __entry->ino, __entry->flags)
  1287. );
  1288. DEFINE_OCFS2_ULL_EVENT(ocfs2_mark_inode_dirty);
  1289. /* End of trace events for fs/ocfs2/inode.c. */
  1290. #endif /* _TRACE_OCFS2_H */
  1291. /* This part must be outside protection */
  1292. #undef TRACE_INCLUDE_PATH
  1293. #define TRACE_INCLUDE_PATH .
  1294. #define TRACE_INCLUDE_FILE ocfs2_trace
  1295. #include <trace/define_trace.h>