SanCov.cpp 910 B

12345678910111213141516171819202122232425262728293031323334353637
  1. /*
  2. * Copyright (c) 2021, Patrick Meyer <git@the-space.agency>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <Kernel/Devices/KCOVDevice.h>
  7. #include <Kernel/Thread.h>
  8. extern bool g_in_early_boot;
  9. extern "C" {
  10. void __sanitizer_cov_trace_pc(void);
  11. void __sanitizer_cov_trace_pc(void)
  12. {
  13. if (g_in_early_boot) [[unlikely]]
  14. return;
  15. if (Processor::current_in_irq()) [[unlikely]] {
  16. // Do not trace in interrupts.
  17. return;
  18. }
  19. auto thread = Thread::current();
  20. auto tid = thread->tid();
  21. auto maybe_kcov_instance = KCOVDevice::thread_instance->get(tid);
  22. if (!maybe_kcov_instance.has_value()) [[likely]] {
  23. // not traced
  24. return;
  25. }
  26. auto kcov_instance = maybe_kcov_instance.value();
  27. if (kcov_instance->state < KCOVInstance::TRACING) [[likely]]
  28. return;
  29. kcov_instance->buffer_add_pc((u64)__builtin_return_address(0));
  30. }
  31. }