亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? aps.c

?? zigbee 2004協議棧
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
*2006/08/16 WXL 2.0
*/

/*
V0.2 added PC-based binding
V0.1 Initial Release                10/July/2006

*/



/*
APS Layer
*/

#include "compiler.h"
#include "lrwpan_config.h"         //user configurations
#include "lrwpan_common_types.h"   //types common acrosss most files
#include "ieee_lrwpan_defs.h"
#include "console.h"
#include "debug.h"
#include "memalloc.h"
#include "neighbor.h"
#include "hal.h"
#include "halStack.h"
#include "phy.h"
#include "mac.h"
#include "nwk.h"
#include "zep.h"
#include "aps.h"
#include "evboard.h"


#define apsTXIdle() (!aps_pib.flags.bits.TxInProgress)
#define apsTXBusy() (aps_pib.flags.bits.TxInProgress)
#define apsSetTxBusy() aps_pib.flags.bits.TxInProgress = 1
#define apsSetTxIdle() aps_pib.flags.bits.TxInProgress = 0


typedef enum _APS_RXSTATE_ENUM {
	APS_RXSTATE_IDLE,
	APS_RXSTATE_START,
	APS_RXSTATE_RESOLVE_INDIRECT,
	APS_RXSTATE_ACK_SEND_WAIT
} APS_RXSTATE_ENUM;



APS_PIB aps_pib;
APS_SERVICE a_aps_service;
APS_STATE_ENUM apsState;
APS_EP_ELEM apsEndPoints[LRWPAN_MAX_ENDPOINTS];

//there can only be one TX in progress at a time, so
//a_aps_tx_data contains the arguments for that TX on the APS layer.
APS_TX_DATA a_aps_tx_data;
APS_RX_DATA a_aps_rx_data;
APS_RX_DATA indirect_data;  //used for holding an indirect packet while being reflected.

void apsFSM(void);
void apsTxData(BOOL copy_payload);

//locals
static APS_RXSTATE_ENUM apsRxState;
static LRWPAN_STATUS_ENUM apsTxFSM_status;

static void apsParseHdr(BYTE *ptr);
static void apsRxFSM(void);
static BOOL apsCheckAck(void);
static void apsFormatAck(void);
static void apsTxFSM(void);
static void apsInjectPacket(BOOL indirect_flag);
static void apsInjectTxPacket(void);

#ifdef LRWPAN_COORDINATOR
void apsRxBuffInit(void);
BOOL apsRxBuffFull(void);
BOOL apsRxBuffEmpty(void);
APS_RX_DATA *apsGetRxPacket(void);
void apsFreeRxPacket(BOOL freemem);
void apsRxBuffAdd (APS_RX_DATA *ptr);

#endif

//converts MAC TICKs to Microseconds
UINT32 aplMacTicksToUs(UINT32 ticks){

	return(halMacTicksToUs(ticks));

}

//this sleeps, then restarts the stack and the radio
void aplShutdown(void){
	//wait until stack is idle
	while(apsBusy()) apsFSM();
	DISABLE_GLOBAL_INTERRUPT();  //disable interrupts, if halSleep wants to reenable them, let it.
	halShutdown();
	a_aps_service.status = LRWPAN_STATUS_SUCCESS;

}

void aplWarmstart(void){
	a_aps_service.status = macWarmStartRadio();
}



//this is top level init, does inits for other layers
void apsInit(void){

	debug_level = 0;
	apsState = APS_STATE_IDLE;
	apsRxState = APS_RXSTATE_IDLE;
#ifdef LRWPAN_COORDINATOR
	aps_pib.rxCnt = 0;
	aps_pib.rxTail = 0;
	aps_pib.rxHead = 0;
#endif

	aps_pib.apsTSN = 0;
	aps_pib.flags.val = 0;
	aps_pib.apscAckWaitDuration = MSECS_TO_MACTICKS(LRWPAN_APS_ACK_WAIT_DURATION) ; //convert to MAC Ticks
	aps_pib.apsAckWaitMultiplier = 1; //default value
	aps_pib.apscMaxFrameRetries = LRWPAN_APS_MAX_FRAME_RETRIES ;
	//initialize the endpoints
	aps_pib.activeEPs = 0;  //only tracks user endpoints.
	phyInit();
	macInit();
	nwkInit();
	zepInit();

}

//simply remembers these so that we can report them to the coordinator.
LRWPAN_STATUS_ENUM aplRegisterEndPoint(BYTE epNum)
{
   if (aps_pib.activeEPs == LRWPAN_MAX_ENDPOINTS) return(LRWPAN_STATUS_APS_MAX_ENDPOINTS_EXCEEDED);
   if (epNum == 0) return(LRWPAN_STATUS_APS_ILLEGAL_ENDPOINT);
   apsEndPoints[aps_pib.activeEPs++].epNum = epNum;
   return(LRWPAN_STATUS_SUCCESS);
}

//Formats a Send Message service
void aplFmtSendMSG (BYTE dstMode,
					LADDR_UNION *dstADDR,
					BYTE dstEP,
					BYTE cluster,
					BYTE srcEP,
					BYTE* pload,
					BYTE  plen,
					BYTE  tsn,
					BYTE  reqack)
{

	BYTE buf[8];
	BYTE i;

	while(apsBusy()) apsFSM();
	a_aps_service.cmd = LRWPAN_SVC_APS_GENERIC_TX;
	a_aps_tx_data.flags.val = 0;
	a_aps_tx_data.srcEP = srcEP;
	a_aps_tx_data.usrPlen = plen;
	a_aps_tx_data.usrPload = pload;
	a_aps_tx_data.tsn = tsn;
	a_aps_tx_data.cluster = cluster;
	a_aps_tx_data.dstMode = dstMode;
	a_aps_tx_data.dstEP = dstEP;
	a_aps_tx_data.srcSADDR = macGetShortAddr();
	a_aps_tx_data.af_fcf = (1 | AF_FRM_TYPE_MSG);


	if (dstMode == APS_DSTMODE_NONE) {
		a_aps_tx_data.aps_fcf = APS_FRM_TYPE_DATA | APS_FRM_DLVRMODE_INDIRECT;
	}else  {
		a_aps_tx_data.aps_fcf = APS_FRM_TYPE_DATA | APS_FRM_DLVRMODE_NORMAL;
		if (a_aps_tx_data.dstMode == APS_DSTMODE_SHORT ){
			a_aps_tx_data.dstSADDR = dstADDR->saddr;
			if (dstADDR->saddr == macGetShortAddr()) {
				//sending to ourselves
				a_aps_tx_data.flags.bits.loopback = 1;
			}
		}
		else {
			a_aps_tx_data.dstLADDR = &dstADDR->laddr.bytes[0];
			a_aps_tx_data.dstSADDR = LRWPAN_SADDR_USE_LADDR;
			/* APS acks to no make sense for LONG addressing, which is
			being used to bypass routing. The MAC acks serve for APS acks
			in this case. Also APS acks would be returned via routing,
			negating the bypass of the routing in the first place.
			*/
			reqack = 0;
			//see if we are sending to ourself
			halGetProcessorIEEEAddress(buf);
			for(i=0;i<8;i++) {
				if (buf[i] != dstADDR->laddr.bytes[i]) break;
			}
			if (i==8) {
				//this is a loopback, so use our short address in this field
				a_aps_tx_data.dstSADDR = macGetShortAddr();
				a_aps_tx_data.flags.bits.loopback = 1;
			}
		}
	}
	if (reqack) a_aps_tx_data.aps_fcf |= (APS_FRM_ACKREQ_MASK);

}

//TODO - add a pib flag that indicates when the User's TX
//buffer has been copied so that user can begin building a
//new TX packet while the old one is being TX'ed.



void apsFSM(void) {


#ifdef LRWPAN_COORDINATOR
	APS_RX_DATA *rxPtr;
#endif



	nwkFSM();
	//if TxFSM is busy we need to call it
	if (apsTXBusy()) apsTxFSM();
	apsRxFSM(); //check RX
	zepFSM();   //do ZEP

apsFSM_start:


	switch (apsState) {
	 case APS_STATE_IDLE:

		 //ackSendPending check must come before the indirect Pending check!
		 if (aps_pib.flags.bits.ackSendPending) {
			 apsState = APS_STATE_ACK_SEND_START;
			 goto apsFSM_start;
		 }

#ifdef LRWPAN_COORDINATOR
		 if (aps_pib.flags.bits.indirectPending) {
			 //free up RX FSM so that we can receive possible APS acks for this packet.
			 aps_pib.flags.bits.indirectPending = 0;  //free up RX FSM
			 // an indirect message needs resolving
			 //initialize the binding table iterator
			 //get pointer to current indirect packet
			 rxPtr = &aps_pib.rxBuff[aps_pib.rxTail];
			 if (!evbBindTableIterInit(rxPtr->srcEP, rxPtr->srcSADDR,rxPtr->cluster)){
				 //a failure to initialize the iterator, give up.
				 DEBUG_STRING(DBG_ERR,"APS: BindTable Iterator initialize failed. Discarding indirect msg.\n");
				 apsState = APS_STATE_IDLE;
			 }else {
				 apsState = APS_STATE_INDIRECT_GETDST;
				 goto apsFSM_start;
			 }
		 }
#endif


		 break;
	 case APS_STATE_COMMAND_START:
		 switch(a_aps_service.cmd) {
	 case LRWPAN_SVC_APS_GENERIC_TX:
		 aps_pib.flags.bits.IsUsrBufferFree = 0;
#ifdef LRWPAN_COORDINATOR
		 if (APS_GET_FRM_DLVRMODE(a_aps_tx_data.aps_fcf) == APS_FRM_DLVRMODE_INDIRECT){
			 //this is a special case. A Coordinator endpoint is sending indirect.
			 //we need to inject this into the stack as if it has been received
			 apsState = APS_STATE_INJECT_INDIRECT;
			 goto apsFSM_start;
		 }
#endif


		 if (a_aps_tx_data.flags.bits.loopback) {
			 apsState = APS_STATE_INJECT_LOOPBACK;  //we are sending a direct packet to ourself!
			 goto apsFSM_start;
		 }

		 //Indirect vs Direct is handled within the apsTxData() function
		 //at this point ready to begin formating packet.
		 //do not exit this state until we can grab the TX buffer.
		 if (phyTxUnLocked()) {
			 phyGrabTxLock(); //prevents lower stack layers from grabbing TX buffer.
			 phy_pib.currentTxFlen = 0;  //set frame length to zero, build from scratch
			 apsTxData(TRUE);
			 aps_pib.flags.bits.IsUsrBufferFree = 1;
			 apsState = APS_STATE_GENERIC_TX_WAIT;
		 }
		 break;

	 case LRWPAN_SVC_APS_DO_ZEP_TX:
		 if (phyTxUnLocked()) {
			 phyGrabTxLock(); //prevents lower stack layers from grabbing TX buffer.
			 switch(a_aps_service.args.zep_tx.clusterID)
			 {
	           case ZEP_END_DEVICE_ANNOUNCE:
			                 zepFmtEndDeviceAnnounce(a_aps_service.args.zep_tx.dst);
							 break;
			   case ZEP_EXTENDED_CMD:
				   switch(a_aps_service.args.zep_tx.extID)
				   {
			          case ZEP_EXT_NODE_INFO_RSP:
				                zepFmtNodeInfoRsp(a_aps_service.args.zep_tx.dst);
							     break;
					  case ZEP_EXT_PING:
						        zepFmtPing(a_aps_service.args.zep_tx.dst);
								 break;
					  case ZEP_EXT_SEND_ALARM:
						        zepFmtAlarm(a_aps_service.args.zep_tx.dst,
									        a_aps_service.args.zep_tx.ext.alarm.mode
											);
						        break;

				   }
				   break;
			   default: break;
			 }

			 phy_pib.currentTxFlen = 0;  //set frame length to zero, build from scratch
			 apsTxData(FALSE);           //payload already in TX buffer
			 apsState = APS_STATE_GENERIC_TX_WAIT;
		 }

		 break;

	
	 case LRWPAN_SVC_APS_NWK_PASSTHRU:
		 //for NWK calls that have to pass thru the APS layer
		 //this just serves to lock the APS layer while the
		 //the NWK layer is doing its thing
		 if (nwkBusy()) break;  //wait until nwk is idle
		 nwkDoService();
		 apsState = APS_STATE_NWK_PASSTHRU_WAIT;
		 break;

	 default: break;
		 }//end switch(a_aps_service.cmd)

		 break;

	 case APS_STATE_ACK_SEND_START:
		 if (phyTxLocked()) break;
		 //send an ACK
		 //lock the TX buffer
		 phyGrabTxLock();
		 //we are now ready
		 apsFormatAck();
		 phy_pib.currentTxFlen = 0;  //set frame length to zero, build from scratch
		 apsTxData(TRUE);
		 //data sent, release the RX buffer, will let RX FSM resume
		 aps_pib.flags.bits.ackSendPending = 0;
		 apsState = APS_STATE_GENERIC_TX_WAIT;

		 break;

	 case APS_STATE_GENERIC_TX_WAIT:
		 if (!apsTXIdle()) break;
		 //TX is finished, copy status
		 a_aps_service.status = apsTxFSM_status;
		 //release the TX buffer lock before exiting.
		 phyReleaseTxLock();
		 apsState = APS_STATE_IDLE;
		 if (aps_pib.flags.bits.indirectPending) {
			 //have used this state to wait for finishing sending an
			 //ACK back to the source of an indirect transmit. Now
			 //finish resolving the indirect
			 goto apsFSM_start;
		 }


		 break;

	 case APS_STATE_NWK_PASSTHRU_WAIT:
		 //for split-phase passthrus
		 if (nwkBusy()) break;
		 a_aps_service.status = a_nwk_service.status;
		 apsState = APS_STATE_IDLE;
		 break;

	 case APS_STATE_INJECT_LOOPBACK:
		 //wait for RX to become idle
		 if (apsRxState != APS_RXSTATE_IDLE) break;
		 //inject packet into RX FSM
		 apsInjectPacket(FALSE);
		 aps_pib.flags.bits.IsUsrBufferFree = 1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频一二三区| 午夜久久电影网| 国产黄色精品网站| 国产农村妇女精品| 国产99精品国产| 中文字幕一区免费在线观看| 成人午夜视频免费看| 欧美国产成人在线| 99精品国产99久久久久久白柏| 中文字幕一区免费在线观看| 色哟哟一区二区| 亚洲成在人线在线播放| 日韩一级欧美一级| 国产成人激情av| 伊人一区二区三区| 777午夜精品视频在线播放| 激情另类小说区图片区视频区| 欧美国产亚洲另类动漫| 91久久人澡人人添人人爽欧美| 天天爽夜夜爽夜夜爽精品视频| 欧美精品一区二区在线观看| www.66久久| 日韩综合在线视频| 国产日韩av一区| 欧美色综合网站| 国产综合色视频| 亚洲综合区在线| 精品国产sm最大网站免费看| 91美女视频网站| 蜜桃久久久久久| 国产精品国模大尺度视频| 欧美日韩综合在线免费观看| 国内精品第一页| 亚洲综合一区二区| 亚洲国产成人在线| 91精品国产乱码| 色婷婷久久久亚洲一区二区三区 | 91精品国模一区二区三区| 国产在线国偷精品免费看| 亚洲裸体在线观看| 2021中文字幕一区亚洲| 欧美影院一区二区| 国产91清纯白嫩初高中在线观看 | 天堂影院一区二区| 欧美国产禁国产网站cc| 91精品国产入口在线| 99久久精品国产观看| 久久aⅴ国产欧美74aaa| 一区二区三区中文字幕精品精品| 久久久不卡网国产精品一区| 欧美日韩性生活| 色综合久久久久综合体| 国产一区999| 美国欧美日韩国产在线播放| 亚洲一区二区三区自拍| 国产精品理伦片| 久久久电影一区二区三区| 日韩一区二区免费高清| 欧美人与性动xxxx| 日本福利一区二区| 色狠狠色狠狠综合| 91论坛在线播放| 99视频国产精品| 高清国产一区二区| 国产一区二区0| 国产在线一区观看| 极品少妇xxxx偷拍精品少妇| 日韩精品久久久久久| 午夜视频在线观看一区| 依依成人综合视频| 亚洲影视在线播放| 亚洲精品国产品国语在线app| 国产精品久久久久久久久久久免费看 | 在线精品视频一区二区| 91网站最新网址| 99久久国产综合精品麻豆| 97久久人人超碰| 99re成人精品视频| 色综合色狠狠天天综合色| 99re热视频这里只精品| 色婷婷综合在线| 欧洲一区在线电影| 欧美午夜影院一区| 91麻豆精品久久久久蜜臀| 欧美另类高清zo欧美| 欧美一二三区在线观看| 欧美videos中文字幕| 精品免费视频.| 久久综合资源网| 中日韩av电影| 一区二区三区四区蜜桃| 一区二区三区不卡视频 | 视频在线观看91| 久久99热这里只有精品| 国产成人精品网址| 91猫先生在线| 91麻豆精品国产91久久久资源速度| 欧美一级欧美一级在线播放| 亚洲精品一区二区三区四区高清| 久久九九影视网| 亚洲裸体xxx| 免费观看成人鲁鲁鲁鲁鲁视频| 激情深爱一区二区| aaa亚洲精品| 欧美精品丝袜中出| 精品国产sm最大网站| 亚洲欧洲另类国产综合| 亚洲chinese男男1069| 国内精品自线一区二区三区视频| 成人午夜精品一区二区三区| 欧美综合视频在线观看| 精品三级在线看| 亚洲精选视频免费看| 蜜臀久久99精品久久久久久9| 成人免费观看视频| 欧美精品在线观看播放| 久久久久亚洲蜜桃| 亚洲一区二区三区在线| 韩国精品在线观看| 欧美色老头old∨ideo| 丝袜亚洲另类丝袜在线| 风流少妇一区二区| 69久久99精品久久久久婷婷| 国产欧美久久久精品影院| 婷婷亚洲久悠悠色悠在线播放| 国产精品一区二区视频| 精品视频一区二区三区免费| 久久久久久久久久久久久夜| 香蕉久久一区二区不卡无毒影院 | 欧美一区二区视频网站| 国产精品久久久久久亚洲毛片| 蜜桃久久精品一区二区| 色偷偷88欧美精品久久久| 国产日产欧美一区| 日本三级韩国三级欧美三级| 一本大道av伊人久久综合| 国产午夜精品福利| 免费高清不卡av| 欧美在线啊v一区| 国产精品伦一区二区三级视频| 免费视频最近日韩| 欧美人牲a欧美精品| 亚洲六月丁香色婷婷综合久久| 国产98色在线|日韩| 精品欧美一区二区久久| 男女男精品视频网| 欧美日韩精品一区视频| 亚洲免费观看高清完整版在线| 国产精品一区二区在线播放| 欧美xxxxxxxx| 美女国产一区二区| 欧美一区二区在线免费观看| 亚洲一卡二卡三卡四卡五卡| 91网站黄www| 亚洲欧洲精品一区二区精品久久久| 国产一区日韩二区欧美三区| 欧美一区二区三区电影| 亚洲va国产天堂va久久en| 欧美在线观看视频在线| 亚洲精品国产一区二区三区四区在线| 大陆成人av片| 国产精品国产三级国产aⅴ原创 | 五月综合激情日本mⅴ| 欧美天天综合网| 亚洲国产精品久久人人爱蜜臀| aaa亚洲精品一二三区| 国产精品国产三级国产普通话蜜臀 | 日韩一区二区在线观看| 亚洲电影视频在线| 欧美日韩中文字幕一区| 亚洲高清不卡在线观看| 欧美午夜片在线看| 亚洲成人自拍网| 欧美男男青年gay1069videost | 91网站最新网址| 一区二区三区精品| 欧美日本一道本在线视频| 奇米色777欧美一区二区| 日韩一级在线观看| 国内精品免费在线观看| 国产欧美日韩精品在线| 91色婷婷久久久久合中文| 成人h动漫精品| 亚洲猫色日本管| 欧美欧美欧美欧美首页| 久久精品国产网站| 中文字幕成人网| 欧美亚洲动漫制服丝袜| 蜜桃视频在线一区| 中文一区二区在线观看| 色悠久久久久综合欧美99| 午夜精品福利一区二区三区av| 欧美一区二区视频在线观看| 国产电影一区二区三区| 亚洲丝袜美腿综合| 日韩欧美电影一二三| 国产+成+人+亚洲欧洲自线| 日韩理论在线观看| 3d动漫精品啪啪| 成人国产精品免费观看视频|