Lines Matching +full:up +full:- +full:to

1 /* SPDX-License-Identifier: GPL-2.0-or-later */
25 ((port)->cons && (port)->cons->index == (port)->line)
37 * struct uart_ops -- interface between serial_core and the driver
55 * This function sets the modem control lines for @port to the state
58 * - %TIOCM_RTS RTS signal.
59 * - %TIOCM_DTR DTR signal.
60 * - %TIOCM_OUT1 OUT1 signal.
61 * - %TIOCM_OUT2 OUT2 signal.
62 * - %TIOCM_LOOP Set the port into loopback mode.
68 * Locking: @port->lock taken.
78 * - %TIOCM_CAR state of DCD signal
79 * - %TIOCM_CTS state of CTS signal
80 * - %TIOCM_DSR state of DSR signal
81 * - %TIOCM_RI state of RI signal
88 * Locking: @port->lock taken.
94 * Stop transmitting characters. This might be due to the CTS line
95 * becoming inactive or the tty layer indicating we want to stop
96 * transmission due to an %XOFF character.
100 * Locking: @port->lock taken.
108 * Locking: @port->lock taken.
115 * close to full, and it should somehow signal that no more characters
116 * should be sent to the serial port.
124 * Notify the serial driver that characters can now be sent to the serial
136 * is used to implement XON/XOFF flow control and tcflow(). If the serial
138 * character to the circular buffer and then call start_tx() / stop_tx()
139 * to flush the data out.
150 * Locking: @port->lock taken.
158 * Locking: @port->lock taken.
169 * Locking: @port->lock taken.
179 * Locking: caller holds tty_port->mutex
185 * this will be done via a separate call to @set_mctrl().
196 * this will have already been done via a separate call to @set_mctrl().
198 * Drivers must not access @port->state once this call has completed.
211 * This will be called whenever the @port->state->xmit circular buffer is
214 * Locking: @port->lock taken.
222 * Update @port->read_status_mask and @port->ignore_status_mask to
226 * - %CSIZE - word size
227 * - %CSTOPB - 2 stop bits
228 * - %PARENB - parity enable
229 * - %PARODD - odd parity (when %PARENB is in force)
230 * - %ADDRB - address bit (changed through uart_port::rs485_config()).
231 * - %CREAD - enable reception of characters (if not set, still receive
233 * - %CRTSCTS - if set, enable CTS status change reporting.
234 * - %CLOCAL - if not set, enable modem status change reporting.
238 * - %INPCK - enable frame and parity error events to be passed to the TTY
240 * - %BRKINT / %PARMRK - both of these enable break events to be passed to
242 * - %IGNPAR - ignore parity and framing errors.
243 * - %IGNBRK - ignore break errors. If %IGNPAR is also set, ignore overrun
261 * Locking: caller holds tty_port->mutex
268 * Documentation/driver-api/tty/tty_ldisc.rst.
270 * Locking: caller holds tty_port->mutex
279 * This function should not be used to grab any resources.
290 * Return a pointer to a string constant describing the specified @port,
308 * it should return -%EBUSY on failure.
318 * @port->type should be set to the type found, or %PORT_UNKNOWN if no
349 * Called by kgdb to perform the minimal hardware initialization needed to
353 * Locking: %tty_mutex and tty_port->mutex taken.
358 * Called by kgdb to write a single character @ch directly to the serial
367 * Called by kgdb to read a single character directly from the serial
477 #define UPIO_MEM (SERIAL_IO_MEM) /* driver-specific */
491 struct uart_state *state; /* pointer to parent state */
499 * These flags must be equivalent to the flags defined in
505 * The remaining bits are serial-core specific and not modifiable by
524 /* Port has hardware-assisted h/w flow control */
528 /* Port has hardware-assisted s/w flow control */
547 #error Change mask not equivalent to userspace-visible bit defines
551 * Must hold termios_rwsem, port mutex and port lock to change;
552 * can hold any one lock to read.
563 bool hw_stopped; /* sw-assisted CTS flow state */
596 * Only for console->device_lock()/_unlock() callbacks and internal
599 static inline void __uart_port_lock_irqsave(struct uart_port *up, unsigned long *flags) in __uart_port_lock_irqsave() argument
601 spin_lock_irqsave(&up->lock, *flags); in __uart_port_lock_irqsave()
605 * Only for console->device_lock()/_unlock() callbacks and internal
608 static inline void __uart_port_unlock_irqrestore(struct uart_port *up, unsigned long flags) in __uart_port_unlock_irqrestore() argument
610 spin_unlock_irqrestore(&up->lock, flags); in __uart_port_unlock_irqrestore()
614 * uart_port_set_cons - Safely set the @cons field for a uart
615 * @up: The uart port to set
616 * @con: The new console to set to
618 * This function must be used to set @up->cons. It uses the port lock to
619 * synchronize with the port lock wrappers in order to ensure that the console
622 static inline void uart_port_set_cons(struct uart_port *up, struct console *con) in uart_port_set_cons() argument
626 __uart_port_lock_irqsave(up, &flags); in uart_port_set_cons()
627 up->cons = con; in uart_port_set_cons()
628 __uart_port_unlock_irqrestore(up, flags); in uart_port_set_cons()
632 static inline bool __uart_port_using_nbcon(struct uart_port *up) in __uart_port_using_nbcon() argument
634 lockdep_assert_held_once(&up->lock); in __uart_port_using_nbcon()
636 if (likely(!uart_console(up))) in __uart_port_using_nbcon()
640 * @up->cons is only modified under the port lock. Therefore it is in __uart_port_using_nbcon()
643 * @up->cons->node is added/removed from the console list under the in __uart_port_using_nbcon()
645 * cannot change here, thus @up->cons->flags can be read directly. in __uart_port_using_nbcon()
647 if (hlist_unhashed_lockless(&up->cons->node) || in __uart_port_using_nbcon()
648 !(up->cons->flags & CON_NBCON) || in __uart_port_using_nbcon()
649 !up->cons->write_atomic) { in __uart_port_using_nbcon()
657 static inline bool __uart_port_nbcon_try_acquire(struct uart_port *up) in __uart_port_nbcon_try_acquire() argument
659 if (!__uart_port_using_nbcon(up)) in __uart_port_nbcon_try_acquire()
662 return nbcon_device_try_acquire(up->cons); in __uart_port_nbcon_try_acquire()
666 static inline void __uart_port_nbcon_acquire(struct uart_port *up) in __uart_port_nbcon_acquire() argument
668 if (!__uart_port_using_nbcon(up)) in __uart_port_nbcon_acquire()
671 while (!nbcon_device_try_acquire(up->cons)) in __uart_port_nbcon_acquire()
676 static inline void __uart_port_nbcon_release(struct uart_port *up) in __uart_port_nbcon_release() argument
678 if (!__uart_port_using_nbcon(up)) in __uart_port_nbcon_release()
681 nbcon_device_release(up->cons); in __uart_port_nbcon_release()
685 * uart_port_lock - Lock the UART port
686 * @up: Pointer to UART port structure
688 static inline void uart_port_lock(struct uart_port *up) in uart_port_lock() argument
690 spin_lock(&up->lock); in uart_port_lock()
691 __uart_port_nbcon_acquire(up); in uart_port_lock()
695 * uart_port_lock_irq - Lock the UART port and disable interrupts
696 * @up: Pointer to UART port structure
698 static inline void uart_port_lock_irq(struct uart_port *up) in uart_port_lock_irq() argument
700 spin_lock_irq(&up->lock); in uart_port_lock_irq()
701 __uart_port_nbcon_acquire(up); in uart_port_lock_irq()
705 * uart_port_lock_irqsave - Lock the UART port, save and disable interrupts
706 * @up: Pointer to UART port structure
707 * @flags: Pointer to interrupt flags storage
709 static inline void uart_port_lock_irqsave(struct uart_port *up, unsigned long *flags) in uart_port_lock_irqsave() argument
711 spin_lock_irqsave(&up->lock, *flags); in uart_port_lock_irqsave()
712 __uart_port_nbcon_acquire(up); in uart_port_lock_irqsave()
716 * uart_port_trylock - Try to lock the UART port
717 * @up: Pointer to UART port structure
721 static inline bool uart_port_trylock(struct uart_port *up) in uart_port_trylock() argument
723 if (!spin_trylock(&up->lock)) in uart_port_trylock()
726 if (!__uart_port_nbcon_try_acquire(up)) { in uart_port_trylock()
727 spin_unlock(&up->lock); in uart_port_trylock()
735 * uart_port_trylock_irqsave - Try to lock the UART port, save and disable interrupts
736 * @up: Pointer to UART port structure
737 * @flags: Pointer to interrupt flags storage
741 static inline bool uart_port_trylock_irqsave(struct uart_port *up, unsigned long *flags) in uart_port_trylock_irqsave() argument
743 if (!spin_trylock_irqsave(&up->lock, *flags)) in uart_port_trylock_irqsave()
746 if (!__uart_port_nbcon_try_acquire(up)) { in uart_port_trylock_irqsave()
747 spin_unlock_irqrestore(&up->lock, *flags); in uart_port_trylock_irqsave()
755 * uart_port_unlock - Unlock the UART port
756 * @up: Pointer to UART port structure
758 static inline void uart_port_unlock(struct uart_port *up) in uart_port_unlock() argument
760 __uart_port_nbcon_release(up); in uart_port_unlock()
761 spin_unlock(&up->lock); in uart_port_unlock()
765 * uart_port_unlock_irq - Unlock the UART port and re-enable interrupts
766 * @up: Pointer to UART port structure
768 static inline void uart_port_unlock_irq(struct uart_port *up) in uart_port_unlock_irq() argument
770 __uart_port_nbcon_release(up); in uart_port_unlock_irq()
771 spin_unlock_irq(&up->lock); in uart_port_unlock_irq()
775 * uart_port_unlock_irqrestore - Unlock the UART port, restore interrupts
776 * @up: Pointer to UART port structure
779 static inline void uart_port_unlock_irqrestore(struct uart_port *up, unsigned long flags) in uart_port_unlock_irqrestore() argument
781 __uart_port_nbcon_release(up); in uart_port_unlock_irqrestore()
782 spin_unlock_irqrestore(&up->lock, flags); in uart_port_unlock_irqrestore()
785 static inline int serial_port_in(struct uart_port *up, int offset) in serial_port_in() argument
787 return up->serial_in(up, offset); in serial_port_in()
790 static inline void serial_port_out(struct uart_port *up, int offset, int value) in serial_port_out() argument
792 up->serial_out(up, offset, value); in serial_port_out()
796 * enum uart_pm_state - power states for UARTs
797 * @UART_PM_STATE_ON: UART is powered, up and operational
827 * uart_xmit_advance - Advance xmit buffer and account Tx'ed chars
828 * @up: uart_port structure describing the port
833 * @up's icount.tx).
835 static inline void uart_xmit_advance(struct uart_port *up, unsigned int chars) in uart_xmit_advance() argument
837 struct tty_port *tport = &up->state->port; in uart_xmit_advance()
839 kfifo_skip_count(&tport->xmit_fifo, chars); in uart_xmit_advance()
840 up->icount.tx += chars; in uart_xmit_advance()
843 static inline unsigned int uart_fifo_out(struct uart_port *up, in uart_fifo_out() argument
846 struct tty_port *tport = &up->state->port; in uart_fifo_out()
848 chars = kfifo_out(&tport->xmit_fifo, buf, chars); in uart_fifo_out()
849 up->icount.tx += chars; in uart_fifo_out()
854 static inline unsigned int uart_fifo_get(struct uart_port *up, in uart_fifo_get() argument
857 struct tty_port *tport = &up->state->port; in uart_fifo_get()
860 chars = kfifo_get(&tport->xmit_fifo, ch); in uart_fifo_get()
861 up->icount.tx += chars; in uart_fifo_get()
880 * touch these; they should be initialised to NULL
889 * enum UART_TX_FLAGS -- flags for uart_port_tx_flags()
891 * @UART_TX_NOSTOP: don't call port->ops->stop_tx() on empty buffer
901 struct tty_port *__tport = &__port->state->port; \
904 for (; (for_test) && (tx_ready); (for_post), __port->icount.tx++) { \
905 if (__port->x_char) { \
906 (ch) = __port->x_char; \
908 __port->x_char = 0; \
915 if (!kfifo_get(&__tport->xmit_fifo, &(ch))) \
923 pending = kfifo_len(&__tport->xmit_fifo); \
928 __port->ops->stop_tx(__port); \
935 * uart_port_tx_limited -- transmit helper for uart_port with count limiting
937 * @ch: variable to store a character to be written to the HW
938 * @count: a limit of characters to send
940 * @put_char: function to write a character
941 * @tx_done: function to call after the loop is done
943 * This helper transmits characters from the xmit buffer to the hardware using
945 * evaluates to true.
950 * * **tx_ready:** should evaluate to true if the HW can accept more data to
952 * * **put_char:** shall write @ch to the device of @port.
954 * action before potential invocation of ops->stop_tx() happens. If the
955 * driver does not need to do anything, use e.g. ({}).
957 * For all of them, @port->lock is held, interrupts are locally disabled and
963 __count--); \
967 * uart_port_tx_limited_flags -- transmit helper for uart_port with count limiting with flags
969 * @ch: variable to store a character to be written to the HW
971 * @count: a limit of characters to send
973 * @put_char: function to write a character
974 * @tx_done: function to call after the loop is done
981 __count--); \
985 * uart_port_tx -- transmit helper for uart_port
987 * @ch: variable to store a character to be written to the HW
989 * @put_char: function to write a character
998 * uart_port_tx_flags -- transmit helper for uart_port with flags
1000 * @ch: variable to store a character to be written to the HW
1003 * @put_char: function to write a character
1024 u64 fifo_timeout = (u64)READ_ONCE(port->frame_time) * port->fifosize; in uart_fifo_timeout()
1037 return timeout > 6 ? (timeout / 2 - 2) : 1; in uart_poll_timeout()
1090 return uart_console(port) && console_is_registered_locked(port->cons); in uart_console_registered_locked()
1095 return uart_console(port) && console_is_registered(port->cons); in uart_console_registered()
1131 struct tty_struct *tty = port->state->port.tty; in uart_tx_stopped()
1132 if ((tty && tty->flow.stopped) || port->hw_stopped) in uart_tx_stopped()
1139 return !!(uport->status & UPSTAT_CTS_ENABLE); in uart_cts_enabled()
1146 return ((uport->status & mask) == UPSTAT_CTS_ENABLE); in uart_softcts_mode()
1168 if (!port->sysrq) in uart_handle_sysrq_char()
1171 if (ch && time_before(jiffies, port->sysrq)) { in uart_handle_sysrq_char()
1174 port->sysrq = 0; in uart_handle_sysrq_char()
1180 port->sysrq = 0; in uart_handle_sysrq_char()
1187 if (!port->sysrq) in uart_prepare_sysrq_char()
1190 if (ch && time_before(jiffies, port->sysrq)) { in uart_prepare_sysrq_char()
1192 port->sysrq_ch = ch; in uart_prepare_sysrq_char()
1193 port->sysrq = 0; in uart_prepare_sysrq_char()
1199 port->sysrq = 0; in uart_prepare_sysrq_char()
1208 if (!port->has_sysrq) { in uart_unlock_and_check_sysrq()
1213 sysrq_ch = port->sysrq_ch; in uart_unlock_and_check_sysrq()
1214 port->sysrq_ch = 0; in uart_unlock_and_check_sysrq()
1227 if (!port->has_sysrq) { in uart_unlock_and_check_sysrq_irqrestore()
1232 sysrq_ch = port->sysrq_ch; in uart_unlock_and_check_sysrq_irqrestore()
1233 port->sysrq_ch = 0; in uart_unlock_and_check_sysrq_irqrestore()
1265 struct uart_state *state = port->state; in uart_handle_break()
1267 if (port->handle_break) in uart_handle_break()
1268 port->handle_break(port); in uart_handle_break()
1271 if (port->has_sysrq && uart_console(port)) { in uart_handle_break()
1272 if (!port->sysrq) { in uart_handle_break()
1273 port->sysrq = jiffies + SYSRQ_TIMEOUT; in uart_handle_break()
1276 port->sysrq = 0; in uart_handle_break()
1279 if (port->flags & UPF_SAK) in uart_handle_break()
1280 do_SAK(state->port.tty); in uart_handle_break()
1285 * UART_ENABLE_MS - determine if port should enable modem status irqs
1287 #define UART_ENABLE_MS(port,cflag) ((port)->flags & UPF_HARDPPS_CD || \