migrate.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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_CMA, "cma"}
  17. TRACE_EVENT(mm_migrate_pages,
  18. TP_PROTO(unsigned long succeeded, unsigned long failed,
  19. enum migrate_mode mode, int reason),
  20. TP_ARGS(succeeded, failed, mode, reason),
  21. TP_STRUCT__entry(
  22. __field( unsigned long, succeeded)
  23. __field( unsigned long, failed)
  24. __field( enum migrate_mode, mode)
  25. __field( int, reason)
  26. ),
  27. TP_fast_assign(
  28. __entry->succeeded = succeeded;
  29. __entry->failed = failed;
  30. __entry->mode = mode;
  31. __entry->reason = reason;
  32. ),
  33. TP_printk("nr_succeeded=%lu nr_failed=%lu mode=%s reason=%s",
  34. __entry->succeeded,
  35. __entry->failed,
  36. __print_symbolic(__entry->mode, MIGRATE_MODE),
  37. __print_symbolic(__entry->reason, MIGRATE_REASON))
  38. );
  39. TRACE_EVENT(mm_numa_migrate_ratelimit,
  40. TP_PROTO(struct task_struct *p, int dst_nid, unsigned long nr_pages),
  41. TP_ARGS(p, dst_nid, nr_pages),
  42. TP_STRUCT__entry(
  43. __array( char, comm, TASK_COMM_LEN)
  44. __field( pid_t, pid)
  45. __field( int, dst_nid)
  46. __field( unsigned long, nr_pages)
  47. ),
  48. TP_fast_assign(
  49. memcpy(__entry->comm, p->comm, TASK_COMM_LEN);
  50. __entry->pid = p->pid;
  51. __entry->dst_nid = dst_nid;
  52. __entry->nr_pages = nr_pages;
  53. ),
  54. TP_printk("comm=%s pid=%d dst_nid=%d nr_pages=%lu",
  55. __entry->comm,
  56. __entry->pid,
  57. __entry->dst_nid,
  58. __entry->nr_pages)
  59. );
  60. #endif /* _TRACE_MIGRATE_H */
  61. /* This part must be outside protection */
  62. #include <trace/define_trace.h>