trace.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /* Copyright 2022 NXP
  3. */
  4. #undef TRACE_SYSTEM
  5. #define TRACE_SYSTEM mv88e6xxx
  6. #if !defined(_MV88E6XXX_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
  7. #define _MV88E6XXX_TRACE_H
  8. #include <linux/device.h>
  9. #include <linux/if_ether.h>
  10. #include <linux/tracepoint.h>
  11. DECLARE_EVENT_CLASS(mv88e6xxx_atu_violation,
  12. TP_PROTO(const struct device *dev, int spid, u16 portvec,
  13. const unsigned char *addr, u16 fid),
  14. TP_ARGS(dev, spid, portvec, addr, fid),
  15. TP_STRUCT__entry(
  16. __string(name, dev_name(dev))
  17. __field(int, spid)
  18. __field(u16, portvec)
  19. __array(unsigned char, addr, ETH_ALEN)
  20. __field(u16, fid)
  21. ),
  22. TP_fast_assign(
  23. __assign_str(name, dev_name(dev));
  24. __entry->spid = spid;
  25. __entry->portvec = portvec;
  26. memcpy(__entry->addr, addr, ETH_ALEN);
  27. __entry->fid = fid;
  28. ),
  29. TP_printk("dev %s spid %d portvec 0x%x addr %pM fid %u",
  30. __get_str(name), __entry->spid, __entry->portvec,
  31. __entry->addr, __entry->fid)
  32. );
  33. DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_member_violation,
  34. TP_PROTO(const struct device *dev, int spid, u16 portvec,
  35. const unsigned char *addr, u16 fid),
  36. TP_ARGS(dev, spid, portvec, addr, fid));
  37. DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_miss_violation,
  38. TP_PROTO(const struct device *dev, int spid, u16 portvec,
  39. const unsigned char *addr, u16 fid),
  40. TP_ARGS(dev, spid, portvec, addr, fid));
  41. DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_full_violation,
  42. TP_PROTO(const struct device *dev, int spid, u16 portvec,
  43. const unsigned char *addr, u16 fid),
  44. TP_ARGS(dev, spid, portvec, addr, fid));
  45. DECLARE_EVENT_CLASS(mv88e6xxx_vtu_violation,
  46. TP_PROTO(const struct device *dev, int spid, u16 vid),
  47. TP_ARGS(dev, spid, vid),
  48. TP_STRUCT__entry(
  49. __string(name, dev_name(dev))
  50. __field(int, spid)
  51. __field(u16, vid)
  52. ),
  53. TP_fast_assign(
  54. __assign_str(name, dev_name(dev));
  55. __entry->spid = spid;
  56. __entry->vid = vid;
  57. ),
  58. TP_printk("dev %s spid %d vid %u",
  59. __get_str(name), __entry->spid, __entry->vid)
  60. );
  61. DEFINE_EVENT(mv88e6xxx_vtu_violation, mv88e6xxx_vtu_member_violation,
  62. TP_PROTO(const struct device *dev, int spid, u16 vid),
  63. TP_ARGS(dev, spid, vid));
  64. DEFINE_EVENT(mv88e6xxx_vtu_violation, mv88e6xxx_vtu_miss_violation,
  65. TP_PROTO(const struct device *dev, int spid, u16 vid),
  66. TP_ARGS(dev, spid, vid));
  67. #endif /* _MV88E6XXX_TRACE_H */
  68. /* We don't want to use include/trace/events */
  69. #undef TRACE_INCLUDE_PATH
  70. #define TRACE_INCLUDE_PATH .
  71. #undef TRACE_INCLUDE_FILE
  72. #define TRACE_INCLUDE_FILE trace
  73. /* This part must be outside protection */
  74. #include <trace/define_trace.h>