Windows2003-3790/enduser/netmeeting/av/callcont/h245send.c

293 lines
8.9 KiB
C
Raw Permalink Normal View History

2001-01-01 00:00:00 +01:00
/******************************************************************************
*
* File: h245send.c
*
* INTEL Corporation Proprietary Information
* Copyright (c) 1994, 1995, 1996 Intel Corporation.
*
* This listing is supplied under the terms of a license agreement
* with INTEL Corporation and may not be used, copied, nor disclosed
* except in accordance with the terms of that agreement.
*
*****************************************************************************/
/******************************************************************************
*
* $Workfile: h245send.c $
* $Revision: 1.8 $
* $Modtime: 22 Jul 1996 17:24:18 $
* $Log: S:/STURGEON/SRC/H245/SRC/VCS/h245send.c_v $
*
* Rev 1.8 22 Jul 1996 17:33:28 EHOWARDX
* Updated to latest Interop API.
*
* Rev 1.7 05 Jun 1996 17:14:30 EHOWARDX
* Further work on converting to HRESULT; added PrintOssError to eliminate
* pErrorString from instance structure.
*
* Rev 1.6 04 Jun 1996 18:18:18 EHOWARDX
* Interop Logging changes inside #if defined(PCS_COMPLIANCE) conditionals.
*
* Rev 1.5 30 May 1996 23:39:12 EHOWARDX
* Cleanup.
*
* Rev 1.4 28 May 1996 14:25:18 EHOWARDX
* Tel Aviv update.
*
* Rev 1.3 21 May 1996 13:40:48 EHOWARDX
* Added LOGGING switch to log PDUs to the file H245.OUT.
* Add /D "LOGGING" to project options to enable this feature.
*
* Rev 1.2 20 May 1996 14:35:14 EHOWARDX
* Got rid of asynchronous H245EndConnection/H245ShutDown stuff...
*
* Rev 1.1 17 May 1996 16:19:46 EHOWARDX
* Changed sendPDU to return an error if link layer send fails.
* (Probably should define a new error code for this...)
*
* Rev 1.0 09 May 1996 21:06:26 EHOWARDX
* Initial revision.
*
* Rev 1.11.1.4 09 May 1996 19:34:46 EHOWARDX
* Redesigned locking logic.
* Simplified link API.
*
* Rev 1.11.1.3 25 Apr 1996 21:27:14 EHOWARDX
* Changed to use pInstance->p_ossWorld instead of bAsnInitialized.
*
* Rev 1.11.1.2 23 Apr 1996 14:44:34 EHOWARDX
* Updated.
*
* Rev 1.11.1.1 15 Apr 1996 15:12:04 EHOWARDX
* Updated.
*
* Rev 1.11.1.0 26 Mar 1996 19:14:46 EHOWARDX
*
* Commented out hTraceFile for H.323
*
* Rev 1.11 21 Mar 1996 17:20:40 dabrown1
* - put in test1/2 trace fdwrite
* .
*
* .
*
*
*
*
* Rev 1.10 13 Mar 1996 11:31:14 DABROWN1
*
* Enable logging for ring0
*
* Rev 1.9 11 Mar 1996 15:32:06 DABROWN1
*
* Defined/Undefined _DLL for _IA_SPOX_ environment
*
* Rev 1.8 06 Mar 1996 13:11:44 DABROWN1
*
* enable flush buffers
*
* Rev 1.7 02 Mar 1996 22:10:26 DABROWN1
* updated to new MemFree
*
* Rev 1.6 01 Mar 1996 17:25:14 DABROWN1
*
* moved oss 'world' context to h245instance
* delete buffer returned in sendcomplete instead of what was held in context
*
* Rev 1.5 28 Feb 1996 14:52:18 DABROWN1
* Put oss errors in range of SR (10000)
*
* Rev 1.4 23 Feb 1996 13:56:30 DABROWN1
*
* added H245TRACE / ASSERT calls
*
* Rev 1.3 21 Feb 1996 16:52:52 DABROWN1
*
* correct pointer passed to SRP for transmits
*
* Rev 1.2 21 Feb 1996 10:50:42 EHOWARDX
* Got rid of unreferenced local variable.
*
* Rev 1.1 21 Feb 1996 08:24:20 DABROWN1
* allocate/deallocate send buffers per message. Enable sendComplete functiot
*
* Rev 1.0 09 Feb 1996 17:37:42 cjutzi
* Initial revision.
*
*****************************************************************************/
#ifndef STRICT
#define STRICT
#endif
/***********************/
/* SYSTEM INCLUDES */
/***********************/
#include <stdio.h>
#include <stdlib.h>
#include <stddef.h>
#include <limits.h>
#include "precomp.h"
/***********************/
/* H245 INCLUDES */
/***********************/
#ifdef _IA_SPOX_
#define _DLL
#endif //_IA_SPOX_
#include "h245com.h"
#include "sr_api.h"
#if defined(_DEBUG) || defined(PCS_COMPLIANCE)
#include "interop.h"
#include "h245plog.h"
extern LPInteropLogger H245Logger;
#endif // (PCS_COMPLIANCE)
#ifdef _IA_SPOX_
#undef _DLL
#endif //_IA_SPOX_
/**************************************************************************
** Function : sendPDU
** Description : Convert struct to ASN.1 PDU and forward to datalink layer
***************************************************************************/
HRESULT sendPDU(struct InstanceStruct *pInstance,
MltmdSystmCntrlMssg *lp245MsgStruct)
{
HRESULT lError;
ASN1_BUF Asn1Buf;
PBYTE pEncoded_pdu;
int nRet;
// Set up the oss struct for passing a pre-allocated buffer
switch (pInstance->Configuration) {
case H245_CONF_H324:
// Allocate a buffer to transmit
pEncoded_pdu = MemAlloc(pInstance->SendReceive.dwPDUSize);
if (pEncoded_pdu == NULL) {
H245TRACE(pInstance->dwInst, 1, "H245Send: No memory");
return H245_ERROR_NOMEM;
}
Asn1Buf.value = &pEncoded_pdu[2];
Asn1Buf.length = pInstance->SendReceive.dwPDUSize - 4;
break;
case H245_CONF_H323:
// Allocate a buffer to transmit
pEncoded_pdu = MemAlloc(pInstance->SendReceive.dwPDUSize);
if (pEncoded_pdu == NULL) {
H245TRACE(pInstance->dwInst, 1, "H245Send: No memory");
return H245_ERROR_NOMEM;
}
Asn1Buf.value = pEncoded_pdu;
Asn1Buf.length = pInstance->SendReceive.dwPDUSize;
break;
default:
H245TRACE(pInstance->dwInst,
1,
"SR: Unknown Configuration %d",
pInstance->Configuration);
return H245_ERROR_SUBSYS;
}
nRet = H245_Encode(pInstance->pWorld,
(void *)lp245MsgStruct,
MltmdSystmCntrlMssg_PDU,
&Asn1Buf);
if (ASN1_SUCCEEDED(nRet))
{
H245TRACE(pInstance->dwInst, 3, "H245: Msg Encode Successful");
#if defined(_DEBUG) || defined(PCS_COMPLIANCE)
if (H245Logger)
InteropOutput(H245Logger,
(BYTE FAR*)(pEncoded_pdu),
(int)Asn1Buf.length,
H245LOG_SENT_PDU);
#endif // (PCS_COMPLIANCE)
lError = pInstance->SendReceive.hLinkSendReq(pInstance->SendReceive.hLinkLayerInstance,
pEncoded_pdu,
Asn1Buf.length);
}
else
{
MemFree(pEncoded_pdu);
lError = H245_ERROR_ASN1;
}
return lError;
}
/**************************************************************************
** Function : h245SendComplete
** Description : Send Completion Callback routine from link layer
***************************************************************************/
void h245SendComplete( DWORD_PTR h245Inst,
HRESULT dwMessage,
PBYTE pbDataBuf,
DWORD dwLength)
{
struct InstanceStruct *pInstance;
pInstance = InstanceLock(h245Inst);
if (pInstance == NULL) {
H245TRACE(h245Inst, 1, "SR: h245SendComplete - invalid instance");
return;
}
// Return the buffer
if (pbDataBuf) {
MemFree(pbDataBuf);
}
switch (dwMessage) {
case LINK_SEND_COMPLETE:
if (pInstance->SendReceive.dwFlushMap & SHUTDOWN_PENDING) {
H245TRACE(h245Inst, 10, "SR: Shutdown Complete");
}
break;
case LINK_SEND_ABORT:
H245TRACE(h245Inst, 10, "SR: TX Abort Buffer");
break;
case LINK_FLUSH_COMPLETE:
// If we are in the process of abort, then the next and
// last mesage out will be the endSession
H245TRACE(h245Inst, 10, "SR: TX Flush Complete");
// Indicate Transmit buffer flush is complete
pInstance->SendReceive.dwFlushMap ^= DATALINK_TRANSMIT;
// If all requested queues have been flushed, call the
// appropriate callback routing
switch (pInstance->SendReceive.dwFlushMap & SHUTDOWN_MASK) {
case 0:
// TBD: Who is interested in callback if not in connection
// with shutdown?
break;
case SHUTDOWN_PENDING:
// Flush buffers completed, and shutdown in progress
// notify the API
H245TRACE(h245Inst, 20, "SR: SHUTDOWN CALLBACK");
break;
default:
// Still waiting for buffers to be flushed. No action now
break;
} // switch (pInstance->SendReceive.dwFlushMap & SHUTDOWN_MASK) {
break;
default:
H245TRACE(h245Inst, 10, "SR: SendComplete");
break;
}
InstanceUnlock(pInstance);
}