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

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

?? ftdi_sio.c

?? NP-Convert,usb4口轉換器的驅動開發示例.面向Linux.
?? C
?? 第 1 頁 / 共 5 頁
字號:
	/* 3. Convert baudrate to device-specific divisor */	if (!baud) baud = 9600;		switch(priv->chip_type) {	case SIO: /* SIO chip */		chip_name = "SIO";		switch(baud) {		case 300: div_value = ftdi_sio_b300; break;		case 600: div_value = ftdi_sio_b600; break;		case 1200: div_value = ftdi_sio_b1200; break;		case 2400: div_value = ftdi_sio_b2400; break;		case 4800: div_value = ftdi_sio_b4800; break;		case 9600: div_value = ftdi_sio_b9600; break;		case 19200: div_value = ftdi_sio_b19200; break;		case 38400: div_value = ftdi_sio_b38400; break;		case 57600: div_value = ftdi_sio_b57600;  break;		case 115200: div_value = ftdi_sio_b115200; break;		} /* baud */		if (div_value == 0) {  			dbg("%s - Baudrate (%d) requested is not supported", __FUNCTION__,  baud);			div_value = ftdi_sio_b9600;			div_okay = 0;		}		break;	case FT8U232AM: /* 8U232AM chip */		chip_name = "FT8U232AM";		if (baud <= 3000000) {			div_value = ftdi_232am_baud_to_divisor(baud);		} else {	                dbg("%s - Baud rate too high!", __FUNCTION__);			div_value = ftdi_232am_baud_to_divisor(9600);			div_okay = 0;		}		break;	case FT232BM: /* FT232BM chip */	case FT2232C: /* FT2232C chip */	case FT232R: /* FT232R chip */		if (priv->chip_type == FT232R) {			chip_name = "FT232R";		} else if (priv->chip_type == FT2232C) {			chip_name = "FT2232C";		} else {			chip_name = "FT232BM";		}		if (baud <= 3000000) {			div_value = ftdi_232bm_baud_to_divisor(baud);		} else {	                dbg("%s - Baud rate too high!", __FUNCTION__);			div_value = ftdi_232bm_baud_to_divisor(9600);			div_okay = 0;		}		break;	} /* priv->chip_type */	if (div_okay) {		dbg("%s - Baud rate set to %d (divisor 0x%lX) on chip %s",			__FUNCTION__, baud, (unsigned long)div_value, chip_name);	}	return(div_value);}static int get_serial_info(struct usb_serial_port * port, struct serial_struct * retinfo){	struct ftdi_private * priv = (struct ftdi_private*) port->private;	struct serial_struct tmp;	if (!retinfo)		return -EFAULT;	memset(&tmp, 0, sizeof(tmp));	tmp.flags = priv->flags;	tmp.baud_base = priv->baud_base;	tmp.custom_divisor = priv->custom_divisor;	if (copy_to_user(retinfo, &tmp, sizeof(*retinfo)))		return -EFAULT;	return 0;} /* get_serial_info */static int set_serial_info(struct usb_serial_port * port, struct serial_struct * newinfo){ /* set_serial_info */	struct ftdi_private * priv = (struct ftdi_private *) port->private;	struct serial_struct new_serial;	struct ftdi_private old_priv;	if (copy_from_user(&new_serial, newinfo, sizeof(new_serial)))		return -EFAULT;	old_priv = * priv;	/* Do error checking and permission checking */	if (!capable(CAP_SYS_ADMIN)) {		if (((new_serial.flags & ~ASYNC_USR_MASK) !=		     (priv->flags & ~ASYNC_USR_MASK)))			return -EPERM;		priv->flags = ((priv->flags & ~ASYNC_USR_MASK) |			       (new_serial.flags & ASYNC_USR_MASK));		priv->custom_divisor = new_serial.custom_divisor;		goto check_and_exit;	}	if ((new_serial.baud_base != priv->baud_base) &&	    (new_serial.baud_base < 9600))		return -EINVAL;	/* Make the changes - these are privileged changes! */	priv->flags = ((priv->flags & ~ASYNC_FLAGS) |	               (new_serial.flags & ASYNC_FLAGS));		priv->custom_divisor = new_serial.custom_divisor;	port->tty->low_latency = (priv->flags & ASYNC_LOW_LATENCY) ? 1 : 0;check_and_exit:	if ((old_priv.flags & ASYNC_SPD_MASK) !=	     (priv->flags & ASYNC_SPD_MASK)) {		if ((priv->flags & ASYNC_SPD_MASK) == ASYNC_SPD_HI)			port->tty->alt_speed = 57600;		else if ((priv->flags & ASYNC_SPD_MASK) == ASYNC_SPD_VHI)			port->tty->alt_speed = 115200;		else if ((priv->flags & ASYNC_SPD_MASK) == ASYNC_SPD_SHI)			port->tty->alt_speed = 230400;		else if ((priv->flags & ASYNC_SPD_MASK) == ASYNC_SPD_WARP)			port->tty->alt_speed = 460800;		else			port->tty->alt_speed = 0;	}	if (((old_priv.flags & ASYNC_SPD_MASK) !=	     (priv->flags & ASYNC_SPD_MASK)) ||	    (((priv->flags & ASYNC_SPD_MASK) == ASYNC_SPD_CUST) &&	     (old_priv.custom_divisor != priv->custom_divisor))) {		change_speed(port);	}		return (0);} /* set_serial_info *//* * *************************************************************************** * FTDI driver specific functions * *************************************************************************** *//* Common startup subroutine *//* Called from ftdi_SIO_startup, etc. */static int ftdi_common_startup (struct usb_serial *serial){	struct usb_serial_port *port = &serial->port[0];	struct ftdi_private *priv;	int i ;	struct urb *urb; 		dbg("%s",__FUNCTION__);	priv = kmalloc(sizeof(struct ftdi_private), GFP_KERNEL);	if (!priv){		err("%s- kmalloc(%Zd) failed.", __FUNCTION__, sizeof(struct ftdi_private));		return -ENOMEM;	}	memset(priv, 0, sizeof(*priv));	        init_waitqueue_head(&priv->delta_msr_wait);	/* This will push the characters through immediately rather	   than queue a task to deliver them */	priv->flags = ASYNC_LOW_LATENCY;	/* Increase the size of read buffers */	if (port->bulk_in_buffer) {		kfree (port->bulk_in_buffer);	}	port->bulk_in_buffer = kmalloc (BUFSZ, GFP_KERNEL);	if (!port->bulk_in_buffer) {		kfree (priv);		return -ENOMEM;	}	if (port->read_urb) {		port->read_urb->transfer_buffer = port->bulk_in_buffer;		port->read_urb->transfer_buffer_length = BUFSZ;	}	/* Free port's existing write urb and transfer buffer. */	if (port->write_urb) {		usb_free_urb (port->write_urb);		port->write_urb = NULL;	}	if (port->bulk_out_buffer) {		kfree (port->bulk_out_buffer);		port->bulk_out_buffer = NULL;	}	/* create our write urb pool and transfer buffers */ 	spin_lock_init (&priv->write_urb_pool_lock);	for (i = 0; i < NUM_URBS; ++i) {		urb = usb_alloc_urb(0);		priv->write_urb_pool[i] = urb;		if (urb == NULL) {			err("Unable to create new urb in urb pool");			break;		}		urb->transfer_buffer = kmalloc (URB_TRANSFER_BUFFER_SIZE, GFP_KERNEL);		if (!urb->transfer_buffer) {			err("%s - out of memory for urb buffers.", 			    __FUNCTION__);			continue;		}	}	/* Need at least one write urb in the pool */	if (i == 0) {		kfree (priv);		return -ENOMEM;	}	port->private = priv;		return (0);}/* Startup for the SIO chip *//* Called from usbserial:serial_probe */static int ftdi_SIO_startup (struct usb_serial *serial){	struct ftdi_private *priv;	int err;	dbg("%s",__FUNCTION__);	err = ftdi_common_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->chip_type = SIO;	priv->baud_base = 12000000 / 16;	priv->write_offset = 1;		return (0);}/* Startup for the 8U232AM chip *//* Called from usbserial:serial_probe */static int ftdi_8U232AM_startup (struct usb_serial *serial){ /* ftdi_8U232AM_startup */	struct ftdi_private *priv;	int err;	dbg("%s",__FUNCTION__);	err = ftdi_common_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->chip_type = FT8U232AM;	priv->baud_base = 48000000 / 2; /* Would be / 16, but FTDI supports 0.125, 0.25 and 0.5 divisor fractions! */		return (0);} /* ftdi_8U232AM_startup *//* Startup for the FT232BM chip *//* Called from usbserial:serial_probe */static int ftdi_FT232BM_startup (struct usb_serial *serial){ /* ftdi_FT232BM_startup */	struct ftdi_private *priv;	int err;	dbg("%s",__FUNCTION__);	err = ftdi_common_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->chip_type = FT232BM;	priv->baud_base = 48000000 / 2; /* Would be / 16, but FT232BM supports multiple of 0.125 divisor fractions! */		return (0);} /* ftdi_FT232BM_startup *//* Startup for the FT2232C chip *//* Called from usbserial:serial_probe */static int ftdi_FT2232C_startup (struct usb_serial *serial){ /* ftdi_FT2232C_startup */	struct ftdi_private *priv;	int err;	int inter;	dbg("%s",__FUNCTION__);	err = ftdi_common_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->chip_type = FT2232C;	inter = serial->interface->altsetting->bInterfaceNumber;	if(inter) {		priv->interface = INTERFACE_B;	}	else  {		priv->interface = INTERFACE_A;	}	priv->baud_base = 48000000 / 2; /* Would be / 16, but FT232BM supports multiple of 0.125 divisor fractions! */		return (0);} /* ftdi_FT2232C_startup *//* Startup for the FT232R chip *//* Called from usbserial:serial_probe */static int ftdi_FT232R_startup (struct usb_serial *serial){ /* ftdi_FT232R_startup */	struct ftdi_private *priv;	int err;	dbg("%s",__FUNCTION__);	err = ftdi_common_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->chip_type = FT232R;	priv->baud_base = 48000000 / 2; /* Would be / 16, but FT232BM supports multiple of 0.125 divisor fractions! */		return (0);} /* ftdi_FT232R_startup *//* Startup for the USB-UIRT device, which requires hardwired baudrate (38400 gets mapped to 312500) *//* Called from usbserial:serial_probe */static int ftdi_USB_UIRT_startup (struct usb_serial *serial){ /* ftdi_USB_UIRT_startup */	struct ftdi_private *priv;	int err;	dbg("%s",__FUNCTION__);	err = ftdi_8U232AM_startup(serial);	if (err){		return (err);	}	priv = serial->port->private;	priv->flags |= ASYNC_SPD_CUST;	priv->custom_divisor = 77;	priv->force_baud = B38400;		return (0);} /* ftdi_USB_UIRT_startup *//* Startup for the HE-TIRA1 device, which requires hardwired

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久久晋中| 在线观看视频一区二区| 精品在线一区二区三区| 美女一区二区在线观看| 久久丁香综合五月国产三级网站 | 久久av资源网| 精品一区二区在线观看| 成人综合日日夜夜| av一区二区三区在线| 97久久精品人人爽人人爽蜜臀| 91污片在线观看| 91精品国产日韩91久久久久久| 欧美一卡二卡在线| 亚洲国产成人一区二区三区| 一区二区三区产品免费精品久久75| 有码一区二区三区| 激情另类小说区图片区视频区| 高清成人免费视频| 欧美日韩成人一区二区| 久久久电影一区二区三区| 亚洲色欲色欲www| 久久超碰97中文字幕| 日本精品免费观看高清观看| 日韩欧美亚洲国产另类| 一区二区三区不卡视频在线观看 | 欧美综合亚洲图片综合区| 欧美一级欧美三级在线观看| 亚洲欧洲在线观看av| 国产成人综合网站| 日韩手机在线导航| 亚洲国产成人va在线观看天堂| 丁香一区二区三区| 久久久久久97三级| 九色综合狠狠综合久久| 欧美高清一级片在线| 一区二区三区中文在线观看| 国产999精品久久| 久久综合国产精品| 久久电影网站中文字幕| 日韩一区二区免费在线观看| 亚洲福中文字幕伊人影院| 在线免费观看日韩欧美| 亚洲综合999| 欧美一区二区三区视频免费播放| 亚洲一区在线免费观看| 欧美日韩夫妻久久| 看电影不卡的网站| 久久精品夜色噜噜亚洲a∨| 另类成人小视频在线| 精品精品欲导航| 国产成人福利片| 亚洲精品国产视频| 777xxx欧美| 丁香婷婷综合激情五月色| 亚洲欧美韩国综合色| 欧美精品一二三四| 成人综合在线网站| 偷拍一区二区三区| 久久精品欧美一区二区三区麻豆 | 国产欧美中文在线| 91丝袜高跟美女视频| 麻豆久久久久久久| 国产精品久久精品日日| 欧美一区二区三区视频免费| 成人小视频在线| 艳妇臀荡乳欲伦亚洲一区| 日韩一区二区三区四区五区六区| 国产精品12区| 日韩vs国产vs欧美| 亚洲视频每日更新| 国产亚洲欧美一区在线观看| 欧美日韩国产小视频在线观看| 成人激情av网| 国产精品白丝jk白祙喷水网站 | 欧美色综合天天久久综合精品| 国内精品免费在线观看| 日韩二区在线观看| 亚洲成人手机在线| 亚洲高清中文字幕| 夜夜嗨av一区二区三区四季av | 成人动漫视频在线| 国产一区二区三区高清播放| 美国三级日本三级久久99| 午夜不卡av免费| 蜜臂av日日欢夜夜爽一区| 亚洲国产aⅴ天堂久久| 丝袜亚洲另类欧美综合| 首页国产欧美久久| 麻豆国产精品官网| 久久黄色级2电影| 国产电影一区在线| 成人av在线播放网站| 一本色道久久加勒比精品| 91久久精品网| 欧美mv日韩mv国产| 国产精品女同一区二区三区| 又紧又大又爽精品一区二区| 午夜精品福利视频网站| 麻豆专区一区二区三区四区五区| 免费观看日韩电影| fc2成人免费人成在线观看播放| 91老师片黄在线观看| 日韩一区二区三区三四区视频在线观看| 欧美日韩视频专区在线播放| 日韩女优视频免费观看| 国产亚洲一二三区| 亚洲午夜精品在线| 国产一区二区三区免费观看| 91浏览器在线视频| 精品粉嫩aⅴ一区二区三区四区| 136国产福利精品导航| 日韩av中文字幕一区二区 | 欧美性色aⅴ视频一区日韩精品| 欧美日韩精品一区二区在线播放 | 美女视频一区在线观看| 91麻豆国产在线观看| 欧美高清一级片在线观看| 日韩二区三区四区| 欧美男生操女生| 亚洲男人的天堂在线观看| 国产一区二区美女| 欧美另类videos死尸| 亚洲品质自拍视频网站| 成人免费视频视频| 中文字幕av资源一区| 国产精品主播直播| 久久人人超碰精品| 国内精品伊人久久久久av影院| 8x福利精品第一导航| 日韩电影在线一区二区三区| 欧美日韩精品免费| 蜜桃视频一区二区三区| 日韩欧美国产综合一区 | 国产亚洲午夜高清国产拍精品| 激情六月婷婷久久| 国产精品你懂的在线欣赏| 94色蜜桃网一区二区三区| 亚洲码国产岛国毛片在线| 日本道免费精品一区二区三区| 亚洲与欧洲av电影| 777色狠狠一区二区三区| 另类小说综合欧美亚洲| 国产日韩精品一区二区三区| 波多野结衣欧美| 日本伊人色综合网| 久久精品亚洲一区二区三区浴池 | 国产精品成人免费在线| 欧美在线免费观看亚洲| 激情文学综合丁香| 亚洲欧洲在线观看av| 欧美一区二区三区免费视频 | 欧美mv和日韩mv的网站| 国产一区二区三区四区五区入口 | 欧美在线短视频| 国产精品中文字幕一区二区三区| 亚洲欧美中日韩| 欧美va在线播放| 精品视频一区二区不卡| 国产精品123| 久久99久久久久| 亚洲高清免费一级二级三级| 国产精品久久久久毛片软件| 欧美一二三四区在线| 欧美日韩国产成人在线免费| 99久久国产综合精品女不卡| 极品少妇xxxx偷拍精品少妇| 亚洲综合偷拍欧美一区色| 欧美激情一区二区三区四区| 26uuu国产在线精品一区二区| 制服丝袜亚洲色图| 欧美日韩国产一区二区三区地区| 色综合天天性综合| 99视频一区二区| 91一区二区在线观看| 波多野结衣在线aⅴ中文字幕不卡| 国产精品一区二区久激情瑜伽 | 欧美一区午夜精品| 日韩欧美123| 国产亚洲一二三区| 国产精品欧美久久久久一区二区| 久久精品一区四区| 欧美激情综合在线| 日韩美女视频一区| 亚洲人成网站精品片在线观看| 亚洲欧洲日产国码二区| 亚洲综合色自拍一区| 日本aⅴ免费视频一区二区三区| 日韩国产欧美视频| 久久成人18免费观看| 99久久久无码国产精品| 色94色欧美sute亚洲线路一ni| 欧美在线不卡视频| 日韩三级.com| 国产精品女主播av| 轻轻草成人在线| 懂色一区二区三区免费观看| 欧美日韩一二三区| 国产日韩三级在线| 免费一级欧美片在线观看| 欧美精品aⅴ在线视频|