| // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // This file contains the command parser class. |
| |
| #ifndef GPU_COMMAND_BUFFER_SERVICE_CMD_PARSER_H_ |
| #define GPU_COMMAND_BUFFER_SERVICE_CMD_PARSER_H_ |
| |
| #include "gpu/command_buffer/common/constants.h" |
| #include "gpu/command_buffer/common/cmd_buffer_common.h" |
| |
| namespace gpu { |
| |
| class AsyncAPIInterface; |
| |
| // Command parser class. This class parses commands from a shared memory |
| // buffer, to implement some asynchronous RPC mechanism. |
| class CommandParser { |
| public: |
| CommandParser(void *shm_address, |
| size_t shm_size, |
| ptrdiff_t offset, |
| size_t size, |
| CommandBufferOffset start_get, |
| AsyncAPIInterface *handler); |
| |
| // Gets the "get" pointer. The get pointer is an index into the command |
| // buffer considered as an array of CommandBufferEntry. |
| CommandBufferOffset get() const { return get_; } |
| |
| // Sets the "get" pointer. The get pointer is an index into the command buffer |
| // considered as an array of CommandBufferEntry. |
| bool set_get(CommandBufferOffset get) { |
| if (get >= 0 && get < entry_count_) { |
| get_ = get; |
| return true; |
| } |
| return false; |
| } |
| |
| // Sets the "put" pointer. The put pointer is an index into the command |
| // buffer considered as an array of CommandBufferEntry. |
| void set_put(CommandBufferOffset put) { put_ = put; } |
| |
| // Gets the "put" pointer. The put pointer is an index into the command |
| // buffer considered as an array of CommandBufferEntry. |
| CommandBufferOffset put() const { return put_; } |
| |
| // Checks whether there are commands to process. |
| bool IsEmpty() const { return put_ == get_; } |
| |
| // Processes one command, updating the get pointer. This will return an error |
| // if there are no commands in the buffer. |
| error::Error ProcessCommand(); |
| |
| // Processes all commands until get == put. |
| error::Error ProcessAllCommands(); |
| |
| // Reports an error. |
| void ReportError(unsigned int command_id, error::Error result); |
| |
| private: |
| CommandBufferOffset get_; |
| CommandBufferOffset put_; |
| CommandBufferEntry *buffer_; |
| int32 entry_count_; |
| AsyncAPIInterface *handler_; |
| }; |
| |
| // This class defines the interface for an asynchronous API handler, that |
| // is responsible for de-multiplexing commands and their arguments. |
| class AsyncAPIInterface { |
| public: |
| AsyncAPIInterface() {} |
| virtual ~AsyncAPIInterface() {} |
| |
| // Executes a command. |
| // Parameters: |
| // command: the command index. |
| // arg_count: the number of CommandBufferEntry arguments. |
| // cmd_data: the command data. |
| // Returns: |
| // error::kNoError if no error was found, one of |
| // error::Error otherwise. |
| virtual error::Error DoCommand( |
| unsigned int command, |
| unsigned int arg_count, |
| const void* cmd_data) = 0; |
| |
| // Returns a name for a command. Useful for logging / debuging. |
| virtual const char* GetCommandName(unsigned int command_id) const = 0; |
| }; |
| |
| } // namespace gpu |
| |
| #endif // GPU_COMMAND_BUFFER_SERVICE_CMD_PARSER_H_ |