Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mpc-hc/mpc-hc.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCasimir666 <casimir666@users.sourceforge.net>2008-02-23 17:03:29 +0300
committerCasimir666 <casimir666@users.sourceforge.net>2008-02-23 17:03:29 +0300
commitb3c4bf8b5bad56ff0fcd14344b0a93b258558ae9 (patch)
tree747ce11af1135dfd650890120824bb6232c93a44 /src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp
parent84658e002c872b72b7b38264fe3de5be02a4e23c (diff)
Fixed : software mode was not working with overlay mixer
Fixed : incorrect value displayed for dxva mode in property window in certain conditions Fixed : dxva mode is not displayed anymore when property window is opened from options / internal filters git-svn-id: https://mpc-hc.svn.sourceforge.net/svnroot/mpc-hc/trunk@420 10f7b99b-c216-0410-bff0-8a66a9350fd8
Diffstat (limited to 'src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp')
-rw-r--r--src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp87
1 files changed, 12 insertions, 75 deletions
diff --git a/src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp b/src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp
index b08091537..7fcf1004e 100644
--- a/src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp
+++ b/src/filters/transform/mpcvideodec/VideoDecOutputPin.cpp
@@ -32,6 +32,8 @@ CVideoDecOutputPin::CVideoDecOutputPin(TCHAR* pObjectName, CBaseVideoFilter* pFi
m_pVideoDecFilter = (CMPCVideoDecFilter*) pFilter;
m_pDXVA2Allocator = NULL;
m_dwDXVA1SurfaceCount = 0;
+ m_GuidDecoderDXVA1 = GUID_NULL;
+ memset (&m_ddUncompPixelFormat, 0, sizeof(m_ddUncompPixelFormat));
}
CVideoDecOutputPin::~CVideoDecOutputPin(void)
@@ -62,77 +64,6 @@ HRESULT CVideoDecOutputPin::InitAllocator(IMemAllocator **ppAlloc)
return __super::InitAllocator(ppAlloc);
}
-
-
-HRESULT CVideoDecOutputPin::Deliver(IMediaSample* pMediaSample)
-{
- if (!m_pVideoDecFilter->UseDXVA2())
- {
- if(!m_pOutputQueue) return NOERROR;
- pMediaSample->AddRef();
- return m_pOutputQueue->Receive(pMediaSample);
- }
- else
- return __super::Deliver (pMediaSample);
-}
-
-
-HRESULT CVideoDecOutputPin::Active()
-{
- CAutoLock cAutoLock(m_pLock);
-
- if(m_Connected && !m_pOutputQueue)
- {
- HRESULT hr = NOERROR;
-
- m_pOutputQueue.Attach(new COutputQueue(m_Connected, &hr));
- if(!m_pOutputQueue) hr = E_OUTOFMEMORY;
-
- if(FAILED(hr))
- {
- m_pOutputQueue.Free();
- return hr;
- }
- }
-
- return __super::Active();
-}
-
-HRESULT CVideoDecOutputPin::Inactive()
-{
- CAutoLock cAutoLock(m_pLock);
- m_pOutputQueue.Free();
- return __super::Inactive();
-}
-
-
-#define CallQueue(call) \
- if(!m_pOutputQueue) return NOERROR; \
- m_pOutputQueue->##call; \
- return NOERROR; \
-
-HRESULT CVideoDecOutputPin::DeliverEndOfStream()
-{
- CallQueue(EOS());
-}
-
-HRESULT CVideoDecOutputPin::DeliverBeginFlush()
-{
- CallQueue(BeginFlush());
-}
-
-HRESULT CVideoDecOutputPin::DeliverEndFlush()
-{
- CallQueue(EndFlush());
-}
-
-HRESULT CVideoDecOutputPin::DeliverNewSegment(REFERENCE_TIME tStart, REFERENCE_TIME tStop, double dRate)
-{
- CallQueue(NewSegment(tStart, tStop, dRate));
-}
-
-
-
STDMETHODIMP CVideoDecOutputPin::NonDelegatingQueryInterface(REFIID riid, void** ppv)
{
return
@@ -157,7 +88,11 @@ STDMETHODIMP CVideoDecOutputPin::GetUncompSurfacesInfo(const GUID *pGuid, LPAMVA
pUncompBufferInfo->dwMinNumSurfaces = m_pVideoDecFilter->GetPicEntryNumber();
hr = m_pVideoDecFilter->FindDXVA1DecoderConfiguration (pAMVideoAccelerator, pGuid, &pUncompBufferInfo->ddUncompPixelFormat);
- if (SUCCEEDED (hr)) m_pVideoDecFilter->SetDXVA1Params (pGuid, &pUncompBufferInfo->ddUncompPixelFormat);
+ if (SUCCEEDED (hr))
+ {
+ memcpy (&m_ddUncompPixelFormat, &pUncompBufferInfo->ddUncompPixelFormat, sizeof(DDPIXELFORMAT));
+ m_GuidDecoderDXVA1 = *pGuid;
+ }
}
}
return hr;
@@ -180,10 +115,10 @@ STDMETHODIMP CVideoDecOutputPin::GetCreateVideoAcceleratorData(const GUID *pGuid
if (pAMVideoAccelerator)
{
- memcpy (&UncompInfo.ddUncompPixelFormat, m_pVideoDecFilter->GetPixelFormat(), sizeof (DDPIXELFORMAT));
+ memcpy (&UncompInfo.ddUncompPixelFormat, &m_ddUncompPixelFormat, sizeof (DDPIXELFORMAT));
UncompInfo.dwUncompHeight = m_pVideoDecFilter->PictHeightRounded();
UncompInfo.dwUncompWidth = m_pVideoDecFilter->PictWidth();
- hr = pAMVideoAccelerator->GetCompBufferInfo(m_pVideoDecFilter->GetDXVADecoderGuid(), &UncompInfo, &dwNumTypesCompBuffers, CompInfo);
+ hr = pAMVideoAccelerator->GetCompBufferInfo(&m_GuidDecoderDXVA1, &UncompInfo, &dwNumTypesCompBuffers, CompInfo);
if (SUCCEEDED (hr))
{
@@ -191,8 +126,10 @@ STDMETHODIMP CVideoDecOutputPin::GetCreateVideoAcceleratorData(const GUID *pGuid
if (SUCCEEDED (hr))
{
+ m_pVideoDecFilter->SetDXVA1Params (&m_GuidDecoderDXVA1, &m_ddUncompPixelFormat);
+
pConnectMode = (DXVA_ConnectMode*)CoTaskMemAlloc (sizeof(DXVA_ConnectMode));
- pConnectMode->guidMode = *m_pVideoDecFilter->GetDXVADecoderGuid();
+ pConnectMode->guidMode = m_GuidDecoderDXVA1;
pConnectMode->wRestrictedMode = m_pVideoDecFilter->GetDXVA1RestrictedMode();
*pdwSizeMiscData = sizeof(DXVA_ConnectMode);
*ppMiscData = pConnectMode;