Lines Matching +full:port +full:- +full:1
1 // SPDX-License-Identifier: GPL-2.0+
5 * Copyright (C) 2012-2016 Alexander Shiyan <shc_work@mail.ru>
78 #define MAX310X_IRQ_LSR_BIT (1 << 0) /* LSR interrupt */
79 #define MAX310X_IRQ_SPCHR_BIT (1 << 1) /* Special char interrupt */
80 #define MAX310X_IRQ_STS_BIT (1 << 2) /* Status interrupt */
81 #define MAX310X_IRQ_RXFIFO_BIT (1 << 3) /* RX FIFO interrupt */
82 #define MAX310X_IRQ_TXFIFO_BIT (1 << 4) /* TX FIFO interrupt */
83 #define MAX310X_IRQ_TXEMPTY_BIT (1 << 5) /* TX FIFO empty interrupt */
84 #define MAX310X_IRQ_RXEMPTY_BIT (1 << 6) /* RX FIFO empty interrupt */
85 #define MAX310X_IRQ_CTS_BIT (1 << 7) /* CTS interrupt */
88 #define MAX310X_LSR_RXTO_BIT (1 << 0) /* RX timeout */
89 #define MAX310X_LSR_RXOVR_BIT (1 << 1) /* RX overrun */
90 #define MAX310X_LSR_RXPAR_BIT (1 << 2) /* RX parity error */
91 #define MAX310X_LSR_FRERR_BIT (1 << 3) /* Frame error */
92 #define MAX310X_LSR_RXBRK_BIT (1 << 4) /* RX break */
93 #define MAX310X_LSR_RXNOISE_BIT (1 << 5) /* RX noise */
94 #define MAX310X_LSR_CTS_BIT (1 << 7) /* CTS pin state */
97 #define MAX310X_SPCHR_XON1_BIT (1 << 0) /* XON1 character */
98 #define MAX310X_SPCHR_XON2_BIT (1 << 1) /* XON2 character */
99 #define MAX310X_SPCHR_XOFF1_BIT (1 << 2) /* XOFF1 character */
100 #define MAX310X_SPCHR_XOFF2_BIT (1 << 3) /* XOFF2 character */
101 #define MAX310X_SPCHR_BREAK_BIT (1 << 4) /* RX break */
102 #define MAX310X_SPCHR_MULTIDROP_BIT (1 << 5) /* 9-bit multidrop addr char */
105 #define MAX310X_STS_GPIO0_BIT (1 << 0) /* GPIO 0 interrupt */
106 #define MAX310X_STS_GPIO1_BIT (1 << 1) /* GPIO 1 interrupt */
107 #define MAX310X_STS_GPIO2_BIT (1 << 2) /* GPIO 2 interrupt */
108 #define MAX310X_STS_GPIO3_BIT (1 << 3) /* GPIO 3 interrupt */
109 #define MAX310X_STS_CLKREADY_BIT (1 << 5) /* Clock ready */
110 #define MAX310X_STS_SLEEP_BIT (1 << 6) /* Sleep interrupt */
113 #define MAX310X_MODE1_RXDIS_BIT (1 << 0) /* RX disable */
114 #define MAX310X_MODE1_TXDIS_BIT (1 << 1) /* TX disable */
115 #define MAX310X_MODE1_TXHIZ_BIT (1 << 2) /* TX pin three-state */
116 #define MAX310X_MODE1_RTSHIZ_BIT (1 << 3) /* RTS pin three-state */
117 #define MAX310X_MODE1_TRNSCVCTRL_BIT (1 << 4) /* Transceiver ctrl enable */
118 #define MAX310X_MODE1_FORCESLEEP_BIT (1 << 5) /* Force sleep mode */
119 #define MAX310X_MODE1_AUTOSLEEP_BIT (1 << 6) /* Auto sleep enable */
120 #define MAX310X_MODE1_IRQSEL_BIT (1 << 7) /* IRQ pin enable */
123 #define MAX310X_MODE2_RST_BIT (1 << 0) /* Chip reset */
124 #define MAX310X_MODE2_FIFORST_BIT (1 << 1) /* FIFO reset */
125 #define MAX310X_MODE2_RXTRIGINV_BIT (1 << 2) /* RX FIFO INT invert */
126 #define MAX310X_MODE2_RXEMPTINV_BIT (1 << 3) /* RX FIFO empty INT invert */
127 #define MAX310X_MODE2_SPCHR_BIT (1 << 4) /* Special chr detect enable */
128 #define MAX310X_MODE2_LOOPBACK_BIT (1 << 5) /* Internal loopback enable */
129 #define MAX310X_MODE2_MULTIDROP_BIT (1 << 6) /* 9-bit multidrop enable */
130 #define MAX310X_MODE2_ECHOSUPR_BIT (1 << 7) /* ECHO suppression enable */
133 #define MAX310X_LCR_LENGTH0_BIT (1 << 0) /* Word length bit 0 */
134 #define MAX310X_LCR_LENGTH1_BIT (1 << 1) /* Word length bit 1
137 * 00 -> 5 bit words
138 * 01 -> 6 bit words
139 * 10 -> 7 bit words
140 * 11 -> 8 bit words
142 #define MAX310X_LCR_STOPLEN_BIT (1 << 2) /* STOP length bit
145 * 0 -> 1 stop bit
146 * 1 -> 1-1.5 stop bits if
150 #define MAX310X_LCR_PARITY_BIT (1 << 3) /* Parity bit enable */
151 #define MAX310X_LCR_EVENPARITY_BIT (1 << 4) /* Even parity bit enable */
152 #define MAX310X_LCR_FORCEPARITY_BIT (1 << 5) /* 9-bit multidrop parity */
153 #define MAX310X_LCR_TXBREAK_BIT (1 << 6) /* TX break enable */
154 #define MAX310X_LCR_RTS_BIT (1 << 7) /* RTS pin control */
157 #define MAX310X_IRDA_IRDAEN_BIT (1 << 0) /* IRDA mode enable */
158 #define MAX310X_IRDA_SIR_BIT (1 << 1) /* SIR mode enable */
173 #define MAX310X_FLOWCTRL_AUTORTS_BIT (1 << 0) /* Auto RTS flow ctrl enable */
174 #define MAX310X_FLOWCTRL_AUTOCTS_BIT (1 << 1) /* Auto CTS flow ctrl enable */
175 #define MAX310X_FLOWCTRL_GPIADDR_BIT (1 << 2) /* Enables that GPIO inputs
179 #define MAX310X_FLOWCTRL_SWFLOWEN_BIT (1 << 3) /* Auto SW flow ctrl enable */
180 #define MAX310X_FLOWCTRL_SWFLOW0_BIT (1 << 4) /* SWFLOW bit 0 */
181 #define MAX310X_FLOWCTRL_SWFLOW1_BIT (1 << 5) /* SWFLOW bit 1
183 * SWFLOW bits 1 & 0 table:
184 * 00 -> no transmitter flow
186 * 01 -> receiver compares
190 * 10 -> receiver compares
194 * 11 -> receiver compares
199 #define MAX310X_FLOWCTRL_SWFLOW2_BIT (1 << 6) /* SWFLOW bit 2 */
200 #define MAX310X_FLOWCTRL_SWFLOW3_BIT (1 << 7) /* SWFLOW bit 3
203 * 00 -> no received flow
205 * 01 -> transmitter generates
207 * 10 -> transmitter generates
209 * 11 -> transmitter generates
219 #define MAX310X_BRGCFG_2XMODE_BIT (1 << 4) /* Double baud rate */
220 #define MAX310X_BRGCFG_4XMODE_BIT (1 << 5) /* Quadruple baud rate */
223 #define MAX310X_CLKSRC_CRYST_BIT (1 << 1) /* Crystal osc enable */
224 #define MAX310X_CLKSRC_PLL_BIT (1 << 2) /* PLL enable */
225 #define MAX310X_CLKSRC_PLLBYP_BIT (1 << 3) /* PLL bypass */
226 #define MAX310X_CLKSRC_EXTCLK_BIT (1 << 4) /* External clock enable */
227 #define MAX310X_CLKSRC_CLK2RTS_BIT (1 << 7) /* Baud clk to RTS pin */
245 #define MAX14830_BRGCFG_CLKDIS_BIT (1 << 6) /* Clock Disable */
257 struct uart_port port; member
267 container_of(_port, struct max310x_one, port)
290 static u8 max310x_port_read(struct uart_port *port, u8 reg) in max310x_port_read() argument
292 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_port_read()
295 regmap_read(s->regmap, port->iobase + reg, &val); in max310x_port_read()
300 static void max310x_port_write(struct uart_port *port, u8 reg, u8 val) in max310x_port_write() argument
302 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_port_write()
304 regmap_write(s->regmap, port->iobase + reg, val); in max310x_port_write()
307 static void max310x_port_update(struct uart_port *port, u8 reg, u8 mask, u8 val) in max310x_port_update() argument
309 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_port_update()
311 regmap_update_bits(s->regmap, port->iobase + reg, mask, val); in max310x_port_update()
320 ret = regmap_read(s->regmap, MAX310X_REVID_REG, &val); in max3107_detect()
326 "%s ID 0x%02x does not match\n", s->devtype->name, val); in max3107_detect()
327 return -ENODEV; in max3107_detect()
342 ret = regmap_read(s->regmap, MAX310X_CLKSRC_REG, &val); in max3108_detect()
347 dev_err(dev, "%s not present\n", s->devtype->name); in max3108_detect()
348 return -ENODEV; in max3108_detect()
360 ret = regmap_write(s->regmap, MAX310X_GLOBALCMD_REG, in max3109_detect()
365 regmap_read(s->regmap, MAX310X_REVID_EXTREG, &val); in max3109_detect()
366 regmap_write(s->regmap, MAX310X_GLOBALCMD_REG, MAX310X_EXTREG_DSBL); in max3109_detect()
369 "%s ID 0x%02x does not match\n", s->devtype->name, val); in max3109_detect()
370 return -ENODEV; in max3109_detect()
376 static void max310x_power(struct uart_port *port, int on) in max310x_power() argument
378 max310x_port_update(port, MAX310X_MODE1_REG, in max310x_power()
391 ret = regmap_write(s->regmap, MAX310X_GLOBALCMD_REG, in max14830_detect()
396 regmap_read(s->regmap, MAX310X_REVID_EXTREG, &val); in max14830_detect()
397 regmap_write(s->regmap, MAX310X_GLOBALCMD_REG, MAX310X_EXTREG_DSBL); in max14830_detect()
400 "%s ID 0x%02x does not match\n", s->devtype->name, val); in max14830_detect()
401 return -ENODEV; in max14830_detect()
407 static void max14830_power(struct uart_port *port, int on) in max14830_power() argument
409 max310x_port_update(port, MAX310X_BRGCFG_REG, in max14830_power()
418 .nr = 1,
426 .nr = 1,
502 static int max310x_set_baud(struct uart_port *port, int baud) in max310x_set_baud() argument
508 * in case if the requested baud is too high for the pre-defined in max310x_set_baud()
511 div = port->uartclk / baud; in max310x_set_baud()
530 frac = (16*(port->uartclk % F)) / F; in max310x_set_baud()
532 div = 1; in max310x_set_baud()
534 max310x_port_write(port, MAX310X_BRGDIVMSB_REG, div >> 8); in max310x_set_baud()
535 max310x_port_write(port, MAX310X_BRGDIVLSB_REG, div); in max310x_set_baud()
536 max310x_port_write(port, MAX310X_BRGCFG_REG, frac | mode); in max310x_set_baud()
539 return (16*port->uartclk) / (c*(16*div + frac)); in max310x_set_baud()
552 return 1; in max310x_update_best_err()
559 long besterr = -1; in max310x_set_ref_clk()
566 for (div = 1; (div <= 63) && besterr; div++) { in max310x_set_ref_clk()
580 pllcfg = (1 << 6) | div; in max310x_set_ref_clk()
605 regmap_write(s->regmap, MAX310X_PLLCFG_REG, pllcfg); in max310x_set_ref_clk()
609 regmap_write(s->regmap, MAX310X_CLKSRC_REG, clksrc); in max310x_set_ref_clk()
615 regmap_read(s->regmap, MAX310X_STS_IRQSTS_REG, &val); in max310x_set_ref_clk()
624 static void max310x_batch_write(struct uart_port *port, u8 *txbuf, unsigned int len) in max310x_batch_write() argument
626 struct max310x_one *one = to_max310x_port(port); in max310x_batch_write()
629 .tx_buf = &one->wr_header, in max310x_batch_write()
630 .len = sizeof(one->wr_header), in max310x_batch_write()
636 spi_sync_transfer(to_spi_device(port->dev), xfer, ARRAY_SIZE(xfer)); in max310x_batch_write()
639 static void max310x_batch_read(struct uart_port *port, u8 *rxbuf, unsigned int len) in max310x_batch_read() argument
641 struct max310x_one *one = to_max310x_port(port); in max310x_batch_read()
644 .tx_buf = &one->rd_header, in max310x_batch_read()
645 .len = sizeof(one->rd_header), in max310x_batch_read()
651 spi_sync_transfer(to_spi_device(port->dev), xfer, ARRAY_SIZE(xfer)); in max310x_batch_read()
654 static void max310x_handle_rx(struct uart_port *port, unsigned int rxlen) in max310x_handle_rx() argument
656 struct max310x_one *one = to_max310x_port(port); in max310x_handle_rx()
659 if (port->read_status_mask == MAX310X_LSR_RXOVR_BIT) { in max310x_handle_rx()
661 * Break condition, parity checking, framing errors -- they in max310x_handle_rx()
662 * are all ignored. That means that we can do a batch-read. in max310x_handle_rx()
671 sts = max310x_port_read(port, MAX310X_LSR_IRQSTS_REG); in max310x_handle_rx()
672 max310x_batch_read(port, one->rx_buf, rxlen); in max310x_handle_rx()
674 port->icount.rx += rxlen; in max310x_handle_rx()
676 sts &= port->read_status_mask; in max310x_handle_rx()
679 dev_warn_ratelimited(port->dev, "Hardware RX FIFO overrun\n"); in max310x_handle_rx()
680 port->icount.overrun++; in max310x_handle_rx()
683 for (i = 0; i < (rxlen - 1); ++i) in max310x_handle_rx()
684 uart_insert_char(port, sts, 0, one->rx_buf[i], flag); in max310x_handle_rx()
691 uart_insert_char(port, sts, MAX310X_LSR_RXOVR_BIT, in max310x_handle_rx()
692 one->rx_buf[rxlen-1], flag); in max310x_handle_rx()
695 if (unlikely(rxlen >= port->fifosize)) { in max310x_handle_rx()
696 dev_warn_ratelimited(port->dev, "Possible RX FIFO overrun\n"); in max310x_handle_rx()
697 port->icount.buf_overrun++; in max310x_handle_rx()
699 rxlen = port->fifosize; in max310x_handle_rx()
702 while (rxlen--) { in max310x_handle_rx()
703 ch = max310x_port_read(port, MAX310X_RHR_REG); in max310x_handle_rx()
704 sts = max310x_port_read(port, MAX310X_LSR_IRQSTS_REG); in max310x_handle_rx()
709 port->icount.rx++; in max310x_handle_rx()
714 port->icount.brk++; in max310x_handle_rx()
715 if (uart_handle_break(port)) in max310x_handle_rx()
718 port->icount.parity++; in max310x_handle_rx()
720 port->icount.frame++; in max310x_handle_rx()
722 port->icount.overrun++; in max310x_handle_rx()
724 sts &= port->read_status_mask; in max310x_handle_rx()
735 if (uart_handle_sysrq_char(port, ch)) in max310x_handle_rx()
738 if (sts & port->ignore_status_mask) in max310x_handle_rx()
741 uart_insert_char(port, sts, MAX310X_LSR_RXOVR_BIT, ch, flag); in max310x_handle_rx()
745 tty_flip_buffer_push(&port->state->port); in max310x_handle_rx()
748 static void max310x_handle_tx(struct uart_port *port) in max310x_handle_tx() argument
750 struct circ_buf *xmit = &port->state->xmit; in max310x_handle_tx()
753 if (unlikely(port->x_char)) { in max310x_handle_tx()
754 max310x_port_write(port, MAX310X_THR_REG, port->x_char); in max310x_handle_tx()
755 port->icount.tx++; in max310x_handle_tx()
756 port->x_char = 0; in max310x_handle_tx()
760 if (uart_circ_empty(xmit) || uart_tx_stopped(port)) in max310x_handle_tx()
765 until_end = CIRC_CNT_TO_END(xmit->head, xmit->tail, UART_XMIT_SIZE); in max310x_handle_tx()
768 txlen = max310x_port_read(port, MAX310X_TXFIFOLVL_REG); in max310x_handle_tx()
769 txlen = port->fifosize - txlen; in max310x_handle_tx()
773 /* It's a circ buffer -- wrap around. in max310x_handle_tx()
775 max310x_batch_write(port, xmit->buf + xmit->tail, until_end); in max310x_handle_tx()
776 max310x_batch_write(port, xmit->buf, to_send - until_end); in max310x_handle_tx()
778 max310x_batch_write(port, xmit->buf + xmit->tail, to_send); in max310x_handle_tx()
782 port->icount.tx += to_send; in max310x_handle_tx()
783 xmit->tail = (xmit->tail + to_send) & (UART_XMIT_SIZE - 1); in max310x_handle_tx()
787 uart_write_wakeup(port); in max310x_handle_tx()
790 static void max310x_start_tx(struct uart_port *port) in max310x_start_tx() argument
792 struct max310x_one *one = to_max310x_port(port); in max310x_start_tx()
794 schedule_work(&one->tx_work); in max310x_start_tx()
799 struct uart_port *port = &s->p[portno].port; in max310x_port_irq() local
806 ists = max310x_port_read(port, MAX310X_IRQSTS_REG); in max310x_port_irq()
807 rxlen = max310x_port_read(port, MAX310X_RXFIFOLVL_REG); in max310x_port_irq()
814 lsr = max310x_port_read(port, MAX310X_LSR_IRQSTS_REG); in max310x_port_irq()
815 uart_handle_cts_change(port, in max310x_port_irq()
819 max310x_handle_rx(port, rxlen); in max310x_port_irq()
821 max310x_start_tx(port); in max310x_port_irq()
822 } while (1); in max310x_port_irq()
831 if (s->devtype->nr > 1) { in max310x_ist()
835 WARN_ON_ONCE(regmap_read(s->regmap, in max310x_ist()
837 val = ((1 << s->devtype->nr) - 1) & ~val; in max310x_ist()
840 if (max310x_port_irq(s, fls(val) - 1) == IRQ_HANDLED) in max310x_ist()
842 } while (1); in max310x_ist()
855 max310x_handle_tx(&one->port); in max310x_tx_proc()
858 static unsigned int max310x_tx_empty(struct uart_port *port) in max310x_tx_empty() argument
860 u8 lvl = max310x_port_read(port, MAX310X_TXFIFOLVL_REG); in max310x_tx_empty()
865 static unsigned int max310x_get_mctrl(struct uart_port *port) in max310x_get_mctrl() argument
877 max310x_port_update(&one->port, MAX310X_MODE2_REG, in max310x_md_proc()
879 (one->port.mctrl & TIOCM_LOOP) ? in max310x_md_proc()
883 static void max310x_set_mctrl(struct uart_port *port, unsigned int mctrl) in max310x_set_mctrl() argument
885 struct max310x_one *one = to_max310x_port(port); in max310x_set_mctrl()
887 schedule_work(&one->md_work); in max310x_set_mctrl()
890 static void max310x_break_ctl(struct uart_port *port, int break_state) in max310x_break_ctl() argument
892 max310x_port_update(port, MAX310X_LCR_REG, in max310x_break_ctl()
897 static void max310x_set_termios(struct uart_port *port, in max310x_set_termios() argument
905 termios->c_cflag &= ~CMSPAR; in max310x_set_termios()
908 switch (termios->c_cflag & CSIZE) { in max310x_set_termios()
924 if (termios->c_cflag & PARENB) { in max310x_set_termios()
926 if (!(termios->c_cflag & PARODD)) in max310x_set_termios()
931 if (termios->c_cflag & CSTOPB) in max310x_set_termios()
935 max310x_port_write(port, MAX310X_LCR_REG, lcr); in max310x_set_termios()
938 port->read_status_mask = MAX310X_LSR_RXOVR_BIT; in max310x_set_termios()
939 if (termios->c_iflag & INPCK) in max310x_set_termios()
940 port->read_status_mask |= MAX310X_LSR_RXPAR_BIT | in max310x_set_termios()
942 if (termios->c_iflag & (IGNBRK | BRKINT | PARMRK)) in max310x_set_termios()
943 port->read_status_mask |= MAX310X_LSR_RXBRK_BIT; in max310x_set_termios()
946 port->ignore_status_mask = 0; in max310x_set_termios()
947 if (termios->c_iflag & IGNBRK) in max310x_set_termios()
948 port->ignore_status_mask |= MAX310X_LSR_RXBRK_BIT; in max310x_set_termios()
949 if (!(termios->c_cflag & CREAD)) in max310x_set_termios()
950 port->ignore_status_mask |= MAX310X_LSR_RXPAR_BIT | in max310x_set_termios()
956 max310x_port_write(port, MAX310X_XON1_REG, termios->c_cc[VSTART]); in max310x_set_termios()
957 max310x_port_write(port, MAX310X_XOFF1_REG, termios->c_cc[VSTOP]); in max310x_set_termios()
962 if (termios->c_cflag & CRTSCTS || termios->c_iflag & IXOFF) { in max310x_set_termios()
963 max310x_port_update(port, MAX310X_MODE1_REG, in max310x_set_termios()
968 port->status &= ~(UPSTAT_AUTOCTS | UPSTAT_AUTORTS | UPSTAT_AUTOXOFF); in max310x_set_termios()
970 if (termios->c_cflag & CRTSCTS) { in max310x_set_termios()
972 port->status |= UPSTAT_AUTOCTS | UPSTAT_AUTORTS; in max310x_set_termios()
976 if (termios->c_iflag & IXON) in max310x_set_termios()
979 if (termios->c_iflag & IXOFF) { in max310x_set_termios()
980 port->status |= UPSTAT_AUTOXOFF; in max310x_set_termios()
984 max310x_port_write(port, MAX310X_FLOWCTRL_REG, flow); in max310x_set_termios()
989 if (!(termios->c_cflag & CRTSCTS) && !(termios->c_iflag & IXOFF)) { in max310x_set_termios()
990 max310x_port_update(port, MAX310X_MODE1_REG, in max310x_set_termios()
996 baud = uart_get_baud_rate(port, termios, old, in max310x_set_termios()
997 port->uartclk / 16 / 0xffff, in max310x_set_termios()
998 port->uartclk / 4); in max310x_set_termios()
1001 baud = max310x_set_baud(port, baud); in max310x_set_termios()
1004 uart_update_timeout(port, termios->c_cflag, baud); in max310x_set_termios()
1012 delay = (one->port.rs485.delay_rts_before_send << 4) | in max310x_rs_proc()
1013 one->port.rs485.delay_rts_after_send; in max310x_rs_proc()
1014 max310x_port_write(&one->port, MAX310X_HDPIXDELAY_REG, delay); in max310x_rs_proc()
1016 if (one->port.rs485.flags & SER_RS485_ENABLED) { in max310x_rs_proc()
1019 if (!(one->port.rs485.flags & SER_RS485_RX_DURING_TX)) in max310x_rs_proc()
1023 max310x_port_update(&one->port, MAX310X_MODE1_REG, in max310x_rs_proc()
1025 max310x_port_update(&one->port, MAX310X_MODE2_REG, in max310x_rs_proc()
1029 static int max310x_rs485_config(struct uart_port *port, in max310x_rs485_config() argument
1032 struct max310x_one *one = to_max310x_port(port); in max310x_rs485_config()
1034 if ((rs485->delay_rts_before_send > 0x0f) || in max310x_rs485_config()
1035 (rs485->delay_rts_after_send > 0x0f)) in max310x_rs485_config()
1036 return -ERANGE; in max310x_rs485_config()
1038 rs485->flags &= SER_RS485_RTS_ON_SEND | SER_RS485_RX_DURING_TX | in max310x_rs485_config()
1040 memset(rs485->padding, 0, sizeof(rs485->padding)); in max310x_rs485_config()
1041 port->rs485 = *rs485; in max310x_rs485_config()
1043 schedule_work(&one->rs_work); in max310x_rs485_config()
1048 static int max310x_startup(struct uart_port *port) in max310x_startup() argument
1050 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_startup()
1053 s->devtype->power(port, 1); in max310x_startup()
1056 max310x_port_update(port, MAX310X_MODE1_REG, in max310x_startup()
1060 max310x_port_write(port, MAX310X_MODE2_REG, in max310x_startup()
1062 max310x_port_update(port, MAX310X_MODE2_REG, in max310x_startup()
1066 val = (clamp(port->rs485.delay_rts_before_send, 0U, 15U) << 4) | in max310x_startup()
1067 clamp(port->rs485.delay_rts_after_send, 0U, 15U); in max310x_startup()
1068 max310x_port_write(port, MAX310X_HDPIXDELAY_REG, val); in max310x_startup()
1070 if (port->rs485.flags & SER_RS485_ENABLED) { in max310x_startup()
1071 max310x_port_update(port, MAX310X_MODE1_REG, in max310x_startup()
1075 if (!(port->rs485.flags & SER_RS485_RX_DURING_TX)) in max310x_startup()
1076 max310x_port_update(port, MAX310X_MODE2_REG, in max310x_startup()
1083 max310x_port_write(port, MAX310X_FLOWLVL_REG, in max310x_startup()
1087 max310x_port_read(port, MAX310X_IRQSTS_REG); in max310x_startup()
1094 max310x_port_write(port, MAX310X_RXTO_REG, 4); in max310x_startup()
1101 max310x_port_write(port, MAX310X_FIFOTRIGLVL_REG, in max310x_startup()
1105 max310x_port_write(port, MAX310X_LSR_IRQEN_REG, in max310x_startup()
1110 max310x_port_write(port, MAX310X_IRQEN_REG, val | MAX310X_IRQ_CTS_BIT); in max310x_startup()
1115 static void max310x_shutdown(struct uart_port *port) in max310x_shutdown() argument
1117 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_shutdown()
1120 max310x_port_write(port, MAX310X_IRQEN_REG, 0); in max310x_shutdown()
1122 s->devtype->power(port, 0); in max310x_shutdown()
1125 static const char *max310x_type(struct uart_port *port) in max310x_type() argument
1127 struct max310x_port *s = dev_get_drvdata(port->dev); in max310x_type()
1129 return (port->type == PORT_MAX310X) ? s->devtype->name : NULL; in max310x_type()
1132 static int max310x_request_port(struct uart_port *port) in max310x_request_port() argument
1138 static void max310x_config_port(struct uart_port *port, int flags) in max310x_config_port() argument
1141 port->type = PORT_MAX310X; in max310x_config_port()
1144 static int max310x_verify_port(struct uart_port *port, struct serial_struct *s) in max310x_verify_port() argument
1146 if ((s->type != PORT_UNKNOWN) && (s->type != PORT_MAX310X)) in max310x_verify_port()
1147 return -EINVAL; in max310x_verify_port()
1148 if (s->irq != port->irq) in max310x_verify_port()
1149 return -EINVAL; in max310x_verify_port()
1154 static void max310x_null_void(struct uart_port *port) in max310x_null_void() argument
1182 for (i = 0; i < s->devtype->nr; i++) { in max310x_suspend()
1183 uart_suspend_port(&max310x_uart, &s->p[i].port); in max310x_suspend()
1184 s->devtype->power(&s->p[i].port, 0); in max310x_suspend()
1195 for (i = 0; i < s->devtype->nr; i++) { in max310x_resume()
1196 s->devtype->power(&s->p[i].port, 1); in max310x_resume()
1197 uart_resume_port(&max310x_uart, &s->p[i].port); in max310x_resume()
1210 struct uart_port *port = &s->p[offset / 4].port; in max310x_gpio_get() local
1212 val = max310x_port_read(port, MAX310X_GPIODATA_REG); in max310x_gpio_get()
1214 return !!((val >> 4) & (1 << (offset % 4))); in max310x_gpio_get()
1220 struct uart_port *port = &s->p[offset / 4].port; in max310x_gpio_set() local
1222 max310x_port_update(port, MAX310X_GPIODATA_REG, 1 << (offset % 4), in max310x_gpio_set()
1223 value ? 1 << (offset % 4) : 0); in max310x_gpio_set()
1229 struct uart_port *port = &s->p[offset / 4].port; in max310x_gpio_direction_input() local
1231 max310x_port_update(port, MAX310X_GPIOCFG_REG, 1 << (offset % 4), 0); in max310x_gpio_direction_input()
1240 struct uart_port *port = &s->p[offset / 4].port; in max310x_gpio_direction_output() local
1242 max310x_port_update(port, MAX310X_GPIODATA_REG, 1 << (offset % 4), in max310x_gpio_direction_output()
1243 value ? 1 << (offset % 4) : 0); in max310x_gpio_direction_output()
1244 max310x_port_update(port, MAX310X_GPIOCFG_REG, 1 << (offset % 4), in max310x_gpio_direction_output()
1245 1 << (offset % 4)); in max310x_gpio_direction_output()
1254 struct uart_port *port = &s->p[offset / 4].port; in max310x_gpio_set_config() local
1258 max310x_port_update(port, MAX310X_GPIOCFG_REG, in max310x_gpio_set_config()
1259 1 << ((offset % 4) + 4), in max310x_gpio_set_config()
1260 1 << ((offset % 4) + 4)); in max310x_gpio_set_config()
1263 max310x_port_update(port, MAX310X_GPIOCFG_REG, in max310x_gpio_set_config()
1264 1 << ((offset % 4) + 4), 0); in max310x_gpio_set_config()
1267 return -ENOTSUPP; in max310x_gpio_set_config()
1283 /* Alloc port structure */ in max310x_probe()
1284 s = devm_kzalloc(dev, struct_size(s, p, devtype->nr), GFP_KERNEL); in max310x_probe()
1286 dev_err(dev, "Error allocating port structure\n"); in max310x_probe()
1287 return -ENOMEM; in max310x_probe()
1293 s->clk = clk_osc; in max310x_probe()
1297 s->clk = clk_xtal; in max310x_probe()
1301 } else if (PTR_ERR(clk_osc) == -EPROBE_DEFER || in max310x_probe()
1302 PTR_ERR(clk_xtal) == -EPROBE_DEFER) { in max310x_probe()
1303 return -EPROBE_DEFER; in max310x_probe()
1306 return -EINVAL; in max310x_probe()
1309 ret = clk_prepare_enable(s->clk); in max310x_probe()
1313 freq = clk_get_rate(s->clk); in max310x_probe()
1316 ret = -ERANGE; in max310x_probe()
1320 s->regmap = regmap; in max310x_probe()
1321 s->devtype = devtype; in max310x_probe()
1325 ret = devtype->detect(dev); in max310x_probe()
1329 for (i = 0; i < devtype->nr; i++) { in max310x_probe()
1332 /* Reset port */ in max310x_probe()
1333 regmap_write(s->regmap, MAX310X_MODE2_REG + offs, in max310x_probe()
1335 /* Clear port reset */ in max310x_probe()
1336 regmap_write(s->regmap, MAX310X_MODE2_REG + offs, 0); in max310x_probe()
1338 /* Wait for port startup */ in max310x_probe()
1340 regmap_read(s->regmap, in max310x_probe()
1344 regmap_write(s->regmap, MAX310X_MODE1_REG + offs, in max310x_probe()
1345 devtype->mode1); in max310x_probe()
1351 for (i = 0; i < devtype->nr; i++) { in max310x_probe()
1356 ret = -ERANGE; in max310x_probe()
1360 /* Initialize port data */ in max310x_probe()
1361 s->p[i].port.line = line; in max310x_probe()
1362 s->p[i].port.dev = dev; in max310x_probe()
1363 s->p[i].port.irq = irq; in max310x_probe()
1364 s->p[i].port.type = PORT_MAX310X; in max310x_probe()
1365 s->p[i].port.fifosize = MAX310X_FIFO_SIZE; in max310x_probe()
1366 s->p[i].port.flags = UPF_FIXED_TYPE | UPF_LOW_LATENCY; in max310x_probe()
1367 s->p[i].port.iotype = UPIO_PORT; in max310x_probe()
1368 s->p[i].port.iobase = i * 0x20; in max310x_probe()
1369 s->p[i].port.membase = (void __iomem *)~0; in max310x_probe()
1370 s->p[i].port.uartclk = uartclk; in max310x_probe()
1371 s->p[i].port.rs485_config = max310x_rs485_config; in max310x_probe()
1372 s->p[i].port.ops = &max310x_ops; in max310x_probe()
1374 max310x_port_write(&s->p[i].port, MAX310X_IRQEN_REG, 0); in max310x_probe()
1376 max310x_port_read(&s->p[i].port, MAX310X_IRQSTS_REG); in max310x_probe()
1378 INIT_WORK(&s->p[i].tx_work, max310x_tx_proc); in max310x_probe()
1380 INIT_WORK(&s->p[i].md_work, max310x_md_proc); in max310x_probe()
1382 INIT_WORK(&s->p[i].rs_work, max310x_rs_proc); in max310x_probe()
1383 /* Initialize SPI-transfer buffers */ in max310x_probe()
1384 s->p[i].wr_header = (s->p[i].port.iobase + MAX310X_THR_REG) | in max310x_probe()
1386 s->p[i].rd_header = (s->p[i].port.iobase + MAX310X_RHR_REG); in max310x_probe()
1388 /* Register port */ in max310x_probe()
1389 ret = uart_add_one_port(&max310x_uart, &s->p[i].port); in max310x_probe()
1391 s->p[i].port.dev = NULL; in max310x_probe()
1397 devtype->power(&s->p[i].port, 0); in max310x_probe()
1402 s->gpio.owner = THIS_MODULE; in max310x_probe()
1403 s->gpio.parent = dev; in max310x_probe()
1404 s->gpio.label = devtype->name; in max310x_probe()
1405 s->gpio.direction_input = max310x_gpio_direction_input; in max310x_probe()
1406 s->gpio.get = max310x_gpio_get; in max310x_probe()
1407 s->gpio.direction_output= max310x_gpio_direction_output; in max310x_probe()
1408 s->gpio.set = max310x_gpio_set; in max310x_probe()
1409 s->gpio.set_config = max310x_gpio_set_config; in max310x_probe()
1410 s->gpio.base = -1; in max310x_probe()
1411 s->gpio.ngpio = devtype->nr * 4; in max310x_probe()
1412 s->gpio.can_sleep = 1; in max310x_probe()
1413 ret = devm_gpiochip_add_data(dev, &s->gpio, s); in max310x_probe()
1427 for (i = 0; i < devtype->nr; i++) { in max310x_probe()
1428 if (s->p[i].port.dev) { in max310x_probe()
1429 uart_remove_one_port(&max310x_uart, &s->p[i].port); in max310x_probe()
1430 clear_bit(s->p[i].port.line, max310x_lines); in max310x_probe()
1435 clk_disable_unprepare(s->clk); in max310x_probe()
1445 for (i = 0; i < s->devtype->nr; i++) { in max310x_remove()
1446 cancel_work_sync(&s->p[i].tx_work); in max310x_remove()
1447 cancel_work_sync(&s->p[i].md_work); in max310x_remove()
1448 cancel_work_sync(&s->p[i].rs_work); in max310x_remove()
1449 uart_remove_one_port(&max310x_uart, &s->p[i].port); in max310x_remove()
1450 clear_bit(s->p[i].port.line, max310x_lines); in max310x_remove()
1451 s->devtype->power(&s->p[i].port, 0); in max310x_remove()
1454 clk_disable_unprepare(s->clk); in max310x_remove()
1486 spi->bits_per_word = 8; in max310x_spi_probe()
1487 spi->mode = spi->mode ? : SPI_MODE_0; in max310x_spi_probe()
1488 spi->max_speed_hz = spi->max_speed_hz ? : 26000000; in max310x_spi_probe()
1493 if (spi->dev.of_node) { in max310x_spi_probe()
1495 of_match_device(max310x_dt_ids, &spi->dev); in max310x_spi_probe()
1497 return -ENODEV; in max310x_spi_probe()
1499 devtype = (struct max310x_devtype *)of_id->data; in max310x_spi_probe()
1503 devtype = (struct max310x_devtype *)id_entry->driver_data; in max310x_spi_probe()
1506 regcfg.max_register = devtype->nr * 0x20 - 1; in max310x_spi_probe()
1509 return max310x_probe(&spi->dev, devtype, regmap, spi->irq); in max310x_spi_probe()
1514 return max310x_remove(&spi->dev); in max310x_spi_remove()