| //* Copyright 2017 The Dawn & Tint Authors |
| //* |
| //* Redistribution and use in source and binary forms, with or without |
| //* modification, are permitted provided that the following conditions are met: |
| //* |
| //* 1. Redistributions of source code must retain the above copyright notice, this |
| //* list of conditions and the following disclaimer. |
| //* |
| //* 2. Redistributions in binary form must reproduce the above copyright notice, |
| //* this list of conditions and the following disclaimer in the documentation |
| //* and/or other materials provided with the distribution. |
| //* |
| //* 3. Neither the name of the copyright holder nor the names of its |
| //* contributors may be used to endorse or promote products derived from |
| //* this software without specific prior written permission. |
| //* |
| //* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| //* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| //* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| //* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
| //* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| //* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
| //* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
| //* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
| //* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| //* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| |
| #ifndef DAWNWIRE_WIRECMD_AUTOGEN_H_ |
| #define DAWNWIRE_WIRECMD_AUTOGEN_H_ |
| |
| #include "dawn/webgpu.h" |
| |
| #include "dawn/wire/BufferConsumer.h" |
| #include "dawn/wire/ObjectType_autogen.h" |
| #include "dawn/wire/ObjectHandle.h" |
| #include "dawn/wire/WireResult.h" |
| |
| namespace dawn::wire { |
| |
| // Interface to allocate more space to deserialize pointed-to data. |
| // nullptr is treated as an error. |
| class DeserializeAllocator { |
| public: |
| virtual void* GetSpace(size_t size) = 0; |
| }; |
| |
| // Interface to convert an ID to a server object, if possible. |
| // Methods return FatalError if the ID is for a non-existent object and Success otherwise. |
| class ObjectIdResolver { |
| public: |
| {% for type in by_category["object"] %} |
| virtual WireResult GetFromId(ObjectId id, {{as_cType(type.name)}}* out) const = 0; |
| virtual WireResult GetOptionalFromId(ObjectId id, {{as_cType(type.name)}}* out) const = 0; |
| {% endfor %} |
| }; |
| |
| // Interface to convert a client object to its ID for the wiring. |
| class ObjectIdProvider { |
| public: |
| {% for type in by_category["object"] %} |
| virtual WireResult GetId({{as_cType(type.name)}} object, ObjectId* out) const = 0; |
| virtual WireResult GetOptionalId({{as_cType(type.name)}} object, ObjectId* out) const = 0; |
| {% endfor %} |
| }; |
| |
| //* Enum used as a prefix to each command on the wire format. |
| enum class WireCmd : uint32_t { |
| {% for command in cmd_records["command"] %} |
| {{command.name.CamelCase()}}, |
| {% endfor %} |
| }; |
| |
| //* Enum used as a prefix to each command on the return wire format. |
| enum class ReturnWireCmd : uint32_t { |
| {% for command in cmd_records["return command"] %} |
| {{command.name.CamelCase()}}, |
| {% endfor %} |
| }; |
| |
| struct CmdHeader { |
| uint64_t commandSize; |
| }; |
| |
| {% macro write_command_struct(command, is_return_command) %} |
| {% set Return = "Return" if is_return_command else "" %} |
| {% set Cmd = command.name.CamelCase() + "Cmd" %} |
| struct {{Return}}{{Cmd}} { |
| //* From a filled structure, compute how much size will be used in the serialization buffer. |
| size_t GetRequiredSize() const; |
| |
| //* Serialize the structure and everything it points to into serializeBuffer which must be |
| //* big enough to contain all the data (as queried from GetRequiredSize). |
| WireResult Serialize(size_t commandSize, SerializeBuffer* serializeBuffer, const ObjectIdProvider& objectIdProvider) const; |
| // Override which produces a FatalError if any object is used. |
| WireResult Serialize(size_t commandSize, SerializeBuffer* serializeBuffer) const; |
| |
| //* Deserializes the structure from a buffer, consuming a maximum of *size bytes. When this |
| //* function returns, buffer and size will be updated by the number of bytes consumed to |
| //* deserialize the structure. Structures containing pointers will use allocator to get |
| //* scratch space to deserialize the pointed-to data. |
| //* Deserialize returns: |
| //* - Success if everything went well (yay!) |
| //* - FatalError is something bad happened (buffer too small for example) |
| WireResult Deserialize(DeserializeBuffer* deserializeBuffer, DeserializeAllocator* allocator, const ObjectIdResolver& resolver); |
| // Override which produces a FatalError if any object is used. |
| WireResult Deserialize(DeserializeBuffer* deserializeBuffer, DeserializeAllocator* allocator); |
| |
| {% if command.derived_method %} |
| //* Command handlers want to know the object ID in addition to the backing object. |
| //* Doesn't need to be filled before Serialize, or GetRequiredSize. |
| ObjectId selfId; |
| {% endif %} |
| |
| {% for member in command.members %} |
| {{as_annotated_cType(member)}}; |
| {% endfor %} |
| }; |
| {% endmacro %} |
| |
| {% for command in cmd_records["command"] %} |
| {{write_command_struct(command, False)}} |
| {% endfor %} |
| |
| {% for command in cmd_records["return command"] %} |
| {{write_command_struct(command, True)}} |
| {% endfor %} |
| |
| } // namespace dawn::wire |
| |
| #endif // DAWNWIRE_WIRECMD_AUTOGEN_H_ |