1 // SPDX-License-Identifier: GPL-2.0
3 * UART driver for the Greybus "generic" UART module.
5 * Copyright 2014 Google Inc.
6 * Copyright 2014 Linaro Ltd.
8 * Heavily based on drivers/usb/class/cdc-acm.c and
9 * drivers/usb/serial/usb-serial.c.
11 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
13 #include <linux/kernel.h>
14 #include <linux/errno.h>
15 #include <linux/module.h>
16 #include <linux/sched/signal.h>
17 #include <linux/wait.h>
18 #include <linux/slab.h>
19 #include <linux/uaccess.h>
20 #include <linux/mutex.h>
21 #include <linux/tty.h>
22 #include <linux/serial.h>
23 #include <linux/tty_driver.h>
24 #include <linux/tty_flip.h>
25 #include <linux/idr.h>
27 #include <linux/kdev_t.h>
28 #include <linux/kfifo.h>
29 #include <linux/workqueue.h>
30 #include <linux/completion.h>
35 #define GB_NUM_MINORS 16 /* 16 is more than enough */
36 #define GB_NAME "ttyGB"
38 #define GB_UART_WRITE_FIFO_SIZE PAGE_SIZE
39 #define GB_UART_WRITE_ROOM_MARGIN 1 /* leave some space in fifo */
40 #define GB_UART_FIRMWARE_CREDITS 4096
41 #define GB_UART_CREDIT_WAIT_TIMEOUT_MSEC 10000
43 struct gb_tty_line_coding
{
52 struct gbphy_device
*gbphy_dev
;
55 size_t buffer_payload_max
;
56 struct gb_connection
*connection
;
62 spinlock_t write_lock
;
63 struct async_icount iocount
;
64 struct async_icount oldcount
;
65 wait_queue_head_t wioctl
;
67 u8 ctrlin
; /* input control lines */
68 u8 ctrlout
; /* output control lines */
69 struct gb_tty_line_coding line_coding
;
70 struct work_struct tx_work
;
71 struct kfifo write_fifo
;
74 struct completion credits_complete
;
77 static struct tty_driver
*gb_tty_driver
;
78 static DEFINE_IDR(tty_minors
);
79 static DEFINE_MUTEX(table_lock
);
81 static int gb_uart_receive_data_handler(struct gb_operation
*op
)
83 struct gb_connection
*connection
= op
->connection
;
84 struct gb_tty
*gb_tty
= gb_connection_get_data(connection
);
85 struct tty_port
*port
= &gb_tty
->port
;
86 struct gb_message
*request
= op
->request
;
87 struct gb_uart_recv_data_request
*receive_data
;
90 unsigned long tty_flags
= TTY_NORMAL
;
92 if (request
->payload_size
< sizeof(*receive_data
)) {
93 dev_err(&gb_tty
->gbphy_dev
->dev
,
94 "short receive-data request received (%zu < %zu)\n",
95 request
->payload_size
, sizeof(*receive_data
));
99 receive_data
= op
->request
->payload
;
100 recv_data_size
= le16_to_cpu(receive_data
->size
);
102 if (recv_data_size
!= request
->payload_size
- sizeof(*receive_data
)) {
103 dev_err(&gb_tty
->gbphy_dev
->dev
,
104 "malformed receive-data request received (%u != %zu)\n",
106 request
->payload_size
- sizeof(*receive_data
));
113 if (receive_data
->flags
) {
114 if (receive_data
->flags
& GB_UART_RECV_FLAG_BREAK
)
115 tty_flags
= TTY_BREAK
;
116 else if (receive_data
->flags
& GB_UART_RECV_FLAG_PARITY
)
117 tty_flags
= TTY_PARITY
;
118 else if (receive_data
->flags
& GB_UART_RECV_FLAG_FRAMING
)
119 tty_flags
= TTY_FRAME
;
121 /* overrun is special, not associated with a char */
122 if (receive_data
->flags
& GB_UART_RECV_FLAG_OVERRUN
)
123 tty_insert_flip_char(port
, 0, TTY_OVERRUN
);
125 count
= tty_insert_flip_string_fixed_flag(port
, receive_data
->data
,
126 tty_flags
, recv_data_size
);
127 if (count
!= recv_data_size
) {
128 dev_err(&gb_tty
->gbphy_dev
->dev
,
129 "UART: RX 0x%08x bytes only wrote 0x%08x\n",
130 recv_data_size
, count
);
133 tty_flip_buffer_push(port
);
137 static int gb_uart_serial_state_handler(struct gb_operation
*op
)
139 struct gb_connection
*connection
= op
->connection
;
140 struct gb_tty
*gb_tty
= gb_connection_get_data(connection
);
141 struct gb_message
*request
= op
->request
;
142 struct gb_uart_serial_state_request
*serial_state
;
144 if (request
->payload_size
< sizeof(*serial_state
)) {
145 dev_err(&gb_tty
->gbphy_dev
->dev
,
146 "short serial-state event received (%zu < %zu)\n",
147 request
->payload_size
, sizeof(*serial_state
));
151 serial_state
= request
->payload
;
152 gb_tty
->ctrlin
= serial_state
->control
;
157 static int gb_uart_receive_credits_handler(struct gb_operation
*op
)
159 struct gb_connection
*connection
= op
->connection
;
160 struct gb_tty
*gb_tty
= gb_connection_get_data(connection
);
161 struct gb_message
*request
= op
->request
;
162 struct gb_uart_receive_credits_request
*credit_request
;
164 unsigned int incoming_credits
;
167 if (request
->payload_size
< sizeof(*credit_request
)) {
168 dev_err(&gb_tty
->gbphy_dev
->dev
,
169 "short receive_credits event received (%zu < %zu)\n",
170 request
->payload_size
,
171 sizeof(*credit_request
));
175 credit_request
= request
->payload
;
176 incoming_credits
= le16_to_cpu(credit_request
->count
);
178 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
179 gb_tty
->credits
+= incoming_credits
;
180 if (gb_tty
->credits
> GB_UART_FIRMWARE_CREDITS
) {
181 gb_tty
->credits
-= incoming_credits
;
184 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
187 dev_err(&gb_tty
->gbphy_dev
->dev
,
188 "invalid number of incoming credits: %d\n",
193 if (!gb_tty
->close_pending
)
194 schedule_work(&gb_tty
->tx_work
);
197 * the port the tty layer may be waiting for credits
199 tty_port_tty_wakeup(&gb_tty
->port
);
201 if (gb_tty
->credits
== GB_UART_FIRMWARE_CREDITS
)
202 complete(&gb_tty
->credits_complete
);
207 static int gb_uart_request_handler(struct gb_operation
*op
)
209 struct gb_connection
*connection
= op
->connection
;
210 struct gb_tty
*gb_tty
= gb_connection_get_data(connection
);
215 case GB_UART_TYPE_RECEIVE_DATA
:
216 ret
= gb_uart_receive_data_handler(op
);
218 case GB_UART_TYPE_SERIAL_STATE
:
219 ret
= gb_uart_serial_state_handler(op
);
221 case GB_UART_TYPE_RECEIVE_CREDITS
:
222 ret
= gb_uart_receive_credits_handler(op
);
225 dev_err(&gb_tty
->gbphy_dev
->dev
,
226 "unsupported unsolicited request: 0x%02x\n", type
);
233 static void gb_uart_tx_write_work(struct work_struct
*work
)
235 struct gb_uart_send_data_request
*request
;
236 struct gb_tty
*gb_tty
;
238 unsigned int send_size
;
241 gb_tty
= container_of(work
, struct gb_tty
, tx_work
);
242 request
= gb_tty
->buffer
;
245 if (gb_tty
->close_pending
)
248 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
249 send_size
= gb_tty
->buffer_payload_max
;
250 if (send_size
> gb_tty
->credits
)
251 send_size
= gb_tty
->credits
;
253 send_size
= kfifo_out_peek(&gb_tty
->write_fifo
,
257 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
261 gb_tty
->credits
-= send_size
;
262 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
264 request
->size
= cpu_to_le16(send_size
);
265 ret
= gb_operation_sync(gb_tty
->connection
,
266 GB_UART_TYPE_SEND_DATA
,
267 request
, sizeof(*request
) + send_size
,
270 dev_err(&gb_tty
->gbphy_dev
->dev
,
271 "send data error: %d\n", ret
);
272 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
273 gb_tty
->credits
+= send_size
;
274 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
275 if (!gb_tty
->close_pending
)
280 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
281 ret
= kfifo_out(&gb_tty
->write_fifo
, &request
->data
[0],
283 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
285 tty_port_tty_wakeup(&gb_tty
->port
);
289 static int send_line_coding(struct gb_tty
*tty
)
291 struct gb_uart_set_line_coding_request request
;
293 memcpy(&request
, &tty
->line_coding
,
294 sizeof(tty
->line_coding
));
295 return gb_operation_sync(tty
->connection
, GB_UART_TYPE_SET_LINE_CODING
,
296 &request
, sizeof(request
), NULL
, 0);
299 static int send_control(struct gb_tty
*gb_tty
, u8 control
)
301 struct gb_uart_set_control_line_state_request request
;
303 request
.control
= control
;
304 return gb_operation_sync(gb_tty
->connection
,
305 GB_UART_TYPE_SET_CONTROL_LINE_STATE
,
306 &request
, sizeof(request
), NULL
, 0);
309 static int send_break(struct gb_tty
*gb_tty
, u8 state
)
311 struct gb_uart_set_break_request request
;
313 if ((state
!= 0) && (state
!= 1)) {
314 dev_err(&gb_tty
->gbphy_dev
->dev
,
315 "invalid break state of %d\n", state
);
319 request
.state
= state
;
320 return gb_operation_sync(gb_tty
->connection
, GB_UART_TYPE_SEND_BREAK
,
321 &request
, sizeof(request
), NULL
, 0);
324 static int gb_uart_wait_for_all_credits(struct gb_tty
*gb_tty
)
328 if (gb_tty
->credits
== GB_UART_FIRMWARE_CREDITS
)
331 ret
= wait_for_completion_timeout(&gb_tty
->credits_complete
,
332 msecs_to_jiffies(GB_UART_CREDIT_WAIT_TIMEOUT_MSEC
));
334 dev_err(&gb_tty
->gbphy_dev
->dev
,
335 "time out waiting for credits\n");
342 static int gb_uart_flush(struct gb_tty
*gb_tty
, u8 flags
)
344 struct gb_uart_serial_flush_request request
;
346 request
.flags
= flags
;
347 return gb_operation_sync(gb_tty
->connection
, GB_UART_TYPE_FLUSH_FIFOS
,
348 &request
, sizeof(request
), NULL
, 0);
351 static struct gb_tty
*get_gb_by_minor(unsigned int minor
)
353 struct gb_tty
*gb_tty
;
355 mutex_lock(&table_lock
);
356 gb_tty
= idr_find(&tty_minors
, minor
);
358 mutex_lock(&gb_tty
->mutex
);
359 if (gb_tty
->disconnected
) {
360 mutex_unlock(&gb_tty
->mutex
);
363 tty_port_get(&gb_tty
->port
);
364 mutex_unlock(&gb_tty
->mutex
);
367 mutex_unlock(&table_lock
);
371 static int alloc_minor(struct gb_tty
*gb_tty
)
375 mutex_lock(&table_lock
);
376 minor
= idr_alloc(&tty_minors
, gb_tty
, 0, GB_NUM_MINORS
, GFP_KERNEL
);
377 mutex_unlock(&table_lock
);
379 gb_tty
->minor
= minor
;
383 static void release_minor(struct gb_tty
*gb_tty
)
385 int minor
= gb_tty
->minor
;
387 gb_tty
->minor
= 0; /* Maybe should use an invalid value instead */
388 mutex_lock(&table_lock
);
389 idr_remove(&tty_minors
, minor
);
390 mutex_unlock(&table_lock
);
393 static int gb_tty_install(struct tty_driver
*driver
, struct tty_struct
*tty
)
395 struct gb_tty
*gb_tty
;
398 gb_tty
= get_gb_by_minor(tty
->index
);
402 retval
= tty_standard_install(driver
, tty
);
406 tty
->driver_data
= gb_tty
;
409 tty_port_put(&gb_tty
->port
);
413 static int gb_tty_open(struct tty_struct
*tty
, struct file
*file
)
415 struct gb_tty
*gb_tty
= tty
->driver_data
;
417 return tty_port_open(&gb_tty
->port
, tty
, file
);
420 static void gb_tty_close(struct tty_struct
*tty
, struct file
*file
)
422 struct gb_tty
*gb_tty
= tty
->driver_data
;
424 tty_port_close(&gb_tty
->port
, tty
, file
);
427 static void gb_tty_cleanup(struct tty_struct
*tty
)
429 struct gb_tty
*gb_tty
= tty
->driver_data
;
431 tty_port_put(&gb_tty
->port
);
434 static void gb_tty_hangup(struct tty_struct
*tty
)
436 struct gb_tty
*gb_tty
= tty
->driver_data
;
438 tty_port_hangup(&gb_tty
->port
);
441 static int gb_tty_write(struct tty_struct
*tty
, const unsigned char *buf
,
444 struct gb_tty
*gb_tty
= tty
->driver_data
;
446 count
= kfifo_in_spinlocked(&gb_tty
->write_fifo
, buf
, count
,
447 &gb_tty
->write_lock
);
448 if (count
&& !gb_tty
->close_pending
)
449 schedule_work(&gb_tty
->tx_work
);
454 static int gb_tty_write_room(struct tty_struct
*tty
)
456 struct gb_tty
*gb_tty
= tty
->driver_data
;
460 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
461 room
= kfifo_avail(&gb_tty
->write_fifo
);
462 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
464 room
-= GB_UART_WRITE_ROOM_MARGIN
;
471 static int gb_tty_chars_in_buffer(struct tty_struct
*tty
)
473 struct gb_tty
*gb_tty
= tty
->driver_data
;
477 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
478 chars
= kfifo_len(&gb_tty
->write_fifo
);
479 if (gb_tty
->credits
< GB_UART_FIRMWARE_CREDITS
)
480 chars
+= GB_UART_FIRMWARE_CREDITS
- gb_tty
->credits
;
481 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
486 static int gb_tty_break_ctl(struct tty_struct
*tty
, int state
)
488 struct gb_tty
*gb_tty
= tty
->driver_data
;
490 return send_break(gb_tty
, state
? 1 : 0);
493 static void gb_tty_set_termios(struct tty_struct
*tty
,
494 struct ktermios
*termios_old
)
496 struct gb_tty
*gb_tty
= tty
->driver_data
;
497 struct ktermios
*termios
= &tty
->termios
;
498 struct gb_tty_line_coding newline
;
499 u8 newctrl
= gb_tty
->ctrlout
;
501 newline
.rate
= cpu_to_le32(tty_get_baud_rate(tty
));
502 newline
.format
= termios
->c_cflag
& CSTOPB
?
503 GB_SERIAL_2_STOP_BITS
: GB_SERIAL_1_STOP_BITS
;
504 newline
.parity
= termios
->c_cflag
& PARENB
?
505 (termios
->c_cflag
& PARODD
? 1 : 2) +
506 (termios
->c_cflag
& CMSPAR
? 2 : 0) : 0;
508 switch (termios
->c_cflag
& CSIZE
) {
510 newline
.data_bits
= 5;
513 newline
.data_bits
= 6;
516 newline
.data_bits
= 7;
520 newline
.data_bits
= 8;
524 /* FIXME: needs to clear unsupported bits in the termios */
525 gb_tty
->clocal
= ((termios
->c_cflag
& CLOCAL
) != 0);
527 if (C_BAUD(tty
) == B0
) {
528 newline
.rate
= gb_tty
->line_coding
.rate
;
529 newctrl
&= ~(GB_UART_CTRL_DTR
| GB_UART_CTRL_RTS
);
530 } else if (termios_old
&& (termios_old
->c_cflag
& CBAUD
) == B0
) {
531 newctrl
|= (GB_UART_CTRL_DTR
| GB_UART_CTRL_RTS
);
534 if (newctrl
!= gb_tty
->ctrlout
) {
535 gb_tty
->ctrlout
= newctrl
;
536 send_control(gb_tty
, newctrl
);
539 if (C_CRTSCTS(tty
) && C_BAUD(tty
) != B0
)
540 newline
.flow_control
|= GB_SERIAL_AUTO_RTSCTS_EN
;
542 newline
.flow_control
&= ~GB_SERIAL_AUTO_RTSCTS_EN
;
544 if (memcmp(&gb_tty
->line_coding
, &newline
, sizeof(newline
))) {
545 memcpy(&gb_tty
->line_coding
, &newline
, sizeof(newline
));
546 send_line_coding(gb_tty
);
550 static int gb_tty_tiocmget(struct tty_struct
*tty
)
552 struct gb_tty
*gb_tty
= tty
->driver_data
;
554 return (gb_tty
->ctrlout
& GB_UART_CTRL_DTR
? TIOCM_DTR
: 0) |
555 (gb_tty
->ctrlout
& GB_UART_CTRL_RTS
? TIOCM_RTS
: 0) |
556 (gb_tty
->ctrlin
& GB_UART_CTRL_DSR
? TIOCM_DSR
: 0) |
557 (gb_tty
->ctrlin
& GB_UART_CTRL_RI
? TIOCM_RI
: 0) |
558 (gb_tty
->ctrlin
& GB_UART_CTRL_DCD
? TIOCM_CD
: 0) |
562 static int gb_tty_tiocmset(struct tty_struct
*tty
, unsigned int set
,
565 struct gb_tty
*gb_tty
= tty
->driver_data
;
566 u8 newctrl
= gb_tty
->ctrlout
;
568 set
= (set
& TIOCM_DTR
? GB_UART_CTRL_DTR
: 0) |
569 (set
& TIOCM_RTS
? GB_UART_CTRL_RTS
: 0);
570 clear
= (clear
& TIOCM_DTR
? GB_UART_CTRL_DTR
: 0) |
571 (clear
& TIOCM_RTS
? GB_UART_CTRL_RTS
: 0);
573 newctrl
= (newctrl
& ~clear
) | set
;
574 if (gb_tty
->ctrlout
== newctrl
)
577 gb_tty
->ctrlout
= newctrl
;
578 return send_control(gb_tty
, newctrl
);
581 static void gb_tty_throttle(struct tty_struct
*tty
)
583 struct gb_tty
*gb_tty
= tty
->driver_data
;
584 unsigned char stop_char
;
588 stop_char
= STOP_CHAR(tty
);
589 retval
= gb_tty_write(tty
, &stop_char
, 1);
594 if (tty
->termios
.c_cflag
& CRTSCTS
) {
595 gb_tty
->ctrlout
&= ~GB_UART_CTRL_RTS
;
596 retval
= send_control(gb_tty
, gb_tty
->ctrlout
);
600 static void gb_tty_unthrottle(struct tty_struct
*tty
)
602 struct gb_tty
*gb_tty
= tty
->driver_data
;
603 unsigned char start_char
;
607 start_char
= START_CHAR(tty
);
608 retval
= gb_tty_write(tty
, &start_char
, 1);
613 if (tty
->termios
.c_cflag
& CRTSCTS
) {
614 gb_tty
->ctrlout
|= GB_UART_CTRL_RTS
;
615 retval
= send_control(gb_tty
, gb_tty
->ctrlout
);
619 static int get_serial_info(struct gb_tty
*gb_tty
,
620 struct serial_struct __user
*info
)
622 struct serial_struct tmp
;
624 memset(&tmp
, 0, sizeof(tmp
));
625 tmp
.type
= PORT_16550A
;
626 tmp
.line
= gb_tty
->minor
;
627 tmp
.xmit_fifo_size
= 16;
628 tmp
.baud_base
= 9600;
629 tmp
.close_delay
= gb_tty
->port
.close_delay
/ 10;
631 gb_tty
->port
.closing_wait
== ASYNC_CLOSING_WAIT_NONE
?
632 ASYNC_CLOSING_WAIT_NONE
: gb_tty
->port
.closing_wait
/ 10;
634 if (copy_to_user(info
, &tmp
, sizeof(tmp
)))
639 static int set_serial_info(struct gb_tty
*gb_tty
,
640 struct serial_struct __user
*newinfo
)
642 struct serial_struct new_serial
;
643 unsigned int closing_wait
;
644 unsigned int close_delay
;
647 if (copy_from_user(&new_serial
, newinfo
, sizeof(new_serial
)))
650 close_delay
= new_serial
.close_delay
* 10;
651 closing_wait
= new_serial
.closing_wait
== ASYNC_CLOSING_WAIT_NONE
?
652 ASYNC_CLOSING_WAIT_NONE
: new_serial
.closing_wait
* 10;
654 mutex_lock(&gb_tty
->port
.mutex
);
655 if (!capable(CAP_SYS_ADMIN
)) {
656 if ((close_delay
!= gb_tty
->port
.close_delay
) ||
657 (closing_wait
!= gb_tty
->port
.closing_wait
))
660 retval
= -EOPNOTSUPP
;
662 gb_tty
->port
.close_delay
= close_delay
;
663 gb_tty
->port
.closing_wait
= closing_wait
;
665 mutex_unlock(&gb_tty
->port
.mutex
);
669 static int wait_serial_change(struct gb_tty
*gb_tty
, unsigned long arg
)
672 DECLARE_WAITQUEUE(wait
, current
);
673 struct async_icount old
;
674 struct async_icount
new;
676 if (!(arg
& (TIOCM_DSR
| TIOCM_RI
| TIOCM_CD
)))
680 spin_lock_irq(&gb_tty
->read_lock
);
681 old
= gb_tty
->oldcount
;
682 new = gb_tty
->iocount
;
683 gb_tty
->oldcount
= new;
684 spin_unlock_irq(&gb_tty
->read_lock
);
686 if ((arg
& TIOCM_DSR
) && (old
.dsr
!= new.dsr
))
688 if ((arg
& TIOCM_CD
) && (old
.dcd
!= new.dcd
))
690 if ((arg
& TIOCM_RI
) && (old
.rng
!= new.rng
))
693 add_wait_queue(&gb_tty
->wioctl
, &wait
);
694 set_current_state(TASK_INTERRUPTIBLE
);
696 remove_wait_queue(&gb_tty
->wioctl
, &wait
);
697 if (gb_tty
->disconnected
) {
701 } else if (signal_pending(current
)) {
702 retval
= -ERESTARTSYS
;
709 static int gb_tty_get_icount(struct tty_struct
*tty
,
710 struct serial_icounter_struct
*icount
)
712 struct gb_tty
*gb_tty
= tty
->driver_data
;
714 icount
->dsr
= gb_tty
->iocount
.dsr
;
715 icount
->rng
= gb_tty
->iocount
.rng
;
716 icount
->dcd
= gb_tty
->iocount
.dcd
;
717 icount
->frame
= gb_tty
->iocount
.frame
;
718 icount
->overrun
= gb_tty
->iocount
.overrun
;
719 icount
->parity
= gb_tty
->iocount
.parity
;
720 icount
->brk
= gb_tty
->iocount
.brk
;
725 static int gb_tty_ioctl(struct tty_struct
*tty
, unsigned int cmd
,
728 struct gb_tty
*gb_tty
= tty
->driver_data
;
732 return get_serial_info(gb_tty
,
733 (struct serial_struct __user
*)arg
);
735 return set_serial_info(gb_tty
,
736 (struct serial_struct __user
*)arg
);
738 return wait_serial_change(gb_tty
, arg
);
744 static void gb_tty_dtr_rts(struct tty_port
*port
, int on
)
746 struct gb_tty
*gb_tty
;
749 gb_tty
= container_of(port
, struct gb_tty
, port
);
750 newctrl
= gb_tty
->ctrlout
;
753 newctrl
|= (GB_UART_CTRL_DTR
| GB_UART_CTRL_RTS
);
755 newctrl
&= ~(GB_UART_CTRL_DTR
| GB_UART_CTRL_RTS
);
757 gb_tty
->ctrlout
= newctrl
;
758 send_control(gb_tty
, newctrl
);
761 static int gb_tty_port_activate(struct tty_port
*port
,
762 struct tty_struct
*tty
)
764 struct gb_tty
*gb_tty
;
766 gb_tty
= container_of(port
, struct gb_tty
, port
);
768 return gbphy_runtime_get_sync(gb_tty
->gbphy_dev
);
771 static void gb_tty_port_shutdown(struct tty_port
*port
)
773 struct gb_tty
*gb_tty
;
777 gb_tty
= container_of(port
, struct gb_tty
, port
);
779 gb_tty
->close_pending
= true;
781 cancel_work_sync(&gb_tty
->tx_work
);
783 spin_lock_irqsave(&gb_tty
->write_lock
, flags
);
784 kfifo_reset_out(&gb_tty
->write_fifo
);
785 spin_unlock_irqrestore(&gb_tty
->write_lock
, flags
);
787 if (gb_tty
->credits
== GB_UART_FIRMWARE_CREDITS
)
790 ret
= gb_uart_flush(gb_tty
, GB_SERIAL_FLAG_FLUSH_TRANSMITTER
);
792 dev_err(&gb_tty
->gbphy_dev
->dev
,
793 "error flushing transmitter: %d\n", ret
);
796 gb_uart_wait_for_all_credits(gb_tty
);
799 gb_tty
->close_pending
= false;
801 gbphy_runtime_put_autosuspend(gb_tty
->gbphy_dev
);
804 static const struct tty_operations gb_ops
= {
805 .install
= gb_tty_install
,
807 .close
= gb_tty_close
,
808 .cleanup
= gb_tty_cleanup
,
809 .hangup
= gb_tty_hangup
,
810 .write
= gb_tty_write
,
811 .write_room
= gb_tty_write_room
,
812 .ioctl
= gb_tty_ioctl
,
813 .throttle
= gb_tty_throttle
,
814 .unthrottle
= gb_tty_unthrottle
,
815 .chars_in_buffer
= gb_tty_chars_in_buffer
,
816 .break_ctl
= gb_tty_break_ctl
,
817 .set_termios
= gb_tty_set_termios
,
818 .tiocmget
= gb_tty_tiocmget
,
819 .tiocmset
= gb_tty_tiocmset
,
820 .get_icount
= gb_tty_get_icount
,
823 static const struct tty_port_operations gb_port_ops
= {
824 .dtr_rts
= gb_tty_dtr_rts
,
825 .activate
= gb_tty_port_activate
,
826 .shutdown
= gb_tty_port_shutdown
,
829 static int gb_uart_probe(struct gbphy_device
*gbphy_dev
,
830 const struct gbphy_device_id
*id
)
832 struct gb_connection
*connection
;
834 struct gb_tty
*gb_tty
;
835 struct device
*tty_dev
;
839 gb_tty
= kzalloc(sizeof(*gb_tty
), GFP_KERNEL
);
843 connection
= gb_connection_create(gbphy_dev
->bundle
,
844 le16_to_cpu(gbphy_dev
->cport_desc
->id
),
845 gb_uart_request_handler
);
846 if (IS_ERR(connection
)) {
847 retval
= PTR_ERR(connection
);
851 max_payload
= gb_operation_get_payload_size_max(connection
);
852 if (max_payload
< sizeof(struct gb_uart_send_data_request
)) {
854 goto exit_connection_destroy
;
857 gb_tty
->buffer_payload_max
= max_payload
-
858 sizeof(struct gb_uart_send_data_request
);
860 gb_tty
->buffer
= kzalloc(gb_tty
->buffer_payload_max
, GFP_KERNEL
);
861 if (!gb_tty
->buffer
) {
863 goto exit_connection_destroy
;
866 INIT_WORK(&gb_tty
->tx_work
, gb_uart_tx_write_work
);
868 retval
= kfifo_alloc(&gb_tty
->write_fifo
, GB_UART_WRITE_FIFO_SIZE
,
873 gb_tty
->credits
= GB_UART_FIRMWARE_CREDITS
;
874 init_completion(&gb_tty
->credits_complete
);
876 minor
= alloc_minor(gb_tty
);
878 if (minor
== -ENOSPC
) {
879 dev_err(&gbphy_dev
->dev
,
880 "no more free minor numbers\n");
885 goto exit_kfifo_free
;
888 gb_tty
->minor
= minor
;
889 spin_lock_init(&gb_tty
->write_lock
);
890 spin_lock_init(&gb_tty
->read_lock
);
891 init_waitqueue_head(&gb_tty
->wioctl
);
892 mutex_init(&gb_tty
->mutex
);
894 tty_port_init(&gb_tty
->port
);
895 gb_tty
->port
.ops
= &gb_port_ops
;
897 gb_tty
->connection
= connection
;
898 gb_tty
->gbphy_dev
= gbphy_dev
;
899 gb_connection_set_data(connection
, gb_tty
);
900 gb_gbphy_set_data(gbphy_dev
, gb_tty
);
902 retval
= gb_connection_enable_tx(connection
);
904 goto exit_release_minor
;
906 send_control(gb_tty
, gb_tty
->ctrlout
);
908 /* initialize the uart to be 9600n81 */
909 gb_tty
->line_coding
.rate
= cpu_to_le32(9600);
910 gb_tty
->line_coding
.format
= GB_SERIAL_1_STOP_BITS
;
911 gb_tty
->line_coding
.parity
= GB_SERIAL_NO_PARITY
;
912 gb_tty
->line_coding
.data_bits
= 8;
913 send_line_coding(gb_tty
);
915 retval
= gb_connection_enable(connection
);
917 goto exit_connection_disable
;
919 tty_dev
= tty_port_register_device(&gb_tty
->port
, gb_tty_driver
, minor
,
921 if (IS_ERR(tty_dev
)) {
922 retval
= PTR_ERR(tty_dev
);
923 goto exit_connection_disable
;
926 gbphy_runtime_put_autosuspend(gbphy_dev
);
929 exit_connection_disable
:
930 gb_connection_disable(connection
);
932 release_minor(gb_tty
);
934 kfifo_free(&gb_tty
->write_fifo
);
936 kfree(gb_tty
->buffer
);
937 exit_connection_destroy
:
938 gb_connection_destroy(connection
);
945 static void gb_uart_remove(struct gbphy_device
*gbphy_dev
)
947 struct gb_tty
*gb_tty
= gb_gbphy_get_data(gbphy_dev
);
948 struct gb_connection
*connection
= gb_tty
->connection
;
949 struct tty_struct
*tty
;
952 ret
= gbphy_runtime_get_sync(gbphy_dev
);
954 gbphy_runtime_get_noresume(gbphy_dev
);
956 mutex_lock(&gb_tty
->mutex
);
957 gb_tty
->disconnected
= true;
959 wake_up_all(&gb_tty
->wioctl
);
960 mutex_unlock(&gb_tty
->mutex
);
962 tty
= tty_port_tty_get(&gb_tty
->port
);
968 gb_connection_disable_rx(connection
);
969 tty_unregister_device(gb_tty_driver
, gb_tty
->minor
);
971 /* FIXME - free transmit / receive buffers */
973 gb_connection_disable(connection
);
974 tty_port_destroy(&gb_tty
->port
);
975 gb_connection_destroy(connection
);
976 release_minor(gb_tty
);
977 kfifo_free(&gb_tty
->write_fifo
);
978 kfree(gb_tty
->buffer
);
982 static int gb_tty_init(void)
986 gb_tty_driver
= tty_alloc_driver(GB_NUM_MINORS
, 0);
987 if (IS_ERR(gb_tty_driver
)) {
988 pr_err("Can not allocate tty driver\n");
990 goto fail_unregister_dev
;
993 gb_tty_driver
->driver_name
= "gb";
994 gb_tty_driver
->name
= GB_NAME
;
995 gb_tty_driver
->major
= 0;
996 gb_tty_driver
->minor_start
= 0;
997 gb_tty_driver
->type
= TTY_DRIVER_TYPE_SERIAL
;
998 gb_tty_driver
->subtype
= SERIAL_TYPE_NORMAL
;
999 gb_tty_driver
->flags
= TTY_DRIVER_REAL_RAW
| TTY_DRIVER_DYNAMIC_DEV
;
1000 gb_tty_driver
->init_termios
= tty_std_termios
;
1001 gb_tty_driver
->init_termios
.c_cflag
= B9600
| CS8
|
1002 CREAD
| HUPCL
| CLOCAL
;
1003 tty_set_operations(gb_tty_driver
, &gb_ops
);
1005 retval
= tty_register_driver(gb_tty_driver
);
1007 pr_err("Can not register tty driver: %d\n", retval
);
1008 goto fail_put_gb_tty
;
1014 put_tty_driver(gb_tty_driver
);
1015 fail_unregister_dev
:
1019 static void gb_tty_exit(void)
1021 tty_unregister_driver(gb_tty_driver
);
1022 put_tty_driver(gb_tty_driver
);
1023 idr_destroy(&tty_minors
);
1026 static const struct gbphy_device_id gb_uart_id_table
[] = {
1027 { GBPHY_PROTOCOL(GREYBUS_PROTOCOL_UART
) },
1030 MODULE_DEVICE_TABLE(gbphy
, gb_uart_id_table
);
1032 static struct gbphy_driver uart_driver
= {
1034 .probe
= gb_uart_probe
,
1035 .remove
= gb_uart_remove
,
1036 .id_table
= gb_uart_id_table
,
1039 static int gb_uart_driver_init(void)
1043 ret
= gb_tty_init();
1047 ret
= gb_gbphy_register(&uart_driver
);
1055 module_init(gb_uart_driver_init
);
1057 static void gb_uart_driver_exit(void)
1059 gb_gbphy_deregister(&uart_driver
);
1063 module_exit(gb_uart_driver_exit
);
1064 MODULE_LICENSE("GPL v2");