diff options
-rw-r--r-- | o3d/command_buffer/command_buffer.gyp | 1 | ||||
-rw-r--r-- | o3d/command_buffer/common/build.scons | 1 | ||||
-rw-r--r-- | o3d/command_buffer/common/cross/cmd_buffer_format.cc | 59 | ||||
-rw-r--r-- | o3d/command_buffer/common/cross/cmd_buffer_format.h | 134 | ||||
-rw-r--r-- | o3d/command_buffer/service/cross/cmd_parser.cc | 7 | ||||
-rw-r--r-- | o3d/command_buffer/service/cross/gapi_decoder.cc | 4 | ||||
-rw-r--r-- | o3d/command_buffer/service/cross/gapi_decoder.h | 2 | ||||
-rw-r--r-- | o3d/core/cross/command_buffer/renderer_cb.h | 34 |
8 files changed, 173 insertions, 69 deletions
diff --git a/o3d/command_buffer/command_buffer.gyp b/o3d/command_buffer/command_buffer.gyp index f86fb11..810ee0f 100644 --- a/o3d/command_buffer/command_buffer.gyp +++ b/o3d/command_buffer/command_buffer.gyp @@ -44,6 +44,7 @@ 'common/cross/buffer_sync_api.cc', 'common/cross/buffer_sync_api.h', 'common/cross/cmd_buffer_format.h', + 'common/cross/cmd_buffer_format.cc', 'common/cross/gapi_interface.h', 'common/cross/logging.h', 'common/cross/mocks.h', diff --git a/o3d/command_buffer/common/build.scons b/o3d/command_buffer/common/build.scons index 0aefd76..93f96bb 100644 --- a/o3d/command_buffer/common/build.scons +++ b/o3d/command_buffer/common/build.scons @@ -32,6 +32,7 @@ Import('env') INPUTS = [ 'cross/buffer_sync_api.cc', + 'cross/cmd_buffer_format.cc', 'cross/resource.cc', 'cross/rpc_imc.cc', ] diff --git a/o3d/command_buffer/common/cross/cmd_buffer_format.cc b/o3d/command_buffer/common/cross/cmd_buffer_format.cc new file mode 100644 index 0000000..0cefbc6c --- /dev/null +++ b/o3d/command_buffer/common/cross/cmd_buffer_format.cc @@ -0,0 +1,59 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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. + * * Neither the name of Google Inc. 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 + * OWNER 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. + */ + + +// This file contains the binary format definition of the command buffer and +// command buffer commands. + +#include "command_buffer/common/cross/cmd_buffer_format.h" + +namespace o3d { +namespace command_buffer { + +const char* GetCommandName(CommandId id) { + static const char* const names[] = { + + #define O3D_COMMAND_BUFFER_CMD_OP(name) # name, + + O3D_COMMAND_BUFFER_CMDS(O3D_COMMAND_BUFFER_CMD_OP) + + #undef O3D_COMMAND_BUFFER_CMD_OP + + }; + + return (static_cast<int>(id) >= 0 && static_cast<int>(id) < kNumCommands) ? + names[id] : "*unknown-command*"; +} + +} // namespace command_buffer +} // namespace o3d + + diff --git a/o3d/command_buffer/common/cross/cmd_buffer_format.h b/o3d/command_buffer/common/cross/cmd_buffer_format.h index cd19dc3..3c5e567 100644 --- a/o3d/command_buffer/common/cross/cmd_buffer_format.h +++ b/o3d/command_buffer/common/cross/cmd_buffer_format.h @@ -76,84 +76,86 @@ namespace command_buffer { // COMMAND_NAME is the name of your command structure. // // NOTE: THE ORDER OF THESE MUST NOT CHANGE (their id is derived by order) -#define O3D_COMMAND_BUFFER_CMDS \ - O3D_COMMAND_BUFFER_CMD_OP(Noop) /* 0 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetToken) /* 1 */ \ - O3D_COMMAND_BUFFER_CMD_OP(BeginFrame) /* 2 */ \ - O3D_COMMAND_BUFFER_CMD_OP(EndFrame) /* 3 */ \ - O3D_COMMAND_BUFFER_CMD_OP(Clear) /* 4 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateVertexBuffer) /* 5 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyVertexBuffer) /* 6 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetVertexBufferData) /* 7 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetVertexBufferDataImmediate) /* 8 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetVertexBufferData) /* 9 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateIndexBuffer) /* 10 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyIndexBuffer) /* 11 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetIndexBufferData) /* 12 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetIndexBufferDataImmediate) /* 13 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetIndexBufferData) /* 14 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateVertexStruct) /* 15 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyVertexStruct) /* 16 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetVertexInput) /* 17 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetVertexStruct) /* 18 */ \ - O3D_COMMAND_BUFFER_CMD_OP(Draw) /* 19 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DrawIndexed) /* 20 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateEffect) /* 21 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateEffectImmediate) /* 22 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyEffect) /* 23 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetEffect) /* 24 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetParamCount) /* 25 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateParam) /* 26 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateParamByName) /* 27 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateParamByNameImmediate) /* 28 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyParam) /* 29 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetParamData) /* 30 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetParamDataImmediate) /* 31 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetParamDesc) /* 32 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetStreamCount) /* 33 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetStreamDesc) /* 34 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyTexture) /* 35 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateTexture2d) /* 36 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateTexture3d) /* 37 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateTextureCube) /* 38 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetTextureData) /* 39 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetTextureDataImmediate) /* 40 */ \ - O3D_COMMAND_BUFFER_CMD_OP(GetTextureData) /* 41 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateSampler) /* 42 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroySampler) /* 43 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetSamplerStates) /* 44 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetSamplerBorderColor) /* 45 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetSamplerTexture) /* 46 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetViewport) /* 47 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetScissor) /* 48 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetPointLineRaster) /* 49 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetPolygonRaster) /* 50 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetPolygonOffset) /* 51 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetAlphaTest) /* 52 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetDepthTest) /* 53 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetStencilTest) /* 54 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetBlending) /* 55 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetBlendingColor) /* 56 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetColorWrite) /* 57 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateRenderSurface) /* 58 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyRenderSurface) /* 59 */ \ - O3D_COMMAND_BUFFER_CMD_OP(CreateDepthSurface) /* 60 */ \ - O3D_COMMAND_BUFFER_CMD_OP(DestroyDepthSurface) /* 61 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetRenderSurface) /* 62 */ \ - O3D_COMMAND_BUFFER_CMD_OP(SetBackSurfaces) /* 63 */ \ +#define O3D_COMMAND_BUFFER_CMDS(OP) \ + OP(Noop) /* 0 */ \ + OP(SetToken) /* 1 */ \ + OP(BeginFrame) /* 2 */ \ + OP(EndFrame) /* 3 */ \ + OP(Clear) /* 4 */ \ + OP(CreateVertexBuffer) /* 5 */ \ + OP(DestroyVertexBuffer) /* 6 */ \ + OP(SetVertexBufferData) /* 7 */ \ + OP(SetVertexBufferDataImmediate) /* 8 */ \ + OP(GetVertexBufferData) /* 9 */ \ + OP(CreateIndexBuffer) /* 10 */ \ + OP(DestroyIndexBuffer) /* 11 */ \ + OP(SetIndexBufferData) /* 12 */ \ + OP(SetIndexBufferDataImmediate) /* 13 */ \ + OP(GetIndexBufferData) /* 14 */ \ + OP(CreateVertexStruct) /* 15 */ \ + OP(DestroyVertexStruct) /* 16 */ \ + OP(SetVertexInput) /* 17 */ \ + OP(SetVertexStruct) /* 18 */ \ + OP(Draw) /* 19 */ \ + OP(DrawIndexed) /* 20 */ \ + OP(CreateEffect) /* 21 */ \ + OP(CreateEffectImmediate) /* 22 */ \ + OP(DestroyEffect) /* 23 */ \ + OP(SetEffect) /* 24 */ \ + OP(GetParamCount) /* 25 */ \ + OP(CreateParam) /* 26 */ \ + OP(CreateParamByName) /* 27 */ \ + OP(CreateParamByNameImmediate) /* 28 */ \ + OP(DestroyParam) /* 29 */ \ + OP(SetParamData) /* 30 */ \ + OP(SetParamDataImmediate) /* 31 */ \ + OP(GetParamDesc) /* 32 */ \ + OP(GetStreamCount) /* 33 */ \ + OP(GetStreamDesc) /* 34 */ \ + OP(DestroyTexture) /* 35 */ \ + OP(CreateTexture2d) /* 36 */ \ + OP(CreateTexture3d) /* 37 */ \ + OP(CreateTextureCube) /* 38 */ \ + OP(SetTextureData) /* 39 */ \ + OP(SetTextureDataImmediate) /* 40 */ \ + OP(GetTextureData) /* 41 */ \ + OP(CreateSampler) /* 42 */ \ + OP(DestroySampler) /* 43 */ \ + OP(SetSamplerStates) /* 44 */ \ + OP(SetSamplerBorderColor) /* 45 */ \ + OP(SetSamplerTexture) /* 46 */ \ + OP(SetViewport) /* 47 */ \ + OP(SetScissor) /* 48 */ \ + OP(SetPointLineRaster) /* 49 */ \ + OP(SetPolygonRaster) /* 50 */ \ + OP(SetPolygonOffset) /* 51 */ \ + OP(SetAlphaTest) /* 52 */ \ + OP(SetDepthTest) /* 53 */ \ + OP(SetStencilTest) /* 54 */ \ + OP(SetBlending) /* 55 */ \ + OP(SetBlendingColor) /* 56 */ \ + OP(SetColorWrite) /* 57 */ \ + OP(CreateRenderSurface) /* 58 */ \ + OP(DestroyRenderSurface) /* 59 */ \ + OP(CreateDepthSurface) /* 60 */ \ + OP(DestroyDepthSurface) /* 61 */ \ + OP(SetRenderSurface) /* 62 */ \ + OP(SetBackSurfaces) /* 63 */ \ // GAPI commands. enum CommandId { #define O3D_COMMAND_BUFFER_CMD_OP(name) k ## name, - O3D_COMMAND_BUFFER_CMDS + O3D_COMMAND_BUFFER_CMDS(O3D_COMMAND_BUFFER_CMD_OP) #undef O3D_COMMAND_BUFFER_CMD_OP kNumCommands, }; +const char* GetCommandName(CommandId id); + namespace cmd { enum ArgFlags { kFixed = 0x0, diff --git a/o3d/command_buffer/service/cross/cmd_parser.cc b/o3d/command_buffer/service/cross/cmd_parser.cc index ffe1d09..0d450268 100644 --- a/o3d/command_buffer/service/cross/cmd_parser.cc +++ b/o3d/command_buffer/service/cross/cmd_parser.cc @@ -74,6 +74,13 @@ BufferSyncInterface::ParseError CommandParser::ProcessCommand() { return BufferSyncInterface::kParseOutOfBounds; BufferSyncInterface::ParseError result = handler_->DoCommand( header.command, header.size - 1, buffer_ + get); + // TODO(gman): If you want to log errors this is the best place to catch them. + // It seems like we need an official way to turn on a debug mode and + // get these errors. + if (result != BufferSyncInterface::kParseNoError) { + DLOG(INFO) << "Error: " << result << " for Command " + << GetCommandName(static_cast<CommandId>(header.command)); + } get_ = (get + header.size) % entry_count_; return result; } diff --git a/o3d/command_buffer/service/cross/gapi_decoder.cc b/o3d/command_buffer/service/cross/gapi_decoder.cc index 9a4be8a..db55421 100644 --- a/o3d/command_buffer/service/cross/gapi_decoder.cc +++ b/o3d/command_buffer/service/cross/gapi_decoder.cc @@ -70,7 +70,7 @@ const CommandInfo g_command_info[] = { cmd::name::kArgFlags, \ sizeof(cmd::name) / sizeof(CommandBufferEntry) - 1, }, /* NOLINT */ \ - O3D_COMMAND_BUFFER_CMDS + O3D_COMMAND_BUFFER_CMDS(O3D_COMMAND_BUFFER_CMD_OP) #undef O3D_COMMAND_BUFFER_CMD_OP }; @@ -98,7 +98,7 @@ BufferSyncInterface::ParseError GAPIDecoder::DoCommand( arg_count, \ *static_cast<const cmd::name*>(cmd_data)); \ - O3D_COMMAND_BUFFER_CMDS + O3D_COMMAND_BUFFER_CMDS(O3D_COMMAND_BUFFER_CMD_OP) #undef O3D_COMMAND_BUFFER_CMD_OP } diff --git a/o3d/command_buffer/service/cross/gapi_decoder.h b/o3d/command_buffer/service/cross/gapi_decoder.h index e75376c..8779cf2 100644 --- a/o3d/command_buffer/service/cross/gapi_decoder.h +++ b/o3d/command_buffer/service/cross/gapi_decoder.h @@ -83,7 +83,7 @@ class GAPIDecoder : public AsyncAPIInterface { unsigned int arg_count, \ const cmd::name& args); \ - O3D_COMMAND_BUFFER_CMDS + O3D_COMMAND_BUFFER_CMDS(O3D_COMMAND_BUFFER_CMD_OP) #undef O3D_COMMAND_BUFFER_CMD_OP diff --git a/o3d/core/cross/command_buffer/renderer_cb.h b/o3d/core/cross/command_buffer/renderer_cb.h index 6a12c72..643e05e 100644 --- a/o3d/core/cross/command_buffer/renderer_cb.h +++ b/o3d/core/cross/command_buffer/renderer_cb.h @@ -36,6 +36,7 @@ #define O3D_CORE_CROSS_COMMAND_BUFFER_RENDERER_CB_H_ #include "core/cross/precompile.h" +#include <vector> #include "core/cross/renderer.h" #include "command_buffer/common/cross/rpc.h" #include "command_buffer/common/cross/resource.h" @@ -79,6 +80,39 @@ class RendererCB : public Renderer { // Destroy() should be called before Init() is called again. virtual void Destroy(); + // Overridden from Renderer. + virtual bool GoFullscreen(const DisplayWindow& display, + int mode_id) { + // TODO(gman): implement this. + return false; + } + + // Overridden from Renderer. + virtual bool CancelFullscreen(const DisplayWindow& display, + int width, int height) { + // TODO(gman): implement this. + return false; + } + + // Tells whether we're currently displayed fullscreen or not. + virtual bool fullscreen() const { + // TODO(gman): implement this. + return false; + } + + // Get a vector of the available fullscreen display modes. + // Clears *modes on error. + virtual void GetDisplayModes(std::vector<DisplayMode> *modes) { + // TODO(gman): implement this. + } + + // Get a single fullscreen display mode by id. + // Returns true on success, false on error. + virtual bool GetDisplayMode(int id, DisplayMode *mode) { + // TODO(gman): implement this. + return false; + } + // Creates a StreamBank, returning a platform specific implementation class. virtual StreamBank::Ref CreateStreamBank(); |