debug.cpp 1006 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /*
  2. * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <Kernel/IO.h>
  7. #include <Kernel/KSyms.h>
  8. #include <Kernel/Process.h>
  9. #include <Kernel/UserOrKernelBuffer.h>
  10. namespace Kernel {
  11. KResultOr<int> Process::sys$dump_backtrace()
  12. {
  13. dump_backtrace();
  14. return 0;
  15. }
  16. KResultOr<int> Process::sys$dbgputch(u8 ch)
  17. {
  18. IO::out8(IO::BOCHS_DEBUG_PORT, ch);
  19. return 0;
  20. }
  21. KResultOr<size_t> Process::sys$dbgputstr(Userspace<const u8*> characters, size_t size)
  22. {
  23. if (size <= 0)
  24. return 0;
  25. if (size > NumericLimits<ssize_t>::max())
  26. return EINVAL;
  27. auto buffer = UserOrKernelBuffer::for_user_buffer(characters, size);
  28. if (!buffer.has_value())
  29. return EFAULT;
  30. return buffer.value().read_buffered<1024>(size, [&](u8 const* buffer, size_t buffer_size) {
  31. for (size_t i = 0; i < buffer_size; ++i)
  32. IO::out8(IO::BOCHS_DEBUG_PORT, buffer[i]);
  33. return buffer_size;
  34. });
  35. }
  36. }