migrate.h 1.9 KB

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