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

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

?? n8250.c

?? 很好的TCP_IP協議源代碼分析,很適用很好
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* OS- and machine-dependent stuff for the 8250 asynch chip on a IBM-PC
 */
#include <stdio.h>
#include <dos.h>
#include <errno.h>
#include "global.h"
#include "mbuf.h"
#include "proc.h"
#include "iface.h"
#include "n8250.h"
#include "asy.h"
#include "devparam.h"
#include "nospc.h"
#include "dialer.h"

static int asyrxint(struct asy *asyp);
static void asytxint(struct asy *asyp);
static void asymsint(struct asy *asyp);
static void pasy(struct asy *asyp);
static INTERRUPT (far *(asycom)(struct asy *))(void);

struct asy Asy[ASY_MAX];

struct fport Fport[FPORT_MAX];

static INTERRUPT (*Fphand[FPORT_MAX])() = {
fp0vec,
};

/* ASY interrupt handlers */
static INTERRUPT (*Handle[ASY_MAX])() = {
asy0vec,asy1vec,asy2vec,asy3vec,asy4vec,asy5vec
};

/* Initialize asynch port "dev" */
int
asy_init(dev,ifp,base,irq,bufsize,trigchar,speed,cts,rlsd,chain)
int dev;
struct iface *ifp;
int base;
int irq;
uint16 bufsize;
int trigchar;
long speed;
int cts;		/* Use CTS flow control */
int rlsd;		/* Use Received Line Signal Detect (aka CD) */
int chain;		/* Chain interrupts */
{
	register struct fifo *fp;
	register struct asy *ap;
	int i_state;

	ap = &Asy[dev];
	ap->iface = ifp;
	ap->addr = base;
	ap->vec = irq;
	ap->chain = chain;

	/* Set up receiver FIFO */
	fp = &ap->fifo;
	fp->buf = mallocw(bufsize);
	fp->bufsize = bufsize;
	fp->wp = fp->rp = fp->buf;
	fp->cnt = 0;
	fp->hiwat = 0;
	fp->overrun = 0;
	base = ap->addr;
	ap->trigchar = trigchar;

	/* Purge the receive data buffer */
	(void)inportb(base+RBR);

	i_state = dirps();

	/* Save original interrupt vector, mask state, control bits */
	if(ap->vec != -1){
		ap->save.vec = getirq(ap->vec);
		ap->save.mask = getmask(ap->vec);
	}
	ap->save.lcr = inportb(base+LCR);
	ap->save.ier = inportb(base+IER);
	ap->save.mcr = inportb(base+MCR);
	ap->msr = ap->save.msr = inportb(base+MSR);
	ap->save.iir = inportb(base+IIR);

	/* save speed bytes */
	setbit(base+LCR,LCR_DLAB);
	ap->save.divl = inportb(base+DLL);
	ap->save.divh = inportb(base+DLM);
	clrbit(base+LCR,LCR_DLAB);

	/* save modem control flags */
	ap->cts = cts;
	ap->rlsd = rlsd;

	/* Set interrupt vector to SIO handler */
	if(ap->vec != -1)
		setirq(ap->vec,Handle[dev]);

	/* Set line control register: 8 bits, no parity */
	outportb(base+LCR,LCR_8BITS);
	
	/* determine if 16550A, turn on FIFO mode and clear RX and TX FIFOs */
	outportb(base+FCR,FIFO_ENABLE);

	/* According to National ap note AN-493, the FIFO in the 16550 chip
	 * is broken and must not be used. To determine if this is a 16550A
	 * (which has a good FIFO implementation) check that both bits 7
	 * and 6 of the IIR are 1 after setting the fifo enable bit. If
	 * not, don't try to use the FIFO.
	 */
	if ((inportb(base+IIR) & IIR_FIFO_ENABLED) == IIR_FIFO_ENABLED) {
		ap->is_16550a = TRUE;
		outportb(base+FCR,FIFO_SETUP);
	} else {
		/* Chip is not a 16550A. In case it's a 16550 (which has a
		 * broken FIFO), turn off the FIFO bit.
		 */
		outportb(base+FCR,0);
		ap->is_16550a = FALSE;
	}

	/* Turn on receive interrupts and optionally modem interrupts;
	 * leave transmit interrupts off until we actually send data.
	 */
	if(ap->rlsd || ap->cts)
		outportb(base+IER,IER_MS|IER_DAV);
	else
		outportb(base+IER,IER_DAV);

	/* Turn on 8250 master interrupt enable (connected to OUT2) */
	setbit(base+MCR,MCR_OUT2);

	/* Enable interrupt */
	if(ap->vec != -1)
		maskon(ap->vec);
	restore(i_state);

	asy_speed(dev,speed);

	return 0;
}


int
asy_stop(ifp)
struct iface *ifp;
{
	register unsigned base;
	register struct asy *ap;
	struct asydialer *dialer;
	int i_state;

	ap = &Asy[ifp->dev];

	if(ap->iface == NULL)
		return -1;	/* Not allocated */		
	ap->iface = NULL;

	base = ap->addr;

	if(ifp->dstate != NULL){
		dialer = (struct asydialer *)ifp->dstate;
		stop_timer(&dialer->idle);	/* Stop the idle timer, if running */		
		free(dialer);
		ifp->dstate = NULL;
	}
	(void)inportb(base+RBR); /* Purge the receive data buffer */

	if(ap->is_16550a){
		/* Purge hardware FIFOs and disable if we weren't already
		 * in FIFO mode when we entered. Apparently some
		 * other comm programs can't handle 16550s in
		 * FIFO mode; they expect 16450 compatibility mode.
		 */
		outportb(base+FCR,FIFO_SETUP);
		if((ap->save.iir & IIR_FIFO_ENABLED) != IIR_FIFO_ENABLED)
			outportb(base+FCR,0);
	}
	/* Restore original interrupt vector and 8259 mask state */
	i_state = dirps();
	if(ap->vec != -1){
		setirq(ap->vec,ap->save.vec);
		if(ap->save.mask)
			maskon(ap->vec);
		else
			maskoff(ap->vec);
	}

	/* Restore speed regs */
	setbit(base+LCR,LCR_DLAB);
	outportb(base+DLL,ap->save.divl);	/* Low byte */
	outportb(base+DLM,ap->save.divh);	/* Hi byte */
	clrbit(base+LCR,LCR_DLAB);

	/* Restore control regs */
	outportb(base+LCR,ap->save.lcr);
	outportb(base+IER,ap->save.ier);
	outportb(base+MCR,ap->save.mcr);

	restore(i_state);
	free(ap->fifo.buf);
	return 0;
}


/* Set asynch line speed */
int
asy_speed(dev,bps)
int dev;
long bps;
{
	register unsigned base;
	register long divisor;
	struct asy *asyp;
	int i_state;

	if(bps <= 0 || dev >= ASY_MAX)
		return -1;
	asyp = &Asy[dev];
	if(asyp->iface == NULL)
		return -1;

	if(bps == 0)
		return -1;
	asyp->speed = bps;

	base = asyp->addr;
	divisor = BAUDCLK / bps;

	i_state = dirps();

	/* Purge the receive data buffer */
	(void)inportb(base+RBR);
	if (asyp->is_16550a)		/* clear tx+rx fifos */
		outportb(base+FCR,FIFO_SETUP);

	/* Turn on divisor latch access bit */
	setbit(base+LCR,LCR_DLAB);

	/* Load the two bytes of the register */
	outportb(base+DLL,divisor);		/* Low byte */
	outportb(base+DLM,divisor >> 8);	/* Hi byte */

	/* Turn off divisor latch access bit */
	clrbit(base+LCR,LCR_DLAB);

	restore(i_state);
	return 0;
}


/* Asynchronous line I/O control */
int32
asy_ioctl(ifp,cmd,set,val)
struct iface *ifp;
int cmd;
int set;
int32 val;
{
	struct asy *ap = &Asy[ifp->dev];
	uint16 base = ap->addr;

	switch(cmd){
	case PARAM_SPEED:
		if(set)
			asy_speed(ifp->dev,val);
		return ap->speed;
	case PARAM_DTR:
		if(set) {
			writebit(base+MCR,MCR_DTR,(int)val);
		}
		return (inportb(base+MCR) & MCR_DTR) ? TRUE : FALSE;
	case PARAM_RTS:
		if(set) {
			writebit(base+MCR,MCR_RTS,(int)val);
		}
		return (inportb(base+MCR) & MCR_RTS) ? TRUE : FALSE;
	case PARAM_DOWN:
		clrbit(base+MCR,MCR_RTS);
		clrbit(base+MCR,MCR_DTR);
		return FALSE;
	case PARAM_UP:
		setbit(base+MCR,MCR_RTS);
		setbit(base+MCR,MCR_DTR);
		return TRUE;
	}
	return -1;
}
/* Open an asynch port for direct I/O, temporarily suspending any
 * packet-mode operations. Returns device number for asy_write and get_asy
 */
int
asy_open(name)
char *name;
{
	struct iface *ifp;
	int dev;

	if((ifp = if_lookup(name)) == NULL){
		errno = ENODEV;
		return -1;
	}
	if((dev = ifp->dev) >= ASY_MAX || Asy[dev].iface != ifp){
		errno = EINVAL;
		return -1;
	}
	/* Suspend the packet drivers */
	suspend(ifp->rxproc);
	suspend(ifp->txproc);

	/* bring the line up (just in case) */
	if(ifp->ioctl != NULL)
		(*ifp->ioctl)(ifp,PARAM_UP,TRUE,0L);
	return dev;
}
int
asy_close(dev)
int dev;
{
	struct iface *ifp;

	if(dev < 0 || dev >= ASY_MAX){
		errno = EINVAL;
		return -1;
	}
	/* Resume the packet drivers */
	if((ifp = Asy[dev].iface) == NULL){
		errno = EINVAL;
		return -1;
	}
	resume(ifp->rxproc);
	resume(ifp->txproc);
	return 0;
}

/* Send a buffer on the serial transmitter and wait for completion */
int
asy_write(dev,buf,cnt)
int dev;
void *buf;
unsigned short cnt;
{
	register struct dma *dp;
	unsigned base;
	struct asy *asyp;
	int tmp;
	int i_state;
	struct iface *ifp;

	if(dev < 0 || dev >= ASY_MAX)
		return -1;
	asyp = &Asy[dev];
	if((ifp = asyp->iface) == NULL)
		return -1;

	base = asyp->addr;
	dp = &asyp->dma;

	if(dp->busy)
		return -1;	/* Already busy */

	dp->data = buf;
	dp->cnt = cnt;
	dp->busy = 1;

	/* If CTS flow control is disabled or CTS is true,
	 * enable transmit interrupts here so we'll take an immediate
	 * interrupt to get things going. Otherwise let the
	 * modem control interrupt enable transmit interrupts
	 * when CTS comes up. If we do turn on TxE,
	 * "kick start" the transmitter interrupt routine, in case just
	 * setting the interrupt enable bit doesn't cause an interrupt
	 */

	if(!asyp->cts || (asyp->msr & MSR_CTS)){
		setbit(base+IER,IER_TxE);
		asytxint(asyp);
	}
	/* Wait for completion */
	for(;;){
		i_state = dirps();
		tmp = dp->busy;
		restore(i_state);
		if(tmp == 0)
			break;
		kwait(&asyp->dma);
	}
	ifp->lastsent = secclock();
	return cnt;
}

/* Read data from asynch line
 * Blocks until at least 1 byte of data is available.
 * returns number of bytes read, up to 'cnt' max
 */
int
asy_read(dev,buf,cnt)
int dev;
void *buf;
unsigned short cnt;
{
	struct fifo *fp;
	int i_state,tmp;
	uint8 c,*obp;

	if(cnt == 0)
		return 0;

	if(dev < 0 || dev >= ASY_MAX){
		errno = EINVAL;
		return -1;
	}
	fp = &Asy[dev].fifo;
	obp = (uint8 *)buf;
	for(;;){
		/* Atomic read of and subtract from fp->cnt */
		i_state = dirps();
		tmp = fp->cnt;
		if(tmp != 0){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品自线一区二区三区视频| 色欧美88888久久久久久影院| 波波电影院一区二区三区| 欧美性大战xxxxx久久久| 26uuu久久综合| 亚洲成av人影院| 国产91丝袜在线播放0| 56国语精品自产拍在线观看| 国产精品国产三级国产三级人妇 | 综合色天天鬼久久鬼色| 久久99精品国产麻豆不卡| 在线一区二区三区| 国产精品久久一卡二卡| 国产在线播放一区二区三区| 欧美精品在线一区二区| 亚洲六月丁香色婷婷综合久久| 国产69精品久久久久毛片| 久久亚洲精精品中文字幕早川悠里 | 精品国产自在久精品国产| 亚洲综合偷拍欧美一区色| 成人中文字幕合集| 国产亚洲人成网站| 久久精品国产99| 欧美日韩一区二区欧美激情| 亚洲欧美综合色| 成人黄色小视频| 国产午夜精品一区二区三区四区| 久久爱另类一区二区小说| 欧美女孩性生活视频| 亚洲一区在线观看视频| 91成人网在线| 亚洲专区一二三| 色哟哟欧美精品| 亚洲精品久久7777| 日本韩国欧美三级| 亚洲一区二区三区自拍| 欧洲一区二区三区在线| 一区二区三区四区国产精品| 91亚洲大成网污www| 亚洲欧美日韩一区二区 | 国产伦精品一区二区三区免费迷| 日韩欧美精品在线视频| 卡一卡二国产精品| 久久亚洲二区三区| 成人动漫精品一区二区| 亚洲欧美一区二区在线观看| 91女厕偷拍女厕偷拍高清| 一区二区在线看| 欧美日韩精品一区二区天天拍小说| 日韩成人午夜电影| 日韩欧美国产一二三区| 国产一区二区三区四区在线观看 | 久热成人在线视频| 久久这里只有精品首页| 国产成人av自拍| 亚洲视频一区二区在线| 欧美精品一二三| 国产在线不卡一卡二卡三卡四卡| 中文字幕制服丝袜一区二区三区| 91在线免费播放| 天天亚洲美女在线视频| 欧美一区二区三级| 国产精品1区2区3区| 亚洲伦理在线精品| 精品嫩草影院久久| 91在线看国产| 久久精品99国产精品| 国产清纯美女被跳蛋高潮一区二区久久w | 一本大道久久a久久精品综合| 一区二区三区四区国产精品| 日韩精品在线一区| 91黄色免费观看| 国产色91在线| 成人a级免费电影| 日韩欧美国产电影| 国产精品一区二区三区乱码| 亚洲日本va午夜在线电影| 欧美一区二区三区免费视频| 国产成人av福利| 午夜精品久久久久久久久久 | 色哟哟在线观看一区二区三区| 日本三级韩国三级欧美三级| 中日韩av电影| 欧美一级在线视频| 色就色 综合激情| 国产精品99久久久久久似苏梦涵 | 国产精品网曝门| 欧美精品久久天天躁| 成人黄色大片在线观看| 国内外成人在线| 五月开心婷婷久久| 亚洲人成亚洲人成在线观看图片| 欧美成人三级在线| 欧美日韩高清影院| 91香蕉视频mp4| 国产91清纯白嫩初高中在线观看| 麻豆精品国产传媒mv男同| 亚洲另类春色校园小说| 国产嫩草影院久久久久| 久久一夜天堂av一区二区三区 | 日本伊人色综合网| 亚洲免费在线电影| 国产精品二三区| 欧美国产日韩亚洲一区| 欧美草草影院在线视频| 欧美精品乱码久久久久久| 欧美亚洲国产一区在线观看网站| 成人高清视频在线| 成人国产视频在线观看| 国产成人午夜精品影院观看视频 | 丝袜亚洲精品中文字幕一区| 日韩一区欧美小说| 国产精品久久久久三级| 国产精品无圣光一区二区| 精品人在线二区三区| 日韩一区二区影院| 欧美一二区视频| 欧美一区二区三区免费视频| 欧美一区二区黄色| 日韩视频在线观看一区二区| 678五月天丁香亚洲综合网| 69堂亚洲精品首页| 欧美一区二区观看视频| 91精品国产入口| 日韩你懂的在线观看| 精品不卡在线视频| 国产欧美日韩在线| 成人免费在线播放视频| 亚洲欧美在线aaa| 亚洲一二三四在线观看| 午夜精品一区二区三区电影天堂 | 成人理论电影网| jvid福利写真一区二区三区| 99精品欧美一区二区蜜桃免费| 色欧美片视频在线观看在线视频| 在线观看一区二区视频| 欧美日韩黄色一区二区| 欧美一级欧美三级在线观看| 26uuu成人网一区二区三区| 亚洲国产精品av| 亚洲一区二区三区四区中文字幕 | 日韩欧美激情四射| 久久美女艺术照精彩视频福利播放| 国产亚洲人成网站| 亚洲欧美激情在线| 美腿丝袜亚洲一区| 国产不卡在线视频| 欧美日韩精品欧美日韩精品一综合| 91精品国产综合久久小美女| 久久久久久99精品| 亚洲一区av在线| 国产中文字幕一区| 91成人看片片| 亚洲精品在线三区| 一级做a爱片久久| 蜜臀国产一区二区三区在线播放| 国产成人精品亚洲午夜麻豆| 色偷偷久久人人79超碰人人澡| 欧美成人a视频| 亚洲一区二区视频在线观看| 激情综合色播五月| 色综合久久中文综合久久牛| 日韩你懂的在线观看| 亚洲视频一区二区在线| 精品一区二区三区av| 欧美性色黄大片手机版| 国产亚洲女人久久久久毛片| 亚洲一级不卡视频| 波多野结衣亚洲一区| 日韩精品中文字幕一区二区三区| 亚洲精品成人少妇| 国产成人在线视频免费播放| 欧美日韩精品二区第二页| 亚洲欧洲日本在线| 国产乱码一区二区三区| 欧美日韩国产高清一区二区三区| 国产精品初高中害羞小美女文| 蜜桃久久久久久久| 欧美日韩在线亚洲一区蜜芽| 欧美激情一区二区三区全黄| 久久精品免费观看| 欧美一区三区四区| 亚洲国产中文字幕在线视频综合 | 亚洲视频你懂的| 国产美女主播视频一区| 欧美一区二区三区思思人| 亚洲综合男人的天堂| av不卡免费电影| 中日韩av电影| 成人午夜精品在线| 中文字幕av一区二区三区免费看 | 午夜av一区二区三区| 日本精品视频一区二区| 国产精品久久久久一区| 国产98色在线|日韩| 久久综合av免费| 国产麻豆精品95视频| 精品少妇一区二区三区日产乱码 | 精品国产一区二区国模嫣然| 亚洲v精品v日韩v欧美v专区|