msm_show_epoch.c 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  4. */
  5. #include <linux/module.h>
  6. #include <trace/hooks/epoch.h>
  7. static u64 suspend_ns;
  8. static u64 suspend_cycles;
  9. static u64 resume_cycles;
  10. static void msm_show_suspend_epoch_val(void *data, u64 ns, u64 cycles)
  11. {
  12. suspend_ns = ns;
  13. suspend_cycles = cycles;
  14. pr_info("suspend ns:%17llu suspend cycles:%17llu\n",
  15. suspend_ns, suspend_cycles);
  16. }
  17. static void msm_show_resume_epoch_val(void *data, u64 cycles)
  18. {
  19. resume_cycles = cycles;
  20. pr_info("resume cycles:%17llu\n", resume_cycles);
  21. }
  22. static int __init msm_show_epoch_init(void)
  23. {
  24. register_trace_android_vh_show_suspend_epoch_val(
  25. msm_show_suspend_epoch_val, NULL);
  26. register_trace_android_vh_show_resume_epoch_val(
  27. msm_show_resume_epoch_val, NULL);
  28. return 0;
  29. }
  30. #if IS_MODULE(CONFIG_SHOW_SUSPEND_EPOCH)
  31. module_init(msm_show_epoch_init);
  32. #else
  33. pure_initcall(msm_show_epoch_init);
  34. #endif
  35. MODULE_DESCRIPTION("Qualcomm Technologies, Inc. show epoch values driver");
  36. MODULE_LICENSE("GPL");