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

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

?? scc.c

?? 這是新華龍(www.xhl.xom.xn)開發的
?? C
?? 第 1 頁 / 共 4 頁
字號:
	case CL_SERIAL_LINE:
	case CL_KISS:
		free(scc->fifo.buf);
	default:
		break;
	}
	free(scc);
	Sccchan[ifp->dev] = NULL;
	restore(i_state);
	return 0;
}

/* de-activate SCC driver on program exit */
void
sccstop()
{
	if(Sccinfo.init){			/* was it initialized? */
		maskoff(Sccinfo.ivec);		/* disable the interrupt */
		setirq(Sccinfo.ivec,Orgivec);	/* restore original interrupt vector */
	}
}

/* perform ioctl on SCC (async) channel
 * this is used for SLIP mode only, and will read/set the line speed
 */
static int32
scc_aioctl(ifp,cmd,set,val)
struct iface *ifp;
int cmd;
int set;
int32 val;
{
	struct sccchan *scc;
	unsigned int brgrate;

	scc = Sccchan[ifp->dev];

	switch(cmd){
	case PARAM_SPEED:
		if(set){
			brgrate = scc_speed(scc,16,val);
			scc->speed = Sccinfo.clk / (32L * (brgrate + 2));
		}
		return scc->speed;
	}
	return 0;
}

/* perform ioctl on SCC (sdlc) channel
 * this is used for AX.25 mode only, and will set the "kiss" parameters
 */
static int32
scc_sioctl(ifp,cmd,set,val)
struct iface *ifp;
int cmd;
int set;
int32 val;
{
	struct sccchan *scc;
	unsigned int brgrate;
	int i_state;
	
	scc = Sccchan[ifp->dev];

	switch(cmd){
	case PARAM_SPEED:
		if(set){
			if(val == 0)
				scc->extclock = 1;
			else {
			    brgrate = scc_speed(scc,32,val);/* init SCC speed */
			    scc->speed = Sccinfo.clk / (64L * (brgrate + 2));/* calc real speed */
			}
		}
		return scc->speed;
	case PARAM_TXDELAY:
		if(set)
			scc->a.txdelay = val;
		return scc->a.txdelay;
	case PARAM_PERSIST:
		if(set)
			scc->a.persist = val;
		return scc->a.persist;
	case PARAM_SLOTTIME:
		if(set)
			scc->a.slottime = val;
		return scc->a.slottime;
	case PARAM_TXTAIL:
		if(set)
			scc->a.tailtime = val;
		return scc->a.tailtime;
	case PARAM_FULLDUP:
		if(set)
			scc->a.fulldup = val;
		return scc->a.fulldup;
	case PARAM_WAIT:
		if(set)
			scc->a.waittime = val;
		return scc->a.waittime;
	case PARAM_MAXKEY:
		if(set)
			scc->a.maxkeyup = val;
		return scc->a.maxkeyup;
	case PARAM_MIN:
		if(set)
			scc->a.mintime = val;
		return scc->a.mintime;
	case PARAM_IDLE:
		if(set)
			scc->a.idletime = val;
		return scc->a.idletime;
	case PARAM_DTR:
		if(set){
			if(val)
				scc->wreg[R5] |= DTR;
			else
				scc->wreg[R5] &= ~DTR;

			i_state = dirps();
			if(scc->a.tstate == IDLE && scc->timercount == 0)
				scc->timercount = 1;	/* force an update */
			restore(i_state);
		}
		return (scc->wreg[R5] & DTR) ? 1 : 0;
	case PARAM_GROUP:
		if(set)
			scc->group = val;
		return scc->group;
	}
	return -1;
}

/* start SCC transmitter when it is idle (SLIP/KISS mode only) */
static void
scc_sstart(scc)
register struct sccchan *scc;
{
	if(scc->tbp != NULL ||	/* busy */
	 scc->sndq == NULL)	/* no work */
		return;

	scc->tbp = dequeue(&scc->sndq);
	WRREG(scc->data,FR_END);
}

/* show SCC status */
int
dosccstat()
{
	register struct sccchan *scc;
	int i;

	if(!Sccinfo.init){
		printf("SCC driver not initialized\n");
		return 0;
	}
	printf("Ch Iface    Sent   Rcvd   Error Space Overr   Rxints   Txints   Exints   Spints\n");

	for(i = 0; i <= Sccinfo.maxchan; i++){
		if((scc = Sccchan[i]) == NULL)
			continue;

		if(scc->int_receive == scc_asyrx)
			printf("%2d %-6s  ** asynch ** %7lu %5u %5u %8lu %8lu %8lu %8lu\n",i,scc->iface->name,
			    scc->rxerrs,scc->nospace,scc->rovers,
			    scc->rxints,scc->txints,scc->exints,scc->spints);
		else
			printf("%2d %-6s %6lu %6lu %7lu %5u %5u %8lu %8lu %8lu %8lu\n",i,scc->iface->name,
			    scc->enqueued,scc->rxframes,scc->rxerrs,scc->nospace,scc->rovers,
			    scc->rxints,scc->txints,scc->exints,scc->spints);
	}
	return 0;
}

/* send raw frame to SCC. used for AX.25 */
static int
scc_raw(
struct iface *ifp,
struct mbuf **bpp
){
	struct sccchan *scc;
	int i_state;

	dump(ifp,IF_TRACE_OUT,*bpp);
	ifp->rawsndcnt++;
	ifp->lastsent = secclock();

	scc = Sccchan[ifp->dev];

	if (scc->tx_inhibit){		/* transmitter inhibit */
		free_p(bpp);
		return -1;
    }

	enqueue(&scc->sndq,bpp);		/* enqueue packet */
	scc->enqueued++;

	i_state = dirps();

	if(scc->a.tstate == IDLE){	/* when transmitter is idle */
		scc->a.tstate = DEFER;	/* start the key-up sequence */
		scc->a.maxdefer = TPS * scc->a.idletime /
			scc->a.slottime;
		scc->timercount = scc->a.waittime;
	}
	restore(i_state);
	return 0;
}

static int
scc_send(
int dev,
struct mbuf **bpp
){
	struct sccchan *scc;

	scc = Sccchan[dev];
	enqueue(&scc->sndq,bpp);

	if(scc->tbp == NULL)
		scc_sstart(scc);
	return(0);
}

/* initialize interface for AX.25 use */
static int
scc_call(ifp,call)
register struct iface *ifp;
char *call;
{
	uint8 out[AXALEN];

	ifp->hwaddr = mallocw(AXALEN);
	if(setcall(out,call) == 0)
		memcpy(ifp->hwaddr,out,AXALEN);
	else
		memcpy(ifp->hwaddr,Mycall,AXALEN);
	return 0;
}

/* Interrupt handlers for asynchronous modes (kiss, slip) */

/* Transmitter interrupt handler */
/* This routine sends data from mbufs in SLIP format */
static void
scc_asytx(scc)
register struct sccchan *scc;
{
	register struct mbuf *bp;

	scc->txints++;

	if(scc->txchar != 0){		/* a character pending for transmit? */
		WRREG(scc->data,scc->txchar);	/* send it now */
		scc->txchar = 0;		/* next time, ignore it */
		return;
	}

	if(scc->tbp == NULL){	/* nothing to send? */
		if((scc->tbp = scc->sndq) != NULL){ /* dequeue next frame */
			scc->sndq = scc->sndq->anext;
			WRREG(scc->data,FR_END);	/* send FR_END to flush line garbage */
		} else {
			WRREG(scc->ctrl,RES_Tx_P);	/* else only reset pending int */
		}
		return;
	}
	while ((bp = scc->tbp)->cnt == 0){ /* nothing left in this mbuf? */
		bp = bp->next;			/* save link to next */

		free_mbuf(&scc->tbp);

		if((scc->tbp = bp) == NULL){ /* see if more mbufs follow */
			WRREG(scc->data,FR_END);	/* frame complete, send FR_END */
			return;
		}
	}
	/* now bp = scc->tbp (either from while or from if stmt above) */

	WRREG(scc->data,*(bp->data));	/* just send the character */
	bp->cnt--;				/* decrease mbuf byte count */
	bp->data++;				/* and increment the data pointer */
}

/* External/Status interrupt handler */
static void
scc_asyex(scc)
register struct sccchan *scc;
{
	register unsigned char status,changes;

	scc->exints++;
	status = RDREG(scc->ctrl);
	changes = status ^ scc->status;

	if(changes & BRK_ABRT){		/* BREAK? */
		if((status & BRK_ABRT) == 0)	/* BREAK now over? */
			VOID(RDREG(scc->data));	/* read the NUL character */
	}
	scc->status = status;
	WRREG(scc->ctrl,RES_EXT_INT);
}

/* Receiver interrupt handler under NOS.
 * Since the higher serial protocol routines are all written to work
 * well with the routines in 8250.c, it makes sense to handle
 * asynch i/o with the 8530 in a similar manner. Therefore, these
 * routines are as close to their counterparts in 8250.c as possible.
 */
 
static void
scc_asyrx(scc)
register struct sccchan *scc;
{
	register struct fifo *fp;
	char c;

	scc->rxints++;

	fp = &(scc->fifo);
	do {
		c = RDREG(scc->data);
		if(fp->cnt != fp->bufsize){
			*fp->wp++ = c;
			if(fp->wp >= &fp->buf[fp->bufsize])
				fp->wp = fp->buf;
			fp->cnt++;
		} else
			scc->nospace++;
	} while(RDREG(scc->ctrl) & Rx_CH_AV);
	ksignal(fp,1);	/* eventually move this to timer routine */
}

/* Blocking read from asynch input.
 * Essentially the same as get_asy() in 8250.c
 * See comments in asyrxint().
 */
static int
get_scc(dev)
int dev;
{
	register struct fifo *fp;
	uint8 c;
	int tmp;
	int i_state;

	fp = &(Sccchan[dev]->fifo);

	for(;;){
		i_state = dirps();
		tmp = fp->cnt;
		if(tmp != 0){
			fp->cnt--;
			restore(i_state);
			break;
		}
		restore(i_state);
		kwait(fp);
	}
	c = *fp->rp++;
	if(fp->rp >= &fp->buf[fp->bufsize])
		fp->rp = fp->buf;

	return c;
}

int
scc_frameup(dev)
int dev;
{
	Sccchan[dev]->rxframes++;
	return 0;
}

/* Receive Special Condition interrupt handler */
static void
scc_asysp(scc)
register struct sccchan *scc;
{
	register unsigned char status;

	scc->spints++;

	status = rd(scc,R1);		/* read receiver status */
	VOID(RDREG(scc->data));		/* flush offending character */

	if(status & (CRC_ERR | Rx_OVR))		/* did a framing error or overrun occur ? */
		scc->rovers++;			/* report as overrun */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区四区在线观看| 蜜臀久久久久久久| 久久免费偷拍视频| 91精品国产综合久久香蕉麻豆| 色av成人天堂桃色av| 色综合天天综合在线视频| 不卡欧美aaaaa| av激情综合网| 在线观看日韩国产| 精品视频一区二区不卡| 欧美一区日韩一区| 精品国产不卡一区二区三区| 国产夜色精品一区二区av| 国产色91在线| 亚洲视频 欧洲视频| 亚洲免费观看高清完整版在线观看| 欧美国产禁国产网站cc| 亚洲手机成人高清视频| 视频一区欧美精品| 日韩av一区二区三区四区| 国产偷国产偷亚洲高清人白洁| 国产精品素人一区二区| 亚洲精品日韩一| 麻豆精品一二三| 国产+成+人+亚洲欧洲自线| 色综合久久九月婷婷色综合| 8x8x8国产精品| 欧美激情一区在线观看| 亚洲亚洲人成综合网络| 精品一区二区三区影院在线午夜| 不卡一区二区三区四区| 91精品国模一区二区三区| 国产精品欧美一级免费| 亚洲18女电影在线观看| 国产不卡在线播放| 欧美日韩亚洲综合| 久久婷婷综合激情| 中文字幕日韩一区二区| 午夜成人免费电影| 国产精品一二三| 欧美日韩精品一区二区三区| 国产女主播一区| 青青草97国产精品免费观看| 97精品电影院| 久久久久久一二三区| 天天综合天天综合色| 成人短视频下载| 日韩欧美国产高清| 亚洲午夜视频在线| 99视频在线精品| 国产日韩欧美综合在线| 奇米综合一区二区三区精品视频| 91麻豆免费观看| 国产精品婷婷午夜在线观看| 久久97超碰色| 欧美大片拔萝卜| 丝袜美腿高跟呻吟高潮一区| 91浏览器在线视频| 久久久久久久久久美女| 蜜桃一区二区三区四区| 欧美精品视频www在线观看| 亚洲精品乱码久久久久久黑人| 国产一区二区三区久久久| 欧美大片在线观看一区| 日韩精品三区四区| 欧美欧美午夜aⅴ在线观看| 自拍偷在线精品自拍偷无码专区 | 中文字幕一区二区在线播放| 国产资源在线一区| 欧美电影免费观看高清完整版在线观看 | 午夜精品一区二区三区电影天堂| 91在线精品秘密一区二区| 欧美国产综合一区二区| 懂色一区二区三区免费观看 | 国产一区二区三区四| 精品国产精品一区二区夜夜嗨| 裸体健美xxxx欧美裸体表演| 欧美电影免费观看完整版| 国产成人av影院| 国产亚洲成av人在线观看导航| 国产一区二区在线看| 久久精品人人做| av色综合久久天堂av综合| 亚洲蜜臀av乱码久久精品蜜桃| 欧美私模裸体表演在线观看| 亚洲成av人片一区二区| 日韩一区二区麻豆国产| 激情六月婷婷久久| 中文字幕av在线一区二区三区| 成人av资源在线观看| 一区二区久久久久| 欧美日韩一二区| 精品亚洲成a人在线观看| 中文字幕电影一区| 日本久久精品电影| 日韩国产精品久久久久久亚洲| 欧美电影免费观看高清完整版在线观看| 久久国产麻豆精品| 国产精品视频在线看| 欧美日韩成人一区| 国内精品免费在线观看| 中文字幕一区二区日韩精品绯色| 欧美色男人天堂| 看片的网站亚洲| 亚洲美女在线一区| 欧美不卡一区二区三区四区| av在线不卡网| 久久99久国产精品黄毛片色诱| 国产精品久久久久久久裸模| 在线成人高清不卡| www.日韩精品| 精品一区二区免费看| 日韩美女久久久| 精品国精品自拍自在线| 在线观看中文字幕不卡| 国产精品一区二区免费不卡| 亚洲国产精品久久久男人的天堂| 精品国产99国产精品| 欧美在线视频你懂得| 国产成人在线视频网站| 日本亚洲一区二区| 亚洲欧美日本韩国| 久久久久国色av免费看影院| 欧美日韩在线三级| 91丨九色丨蝌蚪丨老版| 国产成人综合亚洲91猫咪| 日本va欧美va欧美va精品| 亚洲视频在线一区观看| 欧美激情综合网| 久久久精品免费网站| 欧美一级生活片| 欧美日韩国产另类一区| 色综合天天天天做夜夜夜夜做| 国产资源精品在线观看| 久久国内精品自在自线400部| 亚洲综合色在线| 尤物在线观看一区| 亚洲欧洲av在线| 欧美国产成人精品| 国产欧美一区二区精品婷婷| 日韩欧美的一区| 欧美一级欧美三级在线观看| 欧美日韩中文字幕一区| 欧美专区亚洲专区| 欧美性猛片aaaaaaa做受| 91小视频在线观看| 99视频一区二区| 波多野结衣视频一区| www.亚洲免费av| 91亚洲精品乱码久久久久久蜜桃| 欧美人伦禁忌dvd放荡欲情| 在线观看成人小视频| 日本韩国欧美一区| 欧美视频一二三区| 欧美日韩国产首页在线观看| 88在线观看91蜜桃国自产| 777奇米四色成人影色区| 91精品国产综合久久久久久久 | 日韩欧美国产综合| www国产成人| 精品伦理精品一区| 久久久久国产精品人| 国产欧美一区二区精品忘忧草| 国产精品理论在线观看| 亚洲人成网站精品片在线观看| 亚洲靠逼com| 视频一区中文字幕国产| 九九九精品视频| 波多野洁衣一区| 在线观看日韩一区| 欧美不卡视频一区| 亚洲国产精品国自产拍av| 1区2区3区精品视频| 亚洲成人av电影在线| 国产一区二区三区免费看| 99在线视频精品| 91精品婷婷国产综合久久性色 | 一本久道中文字幕精品亚洲嫩| 欧美日韩国产在线播放网站| 精品久久久久久久一区二区蜜臀| 国产日产亚洲精品系列| 一区二区三区波多野结衣在线观看| 亚洲成人免费看| 国产成人免费在线观看不卡| 欧美午夜理伦三级在线观看| 日韩欧美国产电影| 亚洲免费在线看| 麻豆久久久久久久| 91麻豆产精品久久久久久| 337p亚洲精品色噜噜狠狠| 欧美激情一区不卡| 日韩高清在线一区| thepron国产精品| 日韩精品一区在线观看| 亚洲视频一二区| 国产盗摄女厕一区二区三区| 欧美精品在线一区二区三区| 中文一区一区三区高中清不卡| 日韩影视精彩在线| 91一区在线观看|