pagemap.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM pagemap
  3. #if !defined(_TRACE_PAGEMAP_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_PAGEMAP_H
  5. #include <linux/tracepoint.h>
  6. #include <linux/mm.h>
  7. #define PAGEMAP_MAPPED 0x0001u
  8. #define PAGEMAP_ANONYMOUS 0x0002u
  9. #define PAGEMAP_FILE 0x0004u
  10. #define PAGEMAP_SWAPCACHE 0x0008u
  11. #define PAGEMAP_SWAPBACKED 0x0010u
  12. #define PAGEMAP_MAPPEDDISK 0x0020u
  13. #define PAGEMAP_BUFFERS 0x0040u
  14. #define trace_pagemap_flags(page) ( \
  15. (PageAnon(page) ? PAGEMAP_ANONYMOUS : PAGEMAP_FILE) | \
  16. (page_mapped(page) ? PAGEMAP_MAPPED : 0) | \
  17. (PageSwapCache(page) ? PAGEMAP_SWAPCACHE : 0) | \
  18. (PageSwapBacked(page) ? PAGEMAP_SWAPBACKED : 0) | \
  19. (PageMappedToDisk(page) ? PAGEMAP_MAPPEDDISK : 0) | \
  20. (page_has_private(page) ? PAGEMAP_BUFFERS : 0) \
  21. )
  22. TRACE_EVENT(mm_lru_insertion,
  23. TP_PROTO(
  24. struct page *page,
  25. unsigned long pfn,
  26. int lru,
  27. unsigned long flags
  28. ),
  29. TP_ARGS(page, pfn, lru, flags),
  30. TP_STRUCT__entry(
  31. __field(struct page *, page )
  32. __field(unsigned long, pfn )
  33. __field(int, lru )
  34. __field(unsigned long, flags )
  35. ),
  36. TP_fast_assign(
  37. __entry->page = page;
  38. __entry->pfn = pfn;
  39. __entry->lru = lru;
  40. __entry->flags = flags;
  41. ),
  42. /* Flag format is based on page-types.c formatting for pagemap */
  43. TP_printk("page=%p pfn=%lu lru=%d flags=%s%s%s%s%s%s",
  44. __entry->page,
  45. __entry->pfn,
  46. __entry->lru,
  47. __entry->flags & PAGEMAP_MAPPED ? "M" : " ",
  48. __entry->flags & PAGEMAP_ANONYMOUS ? "a" : "f",
  49. __entry->flags & PAGEMAP_SWAPCACHE ? "s" : " ",
  50. __entry->flags & PAGEMAP_SWAPBACKED ? "b" : " ",
  51. __entry->flags & PAGEMAP_MAPPEDDISK ? "d" : " ",
  52. __entry->flags & PAGEMAP_BUFFERS ? "B" : " ")
  53. );
  54. TRACE_EVENT(mm_lru_activate,
  55. TP_PROTO(struct page *page, unsigned long pfn),
  56. TP_ARGS(page, pfn),
  57. TP_STRUCT__entry(
  58. __field(struct page *, page )
  59. __field(unsigned long, pfn )
  60. ),
  61. TP_fast_assign(
  62. __entry->page = page;
  63. __entry->pfn = pfn;
  64. ),
  65. /* Flag format is based on page-types.c formatting for pagemap */
  66. TP_printk("page=%p pfn=%lu", __entry->page, __entry->pfn)
  67. );
  68. #endif /* _TRACE_PAGEMAP_H */
  69. /* This part must be outside protection */
  70. #include <trace/define_trace.h>