mmap.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #undef TRACE_SYSTEM
  3. #define TRACE_SYSTEM mmap
  4. #if !defined(_TRACE_MMAP_H) || defined(TRACE_HEADER_MULTI_READ)
  5. #define _TRACE_MMAP_H
  6. #include <linux/tracepoint.h>
  7. TRACE_EVENT(vm_unmapped_area,
  8. TP_PROTO(unsigned long addr, struct vm_unmapped_area_info *info),
  9. TP_ARGS(addr, info),
  10. TP_STRUCT__entry(
  11. __field(unsigned long, addr)
  12. __field(unsigned long, total_vm)
  13. __field(unsigned long, flags)
  14. __field(unsigned long, length)
  15. __field(unsigned long, low_limit)
  16. __field(unsigned long, high_limit)
  17. __field(unsigned long, align_mask)
  18. __field(unsigned long, align_offset)
  19. ),
  20. TP_fast_assign(
  21. __entry->addr = addr;
  22. __entry->total_vm = current->mm->total_vm;
  23. __entry->flags = info->flags;
  24. __entry->length = info->length;
  25. __entry->low_limit = info->low_limit;
  26. __entry->high_limit = info->high_limit;
  27. __entry->align_mask = info->align_mask;
  28. __entry->align_offset = info->align_offset;
  29. ),
  30. TP_printk("addr=0x%lx err=%ld total_vm=0x%lx flags=0x%lx len=0x%lx lo=0x%lx hi=0x%lx mask=0x%lx ofs=0x%lx\n",
  31. IS_ERR_VALUE(__entry->addr) ? 0 : __entry->addr,
  32. IS_ERR_VALUE(__entry->addr) ? __entry->addr : 0,
  33. __entry->total_vm, __entry->flags, __entry->length,
  34. __entry->low_limit, __entry->high_limit, __entry->align_mask,
  35. __entry->align_offset)
  36. );
  37. TRACE_EVENT(vma_mas_szero,
  38. TP_PROTO(struct maple_tree *mt, unsigned long start,
  39. unsigned long end),
  40. TP_ARGS(mt, start, end),
  41. TP_STRUCT__entry(
  42. __field(struct maple_tree *, mt)
  43. __field(unsigned long, start)
  44. __field(unsigned long, end)
  45. ),
  46. TP_fast_assign(
  47. __entry->mt = mt;
  48. __entry->start = start;
  49. __entry->end = end;
  50. ),
  51. TP_printk("mt_mod %p, (NULL), SNULL, %lu, %lu,",
  52. __entry->mt,
  53. (unsigned long) __entry->start,
  54. (unsigned long) __entry->end
  55. )
  56. );
  57. TRACE_EVENT(vma_store,
  58. TP_PROTO(struct maple_tree *mt, struct vm_area_struct *vma),
  59. TP_ARGS(mt, vma),
  60. TP_STRUCT__entry(
  61. __field(struct maple_tree *, mt)
  62. __field(struct vm_area_struct *, vma)
  63. __field(unsigned long, vm_start)
  64. __field(unsigned long, vm_end)
  65. ),
  66. TP_fast_assign(
  67. __entry->mt = mt;
  68. __entry->vma = vma;
  69. __entry->vm_start = vma->vm_start;
  70. __entry->vm_end = vma->vm_end - 1;
  71. ),
  72. TP_printk("mt_mod %p, (%p), STORE, %lu, %lu,",
  73. __entry->mt, __entry->vma,
  74. (unsigned long) __entry->vm_start,
  75. (unsigned long) __entry->vm_end
  76. )
  77. );
  78. TRACE_EVENT(exit_mmap,
  79. TP_PROTO(struct mm_struct *mm),
  80. TP_ARGS(mm),
  81. TP_STRUCT__entry(
  82. __field(struct mm_struct *, mm)
  83. __field(struct maple_tree *, mt)
  84. ),
  85. TP_fast_assign(
  86. __entry->mm = mm;
  87. __entry->mt = &mm->mm_mt;
  88. ),
  89. TP_printk("mt_mod %p, DESTROY\n",
  90. __entry->mt
  91. )
  92. );
  93. #endif
  94. /* This part must be outside protection */
  95. #include <trace/define_trace.h>