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

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

?? uartlite.c

?? xilinx uartlite serial driver for linux
?? C
字號:
/* * uartlite.c: Serial driver for Xilinx uartlite serial controller * * Peter Korsgaard <jacmet@sunsite.dk> * * This file is licensed under the terms of the GNU General Public License * version 2.  This program is licensed "as is" without any warranty of any * kind, whether express or implied. */#include <linux/platform_device.h>#include <linux/module.h>#include <linux/console.h>#include <linux/serial.h>#include <linux/serial_core.h>#include <linux/tty.h>#include <linux/delay.h>#include <linux/interrupt.h>#include <asm/io.h>#define ULITE_MAJOR		204#define ULITE_MINOR		187#define ULITE_NR_UARTS		4/* For register details see datasheet:   http://www.xilinx.com/bvdocs/ipcenter/data_sheet/opb_uartlite.pdf*/#define ULITE_RX		0x00#define ULITE_TX		0x04#define ULITE_STATUS		0x08#define ULITE_CONTROL		0x0c#define ULITE_REGION		16#define ULITE_STATUS_RXVALID	0x01#define ULITE_STATUS_RXFULL	0x02#define ULITE_STATUS_TXEMPTY	0x04#define ULITE_STATUS_TXFULL	0x08#define ULITE_STATUS_IE		0x10#define ULITE_STATUS_OVERRUN	0x20#define ULITE_STATUS_FRAME	0x40#define ULITE_STATUS_PARITY	0x80#define ULITE_CONTROL_RST_TX	0x01#define ULITE_CONTROL_RST_RX	0x02#define ULITE_CONTROL_IE	0x10static struct uart_port ports[ULITE_NR_UARTS];static int ulite_receive(struct uart_port *port, int stat){	struct tty_struct *tty = port->info->tty;	unsigned char ch = 0;	char flag = TTY_NORMAL;	if ((stat & (ULITE_STATUS_RXVALID | ULITE_STATUS_OVERRUN		     | ULITE_STATUS_FRAME)) == 0)		return 0;	/* stats */	if (stat & ULITE_STATUS_RXVALID) {		port->icount.rx++;		ch = readb(port->membase + ULITE_RX);		if (stat & ULITE_STATUS_PARITY)			port->icount.parity++;	}	if (stat & ULITE_STATUS_OVERRUN)		port->icount.overrun++;	if (stat & ULITE_STATUS_FRAME)		port->icount.frame++;	/* drop byte with parity error if IGNPAR specificed */	if (stat & port->ignore_status_mask & ULITE_STATUS_PARITY)		stat &= ~ULITE_STATUS_RXVALID;	stat &= port->read_status_mask;	if (stat & ULITE_STATUS_PARITY)		flag = TTY_PARITY;	stat &= ~port->ignore_status_mask;	if (stat & ULITE_STATUS_RXVALID)		tty_insert_flip_char(tty, ch, flag);	if (stat & ULITE_STATUS_FRAME)		tty_insert_flip_char(tty, 0, TTY_FRAME);	if (stat & ULITE_STATUS_OVERRUN)		tty_insert_flip_char(tty, 0, TTY_OVERRUN);	return 1;}static int ulite_transmit(struct uart_port *port, int stat){	struct circ_buf *xmit  = &port->info->xmit;	if (stat & ULITE_STATUS_TXFULL)		return 0;	if (port->x_char) {		writeb(port->x_char, port->membase + ULITE_TX);		port->x_char = 0;		port->icount.tx++;		return 1;	}	if (uart_circ_empty(xmit) || uart_tx_stopped(port))		return 0;	writeb(xmit->buf[xmit->tail], port->membase + ULITE_TX);	xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE-1);	port->icount.tx++;	/* wake up */	if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)		uart_write_wakeup(port);	return 1;}static irqreturn_t ulite_isr(int irq, void *dev_id){	struct uart_port *port = (struct uart_port *)dev_id;	int busy;	do {		int stat = readb(port->membase + ULITE_STATUS);		busy  = ulite_receive(port, stat);		busy |= ulite_transmit(port, stat);	} while (busy);	tty_flip_buffer_push(port->info->tty);	return IRQ_HANDLED;}static unsigned int ulite_tx_empty(struct uart_port *port){	unsigned long flags;	unsigned int ret;	spin_lock_irqsave(&port->lock, flags);	ret = readb(port->membase + ULITE_STATUS);	spin_unlock_irqrestore(&port->lock, flags);	return ret & ULITE_STATUS_TXEMPTY ? TIOCSER_TEMT : 0;}static unsigned int ulite_get_mctrl(struct uart_port *port){	return TIOCM_CTS | TIOCM_DSR | TIOCM_CAR;}static void ulite_set_mctrl(struct uart_port *port, unsigned int mctrl){	/* N/A */}static void ulite_stop_tx(struct uart_port *port){	/* N/A */}static void ulite_start_tx(struct uart_port *port){	ulite_transmit(port, readb(port->membase + ULITE_STATUS));}static void ulite_stop_rx(struct uart_port *port){	/* don't forward any more data (like !CREAD) */	port->ignore_status_mask = ULITE_STATUS_RXVALID | ULITE_STATUS_PARITY		| ULITE_STATUS_FRAME | ULITE_STATUS_OVERRUN;}static void ulite_enable_ms(struct uart_port *port){	/* N/A */}static void ulite_break_ctl(struct uart_port *port, int ctl){	/* N/A */}static int ulite_startup(struct uart_port *port){	int ret;	ret = request_irq(port->irq, ulite_isr,			  IRQF_DISABLED | IRQF_SAMPLE_RANDOM, "uartlite", port);	if (ret)		return ret;	writeb(ULITE_CONTROL_RST_RX | ULITE_CONTROL_RST_TX,	       port->membase + ULITE_CONTROL);	writeb(ULITE_CONTROL_IE, port->membase + ULITE_CONTROL);	return 0;}static void ulite_shutdown(struct uart_port *port){	writeb(0, port->membase + ULITE_CONTROL);	readb(port->membase + ULITE_CONTROL); /* dummy */	free_irq(port->irq, port);}static void ulite_set_termios(struct uart_port *port, struct ktermios *termios,			      struct ktermios *old){	unsigned long flags;	unsigned int baud;	spin_lock_irqsave(&port->lock, flags);	port->read_status_mask = ULITE_STATUS_RXVALID | ULITE_STATUS_OVERRUN		| ULITE_STATUS_TXFULL;	if (termios->c_iflag & INPCK)		port->read_status_mask |=			ULITE_STATUS_PARITY | ULITE_STATUS_FRAME;	port->ignore_status_mask = 0;	if (termios->c_iflag & IGNPAR)		port->ignore_status_mask |= ULITE_STATUS_PARITY			| ULITE_STATUS_FRAME | ULITE_STATUS_OVERRUN;	/* ignore all characters if CREAD is not set */	if ((termios->c_cflag & CREAD) == 0)		port->ignore_status_mask |=			ULITE_STATUS_RXVALID | ULITE_STATUS_PARITY			| ULITE_STATUS_FRAME | ULITE_STATUS_OVERRUN;	/* update timeout */	baud = uart_get_baud_rate(port, termios, old, 0, 460800);	uart_update_timeout(port, termios->c_cflag, baud);	spin_unlock_irqrestore(&port->lock, flags);}static const char *ulite_type(struct uart_port *port){	return port->type == PORT_UARTLITE ? "uartlite" : NULL;}static void ulite_release_port(struct uart_port *port){	release_mem_region(port->mapbase, ULITE_REGION);	iounmap(port->membase);	port->membase = NULL;}static int ulite_request_port(struct uart_port *port){	if (!request_mem_region(port->mapbase, ULITE_REGION, "uartlite")) {		dev_err(port->dev, "Memory region busy\n");		return -EBUSY;	}	port->membase = ioremap(port->mapbase, ULITE_REGION);	if (!port->membase) {		dev_err(port->dev, "Unable to map registers\n");		release_mem_region(port->mapbase, ULITE_REGION);		return -EBUSY;	}	return 0;}static void ulite_config_port(struct uart_port *port, int flags){	if (!ulite_request_port(port))		port->type = PORT_UARTLITE;}static int ulite_verify_port(struct uart_port *port, struct serial_struct *ser){	/* we don't want the core code to modify any port params */	return -EINVAL;}static struct uart_ops ulite_ops = {	.tx_empty	= ulite_tx_empty,	.set_mctrl	= ulite_set_mctrl,	.get_mctrl	= ulite_get_mctrl,	.stop_tx	= ulite_stop_tx,	.start_tx	= ulite_start_tx,	.stop_rx	= ulite_stop_rx,	.enable_ms	= ulite_enable_ms,	.break_ctl	= ulite_break_ctl,	.startup	= ulite_startup,	.shutdown	= ulite_shutdown,	.set_termios	= ulite_set_termios,	.type		= ulite_type,	.release_port	= ulite_release_port,	.request_port	= ulite_request_port,	.config_port	= ulite_config_port,	.verify_port	= ulite_verify_port};#ifdef CONFIG_SERIAL_UARTLITE_CONSOLEstatic void ulite_console_wait_tx(struct uart_port *port){	int i;	/* wait up to 10ms for the character(s) to be sent */	for (i = 0; i < 10000; i++) {		if (readb(port->membase + ULITE_STATUS) & ULITE_STATUS_TXEMPTY)			break;		udelay(1);	}}static void ulite_console_putchar(struct uart_port *port, int ch){	ulite_console_wait_tx(port);	writeb(ch, port->membase + ULITE_TX);}static void ulite_console_write(struct console *co, const char *s,				unsigned int count){	struct uart_port *port = &ports[co->index];	unsigned long flags;	unsigned int ier;	int locked = 1;	if (oops_in_progress) {		locked = spin_trylock_irqsave(&port->lock, flags);	} else		spin_lock_irqsave(&port->lock, flags);	/* save and disable interrupt */	ier = readb(port->membase + ULITE_STATUS) & ULITE_STATUS_IE;	writeb(0, port->membase + ULITE_CONTROL);	uart_console_write(port, s, count, ulite_console_putchar);	ulite_console_wait_tx(port);	/* restore interrupt state */	if (ier)		writeb(ULITE_CONTROL_IE, port->membase + ULITE_CONTROL);	if (locked)		spin_unlock_irqrestore(&port->lock, flags);}static int __init ulite_console_setup(struct console *co, char *options){	struct uart_port *port;	int baud = 9600;	int bits = 8;	int parity = 'n';	int flow = 'n';	if (co->index < 0 || co->index >= ULITE_NR_UARTS)		return -EINVAL;	port = &ports[co->index];	/* not initialized yet? */	if (!port->membase)		return -ENODEV;	if (options)		uart_parse_options(options, &baud, &parity, &bits, &flow);	return uart_set_options(port, co, baud, parity, bits, flow);}static struct uart_driver ulite_uart_driver;static struct console ulite_console = {	.name	= "ttyUL",	.write	= ulite_console_write,	.device	= uart_console_device,	.setup	= ulite_console_setup,	.flags	= CON_PRINTBUFFER,	.index	= -1, /* Specified on the cmdline (e.g. console=ttyUL0 ) */	.data	= &ulite_uart_driver,};static int __init ulite_console_init(void){	register_console(&ulite_console);	return 0;}console_initcall(ulite_console_init);#endif /* CONFIG_SERIAL_UARTLITE_CONSOLE */static struct uart_driver ulite_uart_driver = {	.owner		= THIS_MODULE,	.driver_name	= "uartlite",	.dev_name	= "ttyUL",	.major		= ULITE_MAJOR,	.minor		= ULITE_MINOR,	.nr		= ULITE_NR_UARTS,#ifdef CONFIG_SERIAL_UARTLITE_CONSOLE	.cons		= &ulite_console,#endif};static int __devinit ulite_probe(struct platform_device *pdev){	struct resource *res, *res2;	struct uart_port *port;	if (pdev->id < 0 || pdev->id >= ULITE_NR_UARTS)		return -EINVAL;	if (ports[pdev->id].membase)		return -EBUSY;	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);	if (!res)		return -ENODEV;	res2 = platform_get_resource(pdev, IORESOURCE_IRQ, 0);	if (!res2)		return -ENODEV;	port = &ports[pdev->id];	port->fifosize	= 16;	port->regshift	= 2;	port->iotype	= UPIO_MEM;	port->iobase	= 1; /* mark port in use */	port->mapbase	= res->start;	port->membase	= NULL;	port->ops	= &ulite_ops;	port->irq	= res2->start;	port->flags	= UPF_BOOT_AUTOCONF;	port->dev	= &pdev->dev;	port->type	= PORT_UNKNOWN;	port->line	= pdev->id;	uart_add_one_port(&ulite_uart_driver, port);	platform_set_drvdata(pdev, port);	return 0;}static int ulite_remove(struct platform_device *pdev){	struct uart_port *port = platform_get_drvdata(pdev);	platform_set_drvdata(pdev, NULL);	if (port)		uart_remove_one_port(&ulite_uart_driver, port);	/* mark port as free */	port->membase = NULL;	return 0;}static struct platform_driver ulite_platform_driver = {	.probe	= ulite_probe,	.remove	= ulite_remove,	.driver	= {		   .owner = THIS_MODULE,		   .name  = "uartlite",		   },};int __init ulite_init(void){	int ret;	ret = uart_register_driver(&ulite_uart_driver);	if (ret)		return ret;	ret = platform_driver_register(&ulite_platform_driver);	if (ret)		uart_unregister_driver(&ulite_uart_driver);	return ret;}void __exit ulite_exit(void){	platform_driver_unregister(&ulite_platform_driver);	uart_unregister_driver(&ulite_uart_driver);}module_init(ulite_init);module_exit(ulite_exit);MODULE_AUTHOR("Peter Korsgaard <jacmet@sunsite.dk>");MODULE_DESCRIPTION("Xilinx uartlite serial driver");MODULE_LICENSE("GPL");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合丝袜美腿| 国产成人免费网站| 欧美日韩免费高清一区色橹橹 | 欧美色精品在线视频| 亚洲激情中文1区| 色老头久久综合| 天天综合色天天综合色h| 欧美人伦禁忌dvd放荡欲情| 日韩—二三区免费观看av| 日韩免费性生活视频播放| 国产乱码一区二区三区| 中文字幕视频一区二区三区久| 91免费国产在线| 日韩在线一区二区| 国产三级一区二区三区| 色综合天天视频在线观看| 亚洲成av人综合在线观看| 亚洲激情在线激情| 日韩视频一区二区三区在线播放| 国产精品香蕉一区二区三区| 亚洲免费在线观看| 欧美一区二区视频在线观看2020| 国产黄色精品网站| 亚洲国产视频一区二区| 欧美videofree性高清杂交| 成人黄色大片在线观看| 天天综合网 天天综合色| 国产欧美日韩综合| 欧美浪妇xxxx高跟鞋交| 成人网男人的天堂| 日韩制服丝袜先锋影音| 中文字幕日韩一区| 日韩视频免费观看高清完整版在线观看 | 91蜜桃婷婷狠狠久久综合9色| 91丨porny丨蝌蚪视频| 亚洲国产精品麻豆| 欧美激情一区二区三区蜜桃视频| 欧美午夜精品一区二区蜜桃 | 大桥未久av一区二区三区中文| 亚洲一二三专区| 久久久蜜桃精品| 欧美日韩一区二区三区四区| 成人午夜视频福利| 久久超级碰视频| 亚洲成va人在线观看| 亚洲欧洲日韩在线| 欧美精品一区二区三| 欧美私人免费视频| 99久久精品免费| 国产高清久久久久| 另类专区欧美蜜桃臀第一页| 一区二区在线观看视频在线观看| 国产网站一区二区三区| 日韩亚洲欧美成人一区| 欧美亚洲综合在线| 一本一本久久a久久精品综合麻豆| 国产成人一级电影| 精品一区二区三区视频| 奇米影视在线99精品| 五月天精品一区二区三区| 亚洲欧美一区二区在线观看| 久久久99久久| 久久新电视剧免费观看| 日韩一区二区三区观看| 欧美久久一区二区| 91精品办公室少妇高潮对白| 91丨porny丨户外露出| www.综合网.com| 成人在线综合网| 成人黄色在线视频| 国产成人免费在线视频| 高清成人在线观看| 高清免费成人av| 成人国产视频在线观看| av亚洲产国偷v产偷v自拍| 成人黄动漫网站免费app| 国产白丝精品91爽爽久久 | 成人一级片在线观看| 国产成人免费在线观看不卡| 国产精品影视天天线| 国产一区二区三区av电影 | 久久久噜噜噜久久人人看| 精品99久久久久久| 国产调教视频一区| 中文字幕亚洲区| 亚洲人成人一区二区在线观看| 亚洲女人的天堂| 亚洲一区二区三区美女| 日韩精品高清不卡| 国内精品免费在线观看| 国产成人亚洲综合a∨婷婷| 成人一级黄色片| 在线这里只有精品| 欧美一区二区三区公司| 亚洲精品在线免费播放| 国产精品天天摸av网| 亚洲天堂成人在线观看| 亚洲国产精品麻豆| 极品尤物av久久免费看| av在线不卡电影| 欧美日韩一区在线| 精品日产卡一卡二卡麻豆| 欧美国产激情一区二区三区蜜月| 最新国产精品久久精品| 五月天精品一区二区三区| 国产露脸91国语对白| 91啦中文在线观看| 欧美老女人在线| 国产精品午夜在线| 午夜精品福利一区二区三区av | 国产精品一级在线| 99久久精品免费看| 91精品在线免费| 国产精品乱码一区二区三区软件| 亚洲午夜在线电影| 国产一区91精品张津瑜| 色成年激情久久综合| 精品久久国产老人久久综合| 1024成人网色www| 久久国产精品一区二区| 色就色 综合激情| 久久天天做天天爱综合色| 亚洲在线视频网站| 国产精品1区2区3区在线观看| 欧美午夜精品免费| 欧美国产在线观看| 麻豆精品在线播放| 欧洲精品中文字幕| 国产精品国产三级国产普通话99 | 日本美女一区二区三区| a亚洲天堂av| 亚洲精品一线二线三线| 亚洲成人午夜电影| heyzo一本久久综合| 精品国产髙清在线看国产毛片| 亚洲精品videosex极品| 国产成人av自拍| 精品国产乱码久久久久久牛牛 | 经典三级一区二区| 欧美三级在线看| 亚洲视频一区在线观看| 国产91精品入口| 久久久综合网站| 久久精品国产精品亚洲精品| 在线免费av一区| 亚洲女同女同女同女同女同69| 成人黄色a**站在线观看| 久久麻豆一区二区| 国产中文字幕精品| 5月丁香婷婷综合| 日日欢夜夜爽一区| 精品视频在线视频| 亚洲综合久久久久| 色先锋资源久久综合| 中文字幕一区日韩精品欧美| 丁香婷婷综合激情五月色| 欧美v日韩v国产v| 麻豆国产欧美日韩综合精品二区 | 亚洲大尺度视频在线观看| 99国产精品久久久久久久久久| 国产精品天干天干在观线| 国产.欧美.日韩| 国产精品麻豆网站| av动漫一区二区| 中文字幕在线播放不卡一区| 波多野结衣欧美| 亚洲人一二三区| 99国产精品久久久久| 亚洲天堂a在线| 欧日韩精品视频| 日韩不卡在线观看日韩不卡视频| 在线综合视频播放| 久久精品国产亚洲5555| 日韩视频免费观看高清完整版| 麻豆91精品视频| 国产欧美日产一区| 91免费国产视频网站| 亚洲国产一区视频| 91精品国产日韩91久久久久久| 日本中文在线一区| 精品成人免费观看| 成人ar影院免费观看视频| 亚洲欧美日韩综合aⅴ视频| 91一区二区在线观看| 亚洲成av人片一区二区三区| 91精品国模一区二区三区| 久久国产精品露脸对白| 久久精品亚洲精品国产欧美| 成人a级免费电影| 亚洲综合一区二区精品导航| 欧美喷潮久久久xxxxx| 九色综合国产一区二区三区| 国产精品网站在线观看| 欧洲精品一区二区三区在线观看| 日韩1区2区3区| 国产女主播在线一区二区| 欧美亚洲国产一区在线观看网站| 免费在线观看视频一区| 国产精品成人在线观看| 欧美人体做爰大胆视频|