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

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

?? tsip_ifc.c

?? gps開發專用的源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
	cmd->buf[3] = extra;
	cmd->len = 4;
	cmd->code = 0x70;
}

void cmd_0x71q (TSIPPKT *cmd)
/* request position-velocity filter parameters */
{
	cmd->len = 0;
	cmd->code = 0x71;
}

void cmd_0x71s (TSIPPKT *cmd,
	short pf,
   TSIP_POS_FILT_PARMS *params)
/* enable position-velocity filter with default parameters */
{
	cmd->buf[0] = pf;
	bPutFloat (&params->flt1, &cmd->buf[1]);
	cmd->buf[5] = params->chr1;
	cmd->buf[6] = params->chr2;
	cmd->buf[7] = params->chr3;
	cmd->buf[8] = params->chr4;
	bPutFloat (&params->flt2, &cmd->buf[9]);
	bPutFloat (&params->flt3, &cmd->buf[13]);
	bPutFloat (&params->flt4, &cmd->buf[17]);
	bPutFloat (&params->flt5, &cmd->buf[21]);
	cmd->buf[25] = params->chr5;
	cmd->len = 26;
	cmd->code = 0x71;
}

void cmd_0x73q (TSIPPKT *cmd)
/* request altitude filter parameters */
{
	cmd->len = 0;
	cmd->code = 0x73;
}

void cmd_0x73s (TSIPPKT *cmd,
	float time_constant)
/* set altitude filter parameters */
{
	bPutFloat (&time_constant, &cmd->buf[0]);
	cmd->len = 4;
	cmd->code = 0x73;
}

void cmd_0x73d (TSIPPKT *cmd)
/* disable altitude filter */
{
	float ftemp;

   ftemp = 1.0;
	bPutFloat (&ftemp, &cmd->buf[0]);
	cmd->len = 4;
	cmd->code = 0x73;
}

void cmd_0x73c (TSIPPKT *cmd)
/* set altitude filter parameters to default */
{
	float ftemp;

   ftemp = 0.0;
	bPutFloat (&ftemp, &cmd->buf[0]);
	cmd->len = 4;
	cmd->code = 0x73;
}

void cmd_0x77q (TSIPPKT *cmd)
/* request DC max age */
{
	cmd->len = 0;
	cmd->code = 0x77;
}

void cmd_0x77s (TSIPPKT *cmd,
	short maxage)
/* request DC max age */
{
	cmd->buf[0]= maxage >> 8;
	cmd->buf[1]= maxage & 0x00ff;
	cmd->len = 2;
	cmd->code = 0x77;
}

void cmd_0x7A_0s  (TSIPPKT *cmd,
	unsigned char nmea_interval,
	unsigned long nmea_mask)
/* set NMEA interval [and message mask] */
{

	cmd->buf[0] = 0;		/* subcode */
	cmd->buf[1] = nmea_interval;
	bPutULong (&nmea_mask, &cmd->buf[2]);
	cmd->len = 6;
	cmd->code = 0x7A;
}

void cmd_0x7A_0q  (TSIPPKT *cmd)
/* request NMEA interval and message mask */
{

	cmd->buf[0] = 0;		/* subcode */
	cmd->len = 1;
	cmd->code = 0x7A;
}


void cmd_0xBBs(TSIPPKT *cmd,
	TSIP_RCVR_CFG *TsipxBB)
	/* set Stinger receiver configuration */
{

	/* Manual  29473-00 Rev B. is in error.  Byte count is 40, not 41. */
	cmd->len		= 40;
	cmd->code	= 0xBB;
   memset (cmd->buf, 0, cmd->len);	/* set reserved bytes to 0 */
   if (TsipxBB->bSubcode == 0)
   {
		cmd->buf[0]	=	0;
		cmd->buf[1]	=	TsipxBB->operating_mode;
		cmd->buf[2]	=	TsipxBB->dgps_mode;
		cmd->buf[3]	=	TsipxBB->dyn_code;
/*		cmd->buf[4]	=	TsipxBB->trackmode; not changeable in v7.52 or 7.68 */
		bPutFloat (&TsipxBB->elev_mask, &cmd->buf[5]);
		bPutFloat (&TsipxBB->cno_mask, &cmd->buf[9]);
		bPutFloat (&TsipxBB->dop_mask, &cmd->buf[13]);
		bPutFloat (&TsipxBB->dop_switch, &cmd->buf[17]);
		cmd->buf[21]	=	TsipxBB->dgps_age_limit;
   }
   else if (TsipxBB->bSubcode == 3)
   {
		cmd->buf[0]	=	3;
		cmd->buf[1]	=	TsipxBB->operating_mode;
		cmd->buf[2]	=	TsipxBB->dgps_mode;
		cmd->buf[3]	=	TsipxBB->dyn_code;
		cmd->buf[6]	=	TsipxBB->trackmode;
		bPutFloat (&TsipxBB->elev_mask, &cmd->buf[15]);
		bPutFloat (&TsipxBB->cno_mask, &cmd->buf[19]);
		bPutFloat (&TsipxBB->dop_mask, &cmd->buf[23]);
		bPutFloat (&TsipxBB->dop_switch, &cmd->buf[27]);
		cmd->buf[35]	=	TsipxBB->dgps_age_limit;
   }
}

void cmd_0xBBq (TSIPPKT *cmd,
	unsigned char subcode)
{

	cmd->len = 1;
	cmd->code = 0xBB;
	cmd->buf[0] = subcode;
}

void cmd_0xBCq  (TSIPPKT *cmd, unsigned char port_num)
/* request receiver port configuration */
{

	cmd->buf[0] = port_num;
	cmd->len = 1;
	cmd->code = 0xBC;
}

void cmd_0xBCs  (TSIPPKT *cmd,
	unsigned char port_num,
	unsigned char in_baud,
	unsigned char out_baud,
	unsigned char data_bits,
	unsigned char parity,
	unsigned char stop_bits,
	unsigned char flow_control,
	unsigned char protocols_in,
	unsigned char protocols_out,
	unsigned char reserved)
/* set receiver port configuration */
{

	cmd->buf[0] = port_num;
	cmd->buf[1] = in_baud;
	cmd->buf[2] = out_baud;
	cmd->buf[3] = data_bits;
	cmd->buf[4] = parity;
	cmd->buf[5] = stop_bits;
	cmd->buf[6] = flow_control;
	cmd->buf[7] = protocols_in;
	cmd->buf[8] = protocols_out;
	cmd->buf[9] = reserved;
	cmd->len = 10;
	cmd->code = 0xBC;
}

/**** Superpackets ****/
void cmd_0x8E03q (TSIPPKT *cmd)
/* request Channel B configuration for dual-port operation */
{
	cmd->len = 1;
	cmd->code = 0x8E;
   cmd->buf[0] = 0x03;
}

void cmd_0x8E03s (TSIPPKT *cmd,
	unsigned char baud_out, unsigned char baud_inp,
   unsigned char char_code, unsigned char stopbitcode,
   unsigned char output_mode, unsigned char input_mode)
/* set Channel B configuration for dual-port operation */
{
	cmd->buf[0] = 0x03;
	cmd->buf[1] = baud_out;		/* XMT baud rate */
	cmd->buf[2] = baud_inp;		/* RCV baud rate */
	cmd->buf[3] = char_code;	   /* parity and #bits per byte */
	cmd->buf[4] = stopbitcode;	/* number of stop bits code */
	cmd->buf[5] = output_mode;	/* Ch. A transmission mode */
	cmd->buf[6] = input_mode;	/* Ch. A reception mode */
	cmd->len = 7;
	cmd->code = 0x8E;
}

void cmd_0x8E15q  (TSIPPKT *cmd)
/* datum query */
{

	cmd->len = 1;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x15;
}

void cmd_0x8E15s  (TSIPPKT *cmd, unsigned char datum_index)
/* datum set - standard parameters */
{

	cmd->buf[0] = 0x15;
	cmd->buf[1] = 0;	/* datum index is a short; this is always 0 */
	cmd->buf[2] = datum_index;
	cmd->len = 3;
	cmd->code = 0x8E;
}

void cmd_0x8E15s_2  (TSIPPKT *cmd, double datum_coeffs[5])
/* datum set - special parameters */
{

	cmd->buf[0] = 0x15;  /*Subcode 15 */
	bPutDouble (&datum_coeffs[0], &cmd->buf[1]);
	bPutDouble (&datum_coeffs[1], &cmd->buf[9]);
	bPutDouble (&datum_coeffs[2], &cmd->buf[17]);
	bPutDouble (&datum_coeffs[3], &cmd->buf[25]);
	bPutDouble (&datum_coeffs[4], &cmd->buf[33]);
	cmd->len = 41;
	cmd->code = 0x8E;
}

void cmd_0x8E19q (TSIPPKT *cmd)
/* UTM msg status */
{

	cmd->len = 1;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x19;
}

void cmd_0x8E19e (TSIPPKT *cmd)
/* UTM msg enable/disable */
{

	cmd->len = 2;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x19;
	cmd->buf[1] = 0x45;
}

void cmd_0x8E19d (TSIPPKT *cmd)
/* UTM msg enable/disable */
{

	cmd->len = 2;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x19;
	cmd->buf[1] = 0x44;
}

void cmd_0x8E20q (TSIPPKT *cmd)
/* UTM SP msg query */
{

	cmd->len = 1;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x20;
}

void cmd_0x8E20d (TSIPPKT *cmd)
/* 8F-20 msg auto-output disable */
{

	cmd->len = 2;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x20;
	cmd->buf[1] = 0;
}

void cmd_0x8E20e (TSIPPKT *cmd)
/* 8F-20 msg auto-output enable */
{

	cmd->len = 2;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x20;
	cmd->buf[1] = 1;
}


void cmd_0x8E26s (TSIPPKT *cmd)
/* 8F-26 save to SEEPROM */
{

	cmd->len = 1;
	cmd->code = 0x8E;
	cmd->buf[0] = 0x26;
}

void cmd_0x8E40q (TSIPPKT *cmd)
{
	cmd->len = 1;
   cmd->code = 0x8E;
   cmd->buf[ 0] = 0x40;
}

void cmd_0x8E40s (TSIPPKT *cmd,
	unsigned char Flags,
	unsigned char HeartBeatSentence,
   short TopOfHourOffset,
	short Frequency,
   char VehicleID[4])
{
	cmd->len = 11;
   cmd->code = 0x8E;
   cmd->buf[ 0] = 0x40;
   cmd->buf[ 1] = Flags;
   cmd->buf[ 2] = HeartBeatSentence;
   bPutShort (&TopOfHourOffset, &cmd->buf[3]);
   bPutShort (&Frequency, &cmd->buf[5]);
   cmd->buf[ 7] = VehicleID[0];
   cmd->buf[ 8] = VehicleID[1];
   cmd->buf[ 9] = VehicleID[2];
   cmd->buf[10] = VehicleID[3];
}

void cmd_0x8E  (TSIPPKT *cmd, unsigned char hexbyte[], unsigned char hexnum)
/* turn on superpacket, etc. */
{
	memcpy (cmd->buf, hexbyte, (short)hexnum);
	cmd->len = hexnum;
	cmd->code = 0x8E;
}

void cmd_0xxx  (TSIPPKT *cmd, unsigned char hexcode, unsigned char hexbyte[], unsigned char hexnum)
/* turn on superpacket, etc. */
{
	memcpy (cmd->buf, hexbyte, (short)hexnum);
	cmd->len = hexnum;
	cmd->code = hexcode;
}

#ifdef BYTESWAP
static short bGetShort (unsigned char *bp)
{
	short outval;
   unsigned char *optr;

   optr = (unsigned char*)&outval + 1;
   *optr-- = *bp++;
   *optr = *bp;
	return outval;
}

static long bGetLong (unsigned char *bp)
{
	long outval;
   unsigned char *optr;

   optr = (unsigned char*)&outval + 3;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr = *bp;
	return outval;
}

static unsigned long bGetULong (unsigned char *bp)
{
	unsigned long outval;
   unsigned char *optr;

   optr = (unsigned char*)&outval + 3;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr = *bp;
	return outval;
}

static float bGetSingle (unsigned char *bp)
{
	float outval;
   unsigned char *optr;

   optr = (unsigned char*)&outval + 3;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr = *bp;
	return outval;
}

static double bGetDouble (unsigned char *bp)
{
	double outval;
   unsigned char *optr;

   optr = (unsigned char*)&outval + 7;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr-- = *bp++;
   *optr = *bp;
	return outval;
}

#else	/* not BYTESWAP */

#define bGetShort(bp) 	(*(short*)(bp))
#define bGetLong(bp) 	(*(long*)(bp))
#define bGetULong(bp) 	(*(unsigned long*)(bp))
#define bGetSingle(bp) 	(*(float*)(bp))
#define bGetDouble(bp)	(*(double*)(bp))

#endif


/**/
void tsip_input_proc (TSIPPKT *rpt, short inbyte)
/* reads bytes until serial buffer is empty or a complete report
 * has been received; end of report is signified by DLE ETX.
 */
{                 
	unsigned char newbyte;

	if (inbyte & 0xFF00) return;

	newbyte = (unsigned char)(inbyte & 0x00FF);
	switch (rpt->status)
	{
	case TSIP_PARSED_DLE_1:
		switch (newbyte)
		{
		case 0:
		case ETX:
      	/* illegal TSIP IDs */
         rpt->len = 0;
			rpt->status = TSIP_PARSED_EMPTY;
			break;
		case DLE:
      	/* try normal message start again */
			rpt->len = 0;
			rpt->status = TSIP_PARSED_DLE_1;
			break;
		default:
      	/* legal TSIP ID; start message */
			rpt->code = newbyte;
         rpt->len = 0;
			rpt->status = TSIP_PARSED_DATA;
			break;
		}
		break;
	case TSIP_PARSED_DATA:
		switch (newbyte) {
		case DLE:
      	/* expect DLE or ETX next */
			rpt->status = TSIP_PARSED_DLE_2;
			break;
		default:
      	/* normal data byte  */
			rpt->buf[rpt->len] = newbyte;
			rpt->len++;
         /* no change in rpt->status */
			break;
		}
		break;
	case TSIP_PARSED_DLE_2:
		switch (newbyte) {
		case DLE:
      	/* normal data byte */
			rpt->buf[rpt->len] = newbyte;
			rpt->len++;
			rpt->status = TSIP_PARSED_DATA;
			break;
		case ETX:
			/* end of message; return TRUE here. */
			rpt->status = TSIP_PARSED_FULL;
			break;
		default:
			/* error: treat as TSIP_PARSED_DLE_1; start new report packet */
			rpt->code = newbyte;
         rpt->len = 0;
			rpt->status = TSIP_PARSED_DATA;
		}
		break;
	case TSIP_PARSED_FULL:
	case TSIP_PARSED_EMPTY:
	default:
		switch (newbyte) {
		case DLE:
      	/* normal message start */
			rpt->len = 0;
			rpt->status = TSIP_PARSED_DLE_1;
			break;
		default:
			/* error: ignore newbyte */
			rpt->len = 0;
			rpt->status = TSIP_PARSED_EMPTY;
		}
		break;
	}
	if (rpt->len > MAX_RPTBUF) {
		/* error: start new report packet */
		rpt->status = TSIP_PARSED_EMPTY;
		rpt->len = 0;
	}
}

/**/
short rpt_0x3D (TSIPPKT *rpt,
	unsigned char *tx_baud_index,
	unsigned char *rx_baud_index,
	unsigned char *char_format_index,
	unsigned char *stop_bits,
	unsigned char *tx_mode_index,
	unsigned char *rx_mode_index)
/* Channel A configuration for dual port operation */
{
	unsigned char *buf;
	buf = rpt->buf;

	if (rpt->len != 6) return TRUE;
	*tx_baud_index = buf[0];
	*rx_baud_index = buf[1];
	*char_format_index = buf[2];
	*stop_bits = (buf[3] == 0x07) ? 1 : 2;
	*tx_mode_index = buf[4];
	*rx_mode_index = buf[5];
	return FALSE;
}

/**/
short rpt_0x40 (TSIPPKT *rpt,
	unsigned char *sv_prn,
	short *week_num,
	float *t_zc,
	float *eccentricity,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品18久久久久久久久久久久| 色88888久久久久久影院野外| 国产在线国偷精品免费看| 色综合一区二区三区| 国产精品免费看片| 国产成人在线色| 欧美国产欧美综合| 国产一区二区免费视频| 精品va天堂亚洲国产| 美女尤物国产一区| 精品国产一区二区三区av性色| 偷拍自拍另类欧美| 欧美最猛黑人xxxxx猛交| 一区二区三区美女| 欧美性欧美巨大黑白大战| 一区二区在线观看视频在线观看| 国产高清精品网站| 国产精品妹子av| 91麻豆自制传媒国产之光| 最近中文字幕一区二区三区| 欧美色手机在线观看| 午夜视频在线观看一区二区| 日韩三级视频在线观看| 国产一区在线精品| 亚洲综合av网| 亚洲天堂网中文字| 欧美丰满少妇xxxxx高潮对白| 国内精品嫩模私拍在线| 亚洲柠檬福利资源导航| 精品国产免费人成电影在线观看四季| 韩日av一区二区| 亚洲一二三区在线观看| 精品久久久久久久久久久久久久久| 国产成人免费视频| 亚洲国产一区二区在线播放| 国产视频不卡一区| 91麻豆精品91久久久久久清纯| 精品一区二区三区的国产在线播放| 一区二区三区四区不卡在线| 久久精品综合网| 欧美一区2区视频在线观看| 91在线精品一区二区三区| 国产一区二区不卡老阿姨| 亚洲欧美日本韩国| 国产精品久久久久久一区二区三区| 欧美一二三四在线| 欧美一级理论片| 欧美精品第1页| 精品视频在线视频| 欧美性淫爽ww久久久久无| 99精品欧美一区二区三区小说| 懂色av中文字幕一区二区三区| 欧美一级黄色大片| 欧美色图片你懂的| 欧美夫妻性生活| 欧美一级黄色片| 51久久夜色精品国产麻豆| 91精品国产入口| 欧美va亚洲va| 中文字幕不卡在线播放| 中文字幕在线观看不卡| 亚洲免费观看视频| 亚洲图片欧美综合| 免费在线看成人av| 床上的激情91.| 色综合天天综合网国产成人综合天 | 日本精品裸体写真集在线观看 | 精品在线亚洲视频| 成人免费看视频| 成人免费在线播放视频| 亚洲欧美另类图片小说| 成人午夜av在线| 精品一区二区三区视频| 99re热这里只有精品免费视频| 精品国产欧美一区二区| 日韩和欧美一区二区三区| 欧美日韩一区高清| 亚洲自拍偷拍麻豆| 精品国产伦理网| 亚洲一区二区三区视频在线播放| 99久久99久久免费精品蜜臀| 精品成人a区在线观看| 亚洲国产乱码最新视频| 91久久香蕉国产日韩欧美9色| 久久久久久影视| 国产久卡久卡久卡久卡视频精品| 日韩一区二区三区电影在线观看| 亚洲永久免费av| 91亚洲男人天堂| 亚洲欧洲另类国产综合| 国产乱子伦一区二区三区国色天香| 欧美日韩久久不卡| 亚洲激情成人在线| 91免费版在线看| 亚洲免费观看高清完整版在线观看熊 | 久久久久青草大香线综合精品| 免费看日韩a级影片| 91精品国产色综合久久不卡蜜臀| 国产欧美精品一区二区色综合| 国产精品99久久久久久似苏梦涵 | 国产精品女上位| 99久久99久久精品免费看蜜桃| 中文字幕中文字幕一区二区 | 国产成人亚洲综合a∨猫咪| 日韩女优制服丝袜电影| 麻豆精品视频在线观看免费| 日韩午夜电影av| 国产精品影视网| 亚洲综合在线电影| 精品区一区二区| 丁香啪啪综合成人亚洲小说| 亚洲午夜一区二区| 日韩美女一区二区三区四区| 成人免费高清在线观看| 亚洲综合色视频| 国产日韩亚洲欧美综合| 欧美四级电影网| 91精品1区2区| 狠狠久久亚洲欧美| 亚洲成人动漫在线免费观看| 久久精品男人天堂av| 欧美日韩视频在线一区二区| 91国产成人在线| 欧美性一二三区| 欧美一区二区三区影视| 日韩一区二区三区高清免费看看| 欧美日韩国产精品自在自线| 色综合久久久久综合| 国产成人综合精品三级| 国产综合久久久久久鬼色| 免费看日韩a级影片| 天堂久久一区二区三区| 一区二区三区**美女毛片| 久久久www免费人成精品| 欧美一区二区视频在线观看2020 | 亚洲综合自拍偷拍| 欧美激情一区二区三区四区| 久久免费看少妇高潮| 欧美va亚洲va国产综合| 欧美一二三区精品| 日韩欧美的一区二区| 欧美不卡视频一区| 日韩影院在线观看| 亚洲天堂精品在线观看| 亚洲午夜久久久久中文字幕久| 日韩电影一区二区三区| 欧美日韩国产高清一区二区三区| 一区二区三区在线播放| 亚洲第四色夜色| 丁香一区二区三区| 欧美久久久久久久久| 中文一区二区完整视频在线观看 | 91精品欧美一区二区三区综合在| 日韩精品中文字幕一区二区三区| 国产精品网友自拍| 日韩不卡一二三区| 色综合久久中文字幕| 欧美一级欧美一级在线播放| 欧美性三三影院| 在线一区二区观看| a美女胸又www黄视频久久| 欧美亚洲动漫另类| 色婷婷av久久久久久久| 成人黄页在线观看| 粗大黑人巨茎大战欧美成人| 日韩福利视频网| 日韩成人av影视| 六月丁香婷婷久久| 午夜免费久久看| 亚洲精品国产精品乱码不99| 国产精品高清亚洲| 国产精品久久三区| 亚洲一区二区三区四区不卡| 国产精品系列在线| 亚洲国产精品精华液ab| 国产精品无码永久免费888| 国产日韩欧美精品在线| 欧美激情艳妇裸体舞| 国产精品久久久久9999吃药| 亚洲日本一区二区| 亚洲日本一区二区三区| 洋洋成人永久网站入口| 天天亚洲美女在线视频| 男女视频一区二区| 国产一区二区三区观看| www.欧美日韩| 欧美日韩精品一区二区三区蜜桃| 欧美日韩免费观看一区二区三区| 欧美国产丝袜视频| 国产精品三级视频| 国产mv日韩mv欧美| 久久美女艺术照精彩视频福利播放| 中文字幕一区av| 精品在线播放免费| 欧美一区二区人人喊爽| 在线播放91灌醉迷j高跟美女 | 91久久精品一区二区二区| 国产91精品精华液一区二区三区 | 国产精品国产精品国产专区不蜜| 秋霞午夜av一区二区三区|