ocfs2_trace.h 73 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651
  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_int,
  99. TP_PROTO(unsigned int value1, int value2),
  100. TP_ARGS(value1, value2),
  101. TP_STRUCT__entry(
  102. __field(unsigned int, value1)
  103. __field(int, value2)
  104. ),
  105. TP_fast_assign(
  106. __entry->value1 = value1;
  107. __entry->value2 = value2;
  108. ),
  109. TP_printk("%u %d", __entry->value1, __entry->value2)
  110. );
  111. #define DEFINE_OCFS2_UINT_INT_EVENT(name) \
  112. DEFINE_EVENT(ocfs2__uint_int, name, \
  113. TP_PROTO(unsigned int val1, int val2), \
  114. TP_ARGS(val1, val2))
  115. DECLARE_EVENT_CLASS(ocfs2__uint_uint,
  116. TP_PROTO(unsigned int value1, unsigned int value2),
  117. TP_ARGS(value1, value2),
  118. TP_STRUCT__entry(
  119. __field(unsigned int, value1)
  120. __field(unsigned int, value2)
  121. ),
  122. TP_fast_assign(
  123. __entry->value1 = value1;
  124. __entry->value2 = value2;
  125. ),
  126. TP_printk("%u %u", __entry->value1, __entry->value2)
  127. );
  128. #define DEFINE_OCFS2_UINT_UINT_EVENT(name) \
  129. DEFINE_EVENT(ocfs2__uint_uint, name, \
  130. TP_PROTO(unsigned int val1, unsigned int val2), \
  131. TP_ARGS(val1, val2))
  132. DECLARE_EVENT_CLASS(ocfs2__ull_uint,
  133. TP_PROTO(unsigned long long value1, unsigned int value2),
  134. TP_ARGS(value1, value2),
  135. TP_STRUCT__entry(
  136. __field(unsigned long long, value1)
  137. __field(unsigned int, value2)
  138. ),
  139. TP_fast_assign(
  140. __entry->value1 = value1;
  141. __entry->value2 = value2;
  142. ),
  143. TP_printk("%llu %u", __entry->value1, __entry->value2)
  144. );
  145. #define DEFINE_OCFS2_ULL_UINT_EVENT(name) \
  146. DEFINE_EVENT(ocfs2__ull_uint, name, \
  147. TP_PROTO(unsigned long long val1, unsigned int val2), \
  148. TP_ARGS(val1, val2))
  149. DECLARE_EVENT_CLASS(ocfs2__ull_int,
  150. TP_PROTO(unsigned long long value1, int value2),
  151. TP_ARGS(value1, value2),
  152. TP_STRUCT__entry(
  153. __field(unsigned long long, value1)
  154. __field(int, value2)
  155. ),
  156. TP_fast_assign(
  157. __entry->value1 = value1;
  158. __entry->value2 = value2;
  159. ),
  160. TP_printk("%llu %d", __entry->value1, __entry->value2)
  161. );
  162. #define DEFINE_OCFS2_ULL_INT_EVENT(name) \
  163. DEFINE_EVENT(ocfs2__ull_int, name, \
  164. TP_PROTO(unsigned long long val1, int val2), \
  165. TP_ARGS(val1, val2))
  166. DECLARE_EVENT_CLASS(ocfs2__ull_ull,
  167. TP_PROTO(unsigned long long value1, unsigned long long value2),
  168. TP_ARGS(value1, value2),
  169. TP_STRUCT__entry(
  170. __field(unsigned long long, value1)
  171. __field(unsigned long long, value2)
  172. ),
  173. TP_fast_assign(
  174. __entry->value1 = value1;
  175. __entry->value2 = value2;
  176. ),
  177. TP_printk("%llu %llu", __entry->value1, __entry->value2)
  178. );
  179. #define DEFINE_OCFS2_ULL_ULL_EVENT(name) \
  180. DEFINE_EVENT(ocfs2__ull_ull, name, \
  181. TP_PROTO(unsigned long long val1, unsigned long long val2), \
  182. TP_ARGS(val1, val2))
  183. DECLARE_EVENT_CLASS(ocfs2__ull_ull_uint,
  184. TP_PROTO(unsigned long long value1,
  185. unsigned long long value2, unsigned int value3),
  186. TP_ARGS(value1, value2, value3),
  187. TP_STRUCT__entry(
  188. __field(unsigned long long, value1)
  189. __field(unsigned long long, value2)
  190. __field(unsigned int, value3)
  191. ),
  192. TP_fast_assign(
  193. __entry->value1 = value1;
  194. __entry->value2 = value2;
  195. __entry->value3 = value3;
  196. ),
  197. TP_printk("%llu %llu %u",
  198. __entry->value1, __entry->value2, __entry->value3)
  199. );
  200. #define DEFINE_OCFS2_ULL_ULL_UINT_EVENT(name) \
  201. DEFINE_EVENT(ocfs2__ull_ull_uint, name, \
  202. TP_PROTO(unsigned long long val1, \
  203. unsigned long long val2, unsigned int val3), \
  204. TP_ARGS(val1, val2, val3))
  205. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint,
  206. TP_PROTO(unsigned long long value1,
  207. unsigned int value2, unsigned int value3),
  208. TP_ARGS(value1, value2, value3),
  209. TP_STRUCT__entry(
  210. __field(unsigned long long, value1)
  211. __field(unsigned int, value2)
  212. __field(unsigned int, value3)
  213. ),
  214. TP_fast_assign(
  215. __entry->value1 = value1;
  216. __entry->value2 = value2;
  217. __entry->value3 = value3;
  218. ),
  219. TP_printk("%llu %u %u", __entry->value1,
  220. __entry->value2, __entry->value3)
  221. );
  222. #define DEFINE_OCFS2_ULL_UINT_UINT_EVENT(name) \
  223. DEFINE_EVENT(ocfs2__ull_uint_uint, name, \
  224. TP_PROTO(unsigned long long val1, \
  225. unsigned int val2, unsigned int val3), \
  226. TP_ARGS(val1, val2, val3))
  227. DECLARE_EVENT_CLASS(ocfs2__uint_uint_uint,
  228. TP_PROTO(unsigned int value1, unsigned int value2,
  229. unsigned int value3),
  230. TP_ARGS(value1, value2, value3),
  231. TP_STRUCT__entry(
  232. __field( unsigned int, value1 )
  233. __field( unsigned int, value2 )
  234. __field( unsigned int, value3 )
  235. ),
  236. TP_fast_assign(
  237. __entry->value1 = value1;
  238. __entry->value2 = value2;
  239. __entry->value3 = value3;
  240. ),
  241. TP_printk("%u %u %u", __entry->value1, __entry->value2, __entry->value3)
  242. );
  243. #define DEFINE_OCFS2_UINT_UINT_UINT_EVENT(name) \
  244. DEFINE_EVENT(ocfs2__uint_uint_uint, name, \
  245. TP_PROTO(unsigned int value1, unsigned int value2, \
  246. unsigned int value3), \
  247. TP_ARGS(value1, value2, value3))
  248. DECLARE_EVENT_CLASS(ocfs2__ull_ull_ull,
  249. TP_PROTO(unsigned long long value1,
  250. unsigned long long value2, unsigned long long value3),
  251. TP_ARGS(value1, value2, value3),
  252. TP_STRUCT__entry(
  253. __field(unsigned long long, value1)
  254. __field(unsigned long long, value2)
  255. __field(unsigned long long, value3)
  256. ),
  257. TP_fast_assign(
  258. __entry->value1 = value1;
  259. __entry->value2 = value2;
  260. __entry->value3 = value3;
  261. ),
  262. TP_printk("%llu %llu %llu",
  263. __entry->value1, __entry->value2, __entry->value3)
  264. );
  265. #define DEFINE_OCFS2_ULL_ULL_ULL_EVENT(name) \
  266. DEFINE_EVENT(ocfs2__ull_ull_ull, name, \
  267. TP_PROTO(unsigned long long value1, unsigned long long value2, \
  268. unsigned long long value3), \
  269. TP_ARGS(value1, value2, value3))
  270. DECLARE_EVENT_CLASS(ocfs2__ull_int_int_int,
  271. TP_PROTO(unsigned long long ull, int value1, int value2, int value3),
  272. TP_ARGS(ull, value1, value2, value3),
  273. TP_STRUCT__entry(
  274. __field( unsigned long long, ull )
  275. __field( int, value1 )
  276. __field( int, value2 )
  277. __field( int, value3 )
  278. ),
  279. TP_fast_assign(
  280. __entry->ull = ull;
  281. __entry->value1 = value1;
  282. __entry->value2 = value2;
  283. __entry->value3 = value3;
  284. ),
  285. TP_printk("%llu %d %d %d",
  286. __entry->ull, __entry->value1,
  287. __entry->value2, __entry->value3)
  288. );
  289. #define DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(name) \
  290. DEFINE_EVENT(ocfs2__ull_int_int_int, name, \
  291. TP_PROTO(unsigned long long ull, int value1, \
  292. int value2, int value3), \
  293. TP_ARGS(ull, value1, value2, value3))
  294. DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint_uint,
  295. TP_PROTO(unsigned long long ull, unsigned int value1,
  296. unsigned int value2, unsigned int value3),
  297. TP_ARGS(ull, value1, value2, value3),
  298. TP_STRUCT__entry(
  299. __field(unsigned long long, ull)
  300. __field(unsigned int, value1)
  301. __field(unsigned int, value2)
  302. __field(unsigned int, value3)
  303. ),
  304. TP_fast_assign(
  305. __entry->ull = ull;
  306. __entry->value1 = value1;
  307. __entry->value2 = value2;
  308. __entry->value3 = value3;
  309. ),
  310. TP_printk("%llu %u %u %u",
  311. __entry->ull, __entry->value1,
  312. __entry->value2, __entry->value3)
  313. );
  314. #define DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(name) \
  315. DEFINE_EVENT(ocfs2__ull_uint_uint_uint, name, \
  316. TP_PROTO(unsigned long long ull, unsigned int value1, \
  317. unsigned int value2, unsigned int value3), \
  318. TP_ARGS(ull, value1, value2, value3))
  319. DECLARE_EVENT_CLASS(ocfs2__ull_ull_uint_uint,
  320. TP_PROTO(unsigned long long value1, unsigned long long value2,
  321. unsigned int value3, unsigned int value4),
  322. TP_ARGS(value1, value2, value3, value4),
  323. TP_STRUCT__entry(
  324. __field(unsigned long long, value1)
  325. __field(unsigned long long, value2)
  326. __field(unsigned int, value3)
  327. __field(unsigned int, value4)
  328. ),
  329. TP_fast_assign(
  330. __entry->value1 = value1;
  331. __entry->value2 = value2;
  332. __entry->value3 = value3;
  333. __entry->value4 = value4;
  334. ),
  335. TP_printk("%llu %llu %u %u",
  336. __entry->value1, __entry->value2,
  337. __entry->value3, __entry->value4)
  338. );
  339. #define DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(name) \
  340. DEFINE_EVENT(ocfs2__ull_ull_uint_uint, name, \
  341. TP_PROTO(unsigned long long ull, unsigned long long ull1, \
  342. unsigned int value2, unsigned int value3), \
  343. TP_ARGS(ull, ull1, value2, value3))
  344. /* Trace events for fs/ocfs2/alloc.c. */
  345. DECLARE_EVENT_CLASS(ocfs2__btree_ops,
  346. TP_PROTO(unsigned long long owner,\
  347. unsigned int value1, unsigned int value2),
  348. TP_ARGS(owner, value1, value2),
  349. TP_STRUCT__entry(
  350. __field(unsigned long long, owner)
  351. __field(unsigned int, value1)
  352. __field(unsigned int, value2)
  353. ),
  354. TP_fast_assign(
  355. __entry->owner = owner;
  356. __entry->value1 = value1;
  357. __entry->value2 = value2;
  358. ),
  359. TP_printk("%llu %u %u",
  360. __entry->owner, __entry->value1, __entry->value2)
  361. );
  362. #define DEFINE_OCFS2_BTREE_EVENT(name) \
  363. DEFINE_EVENT(ocfs2__btree_ops, name, \
  364. TP_PROTO(unsigned long long owner, \
  365. unsigned int value1, unsigned int value2), \
  366. TP_ARGS(owner, value1, value2))
  367. DEFINE_OCFS2_BTREE_EVENT(ocfs2_adjust_rightmost_branch);
  368. DEFINE_OCFS2_BTREE_EVENT(ocfs2_rotate_tree_right);
  369. DEFINE_OCFS2_BTREE_EVENT(ocfs2_append_rec_to_path);
  370. DEFINE_OCFS2_BTREE_EVENT(ocfs2_insert_extent_start);
  371. DEFINE_OCFS2_BTREE_EVENT(ocfs2_add_clusters_in_btree);
  372. DEFINE_OCFS2_INT_EVENT(ocfs2_num_free_extents);
  373. DEFINE_OCFS2_INT_EVENT(ocfs2_complete_edge_insert);
  374. TRACE_EVENT(ocfs2_grow_tree,
  375. TP_PROTO(unsigned long long owner, int depth),
  376. TP_ARGS(owner, depth),
  377. TP_STRUCT__entry(
  378. __field(unsigned long long, owner)
  379. __field(int, depth)
  380. ),
  381. TP_fast_assign(
  382. __entry->owner = owner;
  383. __entry->depth = depth;
  384. ),
  385. TP_printk("%llu %d", __entry->owner, __entry->depth)
  386. );
  387. TRACE_EVENT(ocfs2_rotate_subtree,
  388. TP_PROTO(int subtree_root, unsigned long long blkno,
  389. int depth),
  390. TP_ARGS(subtree_root, blkno, depth),
  391. TP_STRUCT__entry(
  392. __field(int, subtree_root)
  393. __field(unsigned long long, blkno)
  394. __field(int, depth)
  395. ),
  396. TP_fast_assign(
  397. __entry->subtree_root = subtree_root;
  398. __entry->blkno = blkno;
  399. __entry->depth = depth;
  400. ),
  401. TP_printk("%d %llu %d", __entry->subtree_root,
  402. __entry->blkno, __entry->depth)
  403. );
  404. TRACE_EVENT(ocfs2_insert_extent,
  405. TP_PROTO(unsigned int ins_appending, unsigned int ins_contig,
  406. int ins_contig_index, int free_records, int ins_tree_depth),
  407. TP_ARGS(ins_appending, ins_contig, ins_contig_index, free_records,
  408. ins_tree_depth),
  409. TP_STRUCT__entry(
  410. __field(unsigned int, ins_appending)
  411. __field(unsigned int, ins_contig)
  412. __field(int, ins_contig_index)
  413. __field(int, free_records)
  414. __field(int, ins_tree_depth)
  415. ),
  416. TP_fast_assign(
  417. __entry->ins_appending = ins_appending;
  418. __entry->ins_contig = ins_contig;
  419. __entry->ins_contig_index = ins_contig_index;
  420. __entry->free_records = free_records;
  421. __entry->ins_tree_depth = ins_tree_depth;
  422. ),
  423. TP_printk("%u %u %d %d %d",
  424. __entry->ins_appending, __entry->ins_contig,
  425. __entry->ins_contig_index, __entry->free_records,
  426. __entry->ins_tree_depth)
  427. );
  428. TRACE_EVENT(ocfs2_split_extent,
  429. TP_PROTO(int split_index, unsigned int c_contig_type,
  430. unsigned int c_has_empty_extent,
  431. unsigned int c_split_covers_rec),
  432. TP_ARGS(split_index, c_contig_type,
  433. c_has_empty_extent, c_split_covers_rec),
  434. TP_STRUCT__entry(
  435. __field(int, split_index)
  436. __field(unsigned int, c_contig_type)
  437. __field(unsigned int, c_has_empty_extent)
  438. __field(unsigned int, c_split_covers_rec)
  439. ),
  440. TP_fast_assign(
  441. __entry->split_index = split_index;
  442. __entry->c_contig_type = c_contig_type;
  443. __entry->c_has_empty_extent = c_has_empty_extent;
  444. __entry->c_split_covers_rec = c_split_covers_rec;
  445. ),
  446. TP_printk("%d %u %u %u", __entry->split_index, __entry->c_contig_type,
  447. __entry->c_has_empty_extent, __entry->c_split_covers_rec)
  448. );
  449. TRACE_EVENT(ocfs2_remove_extent,
  450. TP_PROTO(unsigned long long owner, unsigned int cpos,
  451. unsigned int len, int index,
  452. unsigned int e_cpos, unsigned int clusters),
  453. TP_ARGS(owner, cpos, len, index, e_cpos, clusters),
  454. TP_STRUCT__entry(
  455. __field(unsigned long long, owner)
  456. __field(unsigned int, cpos)
  457. __field(unsigned int, len)
  458. __field(int, index)
  459. __field(unsigned int, e_cpos)
  460. __field(unsigned int, clusters)
  461. ),
  462. TP_fast_assign(
  463. __entry->owner = owner;
  464. __entry->cpos = cpos;
  465. __entry->len = len;
  466. __entry->index = index;
  467. __entry->e_cpos = e_cpos;
  468. __entry->clusters = clusters;
  469. ),
  470. TP_printk("%llu %u %u %d %u %u",
  471. __entry->owner, __entry->cpos, __entry->len, __entry->index,
  472. __entry->e_cpos, __entry->clusters)
  473. );
  474. TRACE_EVENT(ocfs2_commit_truncate,
  475. TP_PROTO(unsigned long long ino, unsigned int new_cpos,
  476. unsigned int clusters, unsigned int depth),
  477. TP_ARGS(ino, new_cpos, clusters, depth),
  478. TP_STRUCT__entry(
  479. __field(unsigned long long, ino)
  480. __field(unsigned int, new_cpos)
  481. __field(unsigned int, clusters)
  482. __field(unsigned int, depth)
  483. ),
  484. TP_fast_assign(
  485. __entry->ino = ino;
  486. __entry->new_cpos = new_cpos;
  487. __entry->clusters = clusters;
  488. __entry->depth = depth;
  489. ),
  490. TP_printk("%llu %u %u %u",
  491. __entry->ino, __entry->new_cpos,
  492. __entry->clusters, __entry->depth)
  493. );
  494. TRACE_EVENT(ocfs2_validate_extent_block,
  495. TP_PROTO(unsigned long long blkno),
  496. TP_ARGS(blkno),
  497. TP_STRUCT__entry(
  498. __field(unsigned long long, blkno)
  499. ),
  500. TP_fast_assign(
  501. __entry->blkno = blkno;
  502. ),
  503. TP_printk("%llu ", __entry->blkno)
  504. );
  505. TRACE_EVENT(ocfs2_rotate_leaf,
  506. TP_PROTO(unsigned int insert_cpos, int insert_index,
  507. int has_empty, int next_free,
  508. unsigned int l_count),
  509. TP_ARGS(insert_cpos, insert_index, has_empty,
  510. next_free, l_count),
  511. TP_STRUCT__entry(
  512. __field(unsigned int, insert_cpos)
  513. __field(int, insert_index)
  514. __field(int, has_empty)
  515. __field(int, next_free)
  516. __field(unsigned int, l_count)
  517. ),
  518. TP_fast_assign(
  519. __entry->insert_cpos = insert_cpos;
  520. __entry->insert_index = insert_index;
  521. __entry->has_empty = has_empty;
  522. __entry->next_free = next_free;
  523. __entry->l_count = l_count;
  524. ),
  525. TP_printk("%u %d %d %d %u", __entry->insert_cpos,
  526. __entry->insert_index, __entry->has_empty,
  527. __entry->next_free, __entry->l_count)
  528. );
  529. TRACE_EVENT(ocfs2_add_clusters_in_btree_ret,
  530. TP_PROTO(int status, int reason, int err),
  531. TP_ARGS(status, reason, err),
  532. TP_STRUCT__entry(
  533. __field(int, status)
  534. __field(int, reason)
  535. __field(int, err)
  536. ),
  537. TP_fast_assign(
  538. __entry->status = status;
  539. __entry->reason = reason;
  540. __entry->err = err;
  541. ),
  542. TP_printk("%d %d %d", __entry->status,
  543. __entry->reason, __entry->err)
  544. );
  545. TRACE_EVENT(ocfs2_mark_extent_written,
  546. TP_PROTO(unsigned long long owner, unsigned int cpos,
  547. unsigned int len, unsigned int phys),
  548. TP_ARGS(owner, cpos, len, phys),
  549. TP_STRUCT__entry(
  550. __field(unsigned long long, owner)
  551. __field(unsigned int, cpos)
  552. __field(unsigned int, len)
  553. __field(unsigned int, phys)
  554. ),
  555. TP_fast_assign(
  556. __entry->owner = owner;
  557. __entry->cpos = cpos;
  558. __entry->len = len;
  559. __entry->phys = phys;
  560. ),
  561. TP_printk("%llu %u %u %u",
  562. __entry->owner, __entry->cpos,
  563. __entry->len, __entry->phys)
  564. );
  565. DECLARE_EVENT_CLASS(ocfs2__truncate_log_ops,
  566. TP_PROTO(unsigned long long blkno, int index,
  567. unsigned int start, unsigned int num),
  568. TP_ARGS(blkno, index, start, num),
  569. TP_STRUCT__entry(
  570. __field(unsigned long long, blkno)
  571. __field(int, index)
  572. __field(unsigned int, start)
  573. __field(unsigned int, num)
  574. ),
  575. TP_fast_assign(
  576. __entry->blkno = blkno;
  577. __entry->index = index;
  578. __entry->start = start;
  579. __entry->num = num;
  580. ),
  581. TP_printk("%llu %d %u %u",
  582. __entry->blkno, __entry->index,
  583. __entry->start, __entry->num)
  584. );
  585. #define DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(name) \
  586. DEFINE_EVENT(ocfs2__truncate_log_ops, name, \
  587. TP_PROTO(unsigned long long blkno, int index, \
  588. unsigned int start, unsigned int num), \
  589. TP_ARGS(blkno, index, start, num))
  590. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_truncate_log_append);
  591. DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_replay_truncate_records);
  592. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_flush_truncate_log);
  593. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_truncate_log_recovery);
  594. DEFINE_OCFS2_INT_EVENT(ocfs2_truncate_log_recovery_num);
  595. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_complete_truncate_log_recovery);
  596. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_free_cached_blocks);
  597. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_cache_cluster_dealloc);
  598. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_run_deallocs);
  599. TRACE_EVENT(ocfs2_cache_block_dealloc,
  600. TP_PROTO(int type, int slot, unsigned long long suballoc,
  601. unsigned long long blkno, unsigned int bit),
  602. TP_ARGS(type, slot, suballoc, blkno, bit),
  603. TP_STRUCT__entry(
  604. __field(int, type)
  605. __field(int, slot)
  606. __field(unsigned long long, suballoc)
  607. __field(unsigned long long, blkno)
  608. __field(unsigned int, bit)
  609. ),
  610. TP_fast_assign(
  611. __entry->type = type;
  612. __entry->slot = slot;
  613. __entry->suballoc = suballoc;
  614. __entry->blkno = blkno;
  615. __entry->bit = bit;
  616. ),
  617. TP_printk("%d %d %llu %llu %u",
  618. __entry->type, __entry->slot, __entry->suballoc,
  619. __entry->blkno, __entry->bit)
  620. );
  621. /* End of trace events for fs/ocfs2/alloc.c. */
  622. /* Trace events for fs/ocfs2/localalloc.c. */
  623. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_la_set_sizes);
  624. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_alloc_should_use_local);
  625. DEFINE_OCFS2_INT_EVENT(ocfs2_load_local_alloc);
  626. DEFINE_OCFS2_INT_EVENT(ocfs2_begin_local_alloc_recovery);
  627. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_reserve_local_alloc_bits);
  628. DEFINE_OCFS2_UINT_EVENT(ocfs2_local_alloc_count_bits);
  629. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits_search_bitmap);
  630. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits);
  631. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_sync_local_to_main);
  632. TRACE_EVENT(ocfs2_sync_local_to_main_free,
  633. TP_PROTO(int count, int bit, unsigned long long start_blk,
  634. unsigned long long blkno),
  635. TP_ARGS(count, bit, start_blk, blkno),
  636. TP_STRUCT__entry(
  637. __field(int, count)
  638. __field(int, bit)
  639. __field(unsigned long long, start_blk)
  640. __field(unsigned long long, blkno)
  641. ),
  642. TP_fast_assign(
  643. __entry->count = count;
  644. __entry->bit = bit;
  645. __entry->start_blk = start_blk;
  646. __entry->blkno = blkno;
  647. ),
  648. TP_printk("%d %d %llu %llu",
  649. __entry->count, __entry->bit, __entry->start_blk,
  650. __entry->blkno)
  651. );
  652. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_new_window);
  653. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_local_alloc_new_window_result);
  654. /* End of trace events for fs/ocfs2/localalloc.c. */
  655. /* Trace events for fs/ocfs2/resize.c. */
  656. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_update_last_group_and_inode);
  657. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_group_extend);
  658. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_group_add);
  659. /* End of trace events for fs/ocfs2/resize.c. */
  660. /* Trace events for fs/ocfs2/suballoc.c. */
  661. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_group_descriptor);
  662. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_contig);
  663. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_discontig);
  664. DEFINE_OCFS2_ULL_EVENT(ocfs2_block_group_alloc);
  665. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_nospc);
  666. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_no_new_group);
  667. DEFINE_OCFS2_ULL_EVENT(ocfs2_reserve_new_inode_new_group);
  668. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_set_bits);
  669. TRACE_EVENT(ocfs2_relink_block_group,
  670. TP_PROTO(unsigned long long i_blkno, unsigned int chain,
  671. unsigned long long bg_blkno,
  672. unsigned long long prev_blkno),
  673. TP_ARGS(i_blkno, chain, bg_blkno, prev_blkno),
  674. TP_STRUCT__entry(
  675. __field(unsigned long long, i_blkno)
  676. __field(unsigned int, chain)
  677. __field(unsigned long long, bg_blkno)
  678. __field(unsigned long long, prev_blkno)
  679. ),
  680. TP_fast_assign(
  681. __entry->i_blkno = i_blkno;
  682. __entry->chain = chain;
  683. __entry->bg_blkno = bg_blkno;
  684. __entry->prev_blkno = prev_blkno;
  685. ),
  686. TP_printk("%llu %u %llu %llu",
  687. __entry->i_blkno, __entry->chain, __entry->bg_blkno,
  688. __entry->prev_blkno)
  689. );
  690. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_cluster_group_search_wrong_max_bits);
  691. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cluster_group_search_max_block);
  692. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_block_group_search_max_block);
  693. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_search_chain_begin);
  694. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_succ);
  695. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_end);
  696. DEFINE_OCFS2_UINT_EVENT(ocfs2_claim_suballoc_bits);
  697. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_claim_new_inode_at_loc);
  698. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_clear_bits);
  699. TRACE_EVENT(ocfs2_free_suballoc_bits,
  700. TP_PROTO(unsigned long long inode, unsigned long long group,
  701. unsigned int start_bit, unsigned int count),
  702. TP_ARGS(inode, group, start_bit, count),
  703. TP_STRUCT__entry(
  704. __field(unsigned long long, inode)
  705. __field(unsigned long long, group)
  706. __field(unsigned int, start_bit)
  707. __field(unsigned int, count)
  708. ),
  709. TP_fast_assign(
  710. __entry->inode = inode;
  711. __entry->group = group;
  712. __entry->start_bit = start_bit;
  713. __entry->count = count;
  714. ),
  715. TP_printk("%llu %llu %u %u", __entry->inode, __entry->group,
  716. __entry->start_bit, __entry->count)
  717. );
  718. TRACE_EVENT(ocfs2_free_clusters,
  719. TP_PROTO(unsigned long long bg_blkno, unsigned long long start_blk,
  720. unsigned int start_bit, unsigned int count),
  721. TP_ARGS(bg_blkno, start_blk, start_bit, count),
  722. TP_STRUCT__entry(
  723. __field(unsigned long long, bg_blkno)
  724. __field(unsigned long long, start_blk)
  725. __field(unsigned int, start_bit)
  726. __field(unsigned int, count)
  727. ),
  728. TP_fast_assign(
  729. __entry->bg_blkno = bg_blkno;
  730. __entry->start_blk = start_blk;
  731. __entry->start_bit = start_bit;
  732. __entry->count = count;
  733. ),
  734. TP_printk("%llu %llu %u %u", __entry->bg_blkno, __entry->start_blk,
  735. __entry->start_bit, __entry->count)
  736. );
  737. DEFINE_OCFS2_ULL_EVENT(ocfs2_get_suballoc_slot_bit);
  738. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_test_suballoc_bit);
  739. DEFINE_OCFS2_ULL_EVENT(ocfs2_test_inode_bit);
  740. /* End of trace events for fs/ocfs2/suballoc.c. */
  741. /* Trace events for fs/ocfs2/refcounttree.c. */
  742. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_refcount_block);
  743. DEFINE_OCFS2_ULL_EVENT(ocfs2_purge_refcount_trees);
  744. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree);
  745. DEFINE_OCFS2_ULL_EVENT(ocfs2_create_refcount_tree_blkno);
  746. DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_change_refcount_rec);
  747. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_expand_inline_ref_root);
  748. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_divide_leaf_refcount_block);
  749. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_new_leaf_refcount_block);
  750. DECLARE_EVENT_CLASS(ocfs2__refcount_tree_ops,
  751. TP_PROTO(unsigned long long blkno, int index,
  752. unsigned long long cpos,
  753. unsigned int clusters, unsigned int refcount),
  754. TP_ARGS(blkno, index, cpos, clusters, refcount),
  755. TP_STRUCT__entry(
  756. __field(unsigned long long, blkno)
  757. __field(int, index)
  758. __field(unsigned long long, cpos)
  759. __field(unsigned int, clusters)
  760. __field(unsigned int, refcount)
  761. ),
  762. TP_fast_assign(
  763. __entry->blkno = blkno;
  764. __entry->index = index;
  765. __entry->cpos = cpos;
  766. __entry->clusters = clusters;
  767. __entry->refcount = refcount;
  768. ),
  769. TP_printk("%llu %d %llu %u %u", __entry->blkno, __entry->index,
  770. __entry->cpos, __entry->clusters, __entry->refcount)
  771. );
  772. #define DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(name) \
  773. DEFINE_EVENT(ocfs2__refcount_tree_ops, name, \
  774. TP_PROTO(unsigned long long blkno, int index, \
  775. unsigned long long cpos, \
  776. unsigned int count, unsigned int refcount), \
  777. TP_ARGS(blkno, index, cpos, count, refcount))
  778. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_insert_refcount_rec);
  779. TRACE_EVENT(ocfs2_split_refcount_rec,
  780. TP_PROTO(unsigned long long cpos,
  781. unsigned int clusters, unsigned int refcount,
  782. unsigned long long split_cpos,
  783. unsigned int split_clusters, unsigned int split_refcount),
  784. TP_ARGS(cpos, clusters, refcount,
  785. split_cpos, split_clusters, split_refcount),
  786. TP_STRUCT__entry(
  787. __field(unsigned long long, cpos)
  788. __field(unsigned int, clusters)
  789. __field(unsigned int, refcount)
  790. __field(unsigned long long, split_cpos)
  791. __field(unsigned int, split_clusters)
  792. __field(unsigned int, split_refcount)
  793. ),
  794. TP_fast_assign(
  795. __entry->cpos = cpos;
  796. __entry->clusters = clusters;
  797. __entry->refcount = refcount;
  798. __entry->split_cpos = split_cpos;
  799. __entry->split_clusters = split_clusters;
  800. __entry->split_refcount = split_refcount;
  801. ),
  802. TP_printk("%llu %u %u %llu %u %u",
  803. __entry->cpos, __entry->clusters, __entry->refcount,
  804. __entry->split_cpos, __entry->split_clusters,
  805. __entry->split_refcount)
  806. );
  807. DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(ocfs2_split_refcount_rec_insert);
  808. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_increase_refcount_begin);
  809. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_change);
  810. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_increase_refcount_insert);
  811. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_increase_refcount_split);
  812. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_remove_refcount_extent);
  813. DEFINE_OCFS2_ULL_EVENT(ocfs2_restore_refcount_block);
  814. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_decrease_refcount_rec);
  815. TRACE_EVENT(ocfs2_decrease_refcount,
  816. TP_PROTO(unsigned long long owner,
  817. unsigned long long cpos,
  818. unsigned int len, int delete),
  819. TP_ARGS(owner, cpos, len, delete),
  820. TP_STRUCT__entry(
  821. __field(unsigned long long, owner)
  822. __field(unsigned long long, cpos)
  823. __field(unsigned int, len)
  824. __field(int, delete)
  825. ),
  826. TP_fast_assign(
  827. __entry->owner = owner;
  828. __entry->cpos = cpos;
  829. __entry->len = len;
  830. __entry->delete = delete;
  831. ),
  832. TP_printk("%llu %llu %u %d",
  833. __entry->owner, __entry->cpos, __entry->len, __entry->delete)
  834. );
  835. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_mark_extent_refcounted);
  836. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_calc_refcount_meta_credits);
  837. TRACE_EVENT(ocfs2_calc_refcount_meta_credits_iterate,
  838. TP_PROTO(int recs_add, unsigned long long cpos,
  839. unsigned int clusters, unsigned long long r_cpos,
  840. unsigned int r_clusters, unsigned int refcount, int index),
  841. TP_ARGS(recs_add, cpos, clusters, r_cpos, r_clusters, refcount, index),
  842. TP_STRUCT__entry(
  843. __field(int, recs_add)
  844. __field(unsigned long long, cpos)
  845. __field(unsigned int, clusters)
  846. __field(unsigned long long, r_cpos)
  847. __field(unsigned int, r_clusters)
  848. __field(unsigned int, refcount)
  849. __field(int, index)
  850. ),
  851. TP_fast_assign(
  852. __entry->recs_add = recs_add;
  853. __entry->cpos = cpos;
  854. __entry->clusters = clusters;
  855. __entry->r_cpos = r_cpos;
  856. __entry->r_clusters = r_clusters;
  857. __entry->refcount = refcount;
  858. __entry->index = index;
  859. ),
  860. TP_printk("%d %llu %u %llu %u %u %d",
  861. __entry->recs_add, __entry->cpos, __entry->clusters,
  862. __entry->r_cpos, __entry->r_clusters,
  863. __entry->refcount, __entry->index)
  864. );
  865. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_add_refcount_flag);
  866. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_prepare_refcount_change_for_del);
  867. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_lock_refcount_allocators);
  868. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_page);
  869. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_duplicate_clusters_by_jbd);
  870. TRACE_EVENT(ocfs2_clear_ext_refcount,
  871. TP_PROTO(unsigned long long ino, unsigned int cpos,
  872. unsigned int len, unsigned int p_cluster,
  873. unsigned int ext_flags),
  874. TP_ARGS(ino, cpos, len, p_cluster, ext_flags),
  875. TP_STRUCT__entry(
  876. __field(unsigned long long, ino)
  877. __field(unsigned int, cpos)
  878. __field(unsigned int, len)
  879. __field(unsigned int, p_cluster)
  880. __field(unsigned int, ext_flags)
  881. ),
  882. TP_fast_assign(
  883. __entry->ino = ino;
  884. __entry->cpos = cpos;
  885. __entry->len = len;
  886. __entry->p_cluster = p_cluster;
  887. __entry->ext_flags = ext_flags;
  888. ),
  889. TP_printk("%llu %u %u %u %u",
  890. __entry->ino, __entry->cpos, __entry->len,
  891. __entry->p_cluster, __entry->ext_flags)
  892. );
  893. TRACE_EVENT(ocfs2_replace_clusters,
  894. TP_PROTO(unsigned long long ino, unsigned int cpos,
  895. unsigned int old, unsigned int new, unsigned int len,
  896. unsigned int ext_flags),
  897. TP_ARGS(ino, cpos, old, new, len, ext_flags),
  898. TP_STRUCT__entry(
  899. __field(unsigned long long, ino)
  900. __field(unsigned int, cpos)
  901. __field(unsigned int, old)
  902. __field(unsigned int, new)
  903. __field(unsigned int, len)
  904. __field(unsigned int, ext_flags)
  905. ),
  906. TP_fast_assign(
  907. __entry->ino = ino;
  908. __entry->cpos = cpos;
  909. __entry->old = old;
  910. __entry->new = new;
  911. __entry->len = len;
  912. __entry->ext_flags = ext_flags;
  913. ),
  914. TP_printk("%llu %u %u %u %u %u",
  915. __entry->ino, __entry->cpos, __entry->old, __entry->new,
  916. __entry->len, __entry->ext_flags)
  917. );
  918. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_make_clusters_writable);
  919. TRACE_EVENT(ocfs2_refcount_cow_hunk,
  920. TP_PROTO(unsigned long long ino, unsigned int cpos,
  921. unsigned int write_len, unsigned int max_cpos,
  922. unsigned int cow_start, unsigned int cow_len),
  923. TP_ARGS(ino, cpos, write_len, max_cpos, cow_start, cow_len),
  924. TP_STRUCT__entry(
  925. __field(unsigned long long, ino)
  926. __field(unsigned int, cpos)
  927. __field(unsigned int, write_len)
  928. __field(unsigned int, max_cpos)
  929. __field(unsigned int, cow_start)
  930. __field(unsigned int, cow_len)
  931. ),
  932. TP_fast_assign(
  933. __entry->ino = ino;
  934. __entry->cpos = cpos;
  935. __entry->write_len = write_len;
  936. __entry->max_cpos = max_cpos;
  937. __entry->cow_start = cow_start;
  938. __entry->cow_len = cow_len;
  939. ),
  940. TP_printk("%llu %u %u %u %u %u",
  941. __entry->ino, __entry->cpos, __entry->write_len,
  942. __entry->max_cpos, __entry->cow_start, __entry->cow_len)
  943. );
  944. /* End of trace events for fs/ocfs2/refcounttree.c. */
  945. /* Trace events for fs/ocfs2/aops.c. */
  946. DECLARE_EVENT_CLASS(ocfs2__get_block,
  947. TP_PROTO(unsigned long long ino, unsigned long long iblock,
  948. void *bh_result, int create),
  949. TP_ARGS(ino, iblock, bh_result, create),
  950. TP_STRUCT__entry(
  951. __field(unsigned long long, ino)
  952. __field(unsigned long long, iblock)
  953. __field(void *, bh_result)
  954. __field(int, create)
  955. ),
  956. TP_fast_assign(
  957. __entry->ino = ino;
  958. __entry->iblock = iblock;
  959. __entry->bh_result = bh_result;
  960. __entry->create = create;
  961. ),
  962. TP_printk("%llu %llu %p %d",
  963. __entry->ino, __entry->iblock,
  964. __entry->bh_result, __entry->create)
  965. );
  966. #define DEFINE_OCFS2_GET_BLOCK_EVENT(name) \
  967. DEFINE_EVENT(ocfs2__get_block, name, \
  968. TP_PROTO(unsigned long long ino, unsigned long long iblock, \
  969. void *bh_result, int create), \
  970. TP_ARGS(ino, iblock, bh_result, create))
  971. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_symlink_get_block);
  972. DEFINE_OCFS2_GET_BLOCK_EVENT(ocfs2_get_block);
  973. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_get_block_end);
  974. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_readpage);
  975. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_writepage);
  976. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_bmap);
  977. TRACE_EVENT(ocfs2_try_to_write_inline_data,
  978. TP_PROTO(unsigned long long ino, unsigned int len,
  979. unsigned long long pos, unsigned int flags),
  980. TP_ARGS(ino, len, pos, flags),
  981. TP_STRUCT__entry(
  982. __field(unsigned long long, ino)
  983. __field(unsigned int, len)
  984. __field(unsigned long long, pos)
  985. __field(unsigned int, flags)
  986. ),
  987. TP_fast_assign(
  988. __entry->ino = ino;
  989. __entry->len = len;
  990. __entry->pos = pos;
  991. __entry->flags = flags;
  992. ),
  993. TP_printk("%llu %u %llu 0x%x",
  994. __entry->ino, __entry->len, __entry->pos, __entry->flags)
  995. );
  996. TRACE_EVENT(ocfs2_write_begin_nolock,
  997. TP_PROTO(unsigned long long ino,
  998. long long i_size, unsigned int i_clusters,
  999. unsigned long long pos, unsigned int len,
  1000. unsigned int flags, void *page,
  1001. unsigned int clusters, unsigned int extents_to_split),
  1002. TP_ARGS(ino, i_size, i_clusters, pos, len, flags,
  1003. page, clusters, extents_to_split),
  1004. TP_STRUCT__entry(
  1005. __field(unsigned long long, ino)
  1006. __field(long long, i_size)
  1007. __field(unsigned int, i_clusters)
  1008. __field(unsigned long long, pos)
  1009. __field(unsigned int, len)
  1010. __field(unsigned int, flags)
  1011. __field(void *, page)
  1012. __field(unsigned int, clusters)
  1013. __field(unsigned int, extents_to_split)
  1014. ),
  1015. TP_fast_assign(
  1016. __entry->ino = ino;
  1017. __entry->i_size = i_size;
  1018. __entry->i_clusters = i_clusters;
  1019. __entry->pos = pos;
  1020. __entry->len = len;
  1021. __entry->flags = flags;
  1022. __entry->page = page;
  1023. __entry->clusters = clusters;
  1024. __entry->extents_to_split = extents_to_split;
  1025. ),
  1026. TP_printk("%llu %lld %u %llu %u %u %p %u %u",
  1027. __entry->ino, __entry->i_size, __entry->i_clusters,
  1028. __entry->pos, __entry->len,
  1029. __entry->flags, __entry->page, __entry->clusters,
  1030. __entry->extents_to_split)
  1031. );
  1032. TRACE_EVENT(ocfs2_write_end_inline,
  1033. TP_PROTO(unsigned long long ino,
  1034. unsigned long long pos, unsigned int copied,
  1035. unsigned int id_count, unsigned int features),
  1036. TP_ARGS(ino, pos, copied, id_count, features),
  1037. TP_STRUCT__entry(
  1038. __field(unsigned long long, ino)
  1039. __field(unsigned long long, pos)
  1040. __field(unsigned int, copied)
  1041. __field(unsigned int, id_count)
  1042. __field(unsigned int, features)
  1043. ),
  1044. TP_fast_assign(
  1045. __entry->ino = ino;
  1046. __entry->pos = pos;
  1047. __entry->copied = copied;
  1048. __entry->id_count = id_count;
  1049. __entry->features = features;
  1050. ),
  1051. TP_printk("%llu %llu %u %u %u",
  1052. __entry->ino, __entry->pos, __entry->copied,
  1053. __entry->id_count, __entry->features)
  1054. );
  1055. /* End of trace events for fs/ocfs2/aops.c. */
  1056. /* Trace events for fs/ocfs2/mmap.c. */
  1057. TRACE_EVENT(ocfs2_fault,
  1058. TP_PROTO(unsigned long long ino,
  1059. void *area, void *page, unsigned long pgoff),
  1060. TP_ARGS(ino, area, page, pgoff),
  1061. TP_STRUCT__entry(
  1062. __field(unsigned long long, ino)
  1063. __field(void *, area)
  1064. __field(void *, page)
  1065. __field(unsigned long, pgoff)
  1066. ),
  1067. TP_fast_assign(
  1068. __entry->ino = ino;
  1069. __entry->area = area;
  1070. __entry->page = page;
  1071. __entry->pgoff = pgoff;
  1072. ),
  1073. TP_printk("%llu %p %p %lu",
  1074. __entry->ino, __entry->area, __entry->page, __entry->pgoff)
  1075. );
  1076. /* End of trace events for fs/ocfs2/mmap.c. */
  1077. /* Trace events for fs/ocfs2/file.c. */
  1078. DECLARE_EVENT_CLASS(ocfs2__file_ops,
  1079. TP_PROTO(void *inode, void *file, void *dentry,
  1080. unsigned long long ino,
  1081. unsigned int d_len, const unsigned char *d_name,
  1082. unsigned long long para),
  1083. TP_ARGS(inode, file, dentry, ino, d_len, d_name, para),
  1084. TP_STRUCT__entry(
  1085. __field(void *, inode)
  1086. __field(void *, file)
  1087. __field(void *, dentry)
  1088. __field(unsigned long long, ino)
  1089. __field(unsigned int, d_len)
  1090. __string(d_name, d_name)
  1091. __field(unsigned long long, para)
  1092. ),
  1093. TP_fast_assign(
  1094. __entry->inode = inode;
  1095. __entry->file = file;
  1096. __entry->dentry = dentry;
  1097. __entry->ino = ino;
  1098. __entry->d_len = d_len;
  1099. __assign_str(d_name, d_name);
  1100. __entry->para = para;
  1101. ),
  1102. TP_printk("%p %p %p %llu %llu %.*s", __entry->inode, __entry->file,
  1103. __entry->dentry, __entry->ino, __entry->para,
  1104. __entry->d_len, __get_str(d_name))
  1105. );
  1106. #define DEFINE_OCFS2_FILE_OPS(name) \
  1107. DEFINE_EVENT(ocfs2__file_ops, name, \
  1108. TP_PROTO(void *inode, void *file, void *dentry, \
  1109. unsigned long long ino, \
  1110. unsigned int d_len, const unsigned char *d_name, \
  1111. unsigned long long mode), \
  1112. TP_ARGS(inode, file, dentry, ino, d_len, d_name, mode))
  1113. DEFINE_OCFS2_FILE_OPS(ocfs2_file_open);
  1114. DEFINE_OCFS2_FILE_OPS(ocfs2_file_release);
  1115. DEFINE_OCFS2_FILE_OPS(ocfs2_sync_file);
  1116. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_write);
  1117. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_write);
  1118. DEFINE_OCFS2_FILE_OPS(ocfs2_file_splice_read);
  1119. DEFINE_OCFS2_FILE_OPS(ocfs2_file_aio_read);
  1120. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_truncate_file);
  1121. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_truncate_file_error);
  1122. TRACE_EVENT(ocfs2_extend_allocation,
  1123. TP_PROTO(unsigned long long ip_blkno, unsigned long long size,
  1124. unsigned int clusters, unsigned int clusters_to_add,
  1125. int why, int restart_func),
  1126. TP_ARGS(ip_blkno, size, clusters, clusters_to_add, why, restart_func),
  1127. TP_STRUCT__entry(
  1128. __field(unsigned long long, ip_blkno)
  1129. __field(unsigned long long, size)
  1130. __field(unsigned int, clusters)
  1131. __field(unsigned int, clusters_to_add)
  1132. __field(int, why)
  1133. __field(int, restart_func)
  1134. ),
  1135. TP_fast_assign(
  1136. __entry->ip_blkno = ip_blkno;
  1137. __entry->size = size;
  1138. __entry->clusters = clusters;
  1139. __entry->clusters_to_add = clusters_to_add;
  1140. __entry->why = why;
  1141. __entry->restart_func = restart_func;
  1142. ),
  1143. TP_printk("%llu %llu %u %u %d %d",
  1144. __entry->ip_blkno, __entry->size, __entry->clusters,
  1145. __entry->clusters_to_add, __entry->why, __entry->restart_func)
  1146. );
  1147. TRACE_EVENT(ocfs2_extend_allocation_end,
  1148. TP_PROTO(unsigned long long ino,
  1149. unsigned int di_clusters, unsigned long long di_size,
  1150. unsigned int ip_clusters, unsigned long long i_size),
  1151. TP_ARGS(ino, di_clusters, di_size, ip_clusters, i_size),
  1152. TP_STRUCT__entry(
  1153. __field(unsigned long long, ino)
  1154. __field(unsigned int, di_clusters)
  1155. __field(unsigned long long, di_size)
  1156. __field(unsigned int, ip_clusters)
  1157. __field(unsigned long long, i_size)
  1158. ),
  1159. TP_fast_assign(
  1160. __entry->ino = ino;
  1161. __entry->di_clusters = di_clusters;
  1162. __entry->di_size = di_size;
  1163. __entry->ip_clusters = ip_clusters;
  1164. __entry->i_size = i_size;
  1165. ),
  1166. TP_printk("%llu %u %llu %u %llu", __entry->ino, __entry->di_clusters,
  1167. __entry->di_size, __entry->ip_clusters, __entry->i_size)
  1168. );
  1169. TRACE_EVENT(ocfs2_write_zero_page,
  1170. TP_PROTO(unsigned long long ino,
  1171. unsigned long long abs_from, unsigned long long abs_to,
  1172. unsigned long index, unsigned int zero_from,
  1173. unsigned int zero_to),
  1174. TP_ARGS(ino, abs_from, abs_to, index, zero_from, zero_to),
  1175. TP_STRUCT__entry(
  1176. __field(unsigned long long, ino)
  1177. __field(unsigned long long, abs_from)
  1178. __field(unsigned long long, abs_to)
  1179. __field(unsigned long, index)
  1180. __field(unsigned int, zero_from)
  1181. __field(unsigned int, zero_to)
  1182. ),
  1183. TP_fast_assign(
  1184. __entry->ino = ino;
  1185. __entry->abs_from = abs_from;
  1186. __entry->abs_to = abs_to;
  1187. __entry->index = index;
  1188. __entry->zero_from = zero_from;
  1189. __entry->zero_to = zero_to;
  1190. ),
  1191. TP_printk("%llu %llu %llu %lu %u %u", __entry->ino,
  1192. __entry->abs_from, __entry->abs_to,
  1193. __entry->index, __entry->zero_from, __entry->zero_to)
  1194. );
  1195. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend_range);
  1196. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_extend);
  1197. TRACE_EVENT(ocfs2_setattr,
  1198. TP_PROTO(void *inode, void *dentry,
  1199. unsigned long long ino,
  1200. unsigned int d_len, const unsigned char *d_name,
  1201. unsigned int ia_valid, unsigned int ia_mode,
  1202. unsigned int ia_uid, unsigned int ia_gid),
  1203. TP_ARGS(inode, dentry, ino, d_len, d_name,
  1204. ia_valid, ia_mode, ia_uid, ia_gid),
  1205. TP_STRUCT__entry(
  1206. __field(void *, inode)
  1207. __field(void *, dentry)
  1208. __field(unsigned long long, ino)
  1209. __field(unsigned int, d_len)
  1210. __string(d_name, d_name)
  1211. __field(unsigned int, ia_valid)
  1212. __field(unsigned int, ia_mode)
  1213. __field(unsigned int, ia_uid)
  1214. __field(unsigned int, ia_gid)
  1215. ),
  1216. TP_fast_assign(
  1217. __entry->inode = inode;
  1218. __entry->dentry = dentry;
  1219. __entry->ino = ino;
  1220. __entry->d_len = d_len;
  1221. __assign_str(d_name, d_name);
  1222. __entry->ia_valid = ia_valid;
  1223. __entry->ia_mode = ia_mode;
  1224. __entry->ia_uid = ia_uid;
  1225. __entry->ia_gid = ia_gid;
  1226. ),
  1227. TP_printk("%p %p %llu %.*s %u %u %u %u", __entry->inode,
  1228. __entry->dentry, __entry->ino, __entry->d_len,
  1229. __get_str(d_name), __entry->ia_valid, __entry->ia_mode,
  1230. __entry->ia_uid, __entry->ia_gid)
  1231. );
  1232. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_write_remove_suid);
  1233. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_zero_partial_clusters);
  1234. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range1);
  1235. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_zero_partial_clusters_range2);
  1236. DEFINE_OCFS2_ULL_ULL_ULL_EVENT(ocfs2_remove_inode_range);
  1237. TRACE_EVENT(ocfs2_prepare_inode_for_write,
  1238. TP_PROTO(unsigned long long ino, unsigned long long saved_pos,
  1239. int appending, unsigned long count,
  1240. int *direct_io, int *has_refcount),
  1241. TP_ARGS(ino, saved_pos, appending, count, direct_io, has_refcount),
  1242. TP_STRUCT__entry(
  1243. __field(unsigned long long, ino)
  1244. __field(unsigned long long, saved_pos)
  1245. __field(int, appending)
  1246. __field(unsigned long, count)
  1247. __field(int, direct_io)
  1248. __field(int, has_refcount)
  1249. ),
  1250. TP_fast_assign(
  1251. __entry->ino = ino;
  1252. __entry->saved_pos = saved_pos;
  1253. __entry->appending = appending;
  1254. __entry->count = count;
  1255. __entry->direct_io = direct_io ? *direct_io : -1;
  1256. __entry->has_refcount = has_refcount ? *has_refcount : -1;
  1257. ),
  1258. TP_printk("%llu %llu %d %lu %d %d", __entry->ino,
  1259. __entry->saved_pos, __entry->appending, __entry->count,
  1260. __entry->direct_io, __entry->has_refcount)
  1261. );
  1262. DEFINE_OCFS2_INT_EVENT(generic_file_aio_read_ret);
  1263. /* End of trace events for fs/ocfs2/file.c. */
  1264. /* Trace events for fs/ocfs2/inode.c. */
  1265. TRACE_EVENT(ocfs2_iget_begin,
  1266. TP_PROTO(unsigned long long ino, unsigned int flags, int sysfile_type),
  1267. TP_ARGS(ino, flags, sysfile_type),
  1268. TP_STRUCT__entry(
  1269. __field(unsigned long long, ino)
  1270. __field(unsigned int, flags)
  1271. __field(int, sysfile_type)
  1272. ),
  1273. TP_fast_assign(
  1274. __entry->ino = ino;
  1275. __entry->flags = flags;
  1276. __entry->sysfile_type = sysfile_type;
  1277. ),
  1278. TP_printk("%llu %u %d", __entry->ino,
  1279. __entry->flags, __entry->sysfile_type)
  1280. );
  1281. DEFINE_OCFS2_ULL_EVENT(ocfs2_iget5_locked);
  1282. TRACE_EVENT(ocfs2_iget_end,
  1283. TP_PROTO(void *inode, unsigned long long ino),
  1284. TP_ARGS(inode, ino),
  1285. TP_STRUCT__entry(
  1286. __field(void *, inode)
  1287. __field(unsigned long long, ino)
  1288. ),
  1289. TP_fast_assign(
  1290. __entry->inode = inode;
  1291. __entry->ino = ino;
  1292. ),
  1293. TP_printk("%p %llu", __entry->inode, __entry->ino)
  1294. );
  1295. TRACE_EVENT(ocfs2_find_actor,
  1296. TP_PROTO(void *inode, unsigned long long ino,
  1297. void *args, unsigned long long fi_blkno),
  1298. TP_ARGS(inode, ino, args, fi_blkno),
  1299. TP_STRUCT__entry(
  1300. __field(void *, inode)
  1301. __field(unsigned long long, ino)
  1302. __field(void *, args)
  1303. __field(unsigned long long, fi_blkno)
  1304. ),
  1305. TP_fast_assign(
  1306. __entry->inode = inode;
  1307. __entry->ino = ino;
  1308. __entry->args = args;
  1309. __entry->fi_blkno = fi_blkno;
  1310. ),
  1311. TP_printk("%p %llu %p %llu", __entry->inode, __entry->ino,
  1312. __entry->args, __entry->fi_blkno)
  1313. );
  1314. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_populate_inode);
  1315. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_read_locked_inode);
  1316. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_check_orphan_recovery_state);
  1317. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_inode_block);
  1318. TRACE_EVENT(ocfs2_inode_is_valid_to_delete,
  1319. TP_PROTO(void *task, void *dc_task, unsigned long long ino,
  1320. unsigned int flags),
  1321. TP_ARGS(task, dc_task, ino, flags),
  1322. TP_STRUCT__entry(
  1323. __field(void *, task)
  1324. __field(void *, dc_task)
  1325. __field(unsigned long long, ino)
  1326. __field(unsigned int, flags)
  1327. ),
  1328. TP_fast_assign(
  1329. __entry->task = task;
  1330. __entry->dc_task = dc_task;
  1331. __entry->ino = ino;
  1332. __entry->flags = flags;
  1333. ),
  1334. TP_printk("%p %p %llu %u", __entry->task, __entry->dc_task,
  1335. __entry->ino, __entry->flags)
  1336. );
  1337. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_query_inode_wipe_begin);
  1338. DEFINE_OCFS2_UINT_EVENT(ocfs2_query_inode_wipe_succ);
  1339. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_query_inode_wipe_end);
  1340. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_cleanup_delete_inode);
  1341. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_delete_inode);
  1342. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_clear_inode);
  1343. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_drop_inode);
  1344. TRACE_EVENT(ocfs2_inode_revalidate,
  1345. TP_PROTO(void *inode, unsigned long long ino,
  1346. unsigned int flags),
  1347. TP_ARGS(inode, ino, flags),
  1348. TP_STRUCT__entry(
  1349. __field(void *, inode)
  1350. __field(unsigned long long, ino)
  1351. __field(unsigned int, flags)
  1352. ),
  1353. TP_fast_assign(
  1354. __entry->inode = inode;
  1355. __entry->ino = ino;
  1356. __entry->flags = flags;
  1357. ),
  1358. TP_printk("%p %llu %u", __entry->inode, __entry->ino, __entry->flags)
  1359. );
  1360. DEFINE_OCFS2_ULL_EVENT(ocfs2_mark_inode_dirty);
  1361. /* End of trace events for fs/ocfs2/inode.c. */
  1362. /* Trace events for fs/ocfs2/extent_map.c. */
  1363. TRACE_EVENT(ocfs2_read_virt_blocks,
  1364. TP_PROTO(void *inode, unsigned long long vblock, int nr,
  1365. void *bhs, unsigned int flags, void *validate),
  1366. TP_ARGS(inode, vblock, nr, bhs, flags, validate),
  1367. TP_STRUCT__entry(
  1368. __field(void *, inode)
  1369. __field(unsigned long long, vblock)
  1370. __field(int, nr)
  1371. __field(void *, bhs)
  1372. __field(unsigned int, flags)
  1373. __field(void *, validate)
  1374. ),
  1375. TP_fast_assign(
  1376. __entry->inode = inode;
  1377. __entry->vblock = vblock;
  1378. __entry->nr = nr;
  1379. __entry->bhs = bhs;
  1380. __entry->flags = flags;
  1381. __entry->validate = validate;
  1382. ),
  1383. TP_printk("%p %llu %d %p %x %p", __entry->inode, __entry->vblock,
  1384. __entry->nr, __entry->bhs, __entry->flags, __entry->validate)
  1385. );
  1386. /* End of trace events for fs/ocfs2/extent_map.c. */
  1387. /* Trace events for fs/ocfs2/slot_map.c. */
  1388. DEFINE_OCFS2_UINT_EVENT(ocfs2_refresh_slot_info);
  1389. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_map_slot_buffers);
  1390. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_map_slot_buffers_block);
  1391. DEFINE_OCFS2_INT_EVENT(ocfs2_find_slot);
  1392. /* End of trace events for fs/ocfs2/slot_map.c. */
  1393. /* Trace events for fs/ocfs2/heartbeat.c. */
  1394. DEFINE_OCFS2_INT_EVENT(ocfs2_do_node_down);
  1395. /* End of trace events for fs/ocfs2/heartbeat.c. */
  1396. /* Trace events for fs/ocfs2/super.c. */
  1397. TRACE_EVENT(ocfs2_remount,
  1398. TP_PROTO(unsigned long s_flags, unsigned long osb_flags, int flags),
  1399. TP_ARGS(s_flags, osb_flags, flags),
  1400. TP_STRUCT__entry(
  1401. __field(unsigned long, s_flags)
  1402. __field(unsigned long, osb_flags)
  1403. __field(int, flags)
  1404. ),
  1405. TP_fast_assign(
  1406. __entry->s_flags = s_flags;
  1407. __entry->osb_flags = osb_flags;
  1408. __entry->flags = flags;
  1409. ),
  1410. TP_printk("%lu %lu %d", __entry->s_flags,
  1411. __entry->osb_flags, __entry->flags)
  1412. );
  1413. TRACE_EVENT(ocfs2_fill_super,
  1414. TP_PROTO(void *sb, void *data, int silent),
  1415. TP_ARGS(sb, data, silent),
  1416. TP_STRUCT__entry(
  1417. __field(void *, sb)
  1418. __field(void *, data)
  1419. __field(int, silent)
  1420. ),
  1421. TP_fast_assign(
  1422. __entry->sb = sb;
  1423. __entry->data = data;
  1424. __entry->silent = silent;
  1425. ),
  1426. TP_printk("%p %p %d", __entry->sb,
  1427. __entry->data, __entry->silent)
  1428. );
  1429. TRACE_EVENT(ocfs2_parse_options,
  1430. TP_PROTO(int is_remount, char *options),
  1431. TP_ARGS(is_remount, options),
  1432. TP_STRUCT__entry(
  1433. __field(int, is_remount)
  1434. __string(options, options)
  1435. ),
  1436. TP_fast_assign(
  1437. __entry->is_remount = is_remount;
  1438. __assign_str(options, options);
  1439. ),
  1440. TP_printk("%d %s", __entry->is_remount, __get_str(options))
  1441. );
  1442. DEFINE_OCFS2_POINTER_EVENT(ocfs2_put_super);
  1443. TRACE_EVENT(ocfs2_statfs,
  1444. TP_PROTO(void *sb, void *buf),
  1445. TP_ARGS(sb, buf),
  1446. TP_STRUCT__entry(
  1447. __field(void *, sb)
  1448. __field(void *, buf)
  1449. ),
  1450. TP_fast_assign(
  1451. __entry->sb = sb;
  1452. __entry->buf = buf;
  1453. ),
  1454. TP_printk("%p %p", __entry->sb, __entry->buf)
  1455. );
  1456. DEFINE_OCFS2_POINTER_EVENT(ocfs2_dismount_volume);
  1457. TRACE_EVENT(ocfs2_initialize_super,
  1458. TP_PROTO(char *label, char *uuid_str, unsigned long long root_dir,
  1459. unsigned long long system_dir, int cluster_bits),
  1460. TP_ARGS(label, uuid_str, root_dir, system_dir, cluster_bits),
  1461. TP_STRUCT__entry(
  1462. __string(label, label)
  1463. __string(uuid_str, uuid_str)
  1464. __field(unsigned long long, root_dir)
  1465. __field(unsigned long long, system_dir)
  1466. __field(int, cluster_bits)
  1467. ),
  1468. TP_fast_assign(
  1469. __assign_str(label, label);
  1470. __assign_str(uuid_str, uuid_str);
  1471. __entry->root_dir = root_dir;
  1472. __entry->system_dir = system_dir;
  1473. __entry->cluster_bits = cluster_bits;
  1474. ),
  1475. TP_printk("%s %s %llu %llu %d", __get_str(label), __get_str(uuid_str),
  1476. __entry->root_dir, __entry->system_dir, __entry->cluster_bits)
  1477. );
  1478. /* End of trace events for fs/ocfs2/super.c. */
  1479. /* Trace events for fs/ocfs2/xattr.c. */
  1480. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_xattr_block);
  1481. DEFINE_OCFS2_UINT_EVENT(ocfs2_xattr_extend_allocation);
  1482. TRACE_EVENT(ocfs2_init_xattr_set_ctxt,
  1483. TP_PROTO(const char *name, int meta, int clusters, int credits),
  1484. TP_ARGS(name, meta, clusters, credits),
  1485. TP_STRUCT__entry(
  1486. __string(name, name)
  1487. __field(int, meta)
  1488. __field(int, clusters)
  1489. __field(int, credits)
  1490. ),
  1491. TP_fast_assign(
  1492. __assign_str(name, name);
  1493. __entry->meta = meta;
  1494. __entry->clusters = clusters;
  1495. __entry->credits = credits;
  1496. ),
  1497. TP_printk("%s %d %d %d", __get_str(name), __entry->meta,
  1498. __entry->clusters, __entry->credits)
  1499. );
  1500. DECLARE_EVENT_CLASS(ocfs2__xattr_find,
  1501. TP_PROTO(unsigned long long ino, const char *name, int name_index,
  1502. unsigned int hash, unsigned long long location,
  1503. int xe_index),
  1504. TP_ARGS(ino, name, name_index, hash, location, xe_index),
  1505. TP_STRUCT__entry(
  1506. __field(unsigned long long, ino)
  1507. __string(name, name)
  1508. __field(int, name_index)
  1509. __field(unsigned int, hash)
  1510. __field(unsigned long long, location)
  1511. __field(int, xe_index)
  1512. ),
  1513. TP_fast_assign(
  1514. __entry->ino = ino;
  1515. __assign_str(name, name);
  1516. __entry->name_index = name_index;
  1517. __entry->hash = hash;
  1518. __entry->location = location;
  1519. __entry->xe_index = xe_index;
  1520. ),
  1521. TP_printk("%llu %s %d %u %llu %d", __entry->ino, __get_str(name),
  1522. __entry->name_index, __entry->hash, __entry->location,
  1523. __entry->xe_index)
  1524. );
  1525. #define DEFINE_OCFS2_XATTR_FIND_EVENT(name) \
  1526. DEFINE_EVENT(ocfs2__xattr_find, name, \
  1527. TP_PROTO(unsigned long long ino, const char *name, int name_index, \
  1528. unsigned int hash, unsigned long long bucket, \
  1529. int xe_index), \
  1530. TP_ARGS(ino, name, name_index, hash, bucket, xe_index))
  1531. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_bucket_find);
  1532. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_index_block_find);
  1533. DEFINE_OCFS2_XATTR_FIND_EVENT(ocfs2_xattr_index_block_find_rec);
  1534. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_iterate_xattr_buckets);
  1535. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_iterate_xattr_bucket);
  1536. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cp_xattr_block_to_bucket_begin);
  1537. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_cp_xattr_block_to_bucket_end);
  1538. DEFINE_OCFS2_ULL_EVENT(ocfs2_xattr_create_index_block_begin);
  1539. DEFINE_OCFS2_ULL_EVENT(ocfs2_xattr_create_index_block);
  1540. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_defrag_xattr_bucket);
  1541. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_mv_xattr_bucket_cross_cluster);
  1542. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_divide_xattr_bucket_begin);
  1543. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_divide_xattr_bucket_move);
  1544. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_cp_xattr_bucket);
  1545. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_mv_xattr_buckets);
  1546. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_adjust_xattr_cross_cluster);
  1547. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_add_new_xattr_cluster_begin);
  1548. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_add_new_xattr_cluster);
  1549. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_add_new_xattr_cluster_insert);
  1550. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_extend_xattr_bucket);
  1551. DEFINE_OCFS2_ULL_EVENT(ocfs2_add_new_xattr_bucket);
  1552. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_xattr_bucket_value_truncate);
  1553. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_rm_xattr_cluster);
  1554. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_reflink_xattr_header);
  1555. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_create_empty_xattr_block);
  1556. DEFINE_OCFS2_STRING_EVENT(ocfs2_xattr_set_entry_bucket);
  1557. DEFINE_OCFS2_STRING_EVENT(ocfs2_xattr_set_entry_index_block);
  1558. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_xattr_bucket_value_refcount);
  1559. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_reflink_xattr_buckets);
  1560. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_reflink_xattr_rec);
  1561. /* End of trace events for fs/ocfs2/xattr.c. */
  1562. /* Trace events for fs/ocfs2/reservations.c. */
  1563. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_resv_insert);
  1564. DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_resmap_find_free_bits_begin);
  1565. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_resmap_find_free_bits_end);
  1566. TRACE_EVENT(ocfs2_resv_find_window_begin,
  1567. TP_PROTO(unsigned int r_start, unsigned int r_end, unsigned int goal,
  1568. unsigned int wanted, int empty_root),
  1569. TP_ARGS(r_start, r_end, goal, wanted, empty_root),
  1570. TP_STRUCT__entry(
  1571. __field(unsigned int, r_start)
  1572. __field(unsigned int, r_end)
  1573. __field(unsigned int, goal)
  1574. __field(unsigned int, wanted)
  1575. __field(int, empty_root)
  1576. ),
  1577. TP_fast_assign(
  1578. __entry->r_start = r_start;
  1579. __entry->r_end = r_end;
  1580. __entry->goal = goal;
  1581. __entry->wanted = wanted;
  1582. __entry->empty_root = empty_root;
  1583. ),
  1584. TP_printk("%u %u %u %u %d", __entry->r_start, __entry->r_end,
  1585. __entry->goal, __entry->wanted, __entry->empty_root)
  1586. );
  1587. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_resv_find_window_prev);
  1588. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_resv_find_window_next);
  1589. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_cannibalize_resv_begin);
  1590. TRACE_EVENT(ocfs2_cannibalize_resv_end,
  1591. TP_PROTO(unsigned int start, unsigned int end, unsigned int len,
  1592. unsigned int last_start, unsigned int last_len),
  1593. TP_ARGS(start, end, len, last_start, last_len),
  1594. TP_STRUCT__entry(
  1595. __field(unsigned int, start)
  1596. __field(unsigned int, end)
  1597. __field(unsigned int, len)
  1598. __field(unsigned int, last_start)
  1599. __field(unsigned int, last_len)
  1600. ),
  1601. TP_fast_assign(
  1602. __entry->start = start;
  1603. __entry->end = end;
  1604. __entry->len = len;
  1605. __entry->last_start = last_start;
  1606. __entry->last_len = last_len;
  1607. ),
  1608. TP_printk("%u %u %u %u %u", __entry->start, __entry->end,
  1609. __entry->len, __entry->last_start, __entry->last_len)
  1610. );
  1611. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_resmap_resv_bits);
  1612. TRACE_EVENT(ocfs2_resmap_claimed_bits_begin,
  1613. TP_PROTO(unsigned int cstart, unsigned int cend, unsigned int clen,
  1614. unsigned int r_start, unsigned int r_end, unsigned int r_len,
  1615. unsigned int last_start, unsigned int last_len),
  1616. TP_ARGS(cstart, cend, clen, r_start, r_end,
  1617. r_len, last_start, last_len),
  1618. TP_STRUCT__entry(
  1619. __field(unsigned int, cstart)
  1620. __field(unsigned int, cend)
  1621. __field(unsigned int, clen)
  1622. __field(unsigned int, r_start)
  1623. __field(unsigned int, r_end)
  1624. __field(unsigned int, r_len)
  1625. __field(unsigned int, last_start)
  1626. __field(unsigned int, last_len)
  1627. ),
  1628. TP_fast_assign(
  1629. __entry->cstart = cstart;
  1630. __entry->cend = cend;
  1631. __entry->clen = clen;
  1632. __entry->r_start = r_start;
  1633. __entry->r_end = r_end;
  1634. __entry->r_len = r_len;
  1635. __entry->last_start = last_start;
  1636. __entry->last_len = last_len;
  1637. ),
  1638. TP_printk("%u %u %u %u %u %u %u %u",
  1639. __entry->cstart, __entry->cend, __entry->clen,
  1640. __entry->r_start, __entry->r_end, __entry->r_len,
  1641. __entry->last_start, __entry->last_len)
  1642. );
  1643. TRACE_EVENT(ocfs2_resmap_claimed_bits_end,
  1644. TP_PROTO(unsigned int start, unsigned int end, unsigned int len,
  1645. unsigned int last_start, unsigned int last_len),
  1646. TP_ARGS(start, end, len, last_start, last_len),
  1647. TP_STRUCT__entry(
  1648. __field(unsigned int, start)
  1649. __field(unsigned int, end)
  1650. __field(unsigned int, len)
  1651. __field(unsigned int, last_start)
  1652. __field(unsigned int, last_len)
  1653. ),
  1654. TP_fast_assign(
  1655. __entry->start = start;
  1656. __entry->end = end;
  1657. __entry->len = len;
  1658. __entry->last_start = last_start;
  1659. __entry->last_len = last_len;
  1660. ),
  1661. TP_printk("%u %u %u %u %u", __entry->start, __entry->end,
  1662. __entry->len, __entry->last_start, __entry->last_len)
  1663. );
  1664. /* End of trace events for fs/ocfs2/reservations.c. */
  1665. /* Trace events for fs/ocfs2/quota_local.c. */
  1666. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_recover_local_quota_file);
  1667. DEFINE_OCFS2_INT_EVENT(ocfs2_finish_quota_recovery);
  1668. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(olq_set_dquot);
  1669. /* End of trace events for fs/ocfs2/quota_local.c. */
  1670. /* Trace events for fs/ocfs2/quota_global.c. */
  1671. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_quota_block);
  1672. TRACE_EVENT(ocfs2_sync_dquot,
  1673. TP_PROTO(unsigned int dq_id, long long dqb_curspace,
  1674. long long spacechange, long long curinodes,
  1675. long long inodechange),
  1676. TP_ARGS(dq_id, dqb_curspace, spacechange, curinodes, inodechange),
  1677. TP_STRUCT__entry(
  1678. __field(unsigned int, dq_id)
  1679. __field(long long, dqb_curspace)
  1680. __field(long long, spacechange)
  1681. __field(long long, curinodes)
  1682. __field(long long, inodechange)
  1683. ),
  1684. TP_fast_assign(
  1685. __entry->dq_id = dq_id;
  1686. __entry->dqb_curspace = dqb_curspace;
  1687. __entry->spacechange = spacechange;
  1688. __entry->curinodes = curinodes;
  1689. __entry->inodechange = inodechange;
  1690. ),
  1691. TP_printk("%u %lld %lld %lld %lld", __entry->dq_id,
  1692. __entry->dqb_curspace, __entry->spacechange,
  1693. __entry->curinodes, __entry->inodechange)
  1694. );
  1695. TRACE_EVENT(ocfs2_sync_dquot_helper,
  1696. TP_PROTO(unsigned int dq_id, unsigned int dq_type, unsigned long type,
  1697. const char *s_id),
  1698. TP_ARGS(dq_id, dq_type, type, s_id),
  1699. TP_STRUCT__entry(
  1700. __field(unsigned int, dq_id)
  1701. __field(unsigned int, dq_type)
  1702. __field(unsigned long, type)
  1703. __string(s_id, s_id)
  1704. ),
  1705. TP_fast_assign(
  1706. __entry->dq_id = dq_id;
  1707. __entry->dq_type = dq_type;
  1708. __entry->type = type;
  1709. __assign_str(s_id, s_id);
  1710. ),
  1711. TP_printk("%u %u %lu %s", __entry->dq_id, __entry->dq_type,
  1712. __entry->type, __get_str(s_id))
  1713. );
  1714. DEFINE_OCFS2_UINT_INT_EVENT(ocfs2_write_dquot);
  1715. DEFINE_OCFS2_UINT_INT_EVENT(ocfs2_release_dquot);
  1716. DEFINE_OCFS2_UINT_INT_EVENT(ocfs2_acquire_dquot);
  1717. DEFINE_OCFS2_UINT_INT_EVENT(ocfs2_mark_dquot_dirty);
  1718. /* End of trace events for fs/ocfs2/quota_global.c. */
  1719. /* Trace events for fs/ocfs2/dir.c. */
  1720. DEFINE_OCFS2_INT_EVENT(ocfs2_search_dirblock);
  1721. DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_dir_block);
  1722. DEFINE_OCFS2_POINTER_EVENT(ocfs2_find_entry_el);
  1723. TRACE_EVENT(ocfs2_dx_dir_search,
  1724. TP_PROTO(unsigned long long ino, int namelen, const char *name,
  1725. unsigned int major_hash, unsigned int minor_hash,
  1726. unsigned long long blkno),
  1727. TP_ARGS(ino, namelen, name, major_hash, minor_hash, blkno),
  1728. TP_STRUCT__entry(
  1729. __field(unsigned long long, ino)
  1730. __field(int, namelen)
  1731. __string(name, name)
  1732. __field(unsigned int, major_hash)
  1733. __field(unsigned int,minor_hash)
  1734. __field(unsigned long long, blkno)
  1735. ),
  1736. TP_fast_assign(
  1737. __entry->ino = ino;
  1738. __entry->namelen = namelen;
  1739. __assign_str(name, name);
  1740. __entry->major_hash = major_hash;
  1741. __entry->minor_hash = minor_hash;
  1742. __entry->blkno = blkno;
  1743. ),
  1744. TP_printk("%llu %.*s %u %u %llu", __entry->ino,
  1745. __entry->namelen, __get_str(name),
  1746. __entry->major_hash, __entry->minor_hash, __entry->blkno)
  1747. );
  1748. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_dx_dir_search_leaf_info);
  1749. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_delete_entry_dx);
  1750. DEFINE_OCFS2_ULL_EVENT(ocfs2_readdir);
  1751. TRACE_EVENT(ocfs2_find_files_on_disk,
  1752. TP_PROTO(int namelen, const char *name, void *blkno,
  1753. unsigned long long dir),
  1754. TP_ARGS(namelen, name, blkno, dir),
  1755. TP_STRUCT__entry(
  1756. __field(int, namelen)
  1757. __string(name, name)
  1758. __field(void *, blkno)
  1759. __field(unsigned long long, dir)
  1760. ),
  1761. TP_fast_assign(
  1762. __entry->namelen = namelen;
  1763. __assign_str(name, name);
  1764. __entry->blkno = blkno;
  1765. __entry->dir = dir;
  1766. ),
  1767. TP_printk("%.*s %p %llu", __entry->namelen, __get_str(name),
  1768. __entry->blkno, __entry->dir)
  1769. );
  1770. TRACE_EVENT(ocfs2_check_dir_for_entry,
  1771. TP_PROTO(unsigned long long dir, int namelen, const char *name),
  1772. TP_ARGS(dir, namelen, name),
  1773. TP_STRUCT__entry(
  1774. __field(unsigned long long, dir)
  1775. __field(int, namelen)
  1776. __string(name, name)
  1777. ),
  1778. TP_fast_assign(
  1779. __entry->dir = dir;
  1780. __entry->namelen = namelen;
  1781. __assign_str(name, name);
  1782. ),
  1783. TP_printk("%llu %.*s", __entry->dir,
  1784. __entry->namelen, __get_str(name))
  1785. );
  1786. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_dx_dir_attach_index);
  1787. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_dx_dir_format_cluster);
  1788. TRACE_EVENT(ocfs2_dx_dir_index_root_block,
  1789. TP_PROTO(unsigned long long dir,
  1790. unsigned int major_hash, unsigned int minor_hash,
  1791. int namelen, const char *name, unsigned int num_used),
  1792. TP_ARGS(dir, major_hash, minor_hash, namelen, name, num_used),
  1793. TP_STRUCT__entry(
  1794. __field(unsigned long long, dir)
  1795. __field(unsigned int, major_hash)
  1796. __field(unsigned int, minor_hash)
  1797. __field(int, namelen)
  1798. __string(name, name)
  1799. __field(unsigned int, num_used)
  1800. ),
  1801. TP_fast_assign(
  1802. __entry->dir = dir;
  1803. __entry->major_hash = major_hash;
  1804. __entry->minor_hash = minor_hash;
  1805. __entry->namelen = namelen;
  1806. __assign_str(name, name);
  1807. __entry->num_used = num_used;
  1808. ),
  1809. TP_printk("%llu %x %x %.*s %u", __entry->dir,
  1810. __entry->major_hash, __entry->minor_hash,
  1811. __entry->namelen, __get_str(name), __entry->num_used)
  1812. );
  1813. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_extend_dir);
  1814. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_dx_dir_rebalance);
  1815. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_dx_dir_rebalance_split);
  1816. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_prepare_dir_for_insert);
  1817. /* End of trace events for fs/ocfs2/dir.c. */
  1818. /* Trace events for fs/ocfs2/namei.c. */
  1819. DECLARE_EVENT_CLASS(ocfs2__dentry_ops,
  1820. TP_PROTO(void *dir, void *dentry, int name_len, const char *name,
  1821. unsigned long long dir_blkno, unsigned long long extra),
  1822. TP_ARGS(dir, dentry, name_len, name, dir_blkno, extra),
  1823. TP_STRUCT__entry(
  1824. __field(void *, dir)
  1825. __field(void *, dentry)
  1826. __field(int, name_len)
  1827. __string(name, name)
  1828. __field(unsigned long long, dir_blkno)
  1829. __field(unsigned long long, extra)
  1830. ),
  1831. TP_fast_assign(
  1832. __entry->dir = dir;
  1833. __entry->dentry = dentry;
  1834. __entry->name_len = name_len;
  1835. __assign_str(name, name);
  1836. __entry->dir_blkno = dir_blkno;
  1837. __entry->extra = extra;
  1838. ),
  1839. TP_printk("%p %p %.*s %llu %llu", __entry->dir, __entry->dentry,
  1840. __entry->name_len, __get_str(name),
  1841. __entry->dir_blkno, __entry->extra)
  1842. );
  1843. #define DEFINE_OCFS2_DENTRY_OPS(name) \
  1844. DEFINE_EVENT(ocfs2__dentry_ops, name, \
  1845. TP_PROTO(void *dir, void *dentry, int name_len, const char *name, \
  1846. unsigned long long dir_blkno, unsigned long long extra), \
  1847. TP_ARGS(dir, dentry, name_len, name, dir_blkno, extra))
  1848. DEFINE_OCFS2_DENTRY_OPS(ocfs2_lookup);
  1849. DEFINE_OCFS2_DENTRY_OPS(ocfs2_mkdir);
  1850. DEFINE_OCFS2_DENTRY_OPS(ocfs2_create);
  1851. DEFINE_OCFS2_DENTRY_OPS(ocfs2_unlink);
  1852. DEFINE_OCFS2_DENTRY_OPS(ocfs2_symlink_create);
  1853. DEFINE_OCFS2_DENTRY_OPS(ocfs2_mv_orphaned_inode_to_new);
  1854. DEFINE_OCFS2_POINTER_EVENT(ocfs2_lookup_ret);
  1855. TRACE_EVENT(ocfs2_mknod,
  1856. TP_PROTO(void *dir, void *dentry, int name_len, const char *name,
  1857. unsigned long long dir_blkno, unsigned long dev, int mode),
  1858. TP_ARGS(dir, dentry, name_len, name, dir_blkno, dev, mode),
  1859. TP_STRUCT__entry(
  1860. __field(void *, dir)
  1861. __field(void *, dentry)
  1862. __field(int, name_len)
  1863. __string(name, name)
  1864. __field(unsigned long long, dir_blkno)
  1865. __field(unsigned long, dev)
  1866. __field(int, mode)
  1867. ),
  1868. TP_fast_assign(
  1869. __entry->dir = dir;
  1870. __entry->dentry = dentry;
  1871. __entry->name_len = name_len;
  1872. __assign_str(name, name);
  1873. __entry->dir_blkno = dir_blkno;
  1874. __entry->dev = dev;
  1875. __entry->mode = mode;
  1876. ),
  1877. TP_printk("%p %p %.*s %llu %lu %d", __entry->dir, __entry->dentry,
  1878. __entry->name_len, __get_str(name),
  1879. __entry->dir_blkno, __entry->dev, __entry->mode)
  1880. );
  1881. TRACE_EVENT(ocfs2_link,
  1882. TP_PROTO(unsigned long long ino, int old_len, const char *old_name,
  1883. int name_len, const char *name),
  1884. TP_ARGS(ino, old_len, old_name, name_len, name),
  1885. TP_STRUCT__entry(
  1886. __field(unsigned long long, ino)
  1887. __field(int, old_len)
  1888. __string(old_name, old_name)
  1889. __field(int, name_len)
  1890. __string(name, name)
  1891. ),
  1892. TP_fast_assign(
  1893. __entry->ino = ino;
  1894. __entry->old_len = old_len;
  1895. __assign_str(old_name, old_name);
  1896. __entry->name_len = name_len;
  1897. __assign_str(name, name);
  1898. ),
  1899. TP_printk("%llu %.*s %.*s", __entry->ino,
  1900. __entry->old_len, __get_str(old_name),
  1901. __entry->name_len, __get_str(name))
  1902. );
  1903. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_unlink_noent);
  1904. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_double_lock);
  1905. DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_double_lock_end);
  1906. TRACE_EVENT(ocfs2_rename,
  1907. TP_PROTO(void *old_dir, void *old_dentry,
  1908. void *new_dir, void *new_dentry,
  1909. int old_len, const char *old_name,
  1910. int new_len, const char *new_name),
  1911. TP_ARGS(old_dir, old_dentry, new_dir, new_dentry,
  1912. old_len, old_name, new_len, new_name),
  1913. TP_STRUCT__entry(
  1914. __field(void *, old_dir)
  1915. __field(void *, old_dentry)
  1916. __field(void *, new_dir)
  1917. __field(void *, new_dentry)
  1918. __field(int, old_len)
  1919. __string(old_name, old_name)
  1920. __field(int, new_len)
  1921. __string(new_name, new_name)
  1922. ),
  1923. TP_fast_assign(
  1924. __entry->old_dir = old_dir;
  1925. __entry->old_dentry = old_dentry;
  1926. __entry->new_dir = new_dir;
  1927. __entry->new_dentry = new_dentry;
  1928. __entry->old_len = old_len;
  1929. __assign_str(old_name, old_name);
  1930. __entry->new_len = new_len;
  1931. __assign_str(new_name, new_name);
  1932. ),
  1933. TP_printk("%p %p %p %p %.*s %.*s",
  1934. __entry->old_dir, __entry->old_dentry,
  1935. __entry->new_dir, __entry->new_dentry,
  1936. __entry->old_len, __get_str(old_name),
  1937. __entry->new_len, __get_str(new_name))
  1938. );
  1939. TRACE_EVENT(ocfs2_rename_target_exists,
  1940. TP_PROTO(int new_len, const char *new_name),
  1941. TP_ARGS(new_len, new_name),
  1942. TP_STRUCT__entry(
  1943. __field(int, new_len)
  1944. __string(new_name, new_name)
  1945. ),
  1946. TP_fast_assign(
  1947. __entry->new_len = new_len;
  1948. __assign_str(new_name, new_name);
  1949. ),
  1950. TP_printk("%.*s", __entry->new_len, __get_str(new_name))
  1951. );
  1952. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_rename_disagree);
  1953. TRACE_EVENT(ocfs2_rename_over_existing,
  1954. TP_PROTO(unsigned long long new_blkno, void *new_bh,
  1955. unsigned long long newdi_blkno),
  1956. TP_ARGS(new_blkno, new_bh, newdi_blkno),
  1957. TP_STRUCT__entry(
  1958. __field(unsigned long long, new_blkno)
  1959. __field(void *, new_bh)
  1960. __field(unsigned long long, newdi_blkno)
  1961. ),
  1962. TP_fast_assign(
  1963. __entry->new_blkno = new_blkno;
  1964. __entry->new_bh = new_bh;
  1965. __entry->newdi_blkno = newdi_blkno;
  1966. ),
  1967. TP_printk("%llu %p %llu", __entry->new_blkno, __entry->new_bh,
  1968. __entry->newdi_blkno)
  1969. );
  1970. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_create_symlink_data);
  1971. TRACE_EVENT(ocfs2_symlink_begin,
  1972. TP_PROTO(void *dir, void *dentry, const char *symname,
  1973. int len, const char *name),
  1974. TP_ARGS(dir, dentry, symname, len, name),
  1975. TP_STRUCT__entry(
  1976. __field(void *, dir)
  1977. __field(void *, dentry)
  1978. __field(const char *, symname)
  1979. __field(int, len)
  1980. __string(name, name)
  1981. ),
  1982. TP_fast_assign(
  1983. __entry->dir = dir;
  1984. __entry->dentry = dentry;
  1985. __entry->symname = symname;
  1986. __entry->len = len;
  1987. __assign_str(name, name);
  1988. ),
  1989. TP_printk("%p %p %s %.*s", __entry->dir, __entry->dentry,
  1990. __entry->symname, __entry->len, __get_str(name))
  1991. );
  1992. TRACE_EVENT(ocfs2_blkno_stringify,
  1993. TP_PROTO(unsigned long long blkno, const char *name, int namelen),
  1994. TP_ARGS(blkno, name, namelen),
  1995. TP_STRUCT__entry(
  1996. __field(unsigned long long, blkno)
  1997. __string(name, name)
  1998. __field(int, namelen)
  1999. ),
  2000. TP_fast_assign(
  2001. __entry->blkno = blkno;
  2002. __assign_str(name, name);
  2003. __entry->namelen = namelen;
  2004. ),
  2005. TP_printk("%llu %s %d", __entry->blkno, __get_str(name),
  2006. __entry->namelen)
  2007. );
  2008. DEFINE_OCFS2_ULL_EVENT(ocfs2_orphan_add_begin);
  2009. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_orphan_add_end);
  2010. TRACE_EVENT(ocfs2_orphan_del,
  2011. TP_PROTO(unsigned long long dir, const char *name, int namelen),
  2012. TP_ARGS(dir, name, namelen),
  2013. TP_STRUCT__entry(
  2014. __field(unsigned long long, dir)
  2015. __string(name, name)
  2016. __field(int, namelen)
  2017. ),
  2018. TP_fast_assign(
  2019. __entry->dir = dir;
  2020. __assign_str(name, name);
  2021. __entry->namelen = namelen;
  2022. ),
  2023. TP_printk("%llu %s %d", __entry->dir, __get_str(name),
  2024. __entry->namelen)
  2025. );
  2026. /* End of trace events for fs/ocfs2/namei.c. */
  2027. /* Trace events for fs/ocfs2/dcache.c. */
  2028. TRACE_EVENT(ocfs2_dentry_revalidate,
  2029. TP_PROTO(void *dentry, int len, const char *name),
  2030. TP_ARGS(dentry, len, name),
  2031. TP_STRUCT__entry(
  2032. __field(void *, dentry)
  2033. __field(int, len)
  2034. __string(name, name)
  2035. ),
  2036. TP_fast_assign(
  2037. __entry->dentry = dentry;
  2038. __entry->len = len;
  2039. __assign_str(name, name);
  2040. ),
  2041. TP_printk("%p %.*s", __entry->dentry, __entry->len, __get_str(name))
  2042. );
  2043. TRACE_EVENT(ocfs2_dentry_revalidate_negative,
  2044. TP_PROTO(int len, const char *name, unsigned long pgen,
  2045. unsigned long gen),
  2046. TP_ARGS(len, name, pgen, gen),
  2047. TP_STRUCT__entry(
  2048. __field(int, len)
  2049. __string(name, name)
  2050. __field(unsigned long, pgen)
  2051. __field(unsigned long, gen)
  2052. ),
  2053. TP_fast_assign(
  2054. __entry->len = len;
  2055. __assign_str(name, name);
  2056. __entry->pgen = pgen;
  2057. __entry->gen = gen;
  2058. ),
  2059. TP_printk("%.*s %lu %lu", __entry->len, __get_str(name),
  2060. __entry->pgen, __entry->gen)
  2061. );
  2062. DEFINE_OCFS2_ULL_EVENT(ocfs2_dentry_revalidate_delete);
  2063. DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_dentry_revalidate_orphaned);
  2064. DEFINE_OCFS2_ULL_EVENT(ocfs2_dentry_revalidate_nofsdata);
  2065. DEFINE_OCFS2_INT_EVENT(ocfs2_dentry_revalidate_ret);
  2066. TRACE_EVENT(ocfs2_find_local_alias,
  2067. TP_PROTO(int len, const char *name),
  2068. TP_ARGS(len, name),
  2069. TP_STRUCT__entry(
  2070. __field(int, len)
  2071. __string(name, name)
  2072. ),
  2073. TP_fast_assign(
  2074. __entry->len = len;
  2075. __assign_str(name, name);
  2076. ),
  2077. TP_printk("%.*s", __entry->len, __get_str(name))
  2078. );
  2079. TRACE_EVENT(ocfs2_dentry_attach_lock,
  2080. TP_PROTO(int len, const char *name,
  2081. unsigned long long parent, void *fsdata),
  2082. TP_ARGS(len, name, parent, fsdata),
  2083. TP_STRUCT__entry(
  2084. __field(int, len)
  2085. __string(name, name)
  2086. __field(unsigned long long, parent)
  2087. __field(void *, fsdata)
  2088. ),
  2089. TP_fast_assign(
  2090. __entry->len = len;
  2091. __assign_str(name, name);
  2092. __entry->parent = parent;
  2093. __entry->fsdata = fsdata;
  2094. ),
  2095. TP_printk("%.*s %llu %p", __entry->len, __get_str(name),
  2096. __entry->parent, __entry->fsdata)
  2097. );
  2098. TRACE_EVENT(ocfs2_dentry_attach_lock_found,
  2099. TP_PROTO(const char *name, unsigned long long parent,
  2100. unsigned long long ino),
  2101. TP_ARGS(name, parent, ino),
  2102. TP_STRUCT__entry(
  2103. __string(name, name)
  2104. __field(unsigned long long, parent)
  2105. __field(unsigned long long, ino)
  2106. ),
  2107. TP_fast_assign(
  2108. __assign_str(name, name);
  2109. __entry->parent = parent;
  2110. __entry->ino = ino;
  2111. ),
  2112. TP_printk("%s %llu %llu", __get_str(name), __entry->parent, __entry->ino)
  2113. );
  2114. /* End of trace events for fs/ocfs2/dcache.c. */
  2115. /* Trace events for fs/ocfs2/export.c. */
  2116. TRACE_EVENT(ocfs2_get_dentry_begin,
  2117. TP_PROTO(void *sb, void *handle, unsigned long long blkno),
  2118. TP_ARGS(sb, handle, blkno),
  2119. TP_STRUCT__entry(
  2120. __field(void *, sb)
  2121. __field(void *, handle)
  2122. __field(unsigned long long, blkno)
  2123. ),
  2124. TP_fast_assign(
  2125. __entry->sb = sb;
  2126. __entry->handle = handle;
  2127. __entry->blkno = blkno;
  2128. ),
  2129. TP_printk("%p %p %llu", __entry->sb, __entry->handle, __entry->blkno)
  2130. );
  2131. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_get_dentry_test_bit);
  2132. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_get_dentry_stale);
  2133. DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_get_dentry_generation);
  2134. DEFINE_OCFS2_POINTER_EVENT(ocfs2_get_dentry_end);
  2135. TRACE_EVENT(ocfs2_get_parent,
  2136. TP_PROTO(void *child, int len, const char *name,
  2137. unsigned long long ino),
  2138. TP_ARGS(child, len, name, ino),
  2139. TP_STRUCT__entry(
  2140. __field(void *, child)
  2141. __field(int, len)
  2142. __string(name, name)
  2143. __field(unsigned long long, ino)
  2144. ),
  2145. TP_fast_assign(
  2146. __entry->child = child;
  2147. __entry->len = len;
  2148. __assign_str(name, name);
  2149. __entry->ino = ino;
  2150. ),
  2151. TP_printk("%p %.*s %llu", __entry->child, __entry->len,
  2152. __get_str(name), __entry->ino)
  2153. );
  2154. DEFINE_OCFS2_POINTER_EVENT(ocfs2_get_parent_end);
  2155. TRACE_EVENT(ocfs2_encode_fh_begin,
  2156. TP_PROTO(void *dentry, int name_len, const char *name,
  2157. void *fh, int len, int connectable),
  2158. TP_ARGS(dentry, name_len, name, fh, len, connectable),
  2159. TP_STRUCT__entry(
  2160. __field(void *, dentry)
  2161. __field(int, name_len)
  2162. __string(name, name)
  2163. __field(void *, fh)
  2164. __field(int, len)
  2165. __field(int, connectable)
  2166. ),
  2167. TP_fast_assign(
  2168. __entry->dentry = dentry;
  2169. __entry->name_len = name_len;
  2170. __assign_str(name, name);
  2171. __entry->fh = fh;
  2172. __entry->len = len;
  2173. __entry->connectable = connectable;
  2174. ),
  2175. TP_printk("%p %.*s %p %d %d", __entry->dentry, __entry->name_len,
  2176. __get_str(name), __entry->fh, __entry->len,
  2177. __entry->connectable)
  2178. );
  2179. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_encode_fh_self);
  2180. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_encode_fh_parent);
  2181. DEFINE_OCFS2_INT_EVENT(ocfs2_encode_fh_type);
  2182. /* End of trace events for fs/ocfs2/export.c. */
  2183. /* Trace events for fs/ocfs2/journal.c. */
  2184. DEFINE_OCFS2_UINT_EVENT(ocfs2_commit_cache_begin);
  2185. DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_commit_cache_end);
  2186. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_extend_trans);
  2187. DEFINE_OCFS2_INT_EVENT(ocfs2_extend_trans_restart);
  2188. DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(ocfs2_journal_access);
  2189. DEFINE_OCFS2_ULL_EVENT(ocfs2_journal_dirty);
  2190. DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_journal_init);
  2191. DEFINE_OCFS2_UINT_EVENT(ocfs2_journal_init_maxlen);
  2192. DEFINE_OCFS2_INT_EVENT(ocfs2_journal_shutdown);
  2193. DEFINE_OCFS2_POINTER_EVENT(ocfs2_journal_shutdown_wait);
  2194. DEFINE_OCFS2_ULL_EVENT(ocfs2_complete_recovery);
  2195. DEFINE_OCFS2_INT_EVENT(ocfs2_complete_recovery_end);
  2196. TRACE_EVENT(ocfs2_complete_recovery_slot,
  2197. TP_PROTO(int slot, unsigned long long la_ino,
  2198. unsigned long long tl_ino, void *qrec),
  2199. TP_ARGS(slot, la_ino, tl_ino, qrec),
  2200. TP_STRUCT__entry(
  2201. __field(int, slot)
  2202. __field(unsigned long long, la_ino)
  2203. __field(unsigned long long, tl_ino)
  2204. __field(void *, qrec)
  2205. ),
  2206. TP_fast_assign(
  2207. __entry->slot = slot;
  2208. __entry->la_ino = la_ino;
  2209. __entry->tl_ino = tl_ino;
  2210. __entry->qrec = qrec;
  2211. ),
  2212. TP_printk("%d %llu %llu %p", __entry->slot, __entry->la_ino,
  2213. __entry->tl_ino, __entry->qrec)
  2214. );
  2215. DEFINE_OCFS2_INT_INT_EVENT(ocfs2_recovery_thread_node);
  2216. DEFINE_OCFS2_INT_EVENT(ocfs2_recovery_thread_end);
  2217. TRACE_EVENT(ocfs2_recovery_thread,
  2218. TP_PROTO(int node_num, int osb_node_num, int disable,
  2219. void *recovery_thread, int map_set),
  2220. TP_ARGS(node_num, osb_node_num, disable, recovery_thread, map_set),
  2221. TP_STRUCT__entry(
  2222. __field(int, node_num)
  2223. __field(int, osb_node_num)
  2224. __field(int,disable)
  2225. __field(void *, recovery_thread)
  2226. __field(int,map_set)
  2227. ),
  2228. TP_fast_assign(
  2229. __entry->node_num = node_num;
  2230. __entry->osb_node_num = osb_node_num;
  2231. __entry->disable = disable;
  2232. __entry->recovery_thread = recovery_thread;
  2233. __entry->map_set = map_set;
  2234. ),
  2235. TP_printk("%d %d %d %p %d", __entry->node_num,
  2236. __entry->osb_node_num, __entry->disable,
  2237. __entry->recovery_thread, __entry->map_set)
  2238. );
  2239. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_replay_journal_recovered);
  2240. DEFINE_OCFS2_INT_EVENT(ocfs2_replay_journal_lock_err);
  2241. DEFINE_OCFS2_INT_EVENT(ocfs2_replay_journal_skip);
  2242. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_recover_node);
  2243. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_recover_node_skip);
  2244. DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_mark_dead_nodes);
  2245. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_queue_orphan_scan_begin);
  2246. DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_queue_orphan_scan_end);
  2247. DEFINE_OCFS2_ULL_EVENT(ocfs2_orphan_filldir);
  2248. DEFINE_OCFS2_INT_EVENT(ocfs2_recover_orphans);
  2249. DEFINE_OCFS2_ULL_EVENT(ocfs2_recover_orphans_iput);
  2250. DEFINE_OCFS2_INT_EVENT(ocfs2_wait_on_mount);
  2251. /* End of trace events for fs/ocfs2/journal.c. */
  2252. #endif /* _TRACE_OCFS2_H */
  2253. /* This part must be outside protection */
  2254. #undef TRACE_INCLUDE_PATH
  2255. #define TRACE_INCLUDE_PATH .
  2256. #define TRACE_INCLUDE_FILE ocfs2_trace
  2257. #include <trace/define_trace.h>