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

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

?? n8250.c

?? TCPIP協議包
?? 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一区二区三区免费野_久草精品视频
天天综合日日夜夜精品| 精品国产乱码久久久久久免费| 国产高清久久久| 美女网站视频久久| 毛片av一区二区三区| 久久99精品国产麻豆婷婷洗澡| 亚洲最大成人综合| 美国十次综合导航| 福利一区二区在线观看| 成人av综合一区| 日本精品视频一区二区| 99免费精品视频| 一本久久a久久精品亚洲| 欧美综合一区二区三区| 日韩一区二区三区三四区视频在线观看| 色94色欧美sute亚洲线路二| 国产成人综合视频| 91美女片黄在线观看| 欧美色网站导航| 国产亚洲一区二区三区四区| 国产精品成人一区二区三区夜夜夜| 亚洲一区二区在线观看视频| 日韩中文字幕av电影| jlzzjlzz亚洲日本少妇| 欧美一卡二卡三卡| 亚洲另类春色校园小说| 韩国三级在线一区| 日韩视频在线一区二区| 日韩成人一级片| 日韩精品资源二区在线| 激情图片小说一区| 国产精品伦理在线| 8x8x8国产精品| 99re热这里只有精品视频| 91麻豆精品国产91久久久使用方法 | 在线影院国内精品| 91在线免费视频观看| 日韩一区二区三区高清免费看看 | 免费的国产精品| 1024国产精品| 日韩国产欧美在线视频| 久久激情综合网| 99久精品国产| 日本一区二区高清| 99久久99久久久精品齐齐| 中文字幕五月欧美| av福利精品导航| 综合激情成人伊人| 91福利国产精品| 五月天中文字幕一区二区| 日韩一区二区三区在线观看| 久久国产精品第一页| 欧美日韩一区三区四区| 欧美老年两性高潮| 欧美一区二区三区色| 美国三级日本三级久久99 | 国产精品99久久久久久宅男| 久久精品免费在线观看| 国产米奇在线777精品观看| 日韩欧美的一区二区| 免费成人av资源网| 精品国产凹凸成av人导航| av在线不卡电影| 日本在线不卡一区| 亚洲视频一区在线观看| 日本韩国欧美国产| 中文字幕一区二区5566日韩| 亚洲国产日韩精品| 欧美一区二区二区| 成人黄色软件下载| 亚洲成人免费视| 亚洲综合免费观看高清完整版| 在线观看免费一区| 国产一区视频导航| 亚洲已满18点击进入久久| 国产日韩精品久久久| 亚洲精品一区二区三区香蕉| 在线电影欧美成精品| 欧美在线观看一区二区| 99久久久无码国产精品| 亚洲一区二区av电影| 国产麻豆精品久久一二三| 69久久99精品久久久久婷婷| 国产在线精品不卡| 日本不卡123| 五月天丁香久久| 五月天激情综合| 日韩—二三区免费观看av| 亚洲国产一区视频| 首页亚洲欧美制服丝腿| 韩国一区二区三区| 国产高清在线观看免费不卡| 蜜桃一区二区三区在线| 精品无人码麻豆乱码1区2区| 日本成人中文字幕在线视频| 福利电影一区二区| 亚洲激情中文1区| 亚洲欧洲99久久| 亚洲国产成人精品视频| 日韩电影在线一区二区三区| 亚洲mv在线观看| 久久精品99久久久| 高清国产午夜精品久久久久久| 国产91精品一区二区麻豆网站 | 国产成人av电影在线观看| 成人精品视频.| 欧美一级日韩一级| 亚洲天堂精品在线观看| 黑人巨大精品欧美一区| 97se亚洲国产综合自在线不卡| 在线亚洲人成电影网站色www| 欧美丰满一区二区免费视频| 日韩一级在线观看| 一个色综合av| 91麻豆自制传媒国产之光| 日韩欧美电影在线| 亚洲电影一级片| 国产一区二区在线看| 99国产欧美另类久久久精品| 欧美不卡在线视频| 午夜视频一区二区三区| 91成人免费电影| 亚洲女人小视频在线观看| av在线播放一区二区三区| 久久色.com| 日韩理论片一区二区| 日韩在线一区二区| 91在线视频观看| 中文字幕在线免费不卡| 99视频有精品| 亚洲乱码中文字幕| 欧美亚洲愉拍一区二区| 亚洲欧洲成人自拍| 国产精品123区| 中文字幕一区二区三区在线播放 | 成人综合婷婷国产精品久久免费| 日韩你懂的在线播放| 国产一区视频在线看| 国产精品欧美综合在线| 91在线视频网址| 日本不卡一区二区三区高清视频| 欧美一三区三区四区免费在线看 | 成人永久免费视频| 337p日本欧洲亚洲大胆精品| 久久97超碰色| 国产精品视频一二三| 97精品国产露脸对白| 亚洲成av人影院| 国产亚洲精品中文字幕| 成人黄色在线网站| 亚洲激情网站免费观看| 欧美综合亚洲图片综合区| 午夜激情久久久| 久久久久久久电影| 在线观看亚洲a| 韩国成人福利片在线播放| 亚洲日穴在线视频| 久久综合国产精品| 欧美性猛交xxxx黑人交| 国产成人综合网站| 秋霞av亚洲一区二区三| 精品福利视频一区二区三区| 成人免费观看视频| 男人的j进女人的j一区| 中文字幕一区二区三区精华液 | 成人国产精品视频| 久久国产婷婷国产香蕉| 日韩国产精品久久| 亚洲乱码国产乱码精品精98午夜| 久久免费看少妇高潮| 91精品国产综合久久精品图片| 91激情五月电影| 欧美三级韩国三级日本一级| 国精产品一区一区三区mba视频| 国产精品久久久久久妇女6080| 日韩小视频在线观看专区| 色哦色哦哦色天天综合| 国产伦精品一区二区三区视频青涩 | 麻豆国产精品官网| 狠狠色狠狠色合久久伊人| 国产一区二区精品久久91| 国产麻豆欧美日韩一区| 久久国产精品色| 国产激情视频一区二区三区欧美| 国产久卡久卡久卡久卡视频精品| 国产一本一道久久香蕉| 国产99久久久国产精品潘金| 日本韩国精品一区二区在线观看| 91原创在线视频| 色婷婷香蕉在线一区二区| 色综合久久88色综合天天| 欧美丝袜丝交足nylons图片| 欧美三区在线视频| 久久综合色鬼综合色| 亚洲欧美在线另类| 国内欧美视频一区二区| 色综合咪咪久久| 91麻豆精品国产自产在线| 久久久影视传媒| 日本美女一区二区三区视频|