mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 21:12:07 +00:00

This implements the memory object cache and its "reset on grow" semantics, as the web depends on the exact behaviour.
48 lines
1.4 KiB
C++
48 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2021, Ali Mohammad Pur <mpfard@serenityos.org>
|
|
* Copyright (c) 2023, Tim Flynn <trflynn89@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Optional.h>
|
|
#include <LibJS/Forward.h>
|
|
#include <LibJS/Heap/GCPtr.h>
|
|
#include <LibJS/Runtime/ArrayBuffer.h>
|
|
#include <LibWasm/AbstractMachine/AbstractMachine.h>
|
|
#include <LibWeb/Bindings/ExceptionOrUtils.h>
|
|
#include <LibWeb/Bindings/PlatformObject.h>
|
|
|
|
namespace Web::WebAssembly {
|
|
|
|
struct MemoryDescriptor {
|
|
u32 initial { 0 };
|
|
Optional<u32> maximum;
|
|
};
|
|
|
|
class Memory : public Bindings::PlatformObject {
|
|
WEB_PLATFORM_OBJECT(Memory, Bindings::PlatformObject);
|
|
|
|
public:
|
|
static WebIDL::ExceptionOr<JS::NonnullGCPtr<Memory>> construct_impl(JS::Realm&, MemoryDescriptor& descriptor);
|
|
|
|
WebIDL::ExceptionOr<u32> grow(u32 delta);
|
|
WebIDL::ExceptionOr<JS::NonnullGCPtr<JS::ArrayBuffer>> buffer() const;
|
|
|
|
Wasm::MemoryAddress address() const { return m_address; }
|
|
|
|
private:
|
|
Memory(JS::Realm&, Wasm::MemoryAddress);
|
|
|
|
virtual JS::ThrowCompletionOr<void> initialize(JS::Realm&) override;
|
|
|
|
WebIDL::ExceptionOr<void> reset_the_memory_buffer();
|
|
static WebIDL::ExceptionOr<JS::NonnullGCPtr<JS::ArrayBuffer>> create_a_memory_buffer(JS::VM&, JS::Realm&, Wasm::MemoryAddress);
|
|
|
|
Wasm::MemoryAddress m_address;
|
|
mutable JS::GCPtr<JS::ArrayBuffer> m_buffer;
|
|
};
|
|
|
|
}
|