summaryrefslogtreecommitdiffstats
path: root/src/gallium/drivers/swr
diff options
context:
space:
mode:
authorGeorge Kyriazis <[email protected]>2018-02-26 15:19:08 -0600
committerGeorge Kyriazis <[email protected]>2018-03-09 09:35:59 -0600
commit714093203eae1acfcbc18920be09a9f2b0e2245b (patch)
tree213cea06c0e6bece4cb7e802c03b1c3af2df396d /src/gallium/drivers/swr
parentcfdd35beaf7bf336a096d4ceec13913bc3527049 (diff)
swr/rast: Refactor api and worker event handlers.
In the API event handler we want to share information between the core layer and the API. Specifically, around associating various ids with different kinds of events. For example, associate render pass id with draw ids, or command buffer ids with draw ids. Reviewed-by: Bruce Cherniak <[email protected]>
Diffstat (limited to 'src/gallium/drivers/swr')
-rw-r--r--src/gallium/drivers/swr/rasterizer/archrast/archrast.cpp86
-rw-r--r--src/gallium/drivers/swr/rasterizer/archrast/eventmanager.h1
2 files changed, 52 insertions, 35 deletions
diff --git a/src/gallium/drivers/swr/rasterizer/archrast/archrast.cpp b/src/gallium/drivers/swr/rasterizer/archrast/archrast.cpp
index 0728a85e020..d5cffbb5cec 100644
--- a/src/gallium/drivers/swr/rasterizer/archrast/archrast.cpp
+++ b/src/gallium/drivers/swr/rasterizer/archrast/archrast.cpp
@@ -74,12 +74,52 @@ namespace ArchRast
};
//////////////////////////////////////////////////////////////////////////
- /// @brief Event handler that saves stat events to event files. This
- /// handler filters out unwanted events.
- class EventHandlerStatsFile : public EventHandlerFile
+ /// @brief Event handler that handles API thread events. This is shared
+ /// between the API and its caller (e.g. driver shim) but typically
+ /// there is only a single API thread per context. So you can save
+ /// information in the class to be used for other events.
+ class EventHandlerApiStats : public EventHandlerFile
{
public:
- EventHandlerStatsFile(uint32_t id) : EventHandlerFile(id), mNeedFlush(false) {}
+ EventHandlerApiStats(uint32_t id) : EventHandlerFile(id) {}
+
+ virtual void Handle(const DrawInstancedEvent& event)
+ {
+ DrawInfoEvent e(event.data.drawId, ArchRast::Instanced, event.data.topology, event.data.numVertices, 0, 0, event.data.startVertex, event.data.numInstances, event.data.startInstance);
+
+ EventHandlerFile::Handle(e);
+ }
+
+ virtual void Handle(const DrawIndexedInstancedEvent& event)
+ {
+ DrawInfoEvent e(event.data.drawId, ArchRast::IndexedInstanced, event.data.topology, 0, event.data.numIndices, event.data.indexOffset, event.data.baseVertex, event.data.numInstances, event.data.startInstance);
+
+ EventHandlerFile::Handle(e);
+ }
+
+ virtual void Handle(const DrawInstancedSplitEvent& event)
+ {
+ DrawInfoEvent e(event.data.drawId, ArchRast::InstancedSplit, 0, 0, 0, 0, 0, 0, 0);
+
+ EventHandlerFile::Handle(e);
+ }
+
+ virtual void Handle(const DrawIndexedInstancedSplitEvent& event)
+ {
+ DrawInfoEvent e(event.data.drawId, ArchRast::IndexedInstancedSplit, 0, 0, 0, 0, 0, 0, 0);
+
+ EventHandlerFile::Handle(e);
+ }
+ };
+
+ //////////////////////////////////////////////////////////////////////////
+ /// @brief Event handler that handles worker thread events. There is one
+ /// event handler per thread. The python script will need to sum
+ /// up counters across all of the threads.
+ class EventHandlerWorkerStats : public EventHandlerFile
+ {
+ public:
+ EventHandlerWorkerStats(uint32_t id) : EventHandlerFile(id), mNeedFlush(false) {}
virtual void Handle(const EarlyDepthStencilInfoSingleSample& event)
{
@@ -215,34 +255,6 @@ namespace ArchRast
mClipper.trivialAcceptCount += _mm_popcnt_u32(event.data.validMask & ~event.data.clipMask);
}
- virtual void Handle(const DrawInstancedEvent& event)
- {
- DrawInfoEvent e(event.data.drawId, ArchRast::Instanced, event.data.topology, event.data.numVertices, 0, 0, event.data.startVertex, event.data.numInstances, event.data.startInstance);
-
- EventHandlerFile::Handle(e);
- }
-
- virtual void Handle(const DrawIndexedInstancedEvent& event)
- {
- DrawInfoEvent e(event.data.drawId, ArchRast::IndexedInstanced, event.data.topology, 0, event.data.numIndices, event.data.indexOffset, event.data.baseVertex, event.data.numInstances, event.data.startInstance);
-
- EventHandlerFile::Handle(e);
- }
-
- virtual void Handle(const DrawInstancedSplitEvent& event)
- {
- DrawInfoEvent e(event.data.drawId, ArchRast::InstancedSplit, 0, 0, 0, 0, 0, 0, 0);
-
- EventHandlerFile::Handle(e);
- }
-
- virtual void Handle(const DrawIndexedInstancedSplitEvent& event)
- {
- DrawInfoEvent e(event.data.drawId, ArchRast::IndexedInstancedSplit, 0, 0, 0, 0, 0, 0, 0);
-
- EventHandlerFile::Handle(e);
- }
-
// Flush cached events for this draw
virtual void FlushDraw(uint32_t drawId)
{
@@ -354,20 +366,24 @@ namespace ArchRast
uint32_t id = counter.fetch_add(1);
EventManager* pManager = new EventManager();
- EventHandlerFile* pHandler = new EventHandlerStatsFile(id);
- if (pManager && pHandler)
+ if (pManager)
{
- pManager->Attach(pHandler);
+ EventHandlerFile* pHandler = nullptr;
if (type == AR_THREAD::API)
{
+ pHandler = new EventHandlerApiStats(id);
+ pManager->Attach(pHandler);
pHandler->Handle(ThreadStartApiEvent());
}
else
{
+ pHandler = new EventHandlerWorkerStats(id);
+ pManager->Attach(pHandler);
pHandler->Handle(ThreadStartWorkerEvent());
}
+
pHandler->MarkHeader();
return pManager;
diff --git a/src/gallium/drivers/swr/rasterizer/archrast/eventmanager.h b/src/gallium/drivers/swr/rasterizer/archrast/eventmanager.h
index c251daf0361..10e0dce6ad9 100644
--- a/src/gallium/drivers/swr/rasterizer/archrast/eventmanager.h
+++ b/src/gallium/drivers/swr/rasterizer/archrast/eventmanager.h
@@ -57,6 +57,7 @@ namespace ArchRast
void Attach(EventHandler* pHandler)
{
+ SWR_ASSERT(pHandler != nullptr);
mHandlers.push_back(pHandler);
}