Lines Matching +full:cpm1 +full:- +full:fsl
1 // SPDX-License-Identifier: GPL-2.0+
10 * Pantelis Antoniou (panto@intracom.gr) (CPM1)
14 * (C) 2005-2006 MontaVista Software, Inc.
28 #include <linux/dma-mapping.h>
59 cpm_command(port->command, cmd); in cpm_line_cr_cmd()
69 cbd_t __iomem *bdp = pinfo->tx_bd_base; in cpm_uart_tx_empty()
73 if (in_be16(&bdp->cbd_sc) & BD_SC_READY) in cpm_uart_tx_empty()
76 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) { in cpm_uart_tx_empty()
83 pr_debug("CPM uart[%d]:tx_empty: %d\n", port->line, ret); in cpm_uart_tx_empty()
93 if (pinfo->gpios[GPIO_RTS]) in cpm_uart_set_mctrl()
94 gpiod_set_value(pinfo->gpios[GPIO_RTS], !(mctrl & TIOCM_RTS)); in cpm_uart_set_mctrl()
96 if (pinfo->gpios[GPIO_DTR]) in cpm_uart_set_mctrl()
97 gpiod_set_value(pinfo->gpios[GPIO_DTR], !(mctrl & TIOCM_DTR)); in cpm_uart_set_mctrl()
106 if (pinfo->gpios[GPIO_CTS]) { in cpm_uart_get_mctrl()
107 if (gpiod_get_value(pinfo->gpios[GPIO_CTS])) in cpm_uart_get_mctrl()
111 if (pinfo->gpios[GPIO_DSR]) { in cpm_uart_get_mctrl()
112 if (gpiod_get_value(pinfo->gpios[GPIO_DSR])) in cpm_uart_get_mctrl()
116 if (pinfo->gpios[GPIO_DCD]) { in cpm_uart_get_mctrl()
117 if (gpiod_get_value(pinfo->gpios[GPIO_DCD])) in cpm_uart_get_mctrl()
121 if (pinfo->gpios[GPIO_RI]) { in cpm_uart_get_mctrl()
122 if (!gpiod_get_value(pinfo->gpios[GPIO_RI])) in cpm_uart_get_mctrl()
136 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_stop_tx()
137 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_stop_tx()
139 pr_debug("CPM uart[%d]:stop tx\n", port->line); in cpm_uart_stop_tx()
142 clrbits8(&smcp->smc_smcm, SMCM_TX); in cpm_uart_stop_tx()
144 clrbits16(&sccp->scc_sccm, UART_SCCM_TX); in cpm_uart_stop_tx()
154 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_start_tx()
155 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_start_tx()
157 pr_debug("CPM uart[%d]:start tx\n", port->line); in cpm_uart_start_tx()
160 if (in_8(&smcp->smc_smcm) & SMCM_TX) in cpm_uart_start_tx()
163 if (in_be16(&sccp->scc_sccm) & UART_SCCM_TX) in cpm_uart_start_tx()
169 setbits8(&smcp->smc_smcm, SMCM_TX); in cpm_uart_start_tx()
171 setbits16(&sccp->scc_sccm, UART_SCCM_TX); in cpm_uart_start_tx()
183 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_stop_rx()
184 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_stop_rx()
186 pr_debug("CPM uart[%d]:stop rx\n", port->line); in cpm_uart_stop_rx()
189 clrbits8(&smcp->smc_smcm, SMCM_RX); in cpm_uart_stop_rx()
191 clrbits16(&sccp->scc_sccm, UART_SCCM_RX); in cpm_uart_stop_rx()
202 pr_debug("CPM uart[%d]:break ctrl, break_state: %d\n", port->line, in cpm_uart_break_ctl()
216 pr_debug("CPM uart[%d]:TX INT\n", port->line); in cpm_uart_int_tx()
233 struct tty_port *tport = &port->state->port; in cpm_uart_int_rx()
240 pr_debug("CPM uart[%d]:RX INT\n", port->line); in cpm_uart_int_rx()
245 bdp = pinfo->rx_cur; in cpm_uart_int_rx()
254 status = in_be16(&bdp->cbd_sc); in cpm_uart_int_rx()
259 /* get number of characters, and check spce in flip-buffer */ in cpm_uart_int_rx()
260 i = in_be16(&bdp->cbd_datlen); in cpm_uart_int_rx()
263 * later, which will be the next rx-interrupt or a timeout in cpm_uart_int_rx()
271 cp = cpm2cpu_addr(in_be32(&bdp->cbd_bufaddr), pinfo); in cpm_uart_int_rx()
274 while (i-- > 0) { in cpm_uart_int_rx()
276 port->icount.rx++; in cpm_uart_int_rx()
293 } /* End while (i--) */ in cpm_uart_int_rx()
296 clrbits16(&bdp->cbd_sc, BD_SC_BR | BD_SC_FR | BD_SC_PR | in cpm_uart_int_rx()
298 setbits16(&bdp->cbd_sc, BD_SC_EMPTY); in cpm_uart_int_rx()
300 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) in cpm_uart_int_rx()
301 bdp = pinfo->rx_bd_base; in cpm_uart_int_rx()
308 pinfo->rx_cur = bdp; in cpm_uart_int_rx()
320 port->icount.brk++; in cpm_uart_int_rx()
322 port->icount.parity++; in cpm_uart_int_rx()
324 port->icount.frame++; in cpm_uart_int_rx()
326 port->icount.overrun++; in cpm_uart_int_rx()
329 status &= port->read_status_mask; in cpm_uart_int_rx()
348 port->sysrq = 0; in cpm_uart_int_rx()
360 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_int()
361 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_int()
363 pr_debug("CPM uart[%d]:IRQ\n", port->line); in cpm_uart_int()
366 events = in_8(&smcp->smc_smce); in cpm_uart_int()
367 out_8(&smcp->smc_smce, events); in cpm_uart_int()
375 events = in_be16(&sccp->scc_scce); in cpm_uart_int()
376 out_be16(&sccp->scc_scce, events); in cpm_uart_int()
393 pr_debug("CPM uart[%d]:startup\n", port->line); in cpm_uart_startup()
396 if (!(pinfo->flags & FLAG_CONSOLE)) { in cpm_uart_startup()
399 clrbits16(&pinfo->smcp->smc_smcmr, SMCMR_REN); in cpm_uart_startup()
400 clrbits8(&pinfo->smcp->smc_smcm, SMCM_RX); in cpm_uart_startup()
402 clrbits32(&pinfo->sccp->scc_gsmrl, SCC_GSMRL_ENR); in cpm_uart_startup()
403 clrbits16(&pinfo->sccp->scc_sccm, UART_SCCM_RX); in cpm_uart_startup()
407 out_be32(&pinfo->smcup->smc_rstate, 0); in cpm_uart_startup()
408 out_be32(&pinfo->smcup->smc_tstate, 0); in cpm_uart_startup()
409 out_be16(&pinfo->smcup->smc_rbptr, in cpm_uart_startup()
410 in_be16(&pinfo->smcup->smc_rbase)); in cpm_uart_startup()
411 out_be16(&pinfo->smcup->smc_tbptr, in cpm_uart_startup()
412 in_be16(&pinfo->smcup->smc_tbase)); in cpm_uart_startup()
418 retval = request_irq(port->irq, cpm_uart_int, 0, "cpm_uart", port); in cpm_uart_startup()
422 /* Startup rx-int */ in cpm_uart_startup()
424 setbits8(&pinfo->smcp->smc_smcm, SMCM_RX); in cpm_uart_startup()
425 setbits16(&pinfo->smcp->smc_smcmr, (SMCMR_REN | SMCMR_TEN)); in cpm_uart_startup()
427 setbits16(&pinfo->sccp->scc_sccm, UART_SCCM_RX); in cpm_uart_startup()
428 setbits32(&pinfo->sccp->scc_gsmrl, (SCC_GSMRL_ENR | SCC_GSMRL_ENT)); in cpm_uart_startup()
437 schedule_timeout(pinfo->wait_closing); in cpm_uart_wait_until_send()
448 pr_debug("CPM uart[%d]:shutdown\n", port->line); in cpm_uart_shutdown()
451 free_irq(port->irq, port); in cpm_uart_shutdown()
454 if (!(pinfo->flags & FLAG_CONSOLE)) { in cpm_uart_shutdown()
461 if (pinfo->wait_closing) in cpm_uart_shutdown()
466 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_shutdown()
467 clrbits16(&smcp->smc_smcmr, SMCMR_REN | SMCMR_TEN); in cpm_uart_shutdown()
468 clrbits8(&smcp->smc_smcm, SMCM_RX | SMCM_TX); in cpm_uart_shutdown()
470 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_shutdown()
471 clrbits32(&sccp->scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); in cpm_uart_shutdown()
472 clrbits16(&sccp->scc_sccm, UART_SCCM_TX | UART_SCCM_RX); in cpm_uart_shutdown()
477 out_be16(&pinfo->smcup->smc_brkcr, 0); in cpm_uart_shutdown()
480 out_be16(&pinfo->sccup->scc_brkcr, 0); in cpm_uart_shutdown()
497 smc_t __iomem *smcp = pinfo->smcp; in cpm_uart_set_termios()
498 scc_t __iomem *sccp = pinfo->sccp; in cpm_uart_set_termios()
501 pr_debug("CPM uart[%d]:set_termios\n", port->line); in cpm_uart_set_termios()
503 baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk / 16); in cpm_uart_set_termios()
504 if (baud < HW_BUF_SPD_THRESHOLD || port->flags & UPF_LOW_LATENCY) in cpm_uart_set_termios()
505 pinfo->rx_fifosize = 1; in cpm_uart_set_termios()
507 pinfo->rx_fifosize = RX_BUF_SIZE; in cpm_uart_set_termios()
523 if (termios->c_cflag & CSTOPB) { in cpm_uart_set_termios()
528 if (termios->c_cflag & PARENB) { in cpm_uart_set_termios()
531 if (!(termios->c_cflag & PARODD)) { in cpm_uart_set_termios()
540 uart_update_timeout(port, termios->c_cflag, baud); in cpm_uart_set_termios()
545 port->read_status_mask = (BD_SC_EMPTY | BD_SC_OV); in cpm_uart_set_termios()
546 if (termios->c_iflag & INPCK) in cpm_uart_set_termios()
547 port->read_status_mask |= BD_SC_FR | BD_SC_PR; in cpm_uart_set_termios()
548 if ((termios->c_iflag & BRKINT) || (termios->c_iflag & PARMRK)) in cpm_uart_set_termios()
549 port->read_status_mask |= BD_SC_BR; in cpm_uart_set_termios()
554 port->ignore_status_mask = 0; in cpm_uart_set_termios()
555 if (termios->c_iflag & IGNPAR) in cpm_uart_set_termios()
556 port->ignore_status_mask |= BD_SC_PR | BD_SC_FR; in cpm_uart_set_termios()
557 if (termios->c_iflag & IGNBRK) { in cpm_uart_set_termios()
558 port->ignore_status_mask |= BD_SC_BR; in cpm_uart_set_termios()
563 if (termios->c_iflag & IGNPAR) in cpm_uart_set_termios()
564 port->ignore_status_mask |= BD_SC_OV; in cpm_uart_set_termios()
569 if ((termios->c_cflag & CREAD) == 0) in cpm_uart_set_termios()
570 port->read_status_mask &= ~BD_SC_EMPTY; in cpm_uart_set_termios()
572 spin_lock_irqsave(&port->lock, flags); in cpm_uart_set_termios()
575 unsigned int bits = tty_get_frame_size(termios->c_cflag); in cpm_uart_set_termios()
579 * if it is done in a single bus cycle with one 16-bit move in cpm_uart_set_termios()
580 * (not two 8-bit bus cycles back-to-back). This occurs when in cpm_uart_set_termios()
586 out_be16(&pinfo->smcup->smc_mrblr, pinfo->rx_fifosize); in cpm_uart_set_termios()
587 out_be16(&pinfo->smcup->smc_maxidl, maxidl); in cpm_uart_set_termios()
593 prev_mode = in_be16(&smcp->smc_smcmr) & (SMCMR_REN | SMCMR_TEN); in cpm_uart_set_termios()
598 out_be16(&smcp->smc_smcmr, smcr_mk_clen(bits - 1) | cval | in cpm_uart_set_termios()
601 unsigned int bits = tty_get_char_size(termios->c_cflag); in cpm_uart_set_termios()
603 out_be16(&pinfo->sccup->scc_genscc.scc_mrblr, pinfo->rx_fifosize); in cpm_uart_set_termios()
604 out_be16(&pinfo->sccup->scc_maxidl, maxidl); in cpm_uart_set_termios()
605 out_be16(&sccp->scc_psmr, (UART_LCR_WLEN(bits) << 12) | scval); in cpm_uart_set_termios()
608 if (pinfo->clk) in cpm_uart_set_termios()
609 clk_set_rate(pinfo->clk, baud); in cpm_uart_set_termios()
611 cpm_setbrg(pinfo->brg - 1, baud); in cpm_uart_set_termios()
612 spin_unlock_irqrestore(&port->lock, flags); in cpm_uart_set_termios()
617 pr_debug("CPM uart[%d]:uart_type\n", port->line); in cpm_uart_type()
619 return port->type == PORT_CPM ? "CPM UART" : NULL; in cpm_uart_type()
630 pr_debug("CPM uart[%d]:verify_port\n", port->line); in cpm_uart_verify_port()
632 if (ser->type != PORT_UNKNOWN && ser->type != PORT_CPM) in cpm_uart_verify_port()
633 ret = -EINVAL; in cpm_uart_verify_port()
634 if (ser->irq < 0 || ser->irq >= nr_irqs) in cpm_uart_verify_port()
635 ret = -EINVAL; in cpm_uart_verify_port()
636 if (ser->baud_base < 9600) in cpm_uart_verify_port()
637 ret = -EINVAL; in cpm_uart_verify_port()
651 struct circ_buf *xmit = &port->state->xmit; in cpm_uart_tx_pump()
654 if (port->x_char) { in cpm_uart_tx_pump()
656 bdp = pinfo->tx_cur; in cpm_uart_tx_pump()
658 p = cpm2cpu_addr(in_be32(&bdp->cbd_bufaddr), pinfo); in cpm_uart_tx_pump()
660 *p++ = port->x_char; in cpm_uart_tx_pump()
662 out_be16(&bdp->cbd_datlen, 1); in cpm_uart_tx_pump()
663 setbits16(&bdp->cbd_sc, BD_SC_READY); in cpm_uart_tx_pump()
665 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) in cpm_uart_tx_pump()
666 bdp = pinfo->tx_bd_base; in cpm_uart_tx_pump()
669 pinfo->tx_cur = bdp; in cpm_uart_tx_pump()
671 port->icount.tx++; in cpm_uart_tx_pump()
672 port->x_char = 0; in cpm_uart_tx_pump()
682 bdp = pinfo->tx_cur; in cpm_uart_tx_pump()
684 while (!(in_be16(&bdp->cbd_sc) & BD_SC_READY) && !uart_circ_empty(xmit)) { in cpm_uart_tx_pump()
686 p = cpm2cpu_addr(in_be32(&bdp->cbd_bufaddr), pinfo); in cpm_uart_tx_pump()
687 while (count < pinfo->tx_fifosize) { in cpm_uart_tx_pump()
688 *p++ = xmit->buf[xmit->tail]; in cpm_uart_tx_pump()
694 out_be16(&bdp->cbd_datlen, count); in cpm_uart_tx_pump()
695 setbits16(&bdp->cbd_sc, BD_SC_READY); in cpm_uart_tx_pump()
697 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) in cpm_uart_tx_pump()
698 bdp = pinfo->tx_bd_base; in cpm_uart_tx_pump()
702 pinfo->tx_cur = bdp; in cpm_uart_tx_pump()
724 pr_debug("CPM uart[%d]:initbd\n", pinfo->port.line); in cpm_uart_initbd()
730 mem_addr = pinfo->mem_addr; in cpm_uart_initbd()
731 bdp = pinfo->rx_cur = pinfo->rx_bd_base; in cpm_uart_initbd()
732 for (i = 0; i < (pinfo->rx_nrfifos - 1); i++, bdp++) { in cpm_uart_initbd()
733 out_be32(&bdp->cbd_bufaddr, cpu2cpm_addr(mem_addr, pinfo)); in cpm_uart_initbd()
734 out_be16(&bdp->cbd_sc, BD_SC_EMPTY | BD_SC_INTRPT); in cpm_uart_initbd()
735 mem_addr += pinfo->rx_fifosize; in cpm_uart_initbd()
738 out_be32(&bdp->cbd_bufaddr, cpu2cpm_addr(mem_addr, pinfo)); in cpm_uart_initbd()
739 out_be16(&bdp->cbd_sc, BD_SC_WRAP | BD_SC_EMPTY | BD_SC_INTRPT); in cpm_uart_initbd()
745 mem_addr = pinfo->mem_addr + L1_CACHE_ALIGN(pinfo->rx_nrfifos * pinfo->rx_fifosize); in cpm_uart_initbd()
746 bdp = pinfo->tx_cur = pinfo->tx_bd_base; in cpm_uart_initbd()
747 for (i = 0; i < (pinfo->tx_nrfifos - 1); i++, bdp++) { in cpm_uart_initbd()
748 out_be32(&bdp->cbd_bufaddr, cpu2cpm_addr(mem_addr, pinfo)); in cpm_uart_initbd()
749 out_be16(&bdp->cbd_sc, BD_SC_INTRPT); in cpm_uart_initbd()
750 mem_addr += pinfo->tx_fifosize; in cpm_uart_initbd()
753 out_be32(&bdp->cbd_bufaddr, cpu2cpm_addr(mem_addr, pinfo)); in cpm_uart_initbd()
754 out_be16(&bdp->cbd_sc, BD_SC_WRAP | BD_SC_INTRPT); in cpm_uart_initbd()
762 pr_debug("CPM uart[%d]:init_scc\n", pinfo->port.line); in cpm_uart_init_scc()
764 scp = pinfo->sccp; in cpm_uart_init_scc()
765 sup = pinfo->sccup; in cpm_uart_init_scc()
768 out_be16(&pinfo->sccup->scc_genscc.scc_rbase, in cpm_uart_init_scc()
769 (u8 __iomem *)pinfo->rx_bd_base - DPRAM_BASE); in cpm_uart_init_scc()
770 out_be16(&pinfo->sccup->scc_genscc.scc_tbase, in cpm_uart_init_scc()
771 (u8 __iomem *)pinfo->tx_bd_base - DPRAM_BASE); in cpm_uart_init_scc()
777 out_8(&sup->scc_genscc.scc_rfcr, CPMFCR_GBL | CPMFCR_EB); in cpm_uart_init_scc()
778 out_8(&sup->scc_genscc.scc_tfcr, CPMFCR_GBL | CPMFCR_EB); in cpm_uart_init_scc()
780 out_be16(&sup->scc_genscc.scc_mrblr, pinfo->rx_fifosize); in cpm_uart_init_scc()
781 out_be16(&sup->scc_maxidl, 0x10); in cpm_uart_init_scc()
782 out_be16(&sup->scc_brkcr, 1); in cpm_uart_init_scc()
783 out_be16(&sup->scc_parec, 0); in cpm_uart_init_scc()
784 out_be16(&sup->scc_frmec, 0); in cpm_uart_init_scc()
785 out_be16(&sup->scc_nosec, 0); in cpm_uart_init_scc()
786 out_be16(&sup->scc_brkec, 0); in cpm_uart_init_scc()
787 out_be16(&sup->scc_uaddr1, 0); in cpm_uart_init_scc()
788 out_be16(&sup->scc_uaddr2, 0); in cpm_uart_init_scc()
789 out_be16(&sup->scc_toseq, 0); in cpm_uart_init_scc()
790 out_be16(&sup->scc_char1, 0x8000); in cpm_uart_init_scc()
791 out_be16(&sup->scc_char2, 0x8000); in cpm_uart_init_scc()
792 out_be16(&sup->scc_char3, 0x8000); in cpm_uart_init_scc()
793 out_be16(&sup->scc_char4, 0x8000); in cpm_uart_init_scc()
794 out_be16(&sup->scc_char5, 0x8000); in cpm_uart_init_scc()
795 out_be16(&sup->scc_char6, 0x8000); in cpm_uart_init_scc()
796 out_be16(&sup->scc_char7, 0x8000); in cpm_uart_init_scc()
797 out_be16(&sup->scc_char8, 0x8000); in cpm_uart_init_scc()
798 out_be16(&sup->scc_rccm, 0xc0ff); in cpm_uart_init_scc()
807 out_be32(&scp->scc_gsmrh, 0); in cpm_uart_init_scc()
808 out_be32(&scp->scc_gsmrl, in cpm_uart_init_scc()
812 out_be16(&scp->scc_sccm, 0); in cpm_uart_init_scc()
813 out_be16(&scp->scc_scce, 0xffff); in cpm_uart_init_scc()
814 out_be16(&scp->scc_dsr, 0x7e7e); in cpm_uart_init_scc()
815 out_be16(&scp->scc_psmr, 0x3000); in cpm_uart_init_scc()
817 setbits32(&scp->scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); in cpm_uart_init_scc()
825 pr_debug("CPM uart[%d]:init_smc\n", pinfo->port.line); in cpm_uart_init_smc()
827 sp = pinfo->smcp; in cpm_uart_init_smc()
828 up = pinfo->smcup; in cpm_uart_init_smc()
831 out_be16(&pinfo->smcup->smc_rbase, in cpm_uart_init_smc()
832 (u8 __iomem *)pinfo->rx_bd_base - DPRAM_BASE); in cpm_uart_init_smc()
833 out_be16(&pinfo->smcup->smc_tbase, in cpm_uart_init_smc()
834 (u8 __iomem *)pinfo->tx_bd_base - DPRAM_BASE); in cpm_uart_init_smc()
839 out_be16(&up->smc_rbptr, in_be16(&pinfo->smcup->smc_rbase)); in cpm_uart_init_smc()
840 out_be16(&up->smc_tbptr, in_be16(&pinfo->smcup->smc_tbase)); in cpm_uart_init_smc()
841 out_be32(&up->smc_rstate, 0); in cpm_uart_init_smc()
842 out_be32(&up->smc_tstate, 0); in cpm_uart_init_smc()
843 out_be16(&up->smc_brkcr, 1); /* number of break chars */ in cpm_uart_init_smc()
844 out_be16(&up->smc_brkec, 0); in cpm_uart_init_smc()
849 out_8(&up->smc_rfcr, CPMFCR_GBL | CPMFCR_EB); in cpm_uart_init_smc()
850 out_8(&up->smc_tfcr, CPMFCR_GBL | CPMFCR_EB); in cpm_uart_init_smc()
853 out_be16(&up->smc_mrblr, pinfo->rx_fifosize); in cpm_uart_init_smc()
854 out_be16(&up->smc_maxidl, 0x10); in cpm_uart_init_smc()
855 out_be16(&up->smc_brklen, 0); in cpm_uart_init_smc()
856 out_be16(&up->smc_brkec, 0); in cpm_uart_init_smc()
857 out_be16(&up->smc_brkcr, 1); in cpm_uart_init_smc()
862 out_be16(&sp->smc_smcmr, smcr_mk_clen(9) | SMCMR_SM_UART); in cpm_uart_init_smc()
865 out_8(&sp->smc_smcm, 0); in cpm_uart_init_smc()
866 out_8(&sp->smc_smce, 0xff); in cpm_uart_init_smc()
868 setbits16(&sp->smc_smcmr, SMCMR_REN | SMCMR_TEN); in cpm_uart_init_smc()
872 * Allocate DP-Ram and memory buffers. We need to allocate a transmit and
885 pr_debug("CPM uart[%d]:allocbuf\n", pinfo->port.line); in cpm_uart_allocbuf()
887 dpmemsz = sizeof(cbd_t) * (pinfo->rx_nrfifos + pinfo->tx_nrfifos); in cpm_uart_allocbuf()
891 return -ENOMEM; in cpm_uart_allocbuf()
896 memsz = L1_CACHE_ALIGN(pinfo->rx_nrfifos * pinfo->rx_fifosize) + in cpm_uart_allocbuf()
897 L1_CACHE_ALIGN(pinfo->tx_nrfifos * pinfo->tx_fifosize); in cpm_uart_allocbuf()
907 mem_addr = dma_alloc_coherent(pinfo->port.dev, memsz, &dma_addr, in cpm_uart_allocbuf()
914 return -ENOMEM; in cpm_uart_allocbuf()
917 pinfo->dp_addr = dp_offset; in cpm_uart_allocbuf()
918 pinfo->mem_addr = mem_addr; in cpm_uart_allocbuf()
919 pinfo->dma_addr = dma_addr; in cpm_uart_allocbuf()
920 pinfo->mem_size = memsz; in cpm_uart_allocbuf()
922 pinfo->rx_buf = mem_addr; in cpm_uart_allocbuf()
923 pinfo->tx_buf = pinfo->rx_buf + L1_CACHE_ALIGN(pinfo->rx_nrfifos in cpm_uart_allocbuf()
924 * pinfo->rx_fifosize); in cpm_uart_allocbuf()
926 pinfo->rx_bd_base = (cbd_t __iomem *)dp_mem; in cpm_uart_allocbuf()
927 pinfo->tx_bd_base = pinfo->rx_bd_base + pinfo->rx_nrfifos; in cpm_uart_allocbuf()
934 dma_free_coherent(pinfo->port.dev, L1_CACHE_ALIGN(pinfo->rx_nrfifos * in cpm_uart_freebuf()
935 pinfo->rx_fifosize) + in cpm_uart_freebuf()
936 L1_CACHE_ALIGN(pinfo->tx_nrfifos * in cpm_uart_freebuf()
937 pinfo->tx_fifosize), (void __force *)pinfo->mem_addr, in cpm_uart_freebuf()
938 pinfo->dma_addr); in cpm_uart_freebuf()
940 cpm_muram_free(pinfo->dp_addr); in cpm_uart_freebuf()
953 pr_debug("CPM uart[%d]:request port\n", port->line); in cpm_uart_request_port()
955 if (pinfo->flags & FLAG_CONSOLE) in cpm_uart_request_port()
959 clrbits8(&pinfo->smcp->smc_smcm, SMCM_RX | SMCM_TX); in cpm_uart_request_port()
960 clrbits16(&pinfo->smcp->smc_smcmr, SMCMR_REN | SMCMR_TEN); in cpm_uart_request_port()
962 clrbits16(&pinfo->sccp->scc_sccm, UART_SCCM_TX | UART_SCCM_RX); in cpm_uart_request_port()
963 clrbits32(&pinfo->sccp->scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); in cpm_uart_request_port()
985 if (!(pinfo->flags & FLAG_CONSOLE)) in cpm_uart_release_port()
994 pr_debug("CPM uart[%d]:config_port\n", port->line); in cpm_uart_config_port()
997 port->type = PORT_CPM; in cpm_uart_config_port()
1016 bdp = pinfo->tx_cur; in cpm_uart_early_write()
1017 bdbase = pinfo->tx_bd_base; in cpm_uart_early_write()
1030 while ((in_be16(&bdp->cbd_sc) & BD_SC_READY) != 0) in cpm_uart_early_write()
1037 cpm_outp_addr = cpm2cpu_addr(in_be32(&bdp->cbd_bufaddr), in cpm_uart_early_write()
1041 out_be16(&bdp->cbd_datlen, 1); in cpm_uart_early_write()
1042 setbits16(&bdp->cbd_sc, BD_SC_READY); in cpm_uart_early_write()
1044 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) in cpm_uart_early_write()
1051 while ((in_be16(&bdp->cbd_sc) & BD_SC_READY) != 0) in cpm_uart_early_write()
1054 cpm_outp_addr = cpm2cpu_addr(in_be32(&bdp->cbd_bufaddr), in cpm_uart_early_write()
1058 out_be16(&bdp->cbd_datlen, 1); in cpm_uart_early_write()
1059 setbits16(&bdp->cbd_sc, BD_SC_READY); in cpm_uart_early_write()
1061 if (in_be16(&bdp->cbd_sc) & BD_SC_WRAP) in cpm_uart_early_write()
1072 while ((in_be16(&bdp->cbd_sc) & BD_SC_READY) != 0) in cpm_uart_early_write()
1075 pinfo->tx_cur = bdp; in cpm_uart_early_write()
1098 bdp = pinfo->rx_cur; in poll_wait_key()
1099 if (bdp->cbd_sc & BD_SC_EMPTY) in poll_wait_key()
1105 cp = cpm2cpu_addr(bdp->cbd_bufaddr, pinfo); in poll_wait_key()
1108 i = c = bdp->cbd_datlen; in poll_wait_key()
1109 while (i-- > 0) in poll_wait_key()
1113 bdp->cbd_sc &= ~(BD_SC_BR | BD_SC_FR | BD_SC_PR | BD_SC_OV | BD_SC_ID); in poll_wait_key()
1114 bdp->cbd_sc |= BD_SC_EMPTY; in poll_wait_key()
1116 if (bdp->cbd_sc & BD_SC_WRAP) in poll_wait_key()
1117 bdp = pinfo->rx_bd_base; in poll_wait_key()
1120 pinfo->rx_cur = (cbd_t *)bdp; in poll_wait_key()
1142 poll_chars--; in cpm_get_poll_char()
1171 return c == NO_POLL_CHAR ? -1 : c; in udbg_cpm_getc_poll()
1178 while ((c = udbg_cpm_getc_poll()) == -1) in udbg_cpm_getc()
1221 if (IS_SMC(port) && port->smcup) in cpm_uart_map_pram()
1222 return port->smcup; in cpm_uart_map_pram()
1223 else if (!IS_SMC(port) && port->sccup) in cpm_uart_map_pram()
1224 return port->sccup; in cpm_uart_map_pram()
1242 port->port.line); in cpm_uart_map_pram()
1263 struct device *dev = pinfo->port.dev; in cpm_uart_init_port()
1272 pinfo->clk = clk; in cpm_uart_init_port()
1274 if (!pinfo->clk) { in cpm_uart_init_port()
1275 data = of_get_property(np, "fsl,cpm-brg", &len); in cpm_uart_init_port()
1278 "fsl,cpm-brg property.\n", np); in cpm_uart_init_port()
1279 return -EINVAL; in cpm_uart_init_port()
1281 pinfo->brg = *data; in cpm_uart_init_port()
1284 data = of_get_property(np, "fsl,cpm-command", &len); in cpm_uart_init_port()
1287 "fsl,cpm-command property.\n", np); in cpm_uart_init_port()
1288 return -EINVAL; in cpm_uart_init_port()
1290 pinfo->command = *data; in cpm_uart_init_port()
1294 return -ENOMEM; in cpm_uart_init_port()
1296 if (of_device_is_compatible(np, "fsl,cpm1-scc-uart") || in cpm_uart_init_port()
1297 of_device_is_compatible(np, "fsl,cpm2-scc-uart")) { in cpm_uart_init_port()
1298 pinfo->sccp = mem; in cpm_uart_init_port()
1299 pinfo->sccup = pram = cpm_uart_map_pram(pinfo, np); in cpm_uart_init_port()
1300 } else if (of_device_is_compatible(np, "fsl,cpm1-smc-uart") || in cpm_uart_init_port()
1301 of_device_is_compatible(np, "fsl,cpm2-smc-uart")) { in cpm_uart_init_port()
1302 pinfo->flags |= FLAG_SMC; in cpm_uart_init_port()
1303 pinfo->smcp = mem; in cpm_uart_init_port()
1304 pinfo->smcup = pram = cpm_uart_map_pram(pinfo, np); in cpm_uart_init_port()
1306 ret = -ENODEV; in cpm_uart_init_port()
1311 ret = -ENOMEM; in cpm_uart_init_port()
1315 pinfo->tx_nrfifos = TX_NUM_FIFO; in cpm_uart_init_port()
1316 pinfo->tx_fifosize = TX_BUF_SIZE; in cpm_uart_init_port()
1317 pinfo->rx_nrfifos = RX_NUM_FIFO; in cpm_uart_init_port()
1318 pinfo->rx_fifosize = RX_BUF_SIZE; in cpm_uart_init_port()
1320 pinfo->port.uartclk = ppc_proc_freq; in cpm_uart_init_port()
1321 pinfo->port.mapbase = (unsigned long)mem; in cpm_uart_init_port()
1322 pinfo->port.type = PORT_CPM; in cpm_uart_init_port()
1323 pinfo->port.ops = &cpm_uart_pops; in cpm_uart_init_port()
1324 pinfo->port.has_sysrq = IS_ENABLED(CONFIG_SERIAL_CPM_CONSOLE); in cpm_uart_init_port()
1325 pinfo->port.iotype = UPIO_MEM; in cpm_uart_init_port()
1326 pinfo->port.fifosize = pinfo->tx_nrfifos * pinfo->tx_fifosize; in cpm_uart_init_port()
1327 spin_lock_init(&pinfo->port.lock); in cpm_uart_init_port()
1332 pinfo->gpios[i] = NULL; in cpm_uart_init_port()
1351 pinfo->gpios[i] = gpiod; in cpm_uart_init_port()
1362 return cpm_uart_request_port(&pinfo->port); in cpm_uart_init_port()
1381 struct uart_cpm_port *pinfo = &cpm_uart_ports[co->index]; in cpm_uart_console_write()
1389 spin_lock_irqsave(&pinfo->port.lock, flags); in cpm_uart_console_write()
1391 spin_unlock_irqrestore(&pinfo->port.lock, flags); in cpm_uart_console_write()
1409 if (co->index >= UART_NR) { in cpm_uart_console_setup()
1411 co->index); in cpm_uart_console_setup()
1412 return -ENODEV; in cpm_uart_console_setup()
1416 if (!of_device_is_compatible(np, "fsl,cpm1-smc-uart") && in cpm_uart_console_setup()
1417 !of_device_is_compatible(np, "fsl,cpm1-scc-uart") && in cpm_uart_console_setup()
1418 !of_device_is_compatible(np, "fsl,cpm2-smc-uart") && in cpm_uart_console_setup()
1419 !of_device_is_compatible(np, "fsl,cpm2-scc-uart")) in cpm_uart_console_setup()
1422 if (i++ == co->index) in cpm_uart_console_setup()
1427 return -ENODEV; in cpm_uart_console_setup()
1429 pinfo = &cpm_uart_ports[co->index]; in cpm_uart_console_setup()
1431 pinfo->flags |= FLAG_CONSOLE; in cpm_uart_console_setup()
1432 port = &pinfo->port; in cpm_uart_console_setup()
1443 if (baud == -1) in cpm_uart_console_setup()
1448 out_be16(&pinfo->smcup->smc_brkcr, 0); in cpm_uart_console_setup()
1450 clrbits8(&pinfo->smcp->smc_smcm, SMCM_RX | SMCM_TX); in cpm_uart_console_setup()
1451 clrbits16(&pinfo->smcp->smc_smcmr, SMCMR_REN | SMCMR_TEN); in cpm_uart_console_setup()
1453 out_be16(&pinfo->sccup->scc_brkcr, 0); in cpm_uart_console_setup()
1455 clrbits16(&pinfo->sccp->scc_sccm, UART_SCCM_TX | UART_SCCM_RX); in cpm_uart_console_setup()
1456 clrbits32(&pinfo->sccp->scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); in cpm_uart_console_setup()
1476 udbg_port = &pinfo->port; in cpm_uart_console_setup()
1493 .index = -1,
1529 pinfo->port.line = index; in cpm_uart_probe()
1532 return -ENODEV; in cpm_uart_probe()
1537 pinfo->port.dev = &ofdev->dev; in cpm_uart_probe()
1539 pinfo->port.irq = irq_of_parse_and_map(ofdev->dev.of_node, 0); in cpm_uart_probe()
1540 if (!pinfo->port.irq) in cpm_uart_probe()
1541 return -EINVAL; in cpm_uart_probe()
1543 ret = cpm_uart_init_port(ofdev->dev.of_node, pinfo); in cpm_uart_probe()
1545 return uart_add_one_port(&cpm_reg, &pinfo->port); in cpm_uart_probe()
1547 irq_dispose_mapping(pinfo->port.irq); in cpm_uart_probe()
1556 uart_remove_one_port(&cpm_reg, &pinfo->port); in cpm_uart_remove()
1563 .compatible = "fsl,cpm1-smc-uart",
1566 .compatible = "fsl,cpm1-scc-uart",
1569 .compatible = "fsl,cpm2-smc-uart",
1572 .compatible = "fsl,cpm2-scc-uart",