亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲图片欧美色图| 国产精品一区一区三区| 久久国产福利国产秒拍| 91视频免费看| 日本一区免费视频| 午夜国产不卡在线观看视频| 成人国产在线观看| 精品国产伦一区二区三区免费| 亚洲精品少妇30p| 国产风韵犹存在线视精品| 9191久久久久久久久久久| 亚洲欧美日韩在线不卡| 粉嫩高潮美女一区二区三区| 欧美一级视频精品观看| 午夜精品一区二区三区免费视频| 成人深夜在线观看| 久久久精品日韩欧美| 裸体歌舞表演一区二区| 欧美疯狂性受xxxxx喷水图片| 最新热久久免费视频| 国产99一区视频免费| 26uuu另类欧美亚洲曰本| 麻豆成人av在线| 欧美一区中文字幕| 天堂影院一区二区| 欧美精品aⅴ在线视频| 亚洲福中文字幕伊人影院| 91麻豆精品在线观看| 一区在线播放视频| 91在线精品一区二区| 亚洲私人黄色宅男| 色欧美乱欧美15图片| 亚洲欧美日韩国产中文在线| 色婷婷综合在线| 亚洲精品伦理在线| 欧美三级日韩在线| 五月激情丁香一区二区三区| 欧美一区二区三区视频免费 | 国产精品午夜免费| 国产综合久久久久影院| 久久久一区二区三区捆绑**| 国产一区二区免费视频| 国产肉丝袜一区二区| 99久久婷婷国产| 亚洲一区免费视频| 欧美日本韩国一区| 精品一区二区三区免费| 国产欧美综合在线| 91在线视频播放地址| 亚洲动漫第一页| 91精品国产免费| 国产一区二区精品在线观看| 欧美国产综合一区二区| 欧美主播一区二区三区| 日本va欧美va瓶| 国产日韩欧美a| 色狠狠一区二区| 裸体健美xxxx欧美裸体表演| 国产丝袜美腿一区二区三区| www.一区二区| 丝袜a∨在线一区二区三区不卡| 久久综合九色综合97_久久久| 成人在线一区二区三区| 亚洲国产一区在线观看| 欧美成人vps| av一区二区三区| 日韩不卡一区二区三区| 欧美激情中文字幕一区二区| 欧美中文字幕一二三区视频| 精品综合久久久久久8888| 亚洲三级免费电影| 欧美一卡2卡3卡4卡| jlzzjlzz亚洲日本少妇| 人人爽香蕉精品| 亚洲欧美另类小说视频| 精品久久久网站| 在线观看亚洲精品视频| 国内外精品视频| 亚洲成人先锋电影| 国产精品乱人伦| 日韩欧美卡一卡二| 91电影在线观看| 久久这里只精品最新地址| 国产91精品一区二区麻豆亚洲| 亚洲电影中文字幕在线观看| 欧美经典一区二区| 日韩一区二区电影网| 色av成人天堂桃色av| 国产91精品一区二区麻豆网站 | 裸体一区二区三区| 亚洲精品成人精品456| 国产欧美精品区一区二区三区 | 色网站国产精品| 风间由美中文字幕在线看视频国产欧美| 亚洲国产精品欧美一二99| 国产精品毛片无遮挡高清| 日韩一区二区三区免费观看| 欧美三级乱人伦电影| av在线一区二区三区| 国产精华液一区二区三区| 人人爽香蕉精品| 丝袜亚洲另类丝袜在线| 亚洲一区二区高清| 亚洲精品国久久99热| 国产精品国模大尺度视频| 久久天堂av综合合色蜜桃网| 日韩免费高清视频| 欧美高清性hdvideosex| 欧美日韩一区不卡| 欧美探花视频资源| 欧美吞精做爰啪啪高潮| 欧美亚一区二区| 欧美亚洲国产一区二区三区 | 9191精品国产综合久久久久久| 欧美亚洲国产bt| 欧美日韩中文国产| 欧美三级三级三级| 欧美喷潮久久久xxxxx| 91精选在线观看| 日韩一区二区麻豆国产| 精品美女一区二区| 久久精子c满五个校花| 久久亚洲一区二区三区四区| 久久久久久久综合狠狠综合| 久久亚洲影视婷婷| 国产精品久久久久久久久快鸭| 国产精品短视频| 亚洲最新视频在线观看| 五月天中文字幕一区二区| 男女性色大片免费观看一区二区| 日本v片在线高清不卡在线观看| 日精品一区二区| 久久黄色级2电影| 国产不卡视频一区二区三区| 99天天综合性| 欧美蜜桃一区二区三区| 欧美一二三四区在线| 久久久www成人免费毛片麻豆 | 欧美成人精精品一区二区频| 精品国产免费一区二区三区香蕉| 日本一区二区三区国色天香| 国产精品毛片无遮挡高清| 亚洲一区免费在线观看| 麻豆91精品91久久久的内涵| 从欧美一区二区三区| 欧美视频精品在线观看| 日韩一区二区影院| 中日韩免费视频中文字幕| 亚洲福中文字幕伊人影院| 国产麻豆9l精品三级站| 色综合久久66| 欧美大片在线观看| 亚洲精选视频免费看| 美女精品一区二区| 91麻豆国产香蕉久久精品| 91麻豆精品国产91久久久久 | 日韩黄色免费电影| 丁香婷婷综合网| 欧美电影在线免费观看| 国产精品理论片| 久久黄色级2电影| 在线观看免费亚洲| 久久久精品国产99久久精品芒果| 亚洲国产精品久久人人爱蜜臀| 国产精品自在在线| 欧美日韩在线综合| 亚洲视频网在线直播| 看电视剧不卡顿的网站| 色av成人天堂桃色av| 久久精品一级爱片| 日本美女一区二区| 91欧美激情一区二区三区成人| 久久综合成人精品亚洲另类欧美 | 久久97超碰色| 欧美日韩一级视频| 亚洲私人黄色宅男| 粉嫩13p一区二区三区| 日韩一二三四区| 天天综合日日夜夜精品| 91福利在线观看| 综合色天天鬼久久鬼色| 高清免费成人av| 2023国产精品| 久久机这里只有精品| 欧美一区二区久久| 婷婷六月综合亚洲| 91九色02白丝porn| 成人欧美一区二区三区白人| 国产成人精品免费视频网站| 精品久久久影院| 久久国产精品99久久久久久老狼| 91精品免费在线| 日本不卡免费在线视频| 欧美日韩精品久久久| 亚洲成人1区2区| 欧美人狂配大交3d怪物一区| 日韩在线播放一区二区| 欧美久久久久久蜜桃| 日韩电影在线观看一区| 91麻豆精品国产91久久久|