1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
/****************************************************************
* *
* Copyright 2001, 2004 Sanchez Computer Associates, Inc. *
* *
* This source code contains the intellectual property *
* of its copyright holder(s), and is made available *
* under a license. If you do not know the terms of *
* the license, please stop and do not read further. *
* *
****************************************************************/
#include <errno.h>
#include "mdef.h"
#include "cmidef.h"
#include "caller_id.h"
#include "iosp.h"
error_def(CMI_NETFAIL);
cmi_status_t cmj_postevent(struct CLB *lnk)
{
struct NTD *tsk = lnk->ntd;
cmi_reason_t reason = lnk->deferred_reason;
cmi_status_t status = lnk->deferred_status;
lnk->deferred_event = FALSE;
switch (reason)
{
case CMI_REASON_IODONE:
if (lnk->ast)
{
CMI_DPRINT(("CALLING AST FROM CMJ_POSTEVENT after IODONE, called from 0x%x\n", caller_id()));
(*lnk->ast)(lnk);
}
break;
case CMI_REASON_INTMSG:
if (tsk->trc)
(*tsk->trc)(lnk, CM_CLB_READ_URG, &lnk->urgdata, (size_t)1);
if (tsk->urg)
(*tsk->urg)(lnk, lnk->urgdata);
break;
case CMI_REASON_CONNECT:
if (tsk->crq)
(*tsk->crq)(lnk);
break;
default:
switch (status)
{
case ECONNABORTED:
reason = CMI_REASON_ABORT;
break;
case ETIMEDOUT:
reason = CMI_REASON_TIMEOUT;
break;
case ECONNREFUSED:
reason = CMI_REASON_REJECT;
break;
default:
reason = CMI_REASON_DISCON;
break;
}
if (lnk->ast)
{
CMI_DPRINT(("CALLING AST FROM CMJ_POSTEVENT after ERROR, called from 0x%x\n", caller_id()));
(*lnk->ast)(lnk);
}
if (tsk->err)
(*tsk->err)(tsk, lnk, reason);
return reason;
}
return SS_NORMAL;
}
|