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

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

?? n8250.c

?? uCLinux下的一個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一区二区三区免费野_久草精品视频
成人一区二区三区| 成人黄色综合网站| 亚洲妇女屁股眼交7| 亚洲欧美一区二区三区极速播放| 国产精品美女一区二区三区| 国产精品久久久久久久久免费相片| 国产欧美中文在线| 国产精品久久久久婷婷二区次| 亚洲欧洲日韩一区二区三区| 亚洲免费大片在线观看| 午夜精品爽啪视频| 美女任你摸久久| 国精产品一区一区三区mba桃花| 国产一区视频在线看| 国产91清纯白嫩初高中在线观看| 不卡视频免费播放| 欧美日韩国产乱码电影| 精品第一国产综合精品aⅴ| 精品久久免费看| 日本一区二区视频在线观看| 国产精品久久精品日日| 偷拍与自拍一区| 国产成人免费高清| 欧美在线观看视频一区二区 | 久久综合色天天久久综合图片| 精品乱码亚洲一区二区不卡| 国产精品国产三级国产三级人妇| 一区二区欧美视频| 久久99精品国产麻豆婷婷| zzijzzij亚洲日本少妇熟睡| 欧美亚洲一区二区在线| 精品91自产拍在线观看一区| 国产精品剧情在线亚洲| 日韩av在线播放中文字幕| 国产成人精品免费| 911精品产国品一二三产区| 国产视频一区在线观看| 午夜伦欧美伦电影理论片| 高清国产午夜精品久久久久久| 欧美日韩精品欧美日韩精品一| 国产婷婷色一区二区三区在线| 夜夜嗨av一区二区三区网页| 国产一区二区在线观看视频| 欧美亚洲一区三区| 日韩一区日韩二区| 国产成人av福利| 日韩色视频在线观看| 性做久久久久久免费观看欧美| 粉嫩嫩av羞羞动漫久久久| 日韩一二三区不卡| 午夜精品久久久久久久久| 91在线porny国产在线看| 日韩欧美色综合网站| 亚洲不卡一区二区三区| 91蜜桃婷婷狠狠久久综合9色| 久久久影视传媒| 久久电影网站中文字幕| 欧美日韩一区二区三区视频| 亚洲欧美综合网| 成人免费视频一区二区| 久久综合九色综合欧美亚洲| 久久99久久99小草精品免视看| 欧美日韩国产影片| 一区二区成人在线| 91蜜桃传媒精品久久久一区二区| 国产精品视频看| 成人av网站在线观看免费| 国产视频不卡一区| 粉嫩aⅴ一区二区三区四区 | 一本久久精品一区二区| 国产日韩欧美a| 高潮精品一区videoshd| 久久久久综合网| 国产成人a级片| 亚洲国产成人在线| 99精品偷自拍| 亚洲一区在线观看视频| 91麻豆精品国产自产在线观看一区 | 欧美电视剧免费观看| 免费看欧美美女黄的网站| 日韩三级电影网址| 国内不卡的二区三区中文字幕 | 国内精品久久久久影院色| 精品少妇一区二区| 国产福利精品一区二区| 中文字幕一区二区三区乱码在线| 91免费观看视频在线| 舔着乳尖日韩一区| 欧美mv和日韩mv国产网站| 成人精品免费看| 一个色妞综合视频在线观看| 欧美老女人在线| 久久精品国产秦先生| 中文字幕巨乱亚洲| 欧美图片一区二区三区| 裸体歌舞表演一区二区| 国产精品美女一区二区三区| 色就色 综合激情| 麻豆免费看一区二区三区| 国产精品蜜臀在线观看| 欧美日韩亚洲丝袜制服| 国产一区二区在线影院| 亚洲精品视频一区二区| 日韩亚洲电影在线| 不卡av在线免费观看| 免费一级片91| 中文字幕日韩精品一区| 在线播放91灌醉迷j高跟美女| 韩国在线一区二区| 一区二区三区在线视频免费| 欧美成人艳星乳罩| 91国内精品野花午夜精品 | 欧美激情在线一区二区| 欧美亚洲精品一区| 国产伦精品一区二区三区免费| 亚洲精品高清在线观看| 久久久久一区二区三区四区| 欧美日韩三级一区二区| 99在线精品一区二区三区| 美女精品一区二区| 亚洲一区二区中文在线| 国产精品毛片久久久久久久| 欧美成人精品高清在线播放| 91久久线看在观草草青青| 国产成人日日夜夜| 免费人成精品欧美精品| 亚洲综合自拍偷拍| 国产农村妇女精品| 日韩一区二区在线免费观看| 一本在线高清不卡dvd| 国产精品一区二区视频| 日韩成人免费看| 亚洲成人免费观看| 亚洲一区二区偷拍精品| 亚洲欧美电影一区二区| 中文字幕一区av| 国产精品污网站| 欧美国产成人精品| 国产日韩欧美精品综合| 国产亚洲成av人在线观看导航 | 欧美日韩精品免费| 在线看国产一区二区| 91小视频在线| 97se亚洲国产综合在线| 成人黄色网址在线观看| 高清shemale亚洲人妖| 国产呦精品一区二区三区网站| 久久国产免费看| 丝袜美腿高跟呻吟高潮一区| 无码av免费一区二区三区试看 | 欧美精品tushy高清| 欧美性猛交xxxx乱大交退制版| 99久久精品国产观看| 91论坛在线播放| 91成人免费网站| 欧美午夜精品久久久| 在线成人午夜影院| 欧美一级艳片视频免费观看| 日韩精品一区二区三区在线播放 | 欧美丰满嫩嫩电影| 日韩欧美国产系列| 久久色中文字幕| 欧美激情中文字幕一区二区| 国产精品福利一区| 一级日本不卡的影视| 日本不卡一二三| 国产剧情一区在线| 粉嫩13p一区二区三区| 色综合久久久久综合体桃花网| 91国偷自产一区二区三区观看| 在线播放91灌醉迷j高跟美女 | 免费欧美在线视频| 国产综合久久久久影院| 成人美女视频在线看| 日本韩国视频一区二区| 日韩一区二区麻豆国产| 国产亚洲自拍一区| 亚洲狠狠爱一区二区三区| 久久av中文字幕片| kk眼镜猥琐国模调教系列一区二区| 一本到不卡精品视频在线观看| 欧美日韩国产经典色站一区二区三区 | 美腿丝袜一区二区三区| 国产美女av一区二区三区| 色综合久久综合网97色综合| 欧美日韩和欧美的一区二区| 久久―日本道色综合久久| 国产精品白丝在线| 日本不卡中文字幕| 97国产精品videossex| 欧美在线free| 国产日产欧美一区二区视频| 图片区日韩欧美亚洲| 成人性生交大合| 精品少妇一区二区三区免费观看| 亚洲区小说区图片区qvod| 国内成+人亚洲+欧美+综合在线 | 国产精品毛片大码女人| 日本不卡视频在线观看| 91麻豆精品在线观看|