133 lines
3.6 KiB
C++
133 lines
3.6 KiB
C++
/*************************************************************************\
|
|
* Copyright (c) 2002 The University of Chicago, as Operator of Argonne
|
|
* National Laboratory.
|
|
* Copyright (c) 2002 The Regents of the University of California, as
|
|
* Operator of Los Alamos National Laboratory.
|
|
* EPICS BASE Versions 3.13.7
|
|
* and higher are distributed subject to a Software License Agreement found
|
|
* in file LICENSE that is included with this distribution.
|
|
\*************************************************************************/
|
|
/*
|
|
* $Id$
|
|
*
|
|
* Author Jeffrey O. Hill
|
|
* johill@lanl.gov
|
|
* 505 665 1831
|
|
*/
|
|
|
|
#include "dbMapper.h"
|
|
|
|
#include "server.h"
|
|
#include "casChannelIIL.h" // casChannelI in line func
|
|
#include "casCtxIL.h" // casCtxI in line func
|
|
|
|
//
|
|
// casAsyncReadIO::casAsyncReadIO()
|
|
//
|
|
casAsyncReadIO::casAsyncReadIO ( const casCtx & ctx ) :
|
|
casAsyncIOI ( ctx ), msg ( *ctx.getMsg() ),
|
|
chan ( *ctx.getChannel () ), pDD ( NULL ), completionStatus ( S_cas_internal )
|
|
{
|
|
assert ( & this->chan );
|
|
this->chan.installAsyncIO ( *this );
|
|
}
|
|
|
|
//
|
|
// casAsyncReadIO::~casAsyncReadIO()
|
|
//
|
|
casAsyncReadIO::~casAsyncReadIO ()
|
|
{
|
|
epicsGuard < casCoreClient > guard ( this->client );
|
|
this->chan.removeAsyncIO ( *this );
|
|
}
|
|
|
|
//
|
|
// casAsyncReadIO::postIOCompletion()
|
|
//
|
|
caStatus casAsyncReadIO::postIOCompletion (caStatus completionStatusIn,
|
|
const gdd &valueRead)
|
|
{
|
|
{
|
|
epicsGuard < casCoreClient > guard ( this->client );
|
|
this->pDD = & valueRead;
|
|
this->completionStatus = completionStatusIn;
|
|
}
|
|
|
|
return this->postIOCompletionI();
|
|
}
|
|
|
|
//
|
|
// casAsyncReadIO::readOP()
|
|
//
|
|
bool casAsyncReadIO::readOP() const
|
|
{
|
|
return true; // it is a read op
|
|
}
|
|
|
|
//
|
|
// casAsyncReadIO::cbFuncAsyncIO()
|
|
// (called when IO completion event reaches top of event queue)
|
|
//
|
|
caStatus casAsyncReadIO::cbFuncAsyncIO()
|
|
{
|
|
caStatus status;
|
|
|
|
switch ( this->msg.m_cmmd ) {
|
|
case CA_PROTO_READ:
|
|
status = client.readResponse ( &this->chan, this->msg,
|
|
*this->pDD, this->completionStatus);
|
|
break;
|
|
|
|
case CA_PROTO_READ_NOTIFY:
|
|
status = client.readNotifyResponse ( &this->chan,
|
|
this->msg, this->pDD,
|
|
this->completionStatus);
|
|
break;
|
|
|
|
case CA_PROTO_EVENT_ADD:
|
|
status = client.monitorResponse ( this->chan,
|
|
this->msg, this->pDD,
|
|
this->completionStatus);
|
|
break;
|
|
|
|
case CA_PROTO_CLAIM_CIU:
|
|
unsigned nativeTypeDBR;
|
|
status = this->chan.getPVI().bestDBRType ( nativeTypeDBR );
|
|
if ( status ) {
|
|
errMessage ( status, "best external dbr type fetch failed" );
|
|
status = client.channelCreateFailedResp ( this->msg, status );
|
|
}
|
|
else {
|
|
// we end up here if the channel claim protocol response is delayed
|
|
// by an asynchronous enum string table fetch response
|
|
if ( this->completionStatus == S_cas_success && this->pDD.valid() ) {
|
|
this->chan.getPVI().updateEnumStringTableAsyncCompletion ( *this->pDD );
|
|
}
|
|
else {
|
|
errMessage ( this->completionStatus,
|
|
"unable to read application type \"enums\" string"
|
|
" conversion table for enumerated PV" );
|
|
}
|
|
status = client.enumPostponedCreateChanResponse ( this->chan,
|
|
this->msg, nativeTypeDBR );
|
|
}
|
|
break;
|
|
|
|
default:
|
|
errPrintf ( S_cas_invalidAsynchIO, __FILE__, __LINE__,
|
|
" - client request type = %u", this->msg.m_cmmd );
|
|
status = S_cas_invalidAsynchIO;
|
|
break;
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
//
|
|
// void casAsyncReadIO::destroy ()
|
|
//
|
|
void casAsyncReadIO::destroy ()
|
|
{
|
|
delete this;
|
|
}
|