debug.cpp 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <Kernel/KSyms.h>
  7. #include <Kernel/Process.h>
  8. #include <Kernel/UserOrKernelBuffer.h>
  9. #include <Kernel/kstdio.h>
  10. namespace Kernel {
  11. KResultOr<FlatPtr> Process::sys$dump_backtrace()
  12. {
  13. VERIFY_NO_PROCESS_BIG_LOCK(this);
  14. dump_backtrace();
  15. return 0;
  16. }
  17. KResultOr<FlatPtr> Process::sys$dbgputch(u8 ch)
  18. {
  19. VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this);
  20. dbgputch(ch);
  21. return 0;
  22. }
  23. KResultOr<FlatPtr> Process::sys$dbgputstr(Userspace<const u8*> characters, size_t size)
  24. {
  25. VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this);
  26. if (size == 0)
  27. return 0;
  28. if (size <= 1024) {
  29. char buffer[1024];
  30. if (!copy_from_user(buffer, characters, size))
  31. return EFAULT;
  32. dbgputstr(buffer, size);
  33. return size;
  34. }
  35. auto result = try_copy_kstring_from_user(reinterpret_cast<char const*>(characters.unsafe_userspace_ptr()), size);
  36. if (result.is_error())
  37. return result.error();
  38. dbgputstr(result.value()->characters(), size);
  39. return size;
  40. }
  41. }