diff options
author | Tim Rowley <[email protected]> | 2016-04-12 19:28:50 -0600 |
---|---|---|
committer | Tim Rowley <[email protected]> | 2016-04-22 18:49:04 -0500 |
commit | 6facf4b74a30581dcbf10d2bd82cd52be5c6bb1b (patch) | |
tree | 138bb124034ee3a4ae5dfc40be126bdbe953d9c7 /src/gallium/drivers/swr | |
parent | 0487377dcec9122173c963360f8d302d071d3434 (diff) |
swr: [rasterizer core] CompleteDrawContext changes for gcc
Add explicit inline and non-inline versions of CompleteDrawContext
to make gcc happy.
Reviewed-by: Bruce Cherniak <[email protected]>
Diffstat (limited to 'src/gallium/drivers/swr')
-rw-r--r-- | src/gallium/drivers/swr/rasterizer/core/threads.cpp | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/src/gallium/drivers/swr/rasterizer/core/threads.cpp b/src/gallium/drivers/swr/rasterizer/core/threads.cpp index 21bff4ec082..47629e53ada 100644 --- a/src/gallium/drivers/swr/rasterizer/core/threads.cpp +++ b/src/gallium/drivers/swr/rasterizer/core/threads.cpp @@ -285,7 +285,8 @@ bool CheckDependency(SWR_CONTEXT *pContext, DRAW_CONTEXT *pDC, uint64_t lastReti return (pDC->dependency > lastRetiredDraw); } -INLINE int64_t CompleteDrawContext(SWR_CONTEXT* pContext, DRAW_CONTEXT* pDC) +// inlined-only version +INLINE int64_t CompleteDrawContextInl(SWR_CONTEXT* pContext, DRAW_CONTEXT* pDC) { int64_t result = InterlockedDecrement64(&pDC->threadsDone); SWR_ASSERT(result >= 0); @@ -311,6 +312,12 @@ INLINE int64_t CompleteDrawContext(SWR_CONTEXT* pContext, DRAW_CONTEXT* pDC) return result; } +// available to other translation modules +int64_t CompleteDrawContext(SWR_CONTEXT* pContext, DRAW_CONTEXT* pDC) +{ + return CompleteDrawContextInl(pContext, pDC); +} + INLINE bool FindFirstIncompleteDraw(SWR_CONTEXT* pContext, uint64_t& curDrawBE, uint64_t& drawEnqueued) { // increment our current draw id to the first incomplete draw @@ -329,7 +336,7 @@ INLINE bool FindFirstIncompleteDraw(SWR_CONTEXT* pContext, uint64_t& curDrawBE, if (isWorkComplete) { curDrawBE++; - CompleteDrawContext(pContext, pDC); + CompleteDrawContextInl(pContext, pDC); } else { @@ -457,7 +464,7 @@ void WorkOnFifoBE( { // We can increment the current BE and safely move to next draw since we know this draw is complete. curDrawBE++; - CompleteDrawContext(pContext, pDC); + CompleteDrawContextInl(pContext, pDC); lastRetiredDraw++; @@ -484,7 +491,7 @@ void WorkOnFifoFE(SWR_CONTEXT *pContext, uint32_t workerId, uint64_t &curDrawFE) DRAW_CONTEXT *pDC = &pContext->dcRing[dcSlot]; if (pDC->isCompute || pDC->doneFE || pDC->FeLock) { - CompleteDrawContext(pContext, pDC); + CompleteDrawContextInl(pContext, pDC); curDrawFE++; } else |