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

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

?? mftmac.c.bak

?? motorola jw32 usb 源碼
?? BAK
?? 第 1 頁 / 共 5 頁
字號:
}
*/
/*********************************************************************
 * Function:        BYTE MACStartScan()
 *
 * PreCondition:    MACInit(), MACEnable() are called
 *                  And MACIsPutReady() == TRUE
 *
 * Output:          None
 *
 * Side Effects:    None
 *
 * Overview:        If this is active scan, receive beacon
 *
 * Note:            None
 ********************************************************************/
void MACStartScan()
{
    // Send beacon if this is active scan

   	  bIsScan = TRUE  ;
   		macStartTick = TickGet();
   		//MACReqNetState();
   		//sendFlag=1;
    	PHYSetTRXState(PHY_TRX_RX_ON);
}


/*********************************************************************
 * Function:        BYTE MACIsScanComplete(void)
 *
 * PreCondition:    MACStartScan() is called.
 *
 * Input:           None
 *
 * Output:          TRUE if scan is complete
 *                  FALSE otherwise.
 *
 * Side Effects:    None
 *
 * Overview:        Checks to see a beacon was received and if it is,
 *                  it processes it.
 *
 * Note:            None
 ********************************************************************/
BYTE MACIsScanComplete(void)
{
    BYTE result;
		unsigned int  tdiff;

    result = FALSE;
    if (bIsGetReady)
    {
        if ( macCurrentFrame.frameCtrl.Control.fields.type == MAC_FRAME_NETST||	macCurrentFrame.frameCtrl.Control.fields.type==MAC_FRAME_BEACON)
        {
            	result=MACProcessNetState();
        }
		  MACDiscardRx();
    }
    else
    {
    	tdiff = TickGet();
    	tdiff = TickGetDiff(tdiff, macStartTick)  ;
			if ( tdiff >= MAC_ACTIVE_SCAN_PERIOD )
            result = TRUE;
    }
    if(result) {  	
         PHYSetTRXState(PHY_TRX_TX_ON);
         macRandom += PHYGetRssi();
    }
    return result;
}






/*********************************************************************
 * Function:        void MACDiscardRx(void)
 *
 * PreCondition:    MACIsGetReady() = TRUE
 *
 * Input:           None
 *
 * Output:          None
 *
 * Side Effects:    None
 *
 * Overview:        Fetches remaining data bytes for current received
 *                  frame.
 *
 * Note:            None
 ********************************************************************/
static void MACDiscardRx(void)
{
    // Mark this frame as empty.
    bIsGetReady = FALSE;

    if(RXBuffer[0].head != NULL)
    {
        RXBuffer[0].head = NULL;
    }
}

/*********************************************************************
 * Function:        void MACPutHeader(BYTE flength,BYTE desAddr)
 *
 * PreCondition:    MACIsPutReady() = TRUE
 *
 * Input:           dest        - Destination node info
 *                  frameCON    - Frame control for frame header
 *                                Logical AND of
 *                                "Frame Control flags" as defined
 *                                in zMAC.h
 *
 * Output:          None
 *
 * Side Effects:    None
 *
 * Overview:        Constructs and loads frame header as per
 *                  IEEE spec.
 *                  If frame requires ack, it makes an entry into
 *                  DSN queue so that future ack can be matched
 *                  against this frame.
 *
 * Note:            None
 ********************************************************************/
void MACPutHeader(BYTE flength,BYTE desAddr)
{
    // If we are not buffering the packet, clear the TX
    macPacketLen=0;
    //put frame length
    MACPut(flength);
    //put destination address
    MACPut(desAddr);

}
/*********************************************************************
 * Function:      void MACPhyDataReady()
 	Description:    when PHY received data,call this program,tell MAC data
 		              is Ready.
  ********************************************************************/

void MACPhyDataReady(void)
{
	if(bIsEnabled)//if have into send becon time slot,we will discard this receive data
	{
		bPhyGetReady = TRUE;
	}

    //PTD_PTD4^=1;

}

/*********************************************************************
 * Function:        void MACBufferPacket(void)
 *
 * PreCondition:    Transceiver has a packet waiting.
 *
 * Input:           None
 *
 * Output:          None
 *
 * Side Effects:    New packet is read in and buffered.
 *
 * Overview:        This function will read the packet out of the RF
 *                  chip and buffer it into RAM. If there is no room
 *                  available in RAM then it will discard the packet.
 *
 * Note:            None
 ********************************************************************/
static void MACBufferPacket(void)
{
	  BYTE packetSize=0;
    BYTE packetLQI=0;
  //  if(RXBuffer[0].head == NULL)
    {
        packetSize = PHYDataIndication(FrameRXBuffer,&packetLQI);
       if(packetSize<MAC_FRAME_LENGTH&&packetSize>0)
        {
            //PrintChar(packetSize);
            RXBuffer[0].length = packetSize;
            RXBuffer[0].head 	= FrameRXBuffer;
            RXBuffer[0].databuffer 	= FrameRXBuffer;
            RXBuffer[0].lqi	 	= packetLQI;
          //  PTD_PTD4^=1;
        }
        else
        {
        	RXBuffer[0].head = NULL;
        }
    }
    /* should we indicate to the user that they are out of RX buffers? */
}
/*********************************************************************
 * Function:       void MACPassDeviceData(BYTE deviceid,BYTE *buffer,BYTE length)
 *
 * PreCondition:    app have received device data
 *
 * Input:           buffer:input data buffer.length:input buffer data length,deviceid:which device
 *
 * Output:          no
 *
 * Overview:        This function will save device data in mac buffer untill beacon time.send it out

 * Note:            None
 ********************************************************************/

void MACPassDeviceData(BYTE deviceid,BYTE *buffer,BYTE length)
{
	BYTE i;
	if(length>KbPassLength)
		return;
	DeviceDataLength =length;
	if(deviceid==MAC_DEVICE_KEYBOARD)
	{
		macKbLedState = buffer[0];
	}
	for(i=0;i<length;i++)
	{
		DeviceBuffer[i]=buffer[i];
	}
	/*if(deviceid==MAC_DEVICE_JOYSTICK0)
	{
		macBeaon.Control.bits.devId=(macJkDev[0].devAddress&0x01)+MAC_DEVICE_JOYSTICK0;
	}
	else 	if(deviceid==MAC_DEVICE_JOYSTICK1)
	{
			macBeaon.Control.bits.devId= 	(macJkDev[1].devAddress&0x01)+MAC_DEVICE_JOYSTICK0;
	}
	else*/
		macBeaon.Control.bits.devId= 	deviceid;
	macBeaon.Control.bits.bData= 	1;
}

//input  device job mode.output :devcieId .0 error
BYTE   MACJudgeDeviceId(BYTE bmode)
{
	if(bmode<MAC_MODE_NUMBER)
	{
		return MAC_DEVICE_MOUSE;

	}
	else if((bmode>=JK1MODEID)&&(bmode<(JK1MODEID+MAC_JKMODE_NUMBER)))
	{
		return MAC_DEVICE_JOYSTICK0;
	}
	else if((bmode>=JK2MODEID)&&(bmode<(JK2MODEID+MAC_JKMODE_NUMBER)))
	{
		return MAC_DEVICE_JOYSTICK1;
	}
	return FALSE;
}
/*********************************************************************
 * Function:       BYTE MACSaveAppData(unsigned char *buffer,unsigned char length)
 *
 * PreCondition:    app have received pc data
 *
 * Input:           buffer:input data buffer.length:input buffer data length
 *
 * Output:          if save successful return true,else return false
 *
 * Overview:        This function will save buffer data into keymap flash area.

 * Note:            None
 ********************************************************************/

BYTE MACSaveAppData(unsigned char *buffer,unsigned char length)
{
    static BYTE newkeyflag = 0;
	static BYTE newTransflag = 0;
	static BYTE btranlength =0;
	static BYTE bErrFlag=0;
    static	BYTE   validCount=0;
    BYTE const* baddress=0;
	BYTE i;
	//if(buffer[0]==0x01)//keyboard pass data
	if(length<3)
	{
	    if(length==2)
		    MACPassDeviceData(MAC_DEVICE_KEYBOARD,buffer+1,length-1);
		else
		     MACPassDeviceData(MAC_DEVICE_KEYBOARD,buffer,length);
		LED_DATA^=1;
		return TRUE;
	}
	else if(buffer[0]==0x06)//download data
	{
	        if(length!=8)
			{
					newkeyflag = 0;
					bErrFlag=1;
				  return FALSE;
			}
				if(newkeyflag==0)  //begin transfer key data
				{
				    macNewKeyMode 	 	= buffer[1];
						macNewKey       	= buffer[2];  //KEY number
						macNewKeyLength  	= buffer[3];  //key map length
						validCount = 0;
						if(macNewKey==0)//transfer first key
						{
							newTransflag = 0;
						}
						if(newTransflag==0)//begin download
				    {
				    		btranlength = 0;				  //clear transfer length
				    		bErrFlag=0;               //clear error flag
				    		downFlash = 0;
				    		downLength = 0;
								if(macNewKeyMode==MAC_NORMAL_MODE)  // first 4byte :store PANDID,CHANNEL
										btranlength=4;
								else if(macNewKeyMode==MAC_WFLASH_MODE) //WRITE FLASH,PANID AND channel
								{
									ReadFlash((byte const *)FLASH_ADDRESS[0],KEYMAPMAXSIZE,Ram_Key);
									for(i=3;i<length;i++)
									{

										macKeyMap[0].keybuffer[btranlength++]=buffer[i];
										validCount++;
										if(buffer[i]==KBDATAEND)
										{
													newkeyflag = 0;
												//	validCount-=2;
													if(validCount!=4)
													{
																bErrFlag=1;
																return FALSE;
													}
													macCurrentChannel= 	macKeyMap[0].keybuffer[2];//channel
													if(macCurrentChannel<FIRSTCHAN)
													{
														macCurrentChannel+=FIRSTCHAN;
													}
													if(macCurrentChannel>=MAXCHAN)
													{
														macCurrentChannel-=MAXCHAN;
														macCurrentChannel&=0x1F;
														macCurrentChannel+=FIRSTCHAN;
													}
													if(macKeyMap[0].keybuffer[1]!=macInfo.devAddress)
													{
																macInfo.devAddress=macKeyMap[0].keybuffer[1];
																macWarncode=0;              //clear all warn information
												  }
												  bchanlost=1;
													//MACSetDeviceAddress(macKeyMap[0].keybuffer[1]);//panid
													//WriteFlash((byte const *)FLASH_ADDRESS[0],KEYMAPMAXSIZE,Ram_Key,NORMAL_WRITE); //
													MACStart();
										}
									}
									return TRUE;
								}
				    }
				    if(bErrFlag)                            //if have error .return
				    	return FALSE;
						newTransflag++;
						//--------------------------------------------------
						// KEY map data
							if(macNewKeyLength>MAC_KEYMAPLEN)//once passs length
							{
							  bErrFlag=1;
								return FALSE;
							}
							if((btranlength+macNewKeyLength)>=MSMAPSIZE)//cannot save it all
							{
								i=MACJudgeDeviceId(macNewKeyMode);
								if((i==MAC_DEVICE_JOYSTICK0)||(i==MAC_DEVICE_JOYSTICK1))
								{
									if(downFlash==0)  //already writed flash once
									{
										downLength = btranlength+1;
										WriteFlash((byte const *)FLASH_BACK,downLength,Ram_Key,NORMAL_WRITE);
										btranlength = 0;
										downFlash = 1;
									}
									else
									{
										 bErrFlag=1;
										return FALSE;
									}
								}
								else
								{
								  bErrFlag=1;
									return FALSE;
								}
							}
							//----------------------------------------------
							// map data is ok.transfer new key map
							newkeyflag        = 1;

						//------------------------------------------------------------
						for(i=3;i<length;i++)
						{

							macKeyMap[0].keybuffer[btranlength++]=buffer[i];
							validCount++;
							if(buffer[i]==KBDATAEND)
							{
								newkeyflag = 0;
								validCount-=2;
								if(validCount!=macNewKeyLength)
								{
											bErrFlag=1;
											return FALSE;

								}
								break;
							}
							 else if(btranlength>MSMAPSIZE)
							 {
							    bErrFlag=1;
								return FALSE;
							 }
						}
					}
					else//continue transfer last times data.no head. all is data
					{
							if(bErrFlag)
									return FALSE;
							for(i=1;i<length;i++)  //save data
							{
								validCount++;
								macKeyMap[0].keybuffer[btranlength++]=buffer[i];
								if(buffer[i]==KBDATAEND)
								{
									newkeyflag = 0;
									validCount-=2;
									if(validCount!=macNewKeyLength)
									{
											bErrFlag=1;
											return FALSE;
									}
									break;
								}
							    else if(btranlength>MSMAPSIZE)
    							 {
    							    bErrFlag=1;
    								return FALSE;
    							 }
							}
					}
					// transfer key map data over.try save it
					if(newkeyflag==0

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费在线观看视频一区| 在线观看网站黄不卡| 欧美一区二区三区免费在线看| 国产免费久久精品| 一区av在线播放| 91在线码无精品| 中文字幕不卡的av| 国产+成+人+亚洲欧洲自线| 欧美日韩精品一二三区| 一区二区三区小说| 色噜噜狠狠成人网p站| 亚洲欧洲精品一区二区三区 | 免费在线看一区| 欧美综合视频在线观看| 亚洲综合色视频| 91久久国产综合久久| 一区二区三国产精华液| 色吧成人激情小说| 亚洲午夜一二三区视频| 欧美日韩国产免费一区二区 | 激情综合五月天| 欧美成人精品二区三区99精品| 日本免费在线视频不卡一不卡二| 日本乱人伦一区| 亚洲超碰97人人做人人爱| 欧美日韩高清在线播放| 视频一区二区三区在线| 欧美日韩免费电影| 日本最新不卡在线| 777久久久精品| 麻豆国产精品官网| 中文一区一区三区高中清不卡| 国产91清纯白嫩初高中在线观看| 国产精品欧美综合在线| 色婷婷综合久色| 麻豆视频观看网址久久| 久久久精品综合| 色综合久久九月婷婷色综合| 亚洲一区二区三区视频在线 | 色综合天天综合网国产成人综合天| wwwwww.欧美系列| av亚洲精华国产精华精| 亚洲国产精品影院| 337p日本欧洲亚洲大胆精品| 国产精品一区二区果冻传媒| 国产精品成人午夜| 日韩亚洲欧美在线| 国产不卡高清在线观看视频| 亚洲美女免费视频| 欧美成人一区二区三区片免费 | 欧美日韩高清一区二区三区| 日韩成人免费在线| 久久久精品天堂| 欧美日韩另类一区| 国产福利一区二区三区在线视频| 亚洲裸体xxx| 26uuuu精品一区二区| 91同城在线观看| 激情深爱一区二区| 亚洲欧美日韩中文字幕一区二区三区| 欧美日本乱大交xxxxx| 高清不卡一区二区| 首页国产欧美日韩丝袜| 国产精品毛片大码女人| 日韩欧美中文一区二区| 国产美女娇喘av呻吟久久| 亚洲午夜一区二区| 国产精品久久午夜| 精品国产乱码久久久久久久久 | 91精品国产色综合久久久蜜香臀| 99视频超级精品| 韩国女主播一区| 婷婷丁香久久五月婷婷| 亚洲乱码中文字幕综合| 一区二区三区四区五区视频在线观看| 国产精品蜜臀av| 亚洲欧美视频在线观看视频| 亚洲视频狠狠干| 亚洲蜜桃精久久久久久久| 亚洲精品福利视频网站| 亚洲国产一二三| 日韩高清在线一区| 蜜桃一区二区三区四区| 激情偷乱视频一区二区三区| 国产精品中文字幕欧美| 国产精品一二三在| 粉嫩蜜臀av国产精品网站| 国产成人免费在线观看| 91在线国产福利| 欧美影院一区二区| 欧美肥大bbwbbw高潮| 日韩三级.com| 中文字幕不卡的av| 亚洲一区二区高清| 久久精品国产99| 高清国产一区二区三区| 91啪亚洲精品| 777午夜精品免费视频| 亚洲精品一区在线观看| 中文av一区二区| 一区二区三区国产精华| 免费av成人在线| 成人中文字幕在线| 欧美亚洲高清一区| 精品国产一二三区| 亚洲日本丝袜连裤袜办公室| 午夜精品视频一区| 国产毛片精品视频| 一本高清dvd不卡在线观看 | 欧美一区二区日韩一区二区| 久久九九全国免费| 亚洲国产视频一区二区| 国产精品99久久久久久宅男| 色先锋久久av资源部| 精品日韩欧美一区二区| 国产精品久久久久久亚洲毛片| 午夜不卡av在线| 国产成人99久久亚洲综合精品| 91免费观看视频| 精品久久久网站| 一区二区三区欧美日| 精品在线你懂的| 欧美亚洲一区二区三区四区| 久久精品一区二区三区不卡 | 免费人成精品欧美精品| 成人激情图片网| 欧美一级二级三级乱码| 国产麻豆欧美日韩一区| 国产专区综合网| 日韩黄色片在线观看| 极品美女销魂一区二区三区免费 | 国精产品一区一区三区mba视频| 99久久精品国产网站| 亚洲精品一区二区三区在线观看| 亚洲日本青草视频在线怡红院| 毛片av中文字幕一区二区| 欧美制服丝袜第一页| 国产精品午夜在线| 精品一区二区国语对白| 欧美男女性生活在线直播观看| 自拍偷拍欧美激情| 国产乱人伦偷精品视频免下载| 日本二三区不卡| 国产精品久久久久久久午夜片 | 亚洲国产高清在线观看视频| 五月综合激情网| 91免费看`日韩一区二区| 国产亚洲成av人在线观看导航| 热久久免费视频| 欧美精品视频www在线观看 | 懂色av中文字幕一区二区三区| 日韩精品一区二区在线观看| 亚洲高清中文字幕| 欧美在线影院一区二区| 亚洲视频香蕉人妖| 99久久久精品免费观看国产蜜| 久久久国产精华| 国产传媒久久文化传媒| 国产午夜精品一区二区三区嫩草| 免费成人性网站| 日韩精品中文字幕一区| 蜜桃视频第一区免费观看| 制服丝袜亚洲色图| 亚洲国产成人av网| 欧洲色大大久久| 亚洲一区二区三区三| 欧美日韩久久久一区| 天天色天天操综合| 欧美一区二区三区在线看| 免费的成人av| 久久精品一区二区三区av| 国产一区 二区 三区一级| 国产人久久人人人人爽| 国产91精品一区二区麻豆亚洲| 久久精品一区二区| 成人18视频日本| 亚洲精品v日韩精品| 欧美在线免费播放| 婷婷久久综合九色综合伊人色| 欧美日产国产精品| 久久se这里有精品| 久久久国产午夜精品| av在线播放不卡| 亚洲成人av中文| 日韩精品一区在线观看| 高清日韩电视剧大全免费| 亚洲女人的天堂| 欧美精品第1页| 精品一区二区久久久| 日本一区二区免费在线| 色综合久久久久综合| 日日噜噜夜夜狠狠视频欧美人| 欧美tk—视频vk| 成人一区二区三区| 亚洲成人免费视频| www国产成人免费观看视频 深夜成人网| 高潮精品一区videoshd| 亚洲午夜久久久久| 久久综合久久综合亚洲| 日本道免费精品一区二区三区|