BasicBlock.h 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Copyright (c) 2021, Andreas Kling <andreas@ladybird.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Badge.h>
  8. #include <AK/String.h>
  9. #include <LibGC/Root.h>
  10. #include <LibJS/Bytecode/Executable.h>
  11. #include <LibJS/Bytecode/ScopedOperand.h>
  12. #include <LibJS/Forward.h>
  13. namespace JS::Bytecode {
  14. struct UnwindInfo {
  15. GC::Ptr<Executable const> executable;
  16. GC::Ptr<Environment> lexical_environment;
  17. bool handler_called { false };
  18. };
  19. class BasicBlock {
  20. AK_MAKE_NONCOPYABLE(BasicBlock);
  21. public:
  22. static NonnullOwnPtr<BasicBlock> create(u32 index, String name);
  23. ~BasicBlock();
  24. u32 index() const { return m_index; }
  25. ReadonlyBytes instruction_stream() const { return m_buffer.span(); }
  26. u8* data() { return m_buffer.data(); }
  27. u8 const* data() const { return m_buffer.data(); }
  28. size_t size() const { return m_buffer.size(); }
  29. void rewind()
  30. {
  31. m_buffer.resize_and_keep_capacity(m_last_instruction_start_offset);
  32. m_terminated = false;
  33. }
  34. void grow(size_t additional_size);
  35. void terminate(Badge<Generator>) { m_terminated = true; }
  36. bool is_terminated() const { return m_terminated; }
  37. String const& name() const { return m_name; }
  38. void set_handler(BasicBlock const& handler) { m_handler = &handler; }
  39. void set_finalizer(BasicBlock const& finalizer) { m_finalizer = &finalizer; }
  40. BasicBlock const* handler() const { return m_handler; }
  41. BasicBlock const* finalizer() const { return m_finalizer; }
  42. auto const& source_map() const { return m_source_map; }
  43. void add_source_map_entry(size_t bytecode_offset, SourceRecord const& source_record) { m_source_map.set(bytecode_offset, source_record); }
  44. [[nodiscard]] bool has_resolved_this() const { return m_has_resolved_this; }
  45. void set_has_resolved_this() { m_has_resolved_this = true; }
  46. [[nodiscard]] size_t last_instruction_start_offset() const { return m_last_instruction_start_offset; }
  47. void set_last_instruction_start_offset(size_t offset) { m_last_instruction_start_offset = offset; }
  48. private:
  49. explicit BasicBlock(u32 index, String name);
  50. u32 m_index { 0 };
  51. Vector<u8> m_buffer;
  52. BasicBlock const* m_handler { nullptr };
  53. BasicBlock const* m_finalizer { nullptr };
  54. String m_name;
  55. bool m_terminated { false };
  56. bool m_has_resolved_this { false };
  57. HashMap<size_t, SourceRecord> m_source_map;
  58. size_t m_last_instruction_start_offset { 0 };
  59. };
  60. }