trace_readwrite.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Register read and write tracepoints
  4. *
  5. * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
  6. */
  7. #include <linux/ftrace.h>
  8. #include <linux/module.h>
  9. #include <asm-generic/io.h>
  10. #define CREATE_TRACE_POINTS
  11. #include <trace/events/rwmmio.h>
  12. #ifdef CONFIG_TRACE_MMIO_ACCESS
  13. void log_write_mmio(u64 val, u8 width, volatile void __iomem *addr,
  14. unsigned long caller_addr, unsigned long caller_addr0)
  15. {
  16. trace_rwmmio_write(caller_addr, caller_addr0, val, width, addr);
  17. }
  18. EXPORT_SYMBOL_GPL(log_write_mmio);
  19. EXPORT_TRACEPOINT_SYMBOL_GPL(rwmmio_write);
  20. void log_post_write_mmio(u64 val, u8 width, volatile void __iomem *addr,
  21. unsigned long caller_addr, unsigned long caller_addr0)
  22. {
  23. trace_rwmmio_post_write(caller_addr, caller_addr0, val, width, addr);
  24. }
  25. EXPORT_SYMBOL_GPL(log_post_write_mmio);
  26. EXPORT_TRACEPOINT_SYMBOL_GPL(rwmmio_post_write);
  27. void log_read_mmio(u8 width, const volatile void __iomem *addr,
  28. unsigned long caller_addr, unsigned long caller_addr0)
  29. {
  30. trace_rwmmio_read(caller_addr, caller_addr0, width, addr);
  31. }
  32. EXPORT_SYMBOL_GPL(log_read_mmio);
  33. EXPORT_TRACEPOINT_SYMBOL_GPL(rwmmio_read);
  34. void log_post_read_mmio(u64 val, u8 width, const volatile void __iomem *addr,
  35. unsigned long caller_addr, unsigned long caller_addr0)
  36. {
  37. trace_rwmmio_post_read(caller_addr, caller_addr0, val, width, addr);
  38. }
  39. EXPORT_SYMBOL_GPL(log_post_read_mmio);
  40. EXPORT_TRACEPOINT_SYMBOL_GPL(rwmmio_post_read);
  41. #endif /* CONFIG_TRACE_MMIO_ACCESS */