pagemap.h 2.1 KB

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