migrate.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM migrate
  3. #if !defined(_TRACE_MIGRATE_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_MIGRATE_H
  5. #include <linux/tracepoint.h>
  6. #define MIGRATE_MODE \
  7. {MIGRATE_ASYNC, "MIGRATE_ASYNC"}, \
  8. {MIGRATE_SYNC_LIGHT, "MIGRATE_SYNC_LIGHT"}, \
  9. {MIGRATE_SYNC, "MIGRATE_SYNC"}
  10. #define MIGRATE_REASON \
  11. {MR_COMPACTION, "compaction"}, \
  12. {MR_MEMORY_FAILURE, "memory_failure"}, \
  13. {MR_MEMORY_HOTPLUG, "memory_hotplug"}, \
  14. {MR_SYSCALL, "syscall_or_cpuset"}, \
  15. {MR_MEMPOLICY_MBIND, "mempolicy_mbind"}, \
  16. {MR_NUMA_MISPLACED, "numa_misplaced"}, \
  17. {MR_CMA, "cma"}
  18. TRACE_EVENT(mm_migrate_pages,
  19. TP_PROTO(unsigned long succeeded, unsigned long failed,
  20. enum migrate_mode mode, int reason),
  21. TP_ARGS(succeeded, failed, mode, reason),
  22. TP_STRUCT__entry(
  23. __field( unsigned long, succeeded)
  24. __field( unsigned long, failed)
  25. __field( enum migrate_mode, mode)
  26. __field( int, reason)
  27. ),
  28. TP_fast_assign(
  29. __entry->succeeded = succeeded;
  30. __entry->failed = failed;
  31. __entry->mode = mode;
  32. __entry->reason = reason;
  33. ),
  34. TP_printk("nr_succeeded=%lu nr_failed=%lu mode=%s reason=%s",
  35. __entry->succeeded,
  36. __entry->failed,
  37. __print_symbolic(__entry->mode, MIGRATE_MODE),
  38. __print_symbolic(__entry->reason, MIGRATE_REASON))
  39. );
  40. TRACE_EVENT(mm_numa_migrate_ratelimit,
  41. TP_PROTO(struct task_struct *p, int dst_nid, unsigned long nr_pages),
  42. TP_ARGS(p, dst_nid, nr_pages),
  43. TP_STRUCT__entry(
  44. __array( char, comm, TASK_COMM_LEN)
  45. __field( pid_t, pid)
  46. __field( int, dst_nid)
  47. __field( unsigned long, nr_pages)
  48. ),
  49. TP_fast_assign(
  50. memcpy(__entry->comm, p->comm, TASK_COMM_LEN);
  51. __entry->pid = p->pid;
  52. __entry->dst_nid = dst_nid;
  53. __entry->nr_pages = nr_pages;
  54. ),
  55. TP_printk("comm=%s pid=%d dst_nid=%d nr_pages=%lu",
  56. __entry->comm,
  57. __entry->pid,
  58. __entry->dst_nid,
  59. __entry->nr_pages)
  60. );
  61. #endif /* _TRACE_MIGRATE_H */
  62. /* This part must be outside protection */
  63. #include <trace/define_trace.h>