]> git.cworth.org Git - apitrace/commitdiff
d3d10state: Dump rendertargets.
authorJosé Fonseca <jfonseca@vmware.com>
Wed, 28 Nov 2012 12:56:01 +0000 (12:56 +0000)
committerJosé Fonseca <jfonseca@vmware.com>
Wed, 28 Nov 2012 12:56:01 +0000 (12:56 +0000)
retrace/d3d10state.cpp
retrace/d3d10state_images.cpp
retrace/d3dstate.hpp
retrace/json.cpp

index fd0eb5b16cd0dab1aa1ee499f4aca0db02c1335e..543017d780f603448a38283c7119254ede35bf68 100644 (file)
@@ -30,6 +30,7 @@
 
 #include "d3d11imports.hpp"
 #include "json.hpp"
+#include "d3dstate.hpp"
 
 
 namespace d3dstate {
@@ -41,6 +42,23 @@ dumpDevice(std::ostream &os, ID3D10Device *pDevice)
     JSONWriter json(os);
 
     /* TODO */
+    json.beginMember("parameters");
+    json.beginObject();
+    json.endObject();
+    json.endMember(); // parameters
+
+    json.beginMember("shaders");
+    json.beginObject();
+    json.endObject();
+    json.endMember(); // shaders
+
+    json.beginMember("textures");
+    json.beginObject();
+    json.endObject();
+    json.endMember(); // textures
+
+    dumpFramebuffer(json, pDevice);
+
 }
 
 
index d56c7562d7dc1012a55bd116bd213341c993a240..a9d95c966cb8d9ed00868c6f055a12e701b6ebaa 100644 (file)
@@ -30,7 +30,9 @@
 #include <algorithm>
 
 #include "image.hpp"
+#include "json.hpp"
 #include "d3d10imports.hpp"
+#include "d3dstate.hpp"
 
 
 namespace d3dstate {
@@ -179,10 +181,10 @@ unmapResource(ID3D10Resource *pResource, UINT Subresource) {
     }
 }
 
-image::Image *
-getRenderTargetImage(ID3D10Device *pDevice) {
+static image::Image *
+getRenderTargetViewImage(ID3D10Device *pDevice,
+                         ID3D10RenderTargetView *pRenderTargetView) {
     image::Image *image = NULL;
-    ID3D10RenderTargetView *pRenderTargetView = NULL;
     D3D10_RENDER_TARGET_VIEW_DESC Desc;
     ID3D10Resource *pResource = NULL;
     ID3D10Resource *pStagingResource = NULL;
@@ -194,9 +196,8 @@ getRenderTargetImage(ID3D10Device *pDevice) {
     const unsigned char *src;
     unsigned char *dst;
 
-    pDevice->OMGetRenderTargets(1, &pRenderTargetView, NULL);
     if (!pRenderTargetView) {
-        goto no_rendertarget;
+        return NULL;
     }
 
     pRenderTargetView->GetResource(&pResource);
@@ -300,12 +301,55 @@ no_staging:
     if (pResource) {
         pResource->Release();
     }
+    return image;
+}
+
+
+image::Image *
+getRenderTargetImage(ID3D10Device *pDevice) {
+    ID3D10RenderTargetView *pRenderTargetView = NULL;
+    pDevice->OMGetRenderTargets(1, &pRenderTargetView, NULL);
+
+    image::Image *image = NULL;
     if (pRenderTargetView) {
+        image = getRenderTargetViewImage(pDevice, pRenderTargetView);
         pRenderTargetView->Release();
     }
-no_rendertarget:
+
     return image;
 }
 
 
+void
+dumpFramebuffer(JSONWriter &json, ID3D10Device *pDevice)
+{
+    json.beginMember("framebuffer");
+    json.beginObject();
+
+    ID3D10RenderTargetView *pRenderTargetViews[D3D10_SIMULTANEOUS_RENDER_TARGET_COUNT];
+    pDevice->OMGetRenderTargets(D3D10_SIMULTANEOUS_RENDER_TARGET_COUNT, pRenderTargetViews, NULL);
+
+    for (UINT i = 0; i < D3D10_SIMULTANEOUS_RENDER_TARGET_COUNT; ++i) {
+        if (!pRenderTargetViews[i]) {
+            continue;
+        }
+
+        image::Image *image;
+        image = getRenderTargetViewImage(pDevice, pRenderTargetViews[i]);
+        if (image) {
+            char label[64];
+            snprintf(label, sizeof label, "RENDER_TARGET_%u", i);
+            json.beginMember(label);
+            json.writeImage(image, "UNKNOWN");
+            json.endMember(); // RENDER_TARGET_*
+        }
+
+        pRenderTargetViews[i]->Release();
+    }
+
+    json.endObject();
+    json.endMember(); // framebuffer
+}
+
+
 } /* namespace d3dstate */
index c21c3618c75214f656946500db99170e2a141481..5985052547dd57d149a9a1c6f3c5ed4622eb1b80 100644 (file)
@@ -35,6 +35,8 @@ struct ID3D10Device;
 struct ID3D11DeviceContext;
 
 
+class JSONWriter;
+
 namespace image {
     class Image;
 }
@@ -53,6 +55,9 @@ dumpDevice(std::ostream &os, IDirect3DDevice9 *pDevice);
 image::Image *
 getRenderTargetImage(ID3D10Device *pDevice);
 
+void
+dumpFramebuffer(JSONWriter &json, ID3D10Device *pDevice);
+
 void
 dumpDevice(std::ostream &os, ID3D10Device *pDevice);
 
index bb901c2e5fbcec1c7833f9e3ae855868a88a49db..53a61a3a79c3af115d51e89c083564a23bb9a19b 100644 (file)
@@ -304,6 +304,11 @@ JSONWriter::writeBool(bool b) {
 void
 JSONWriter::writeImage(image::Image *image, const char *format, unsigned depth)
 {
+    if (!image) {
+        writeNull();
+        return;
+    }
+
     beginObject();
 
     // Tell the GUI this is no ordinary object, but an image