⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 belkin_sa.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
	else		priv->control_state &= ~TIOCM_CD;	/* Now to report any errors */	priv->last_lsr = data[BELKIN_SA_LSR_INDEX];#if 0	/*	 * fill in the flip buffer here, but I do not know the relation	 * to the current/next receive buffer or characters.  I need	 * to look in to this before committing any code.	 */	if (priv->last_lsr & BELKIN_SA_LSR_ERR) {		tty = port->tty;		/* Overrun Error */		if (priv->last_lsr & BELKIN_SA_LSR_OE) {		}		/* Parity Error */		if (priv->last_lsr & BELKIN_SA_LSR_PE) {		}		/* Framing Error */		if (priv->last_lsr & BELKIN_SA_LSR_FE) {		}		/* Break Indicator */		if (priv->last_lsr & BELKIN_SA_LSR_BI) {		}	}#endif	spin_unlock_irqrestore(&priv->lock, flags);exit:	retval = usb_submit_urb (urb, GFP_ATOMIC);	if (retval)		err ("%s - usb_submit_urb failed with result %d",		     __FUNCTION__, retval);}static void belkin_sa_set_termios (struct usb_serial_port *port, struct ktermios *old_termios){	struct usb_serial *serial = port->serial;	struct belkin_sa_private *priv = usb_get_serial_port_data(port);	unsigned int iflag;	unsigned int cflag;	unsigned int old_iflag = 0;	unsigned int old_cflag = 0;	__u16 urb_value = 0; /* Will hold the new flags */	unsigned long flags;	unsigned long control_state;	int bad_flow_control;	speed_t baud;		if ((!port->tty) || (!port->tty->termios)) {		dbg ("%s - no tty or termios structure", __FUNCTION__);		return;	}	iflag = port->tty->termios->c_iflag;	cflag = port->tty->termios->c_cflag;	/* get a local copy of the current port settings */	spin_lock_irqsave(&priv->lock, flags);	control_state = priv->control_state;	bad_flow_control = priv->bad_flow_control;	spin_unlock_irqrestore(&priv->lock, flags);		old_iflag = old_termios->c_iflag;	old_cflag = old_termios->c_cflag;	/* Set the baud rate */	if( (cflag&CBAUD) != (old_cflag&CBAUD) ) {		/* reassert DTR and (maybe) RTS on transition from B0 */		if( (old_cflag&CBAUD) == B0 ) {			control_state |= (TIOCM_DTR|TIOCM_RTS);			if (BSA_USB_CMD(BELKIN_SA_SET_DTR_REQUEST, 1) < 0)				err("Set DTR error");			/* don't set RTS if using hardware flow control */			if (!(old_cflag&CRTSCTS) )				if (BSA_USB_CMD(BELKIN_SA_SET_RTS_REQUEST, 1) < 0)					err("Set RTS error");		}	}	baud = tty_get_baud_rate(port->tty);	if (baud == 0) {		dbg("%s - tty_get_baud_rate says 0 baud", __FUNCTION__);		return;	}	urb_value = BELKIN_SA_BAUD(baud);	/* Clip to maximum speed */	if (urb_value == 0)		urb_value = 1;	/* Turn it back into a resulting real baud rate */	baud = BELKIN_SA_BAUD(urb_value);	/* FIXME: Once the tty updates are done then push this back to the tty */	if ((cflag & CBAUD) != B0 ) {		if (BSA_USB_CMD(BELKIN_SA_SET_BAUDRATE_REQUEST, urb_value) < 0)			err("Set baudrate error");	} else {		/* Disable flow control */		if (BSA_USB_CMD(BELKIN_SA_SET_FLOW_CTRL_REQUEST, BELKIN_SA_FLOW_NONE) < 0)			err("Disable flowcontrol error");		/* Drop RTS and DTR */		control_state &= ~(TIOCM_DTR | TIOCM_RTS);		if (BSA_USB_CMD(BELKIN_SA_SET_DTR_REQUEST, 0) < 0)			err("DTR LOW error");		if (BSA_USB_CMD(BELKIN_SA_SET_RTS_REQUEST, 0) < 0)			err("RTS LOW error");	}	/* set the parity */	if( (cflag&(PARENB|PARODD)) != (old_cflag&(PARENB|PARODD)) ) {		if (cflag & PARENB)			urb_value = (cflag & PARODD) ?  BELKIN_SA_PARITY_ODD : BELKIN_SA_PARITY_EVEN;		else			urb_value = BELKIN_SA_PARITY_NONE;		if (BSA_USB_CMD(BELKIN_SA_SET_PARITY_REQUEST, urb_value) < 0)			err("Set parity error");	}	/* set the number of data bits */	if( (cflag&CSIZE) != (old_cflag&CSIZE) ) {		switch (cflag & CSIZE) {			case CS5: urb_value = BELKIN_SA_DATA_BITS(5); break;			case CS6: urb_value = BELKIN_SA_DATA_BITS(6); break;			case CS7: urb_value = BELKIN_SA_DATA_BITS(7); break;			case CS8: urb_value = BELKIN_SA_DATA_BITS(8); break;			default: dbg("CSIZE was not CS5-CS8, using default of 8");				urb_value = BELKIN_SA_DATA_BITS(8);				break;		}		if (BSA_USB_CMD(BELKIN_SA_SET_DATA_BITS_REQUEST, urb_value) < 0)			err("Set data bits error");	}	/* set the number of stop bits */	if( (cflag&CSTOPB) != (old_cflag&CSTOPB) ) {		urb_value = (cflag & CSTOPB) ? BELKIN_SA_STOP_BITS(2) : BELKIN_SA_STOP_BITS(1);		if (BSA_USB_CMD(BELKIN_SA_SET_STOP_BITS_REQUEST, urb_value) < 0)			err("Set stop bits error");	}	/* Set flow control */	if( (iflag&IXOFF)   != (old_iflag&IXOFF)	||	(iflag&IXON)    != (old_iflag&IXON)	||  (cflag&CRTSCTS) != (old_cflag&CRTSCTS) ) {		urb_value = 0;		if ((iflag & IXOFF) || (iflag & IXON))			urb_value |= (BELKIN_SA_FLOW_OXON | BELKIN_SA_FLOW_IXON);		else			urb_value &= ~(BELKIN_SA_FLOW_OXON | BELKIN_SA_FLOW_IXON);		if (cflag & CRTSCTS)			urb_value |=  (BELKIN_SA_FLOW_OCTS | BELKIN_SA_FLOW_IRTS);		else			urb_value &= ~(BELKIN_SA_FLOW_OCTS | BELKIN_SA_FLOW_IRTS);		if (bad_flow_control)			urb_value &= ~(BELKIN_SA_FLOW_IRTS);		if (BSA_USB_CMD(BELKIN_SA_SET_FLOW_CTRL_REQUEST, urb_value) < 0)			err("Set flow control error");	}	/* save off the modified port settings */	spin_lock_irqsave(&priv->lock, flags);	priv->control_state = control_state;	spin_unlock_irqrestore(&priv->lock, flags);} /* belkin_sa_set_termios */static void belkin_sa_break_ctl( struct usb_serial_port *port, int break_state ){	struct usb_serial *serial = port->serial;	if (BSA_USB_CMD(BELKIN_SA_SET_BREAK_REQUEST, break_state ? 1 : 0) < 0)		err("Set break_ctl %d", break_state);}static int belkin_sa_tiocmget (struct usb_serial_port *port, struct file *file){	struct belkin_sa_private *priv = usb_get_serial_port_data(port);	unsigned long control_state;	unsigned long flags;		dbg("%s", __FUNCTION__);	spin_lock_irqsave(&priv->lock, flags);	control_state = priv->control_state;	spin_unlock_irqrestore(&priv->lock, flags);	return control_state;}static int belkin_sa_tiocmset (struct usb_serial_port *port, struct file *file,			       unsigned int set, unsigned int clear){	struct usb_serial *serial = port->serial;	struct belkin_sa_private *priv = usb_get_serial_port_data(port);	unsigned long control_state;	unsigned long flags;	int retval;	int rts = 0;	int dtr = 0;		dbg("%s", __FUNCTION__);	spin_lock_irqsave(&priv->lock, flags);	control_state = priv->control_state;	if (set & TIOCM_RTS) {		control_state |= TIOCM_RTS;		rts = 1;	}	if (set & TIOCM_DTR) {		control_state |= TIOCM_DTR;		dtr = 1;	}	if (clear & TIOCM_RTS) {		control_state &= ~TIOCM_RTS;		rts = 0;	}	if (clear & TIOCM_DTR) {		control_state &= ~TIOCM_DTR;		dtr = 0;	}	priv->control_state = control_state;	spin_unlock_irqrestore(&priv->lock, flags);	retval = BSA_USB_CMD(BELKIN_SA_SET_RTS_REQUEST, rts);	if (retval < 0) {		err("Set RTS error %d", retval);		goto exit;	}	retval = BSA_USB_CMD(BELKIN_SA_SET_DTR_REQUEST, dtr);	if (retval < 0) {		err("Set DTR error %d", retval);		goto exit;	}exit:	return retval;}static int belkin_sa_ioctl (struct usb_serial_port *port, struct file * file, unsigned int cmd, unsigned long arg){	switch (cmd) {	case TIOCMIWAIT:		/* wait for any of the 4 modem inputs (DCD,RI,DSR,CTS)*/		/* TODO */		return( 0 );	case TIOCGICOUNT:		/* return count of modemline transitions */		/* TODO */		return 0;	default:		dbg("belkin_sa_ioctl arg not supported - 0x%04x",cmd);		return(-ENOIOCTLCMD);		break;	}	return 0;} /* belkin_sa_ioctl */static int __init belkin_sa_init (void){	int retval;	retval = usb_serial_register(&belkin_device);	if (retval)		goto failed_usb_serial_register;	retval = usb_register(&belkin_driver);	if (retval)		goto failed_usb_register;	info(DRIVER_DESC " " DRIVER_VERSION);	return 0;failed_usb_register:	usb_serial_deregister(&belkin_device);failed_usb_serial_register:	return retval;}static void __exit belkin_sa_exit (void){	usb_deregister (&belkin_driver);	usb_serial_deregister (&belkin_device);}module_init (belkin_sa_init);module_exit (belkin_sa_exit);MODULE_AUTHOR( DRIVER_AUTHOR );MODULE_DESCRIPTION( DRIVER_DESC );MODULE_VERSION( DRIVER_VERSION );MODULE_LICENSE("GPL");module_param(debug, bool, S_IRUGO | S_IWUSR);MODULE_PARM_DESC(debug, "Debug enabled or not");

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -