[ofw] [ND 6/7] ND: CQ APIs
Sean Hefty
sean.hefty at intel.com
Mon Apr 6 10:24:23 PDT 2009
/*
* Copyright (c) 2009 Intel Corporation. All rights reserved.
*
* This software is available to you under the OpenIB.org BSD license
* below:
*
* 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.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#pragma once
#ifndef _ND_CQ_H_
#define _ND_CQ_H_
#include <initguid.h>
#include <ndspi.h>
#include "nd_base.h"
#include "nd_adapter.h"
class CNDCompletionQueue : INDCompletionQueue, public CNDBase
{
public:
// IUnknown methods
STDMETHODIMP QueryInterface(REFIID riid, LPVOID FAR* ppvObj);
STDMETHODIMP_(ULONG) AddRef();
STDMETHODIMP_(ULONG) Release();
// INDOverlapped methods
STDMETHODIMP CancelOverlappedRequests();
STDMETHODIMP GetOverlappedResult(OVERLAPPED *pOverlapped,
SIZE_T *pNumberOfBytesTransferred, BOOL bWait);
// INDCompletionQueue methods
STDMETHODIMP Resize(SIZE_T nEntries);
STDMETHODIMP Notify(DWORD Type, OVERLAPPED* pOverlapped);
STDMETHODIMP_(SIZE_T) GetResults(ND_RESULT* pResults[], SIZE_T nResults);
CNDCompletionQueue(CNDAdapter *pAdapter);
~CNDCompletionQueue();
void Delete() {delete this;}
static STDMETHODIMP
CreateInstance(CNDAdapter *pAdapter, SIZE_T nEntries, INDCompletionQueue** ppCq)
{
HRESULT hr;
CNDCompletionQueue *cq;
cq = new CNDCompletionQueue(pAdapter);
if (cq == NULL) {
hr = ND_NO_MEMORY;
goto err1;
}
hr = cq->Init(nEntries);
if (FAILED(hr)) {
goto err2;
}
*ppCq = cq;
return ND_SUCCESS;
err2:
cq->Release();
err1:
*ppCq = NULL;
return hr;
}
IWVCompletionQueue *m_pWvCq;
protected:
CNDAdapter *m_pAdapter;
STDMETHODIMP Init(SIZE_T nEntries);
};
#endif // _ND_CQ_H_
/*
* Copyright (c) 2009 Intel Corporation. All rights reserved.
*
* This software is available to you under the OpenIB.org BSD license
* below:
*
* 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.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#include "nd_cq.h"
CNDCompletionQueue::CNDCompletionQueue(CNDAdapter *pAdapter)
{
pAdapter->AddRef();
m_pAdapter = pAdapter;
m_pWvCq = NULL;
}
STDMETHODIMP CNDCompletionQueue::
Init(SIZE_T nEntries)
{
return m_pAdapter->m_pWvDevice->CreateCompletionQueue(&nEntries, &m_pWvCq);
}
CNDCompletionQueue::~CNDCompletionQueue()
{
if (m_pWvCq != NULL) {
m_pWvCq->Release();
}
m_pAdapter->Release();
}
STDMETHODIMP CNDCompletionQueue::
QueryInterface(REFIID riid, LPVOID FAR* ppvObj)
{
if (riid != IID_IUnknown && riid != IID_INDCompletionQueue) {
*ppvObj = NULL;
return E_NOINTERFACE;
}
*ppvObj = this;
AddRef();
return ND_SUCCESS;
}
STDMETHODIMP_(ULONG) CNDCompletionQueue::
AddRef(void)
{
return CNDBase::AddRef();
}
STDMETHODIMP_(ULONG) CNDCompletionQueue::
Release(void)
{
return CNDBase::Release();
}
STDMETHODIMP CNDCompletionQueue::
CancelOverlappedRequests(void)
{
return m_pWvCq->CancelOverlappedRequests();
}
STDMETHODIMP CNDCompletionQueue::
GetOverlappedResult(OVERLAPPED *pOverlapped,
SIZE_T *pNumberOfBytesTransferred, BOOL bWait)
{
return m_pWvCq->GetOverlappedResult(pOverlapped,
(DWORD *) pNumberOfBytesTransferred, bWait);
}
STDMETHODIMP CNDCompletionQueue::
Resize(SIZE_T nEntries)
{
return m_pWvCq->Resize(&nEntries);
}
STDMETHODIMP CNDCompletionQueue::
Notify(DWORD Type, OVERLAPPED* pOverlapped)
{
return m_pWvCq->Notify((WV_CQ_NOTIFY_TYPE) Type, pOverlapped);
}
STDMETHODIMP_(SIZE_T) CNDCompletionQueue::
GetResults(ND_RESULT* pResults[], SIZE_T nResults)
{
WV_COMPLETION comp[8];
SIZE_T cnt, total, i;
for (total = 0; nResults; nResults -= cnt) {
cnt = min(8, nResults);
cnt = m_pWvCq->Poll(comp, cnt);
if (cnt == 0) {
break;
}
for (i = 0; i < cnt; i++) {
pResults[total] = (ND_RESULT *) comp[i].WrId;
pResults[total]->Status = comp[i].Status;
pResults[total++]->BytesTransferred = comp[i].Length;
}
}
return total;
}
More information about the ofw
mailing list