2 * Driver for msm7k serial device and console
4 * Copyright (C) 2007 Google, Inc.
5 * Author: Robert Love <rlove@google.com>
6 * Copyright (c) 2011, Code Aurora Forum. All rights reserved.
8 * This software is licensed under the terms of the GNU General Public
9 * License version 2, as published by the Free Software Foundation, and
10 * may be copied, distributed, and modified under those terms.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
18 #if defined(CONFIG_SERIAL_MSM_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
19 # define SUPPORT_SYSRQ
22 #include <linux/atomic.h>
23 #include <linux/dma-mapping.h>
24 #include <linux/dmaengine.h>
25 #include <linux/hrtimer.h>
26 #include <linux/module.h>
28 #include <linux/ioport.h>
29 #include <linux/irq.h>
30 #include <linux/init.h>
31 #include <linux/console.h>
32 #include <linux/tty.h>
33 #include <linux/tty_flip.h>
34 #include <linux/serial_core.h>
35 #include <linux/serial.h>
36 #include <linux/slab.h>
37 #include <linux/clk.h>
38 #include <linux/platform_device.h>
39 #include <linux/delay.h>
41 #include <linux/of_device.h>
43 #include "msm_serial.h"
45 #define UARTDM_BURST_SIZE 16 /* in bytes */
46 #define UARTDM_TX_AIGN(x) ((x) & ~0x3) /* valid for > 1p3 */
47 #define UARTDM_TX_MAX 256 /* in bytes, valid for <= 1p3 */
48 #define UARTDM_RX_SIZE (UART_XMIT_SIZE / 4)
58 struct dma_chan
*chan
;
59 enum dma_data_direction dir
;
65 struct dma_async_tx_descriptor
*desc
;
69 struct uart_port uart
;
75 unsigned int old_snap_state
;
77 struct msm_dma tx_dma
;
78 struct msm_dma rx_dma
;
81 static void msm_handle_tx(struct uart_port
*port
);
82 static void msm_start_rx_dma(struct msm_port
*msm_port
);
84 void msm_stop_dma(struct uart_port
*port
, struct msm_dma
*dma
)
86 struct device
*dev
= port
->dev
;
93 dmaengine_terminate_all(dma
->chan
);
96 * DMA Stall happens if enqueue and flush command happens concurrently.
97 * For example before changing the baud rate/protocol configuration and
98 * sending flush command to ADM, disable the channel of UARTDM.
99 * Note: should not reset the receiver here immediately as it is not
100 * suggested to do disable/reset or reset/disable at the same time.
102 val
= msm_read(port
, UARTDM_DMEN
);
103 val
&= ~dma
->enable_bit
;
104 msm_write(port
, val
, UARTDM_DMEN
);
107 dma_unmap_single(dev
, dma
->phys
, mapped
, dma
->dir
);
110 static void msm_release_dma(struct msm_port
*msm_port
)
114 dma
= &msm_port
->tx_dma
;
116 msm_stop_dma(&msm_port
->uart
, dma
);
117 dma_release_channel(dma
->chan
);
120 memset(dma
, 0, sizeof(*dma
));
122 dma
= &msm_port
->rx_dma
;
124 msm_stop_dma(&msm_port
->uart
, dma
);
125 dma_release_channel(dma
->chan
);
129 memset(dma
, 0, sizeof(*dma
));
132 static void msm_request_tx_dma(struct msm_port
*msm_port
, resource_size_t base
)
134 struct device
*dev
= msm_port
->uart
.dev
;
135 struct dma_slave_config conf
;
140 dma
= &msm_port
->tx_dma
;
142 /* allocate DMA resources, if available */
143 dma
->chan
= dma_request_slave_channel_reason(dev
, "tx");
144 if (IS_ERR(dma
->chan
))
147 of_property_read_u32(dev
->of_node
, "qcom,tx-crci", &crci
);
149 memset(&conf
, 0, sizeof(conf
));
150 conf
.direction
= DMA_MEM_TO_DEV
;
151 conf
.device_fc
= true;
152 conf
.dst_addr
= base
+ UARTDM_TF
;
153 conf
.dst_maxburst
= UARTDM_BURST_SIZE
;
154 conf
.slave_id
= crci
;
156 ret
= dmaengine_slave_config(dma
->chan
, &conf
);
160 dma
->dir
= DMA_TO_DEVICE
;
162 if (msm_port
->is_uartdm
< UARTDM_1P4
)
163 dma
->enable_bit
= UARTDM_DMEN_TX_DM_ENABLE
;
165 dma
->enable_bit
= UARTDM_DMEN_TX_BAM_ENABLE
;
170 dma_release_channel(dma
->chan
);
172 memset(dma
, 0, sizeof(*dma
));
175 static void msm_request_rx_dma(struct msm_port
*msm_port
, resource_size_t base
)
177 struct device
*dev
= msm_port
->uart
.dev
;
178 struct dma_slave_config conf
;
183 dma
= &msm_port
->rx_dma
;
185 /* allocate DMA resources, if available */
186 dma
->chan
= dma_request_slave_channel_reason(dev
, "rx");
187 if (IS_ERR(dma
->chan
))
190 of_property_read_u32(dev
->of_node
, "qcom,rx-crci", &crci
);
192 dma
->virt
= kzalloc(UARTDM_RX_SIZE
, GFP_KERNEL
);
196 memset(&conf
, 0, sizeof(conf
));
197 conf
.direction
= DMA_DEV_TO_MEM
;
198 conf
.device_fc
= true;
199 conf
.src_addr
= base
+ UARTDM_RF
;
200 conf
.src_maxburst
= UARTDM_BURST_SIZE
;
201 conf
.slave_id
= crci
;
203 ret
= dmaengine_slave_config(dma
->chan
, &conf
);
207 dma
->dir
= DMA_FROM_DEVICE
;
209 if (msm_port
->is_uartdm
< UARTDM_1P4
)
210 dma
->enable_bit
= UARTDM_DMEN_RX_DM_ENABLE
;
212 dma
->enable_bit
= UARTDM_DMEN_RX_BAM_ENABLE
;
218 dma_release_channel(dma
->chan
);
220 memset(dma
, 0, sizeof(*dma
));
223 static inline void msm_wait_for_xmitr(struct uart_port
*port
)
225 while (!(msm_read(port
, UART_SR
) & UART_SR_TX_EMPTY
)) {
226 if (msm_read(port
, UART_ISR
) & UART_ISR_TX_READY
)
230 msm_write(port
, UART_CR_CMD_RESET_TX_READY
, UART_CR
);
233 static void msm_stop_tx(struct uart_port
*port
)
235 struct msm_port
*msm_port
= UART_TO_MSM(port
);
237 msm_port
->imr
&= ~UART_IMR_TXLEV
;
238 msm_write(port
, msm_port
->imr
, UART_IMR
);
241 static void msm_start_tx(struct uart_port
*port
)
243 struct msm_port
*msm_port
= UART_TO_MSM(port
);
244 struct msm_dma
*dma
= &msm_port
->tx_dma
;
246 /* Already started in DMA mode */
250 msm_port
->imr
|= UART_IMR_TXLEV
;
251 msm_write(port
, msm_port
->imr
, UART_IMR
);
254 static void msm_reset_dm_count(struct uart_port
*port
, int count
)
256 msm_wait_for_xmitr(port
);
257 msm_write(port
, count
, UARTDM_NCF_TX
);
258 msm_read(port
, UARTDM_NCF_TX
);
261 static void msm_complete_tx_dma(void *args
)
263 struct msm_port
*msm_port
= args
;
264 struct uart_port
*port
= &msm_port
->uart
;
265 struct circ_buf
*xmit
= &port
->state
->xmit
;
266 struct msm_dma
*dma
= &msm_port
->tx_dma
;
267 struct dma_tx_state state
;
268 enum dma_status status
;
273 spin_lock_irqsave(&port
->lock
, flags
);
275 /* Already stopped */
279 status
= dmaengine_tx_status(dma
->chan
, dma
->cookie
, &state
);
281 dma_unmap_single(port
->dev
, dma
->phys
, dma
->count
, dma
->dir
);
283 val
= msm_read(port
, UARTDM_DMEN
);
284 val
&= ~dma
->enable_bit
;
285 msm_write(port
, val
, UARTDM_DMEN
);
287 if (msm_port
->is_uartdm
> UARTDM_1P3
) {
288 msm_write(port
, UART_CR_CMD_RESET_TX
, UART_CR
);
289 msm_write(port
, UART_CR_TX_ENABLE
, UART_CR
);
292 count
= dma
->count
- state
.residue
;
293 port
->icount
.tx
+= count
;
297 xmit
->tail
&= UART_XMIT_SIZE
- 1;
299 /* Restore "Tx FIFO below watermark" interrupt */
300 msm_port
->imr
|= UART_IMR_TXLEV
;
301 msm_write(port
, msm_port
->imr
, UART_IMR
);
303 if (uart_circ_chars_pending(xmit
) < WAKEUP_CHARS
)
304 uart_write_wakeup(port
);
308 spin_unlock_irqrestore(&port
->lock
, flags
);
311 static int msm_handle_tx_dma(struct msm_port
*msm_port
, unsigned int count
)
313 struct circ_buf
*xmit
= &msm_port
->uart
.state
->xmit
;
314 struct uart_port
*port
= &msm_port
->uart
;
315 struct msm_dma
*dma
= &msm_port
->tx_dma
;
320 cpu_addr
= &xmit
->buf
[xmit
->tail
];
322 dma
->phys
= dma_map_single(port
->dev
, cpu_addr
, count
, dma
->dir
);
323 ret
= dma_mapping_error(port
->dev
, dma
->phys
);
327 dma
->desc
= dmaengine_prep_slave_single(dma
->chan
, dma
->phys
,
328 count
, DMA_MEM_TO_DEV
,
336 dma
->desc
->callback
= msm_complete_tx_dma
;
337 dma
->desc
->callback_param
= msm_port
;
339 dma
->cookie
= dmaengine_submit(dma
->desc
);
340 ret
= dma_submit_error(dma
->cookie
);
345 * Using DMA complete for Tx FIFO reload, no need for
346 * "Tx FIFO below watermark" one, disable it
348 msm_port
->imr
&= ~UART_IMR_TXLEV
;
349 msm_write(port
, msm_port
->imr
, UART_IMR
);
353 val
= msm_read(port
, UARTDM_DMEN
);
354 val
|= dma
->enable_bit
;
356 if (msm_port
->is_uartdm
< UARTDM_1P4
)
357 msm_write(port
, val
, UARTDM_DMEN
);
359 msm_reset_dm_count(port
, count
);
361 if (msm_port
->is_uartdm
> UARTDM_1P3
)
362 msm_write(port
, val
, UARTDM_DMEN
);
364 dma_async_issue_pending(dma
->chan
);
367 dma_unmap_single(port
->dev
, dma
->phys
, count
, dma
->dir
);
371 static void msm_complete_rx_dma(void *args
)
373 struct msm_port
*msm_port
= args
;
374 struct uart_port
*port
= &msm_port
->uart
;
375 struct tty_port
*tport
= &port
->state
->port
;
376 struct msm_dma
*dma
= &msm_port
->rx_dma
;
377 int count
= 0, i
, sysrq
;
381 spin_lock_irqsave(&port
->lock
, flags
);
383 /* Already stopped */
387 val
= msm_read(port
, UARTDM_DMEN
);
388 val
&= ~dma
->enable_bit
;
389 msm_write(port
, val
, UARTDM_DMEN
);
391 /* Restore interrupts */
392 msm_port
->imr
|= UART_IMR_RXLEV
| UART_IMR_RXSTALE
;
393 msm_write(port
, msm_port
->imr
, UART_IMR
);
395 if (msm_read(port
, UART_SR
) & UART_SR_OVERRUN
) {
396 port
->icount
.overrun
++;
397 tty_insert_flip_char(tport
, 0, TTY_OVERRUN
);
398 msm_write(port
, UART_CR_CMD_RESET_ERR
, UART_CR
);
401 count
= msm_read(port
, UARTDM_RX_TOTAL_SNAP
);
403 port
->icount
.rx
+= count
;
407 dma_unmap_single(port
->dev
, dma
->phys
, UARTDM_RX_SIZE
, dma
->dir
);
409 for (i
= 0; i
< count
; i
++) {
410 char flag
= TTY_NORMAL
;
412 if (msm_port
->break_detected
&& dma
->virt
[i
] == 0) {
415 msm_port
->break_detected
= false;
416 if (uart_handle_break(port
))
420 if (!(port
->read_status_mask
& UART_SR_RX_BREAK
))
423 spin_unlock_irqrestore(&port
->lock
, flags
);
424 sysrq
= uart_handle_sysrq_char(port
, dma
->virt
[i
]);
425 spin_lock_irqsave(&port
->lock
, flags
);
427 tty_insert_flip_char(tport
, dma
->virt
[i
], flag
);
430 msm_start_rx_dma(msm_port
);
432 spin_unlock_irqrestore(&port
->lock
, flags
);
435 tty_flip_buffer_push(tport
);
438 static void msm_start_rx_dma(struct msm_port
*msm_port
)
440 struct msm_dma
*dma
= &msm_port
->rx_dma
;
441 struct uart_port
*uart
= &msm_port
->uart
;
448 dma
->phys
= dma_map_single(uart
->dev
, dma
->virt
,
449 UARTDM_RX_SIZE
, dma
->dir
);
450 ret
= dma_mapping_error(uart
->dev
, dma
->phys
);
454 dma
->desc
= dmaengine_prep_slave_single(dma
->chan
, dma
->phys
,
455 UARTDM_RX_SIZE
, DMA_DEV_TO_MEM
,
460 dma
->desc
->callback
= msm_complete_rx_dma
;
461 dma
->desc
->callback_param
= msm_port
;
463 dma
->cookie
= dmaengine_submit(dma
->desc
);
464 ret
= dma_submit_error(dma
->cookie
);
468 * Using DMA for FIFO off-load, no need for "Rx FIFO over
469 * watermark" or "stale" interrupts, disable them
471 msm_port
->imr
&= ~(UART_IMR_RXLEV
| UART_IMR_RXSTALE
);
474 * Well, when DMA is ADM3 engine(implied by <= UARTDM v1.3),
475 * we need RXSTALE to flush input DMA fifo to memory
477 if (msm_port
->is_uartdm
< UARTDM_1P4
)
478 msm_port
->imr
|= UART_IMR_RXSTALE
;
480 msm_write(uart
, msm_port
->imr
, UART_IMR
);
482 dma
->count
= UARTDM_RX_SIZE
;
484 dma_async_issue_pending(dma
->chan
);
486 msm_write(uart
, UART_CR_CMD_RESET_STALE_INT
, UART_CR
);
487 msm_write(uart
, UART_CR_CMD_STALE_EVENT_ENABLE
, UART_CR
);
489 val
= msm_read(uart
, UARTDM_DMEN
);
490 val
|= dma
->enable_bit
;
492 if (msm_port
->is_uartdm
< UARTDM_1P4
)
493 msm_write(uart
, val
, UARTDM_DMEN
);
495 msm_write(uart
, UARTDM_RX_SIZE
, UARTDM_DMRX
);
497 if (msm_port
->is_uartdm
> UARTDM_1P3
)
498 msm_write(uart
, val
, UARTDM_DMEN
);
502 dma_unmap_single(uart
->dev
, dma
->phys
, UARTDM_RX_SIZE
, dma
->dir
);
505 static void msm_stop_rx(struct uart_port
*port
)
507 struct msm_port
*msm_port
= UART_TO_MSM(port
);
508 struct msm_dma
*dma
= &msm_port
->rx_dma
;
510 msm_port
->imr
&= ~(UART_IMR_RXLEV
| UART_IMR_RXSTALE
);
511 msm_write(port
, msm_port
->imr
, UART_IMR
);
514 msm_stop_dma(port
, dma
);
517 static void msm_enable_ms(struct uart_port
*port
)
519 struct msm_port
*msm_port
= UART_TO_MSM(port
);
521 msm_port
->imr
|= UART_IMR_DELTA_CTS
;
522 msm_write(port
, msm_port
->imr
, UART_IMR
);
525 static void msm_handle_rx_dm(struct uart_port
*port
, unsigned int misr
)
527 struct tty_port
*tport
= &port
->state
->port
;
530 struct msm_port
*msm_port
= UART_TO_MSM(port
);
532 if ((msm_read(port
, UART_SR
) & UART_SR_OVERRUN
)) {
533 port
->icount
.overrun
++;
534 tty_insert_flip_char(tport
, 0, TTY_OVERRUN
);
535 msm_write(port
, UART_CR_CMD_RESET_ERR
, UART_CR
);
538 if (misr
& UART_IMR_RXSTALE
) {
539 count
= msm_read(port
, UARTDM_RX_TOTAL_SNAP
) -
540 msm_port
->old_snap_state
;
541 msm_port
->old_snap_state
= 0;
543 count
= 4 * (msm_read(port
, UART_RFWR
));
544 msm_port
->old_snap_state
+= count
;
547 /* TODO: Precise error reporting */
549 port
->icount
.rx
+= count
;
552 unsigned char buf
[4];
553 int sysrq
, r_count
, i
;
555 sr
= msm_read(port
, UART_SR
);
556 if ((sr
& UART_SR_RX_READY
) == 0) {
557 msm_port
->old_snap_state
-= count
;
561 ioread32_rep(port
->membase
+ UARTDM_RF
, buf
, 1);
562 r_count
= min_t(int, count
, sizeof(buf
));
564 for (i
= 0; i
< r_count
; i
++) {
565 char flag
= TTY_NORMAL
;
567 if (msm_port
->break_detected
&& buf
[i
] == 0) {
570 msm_port
->break_detected
= false;
571 if (uart_handle_break(port
))
575 if (!(port
->read_status_mask
& UART_SR_RX_BREAK
))
578 spin_unlock(&port
->lock
);
579 sysrq
= uart_handle_sysrq_char(port
, buf
[i
]);
580 spin_lock(&port
->lock
);
582 tty_insert_flip_char(tport
, buf
[i
], flag
);
587 spin_unlock(&port
->lock
);
588 tty_flip_buffer_push(tport
);
589 spin_lock(&port
->lock
);
591 if (misr
& (UART_IMR_RXSTALE
))
592 msm_write(port
, UART_CR_CMD_RESET_STALE_INT
, UART_CR
);
593 msm_write(port
, 0xFFFFFF, UARTDM_DMRX
);
594 msm_write(port
, UART_CR_CMD_STALE_EVENT_ENABLE
, UART_CR
);
597 msm_start_rx_dma(msm_port
);
600 static void msm_handle_rx(struct uart_port
*port
)
602 struct tty_port
*tport
= &port
->state
->port
;
606 * Handle overrun. My understanding of the hardware is that overrun
607 * is not tied to the RX buffer, so we handle the case out of band.
609 if ((msm_read(port
, UART_SR
) & UART_SR_OVERRUN
)) {
610 port
->icount
.overrun
++;
611 tty_insert_flip_char(tport
, 0, TTY_OVERRUN
);
612 msm_write(port
, UART_CR_CMD_RESET_ERR
, UART_CR
);
615 /* and now the main RX loop */
616 while ((sr
= msm_read(port
, UART_SR
)) & UART_SR_RX_READY
) {
618 char flag
= TTY_NORMAL
;
621 c
= msm_read(port
, UART_RF
);
623 if (sr
& UART_SR_RX_BREAK
) {
625 if (uart_handle_break(port
))
627 } else if (sr
& UART_SR_PAR_FRAME_ERR
) {
628 port
->icount
.frame
++;
633 /* Mask conditions we're ignorning. */
634 sr
&= port
->read_status_mask
;
636 if (sr
& UART_SR_RX_BREAK
)
638 else if (sr
& UART_SR_PAR_FRAME_ERR
)
641 spin_unlock(&port
->lock
);
642 sysrq
= uart_handle_sysrq_char(port
, c
);
643 spin_lock(&port
->lock
);
645 tty_insert_flip_char(tport
, c
, flag
);
648 spin_unlock(&port
->lock
);
649 tty_flip_buffer_push(tport
);
650 spin_lock(&port
->lock
);
653 static void msm_handle_tx_pio(struct uart_port
*port
, unsigned int tx_count
)
655 struct circ_buf
*xmit
= &port
->state
->xmit
;
656 struct msm_port
*msm_port
= UART_TO_MSM(port
);
657 unsigned int num_chars
;
658 unsigned int tf_pointer
= 0;
661 if (msm_port
->is_uartdm
)
662 tf
= port
->membase
+ UARTDM_TF
;
664 tf
= port
->membase
+ UART_TF
;
666 if (tx_count
&& msm_port
->is_uartdm
)
667 msm_reset_dm_count(port
, tx_count
);
669 while (tf_pointer
< tx_count
) {
673 if (!(msm_read(port
, UART_SR
) & UART_SR_TX_READY
))
676 if (msm_port
->is_uartdm
)
677 num_chars
= min(tx_count
- tf_pointer
,
678 (unsigned int)sizeof(buf
));
682 for (i
= 0; i
< num_chars
; i
++) {
683 buf
[i
] = xmit
->buf
[xmit
->tail
+ i
];
687 iowrite32_rep(tf
, buf
, 1);
688 xmit
->tail
= (xmit
->tail
+ num_chars
) & (UART_XMIT_SIZE
- 1);
689 tf_pointer
+= num_chars
;
692 /* disable tx interrupts if nothing more to send */
693 if (uart_circ_empty(xmit
))
696 if (uart_circ_chars_pending(xmit
) < WAKEUP_CHARS
)
697 uart_write_wakeup(port
);
700 static void msm_handle_tx(struct uart_port
*port
)
702 struct msm_port
*msm_port
= UART_TO_MSM(port
);
703 struct circ_buf
*xmit
= &msm_port
->uart
.state
->xmit
;
704 struct msm_dma
*dma
= &msm_port
->tx_dma
;
705 unsigned int pio_count
, dma_count
, dma_min
;
710 if (msm_port
->is_uartdm
)
711 tf
= port
->membase
+ UARTDM_TF
;
713 tf
= port
->membase
+ UART_TF
;
715 if (msm_port
->is_uartdm
)
716 msm_reset_dm_count(port
, 1);
718 iowrite8_rep(tf
, &port
->x_char
, 1);
724 if (uart_circ_empty(xmit
) || uart_tx_stopped(port
)) {
729 pio_count
= CIRC_CNT(xmit
->head
, xmit
->tail
, UART_XMIT_SIZE
);
730 dma_count
= CIRC_CNT_TO_END(xmit
->head
, xmit
->tail
, UART_XMIT_SIZE
);
732 dma_min
= 1; /* Always DMA */
733 if (msm_port
->is_uartdm
> UARTDM_1P3
) {
734 dma_count
= UARTDM_TX_AIGN(dma_count
);
735 dma_min
= UARTDM_BURST_SIZE
;
737 if (dma_count
> UARTDM_TX_MAX
)
738 dma_count
= UARTDM_TX_MAX
;
741 if (pio_count
> port
->fifosize
)
742 pio_count
= port
->fifosize
;
744 if (!dma
->chan
|| dma_count
< dma_min
)
745 msm_handle_tx_pio(port
, pio_count
);
747 err
= msm_handle_tx_dma(msm_port
, dma_count
);
749 if (err
) /* fall back to PIO mode */
750 msm_handle_tx_pio(port
, pio_count
);
753 static void msm_handle_delta_cts(struct uart_port
*port
)
755 msm_write(port
, UART_CR_CMD_RESET_CTS
, UART_CR
);
757 wake_up_interruptible(&port
->state
->port
.delta_msr_wait
);
760 static irqreturn_t
msm_uart_irq(int irq
, void *dev_id
)
762 struct uart_port
*port
= dev_id
;
763 struct msm_port
*msm_port
= UART_TO_MSM(port
);
764 struct msm_dma
*dma
= &msm_port
->rx_dma
;
769 spin_lock_irqsave(&port
->lock
, flags
);
770 misr
= msm_read(port
, UART_MISR
);
771 msm_write(port
, 0, UART_IMR
); /* disable interrupt */
773 if (misr
& UART_IMR_RXBREAK_START
) {
774 msm_port
->break_detected
= true;
775 msm_write(port
, UART_CR_CMD_RESET_RXBREAK_START
, UART_CR
);
778 if (misr
& (UART_IMR_RXLEV
| UART_IMR_RXSTALE
)) {
780 val
= UART_CR_CMD_STALE_EVENT_DISABLE
;
781 msm_write(port
, val
, UART_CR
);
782 val
= UART_CR_CMD_RESET_STALE_INT
;
783 msm_write(port
, val
, UART_CR
);
785 * Flush DMA input fifo to memory, this will also
786 * trigger DMA RX completion
788 dmaengine_terminate_all(dma
->chan
);
789 } else if (msm_port
->is_uartdm
) {
790 msm_handle_rx_dm(port
, misr
);
795 if (misr
& UART_IMR_TXLEV
)
797 if (misr
& UART_IMR_DELTA_CTS
)
798 msm_handle_delta_cts(port
);
800 msm_write(port
, msm_port
->imr
, UART_IMR
); /* restore interrupt */
801 spin_unlock_irqrestore(&port
->lock
, flags
);
806 static unsigned int msm_tx_empty(struct uart_port
*port
)
808 return (msm_read(port
, UART_SR
) & UART_SR_TX_EMPTY
) ? TIOCSER_TEMT
: 0;
811 static unsigned int msm_get_mctrl(struct uart_port
*port
)
813 return TIOCM_CAR
| TIOCM_CTS
| TIOCM_DSR
| TIOCM_RTS
;
816 static void msm_reset(struct uart_port
*port
)
818 struct msm_port
*msm_port
= UART_TO_MSM(port
);
820 /* reset everything */
821 msm_write(port
, UART_CR_CMD_RESET_RX
, UART_CR
);
822 msm_write(port
, UART_CR_CMD_RESET_TX
, UART_CR
);
823 msm_write(port
, UART_CR_CMD_RESET_ERR
, UART_CR
);
824 msm_write(port
, UART_CR_CMD_RESET_BREAK_INT
, UART_CR
);
825 msm_write(port
, UART_CR_CMD_RESET_CTS
, UART_CR
);
826 msm_write(port
, UART_CR_CMD_SET_RFR
, UART_CR
);
828 /* Disable DM modes */
829 if (msm_port
->is_uartdm
)
830 msm_write(port
, 0, UARTDM_DMEN
);
833 static void msm_set_mctrl(struct uart_port
*port
, unsigned int mctrl
)
837 mr
= msm_read(port
, UART_MR1
);
839 if (!(mctrl
& TIOCM_RTS
)) {
840 mr
&= ~UART_MR1_RX_RDY_CTL
;
841 msm_write(port
, mr
, UART_MR1
);
842 msm_write(port
, UART_CR_CMD_RESET_RFR
, UART_CR
);
844 mr
|= UART_MR1_RX_RDY_CTL
;
845 msm_write(port
, mr
, UART_MR1
);
849 static void msm_break_ctl(struct uart_port
*port
, int break_ctl
)
852 msm_write(port
, UART_CR_CMD_START_BREAK
, UART_CR
);
854 msm_write(port
, UART_CR_CMD_STOP_BREAK
, UART_CR
);
857 struct msm_baud_map
{
863 static const struct msm_baud_map
*
864 msm_find_best_baud(struct uart_port
*port
, unsigned int baud
,
867 struct msm_port
*msm_port
= UART_TO_MSM(port
);
868 unsigned int divisor
, result
;
869 unsigned long target
, old
, best_rate
= 0, diff
, best_diff
= ULONG_MAX
;
870 const struct msm_baud_map
*entry
, *end
, *best
;
871 static const struct msm_baud_map table
[] = {
890 best
= table
; /* Default to smallest divider */
891 target
= clk_round_rate(msm_port
->clk
, 16 * baud
);
892 divisor
= DIV_ROUND_CLOSEST(target
, 16 * baud
);
894 end
= table
+ ARRAY_SIZE(table
);
896 while (entry
< end
) {
897 if (entry
->divisor
<= divisor
) {
898 result
= target
/ entry
->divisor
/ 16;
899 diff
= abs(result
- baud
);
901 /* Keep track of best entry */
902 if (diff
< best_diff
) {
910 } else if (entry
->divisor
> divisor
) {
912 target
= clk_round_rate(msm_port
->clk
, old
+ 1);
914 * The rate didn't get any faster so we can't do
915 * better at dividing it down
920 /* Start the divisor search over at this new rate */
922 divisor
= DIV_ROUND_CLOSEST(target
, 16 * baud
);
932 static int msm_set_baud_rate(struct uart_port
*port
, unsigned int baud
,
933 unsigned long *saved_flags
)
935 unsigned int rxstale
, watermark
, mask
;
936 struct msm_port
*msm_port
= UART_TO_MSM(port
);
937 const struct msm_baud_map
*entry
;
938 unsigned long flags
, rate
;
940 flags
= *saved_flags
;
941 spin_unlock_irqrestore(&port
->lock
, flags
);
943 entry
= msm_find_best_baud(port
, baud
, &rate
);
944 clk_set_rate(msm_port
->clk
, rate
);
945 baud
= rate
/ 16 / entry
->divisor
;
947 spin_lock_irqsave(&port
->lock
, flags
);
948 *saved_flags
= flags
;
949 port
->uartclk
= rate
;
951 msm_write(port
, entry
->code
, UART_CSR
);
953 /* RX stale watermark */
954 rxstale
= entry
->rxstale
;
955 watermark
= UART_IPR_STALE_LSB
& rxstale
;
956 if (msm_port
->is_uartdm
) {
957 mask
= UART_DM_IPR_STALE_TIMEOUT_MSB
;
959 watermark
|= UART_IPR_RXSTALE_LAST
;
960 mask
= UART_IPR_STALE_TIMEOUT_MSB
;
963 watermark
|= mask
& (rxstale
<< 2);
965 msm_write(port
, watermark
, UART_IPR
);
967 /* set RX watermark */
968 watermark
= (port
->fifosize
* 3) / 4;
969 msm_write(port
, watermark
, UART_RFWR
);
971 /* set TX watermark */
972 msm_write(port
, 10, UART_TFWR
);
974 msm_write(port
, UART_CR_CMD_PROTECTION_EN
, UART_CR
);
977 /* Enable RX and TX */
978 msm_write(port
, UART_CR_TX_ENABLE
| UART_CR_RX_ENABLE
, UART_CR
);
980 /* turn on RX and CTS interrupts */
981 msm_port
->imr
= UART_IMR_RXLEV
| UART_IMR_RXSTALE
|
982 UART_IMR_CURRENT_CTS
| UART_IMR_RXBREAK_START
;
984 msm_write(port
, msm_port
->imr
, UART_IMR
);
986 if (msm_port
->is_uartdm
) {
987 msm_write(port
, UART_CR_CMD_RESET_STALE_INT
, UART_CR
);
988 msm_write(port
, 0xFFFFFF, UARTDM_DMRX
);
989 msm_write(port
, UART_CR_CMD_STALE_EVENT_ENABLE
, UART_CR
);
995 static void msm_init_clock(struct uart_port
*port
)
997 struct msm_port
*msm_port
= UART_TO_MSM(port
);
999 clk_prepare_enable(msm_port
->clk
);
1000 clk_prepare_enable(msm_port
->pclk
);
1001 msm_serial_set_mnd_regs(port
);
1004 static int msm_startup(struct uart_port
*port
)
1006 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1007 unsigned int data
, rfr_level
, mask
;
1010 snprintf(msm_port
->name
, sizeof(msm_port
->name
),
1011 "msm_serial%d", port
->line
);
1013 ret
= request_irq(port
->irq
, msm_uart_irq
, IRQF_TRIGGER_HIGH
,
1014 msm_port
->name
, port
);
1018 msm_init_clock(port
);
1020 if (likely(port
->fifosize
> 12))
1021 rfr_level
= port
->fifosize
- 12;
1023 rfr_level
= port
->fifosize
;
1025 /* set automatic RFR level */
1026 data
= msm_read(port
, UART_MR1
);
1028 if (msm_port
->is_uartdm
)
1029 mask
= UART_DM_MR1_AUTO_RFR_LEVEL1
;
1031 mask
= UART_MR1_AUTO_RFR_LEVEL1
;
1034 data
&= ~UART_MR1_AUTO_RFR_LEVEL0
;
1035 data
|= mask
& (rfr_level
<< 2);
1036 data
|= UART_MR1_AUTO_RFR_LEVEL0
& rfr_level
;
1037 msm_write(port
, data
, UART_MR1
);
1039 if (msm_port
->is_uartdm
) {
1040 msm_request_tx_dma(msm_port
, msm_port
->uart
.mapbase
);
1041 msm_request_rx_dma(msm_port
, msm_port
->uart
.mapbase
);
1047 static void msm_shutdown(struct uart_port
*port
)
1049 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1052 msm_write(port
, 0, UART_IMR
); /* disable interrupts */
1054 if (msm_port
->is_uartdm
)
1055 msm_release_dma(msm_port
);
1057 clk_disable_unprepare(msm_port
->clk
);
1059 free_irq(port
->irq
, port
);
1062 static void msm_set_termios(struct uart_port
*port
, struct ktermios
*termios
,
1063 struct ktermios
*old
)
1065 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1066 struct msm_dma
*dma
= &msm_port
->rx_dma
;
1067 unsigned long flags
;
1068 unsigned int baud
, mr
;
1070 spin_lock_irqsave(&port
->lock
, flags
);
1072 if (dma
->chan
) /* Terminate if any */
1073 msm_stop_dma(port
, dma
);
1075 /* calculate and set baud rate */
1076 baud
= uart_get_baud_rate(port
, termios
, old
, 300, 4000000);
1077 baud
= msm_set_baud_rate(port
, baud
, &flags
);
1078 if (tty_termios_baud_rate(termios
))
1079 tty_termios_encode_baud_rate(termios
, baud
, baud
);
1081 /* calculate parity */
1082 mr
= msm_read(port
, UART_MR2
);
1083 mr
&= ~UART_MR2_PARITY_MODE
;
1084 if (termios
->c_cflag
& PARENB
) {
1085 if (termios
->c_cflag
& PARODD
)
1086 mr
|= UART_MR2_PARITY_MODE_ODD
;
1087 else if (termios
->c_cflag
& CMSPAR
)
1088 mr
|= UART_MR2_PARITY_MODE_SPACE
;
1090 mr
|= UART_MR2_PARITY_MODE_EVEN
;
1093 /* calculate bits per char */
1094 mr
&= ~UART_MR2_BITS_PER_CHAR
;
1095 switch (termios
->c_cflag
& CSIZE
) {
1097 mr
|= UART_MR2_BITS_PER_CHAR_5
;
1100 mr
|= UART_MR2_BITS_PER_CHAR_6
;
1103 mr
|= UART_MR2_BITS_PER_CHAR_7
;
1107 mr
|= UART_MR2_BITS_PER_CHAR_8
;
1111 /* calculate stop bits */
1112 mr
&= ~(UART_MR2_STOP_BIT_LEN_ONE
| UART_MR2_STOP_BIT_LEN_TWO
);
1113 if (termios
->c_cflag
& CSTOPB
)
1114 mr
|= UART_MR2_STOP_BIT_LEN_TWO
;
1116 mr
|= UART_MR2_STOP_BIT_LEN_ONE
;
1118 /* set parity, bits per char, and stop bit */
1119 msm_write(port
, mr
, UART_MR2
);
1121 /* calculate and set hardware flow control */
1122 mr
= msm_read(port
, UART_MR1
);
1123 mr
&= ~(UART_MR1_CTS_CTL
| UART_MR1_RX_RDY_CTL
);
1124 if (termios
->c_cflag
& CRTSCTS
) {
1125 mr
|= UART_MR1_CTS_CTL
;
1126 mr
|= UART_MR1_RX_RDY_CTL
;
1128 msm_write(port
, mr
, UART_MR1
);
1130 /* Configure status bits to ignore based on termio flags. */
1131 port
->read_status_mask
= 0;
1132 if (termios
->c_iflag
& INPCK
)
1133 port
->read_status_mask
|= UART_SR_PAR_FRAME_ERR
;
1134 if (termios
->c_iflag
& (IGNBRK
| BRKINT
| PARMRK
))
1135 port
->read_status_mask
|= UART_SR_RX_BREAK
;
1137 uart_update_timeout(port
, termios
->c_cflag
, baud
);
1139 /* Try to use DMA */
1140 msm_start_rx_dma(msm_port
);
1142 spin_unlock_irqrestore(&port
->lock
, flags
);
1145 static const char *msm_type(struct uart_port
*port
)
1150 static void msm_release_port(struct uart_port
*port
)
1152 struct platform_device
*pdev
= to_platform_device(port
->dev
);
1153 struct resource
*uart_resource
;
1154 resource_size_t size
;
1156 uart_resource
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1157 if (unlikely(!uart_resource
))
1159 size
= resource_size(uart_resource
);
1161 release_mem_region(port
->mapbase
, size
);
1162 iounmap(port
->membase
);
1163 port
->membase
= NULL
;
1166 static int msm_request_port(struct uart_port
*port
)
1168 struct platform_device
*pdev
= to_platform_device(port
->dev
);
1169 struct resource
*uart_resource
;
1170 resource_size_t size
;
1173 uart_resource
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1174 if (unlikely(!uart_resource
))
1177 size
= resource_size(uart_resource
);
1179 if (!request_mem_region(port
->mapbase
, size
, "msm_serial"))
1182 port
->membase
= ioremap(port
->mapbase
, size
);
1183 if (!port
->membase
) {
1185 goto fail_release_port
;
1191 release_mem_region(port
->mapbase
, size
);
1195 static void msm_config_port(struct uart_port
*port
, int flags
)
1199 if (flags
& UART_CONFIG_TYPE
) {
1200 port
->type
= PORT_MSM
;
1201 ret
= msm_request_port(port
);
1207 static int msm_verify_port(struct uart_port
*port
, struct serial_struct
*ser
)
1209 if (unlikely(ser
->type
!= PORT_UNKNOWN
&& ser
->type
!= PORT_MSM
))
1211 if (unlikely(port
->irq
!= ser
->irq
))
1216 static void msm_power(struct uart_port
*port
, unsigned int state
,
1217 unsigned int oldstate
)
1219 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1223 clk_prepare_enable(msm_port
->clk
);
1224 clk_prepare_enable(msm_port
->pclk
);
1227 clk_disable_unprepare(msm_port
->clk
);
1228 clk_disable_unprepare(msm_port
->pclk
);
1231 pr_err("msm_serial: Unknown PM state %d\n", state
);
1235 #ifdef CONFIG_CONSOLE_POLL
1236 static int msm_poll_get_char_single(struct uart_port
*port
)
1238 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1239 unsigned int rf_reg
= msm_port
->is_uartdm
? UARTDM_RF
: UART_RF
;
1241 if (!(msm_read(port
, UART_SR
) & UART_SR_RX_READY
))
1242 return NO_POLL_CHAR
;
1244 return msm_read(port
, rf_reg
) & 0xff;
1247 static int msm_poll_get_char_dm(struct uart_port
*port
)
1252 unsigned char *sp
= (unsigned char *)&slop
;
1254 /* Check if a previous read had more than one char */
1256 c
= sp
[sizeof(slop
) - count
];
1258 /* Or if FIFO is empty */
1259 } else if (!(msm_read(port
, UART_SR
) & UART_SR_RX_READY
)) {
1261 * If RX packing buffer has less than a word, force stale to
1262 * push contents into RX FIFO
1264 count
= msm_read(port
, UARTDM_RXFS
);
1265 count
= (count
>> UARTDM_RXFS_BUF_SHIFT
) & UARTDM_RXFS_BUF_MASK
;
1267 msm_write(port
, UART_CR_CMD_FORCE_STALE
, UART_CR
);
1268 slop
= msm_read(port
, UARTDM_RF
);
1271 msm_write(port
, UART_CR_CMD_RESET_STALE_INT
, UART_CR
);
1272 msm_write(port
, 0xFFFFFF, UARTDM_DMRX
);
1273 msm_write(port
, UART_CR_CMD_STALE_EVENT_ENABLE
,
1278 /* FIFO has a word */
1280 slop
= msm_read(port
, UARTDM_RF
);
1282 count
= sizeof(slop
) - 1;
1288 static int msm_poll_get_char(struct uart_port
*port
)
1292 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1294 /* Disable all interrupts */
1295 imr
= msm_read(port
, UART_IMR
);
1296 msm_write(port
, 0, UART_IMR
);
1298 if (msm_port
->is_uartdm
)
1299 c
= msm_poll_get_char_dm(port
);
1301 c
= msm_poll_get_char_single(port
);
1303 /* Enable interrupts */
1304 msm_write(port
, imr
, UART_IMR
);
1309 static void msm_poll_put_char(struct uart_port
*port
, unsigned char c
)
1312 struct msm_port
*msm_port
= UART_TO_MSM(port
);
1314 /* Disable all interrupts */
1315 imr
= msm_read(port
, UART_IMR
);
1316 msm_write(port
, 0, UART_IMR
);
1318 if (msm_port
->is_uartdm
)
1319 msm_reset_dm_count(port
, 1);
1321 /* Wait until FIFO is empty */
1322 while (!(msm_read(port
, UART_SR
) & UART_SR_TX_READY
))
1325 /* Write a character */
1326 msm_write(port
, c
, msm_port
->is_uartdm
? UARTDM_TF
: UART_TF
);
1328 /* Wait until FIFO is empty */
1329 while (!(msm_read(port
, UART_SR
) & UART_SR_TX_READY
))
1332 /* Enable interrupts */
1333 msm_write(port
, imr
, UART_IMR
);
1337 static struct uart_ops msm_uart_pops
= {
1338 .tx_empty
= msm_tx_empty
,
1339 .set_mctrl
= msm_set_mctrl
,
1340 .get_mctrl
= msm_get_mctrl
,
1341 .stop_tx
= msm_stop_tx
,
1342 .start_tx
= msm_start_tx
,
1343 .stop_rx
= msm_stop_rx
,
1344 .enable_ms
= msm_enable_ms
,
1345 .break_ctl
= msm_break_ctl
,
1346 .startup
= msm_startup
,
1347 .shutdown
= msm_shutdown
,
1348 .set_termios
= msm_set_termios
,
1350 .release_port
= msm_release_port
,
1351 .request_port
= msm_request_port
,
1352 .config_port
= msm_config_port
,
1353 .verify_port
= msm_verify_port
,
1355 #ifdef CONFIG_CONSOLE_POLL
1356 .poll_get_char
= msm_poll_get_char
,
1357 .poll_put_char
= msm_poll_put_char
,
1361 static struct msm_port msm_uart_ports
[] = {
1365 .ops
= &msm_uart_pops
,
1366 .flags
= UPF_BOOT_AUTOCONF
,
1374 .ops
= &msm_uart_pops
,
1375 .flags
= UPF_BOOT_AUTOCONF
,
1383 .ops
= &msm_uart_pops
,
1384 .flags
= UPF_BOOT_AUTOCONF
,
1391 #define UART_NR ARRAY_SIZE(msm_uart_ports)
1393 static inline struct uart_port
*msm_get_port_from_line(unsigned int line
)
1395 return &msm_uart_ports
[line
].uart
;
1398 #ifdef CONFIG_SERIAL_MSM_CONSOLE
1399 static void __msm_console_write(struct uart_port
*port
, const char *s
,
1400 unsigned int count
, bool is_uartdm
)
1403 int num_newlines
= 0;
1404 bool replaced
= false;
1408 tf
= port
->membase
+ UARTDM_TF
;
1410 tf
= port
->membase
+ UART_TF
;
1412 /* Account for newlines that will get a carriage return added */
1413 for (i
= 0; i
< count
; i
++)
1416 count
+= num_newlines
;
1418 spin_lock(&port
->lock
);
1420 msm_reset_dm_count(port
, count
);
1425 unsigned int num_chars
;
1426 char buf
[4] = { 0 };
1429 num_chars
= min(count
- i
, (unsigned int)sizeof(buf
));
1433 for (j
= 0; j
< num_chars
; j
++) {
1436 if (c
== '\n' && !replaced
) {
1441 if (j
< num_chars
) {
1448 while (!(msm_read(port
, UART_SR
) & UART_SR_TX_READY
))
1451 iowrite32_rep(tf
, buf
, 1);
1454 spin_unlock(&port
->lock
);
1457 static void msm_console_write(struct console
*co
, const char *s
,
1460 struct uart_port
*port
;
1461 struct msm_port
*msm_port
;
1463 BUG_ON(co
->index
< 0 || co
->index
>= UART_NR
);
1465 port
= msm_get_port_from_line(co
->index
);
1466 msm_port
= UART_TO_MSM(port
);
1468 __msm_console_write(port
, s
, count
, msm_port
->is_uartdm
);
1471 static int __init
msm_console_setup(struct console
*co
, char *options
)
1473 struct uart_port
*port
;
1479 if (unlikely(co
->index
>= UART_NR
|| co
->index
< 0))
1482 port
= msm_get_port_from_line(co
->index
);
1484 if (unlikely(!port
->membase
))
1487 msm_init_clock(port
);
1490 uart_parse_options(options
, &baud
, &parity
, &bits
, &flow
);
1492 pr_info("msm_serial: console setup on port #%d\n", port
->line
);
1494 return uart_set_options(port
, co
, baud
, parity
, bits
, flow
);
1498 msm_serial_early_write(struct console
*con
, const char *s
, unsigned n
)
1500 struct earlycon_device
*dev
= con
->data
;
1502 __msm_console_write(&dev
->port
, s
, n
, false);
1506 msm_serial_early_console_setup(struct earlycon_device
*device
, const char *opt
)
1508 if (!device
->port
.membase
)
1511 device
->con
->write
= msm_serial_early_write
;
1514 OF_EARLYCON_DECLARE(msm_serial
, "qcom,msm-uart",
1515 msm_serial_early_console_setup
);
1518 msm_serial_early_write_dm(struct console
*con
, const char *s
, unsigned n
)
1520 struct earlycon_device
*dev
= con
->data
;
1522 __msm_console_write(&dev
->port
, s
, n
, true);
1526 msm_serial_early_console_setup_dm(struct earlycon_device
*device
,
1529 if (!device
->port
.membase
)
1532 device
->con
->write
= msm_serial_early_write_dm
;
1535 OF_EARLYCON_DECLARE(msm_serial_dm
, "qcom,msm-uartdm",
1536 msm_serial_early_console_setup_dm
);
1538 static struct uart_driver msm_uart_driver
;
1540 static struct console msm_console
= {
1542 .write
= msm_console_write
,
1543 .device
= uart_console_device
,
1544 .setup
= msm_console_setup
,
1545 .flags
= CON_PRINTBUFFER
,
1547 .data
= &msm_uart_driver
,
1550 #define MSM_CONSOLE (&msm_console)
1553 #define MSM_CONSOLE NULL
1556 static struct uart_driver msm_uart_driver
= {
1557 .owner
= THIS_MODULE
,
1558 .driver_name
= "msm_serial",
1559 .dev_name
= "ttyMSM",
1561 .cons
= MSM_CONSOLE
,
1564 static atomic_t msm_uart_next_id
= ATOMIC_INIT(0);
1566 static const struct of_device_id msm_uartdm_table
[] = {
1567 { .compatible
= "qcom,msm-uartdm-v1.1", .data
= (void *)UARTDM_1P1
},
1568 { .compatible
= "qcom,msm-uartdm-v1.2", .data
= (void *)UARTDM_1P2
},
1569 { .compatible
= "qcom,msm-uartdm-v1.3", .data
= (void *)UARTDM_1P3
},
1570 { .compatible
= "qcom,msm-uartdm-v1.4", .data
= (void *)UARTDM_1P4
},
1574 static int msm_serial_probe(struct platform_device
*pdev
)
1576 struct msm_port
*msm_port
;
1577 struct resource
*resource
;
1578 struct uart_port
*port
;
1579 const struct of_device_id
*id
;
1582 if (pdev
->dev
.of_node
)
1583 line
= of_alias_get_id(pdev
->dev
.of_node
, "serial");
1588 line
= atomic_inc_return(&msm_uart_next_id
) - 1;
1590 if (unlikely(line
< 0 || line
>= UART_NR
))
1593 dev_info(&pdev
->dev
, "msm_serial: detected port #%d\n", line
);
1595 port
= msm_get_port_from_line(line
);
1596 port
->dev
= &pdev
->dev
;
1597 msm_port
= UART_TO_MSM(port
);
1599 id
= of_match_device(msm_uartdm_table
, &pdev
->dev
);
1601 msm_port
->is_uartdm
= (unsigned long)id
->data
;
1603 msm_port
->is_uartdm
= 0;
1605 msm_port
->clk
= devm_clk_get(&pdev
->dev
, "core");
1606 if (IS_ERR(msm_port
->clk
))
1607 return PTR_ERR(msm_port
->clk
);
1609 if (msm_port
->is_uartdm
) {
1610 msm_port
->pclk
= devm_clk_get(&pdev
->dev
, "iface");
1611 if (IS_ERR(msm_port
->pclk
))
1612 return PTR_ERR(msm_port
->pclk
);
1615 port
->uartclk
= clk_get_rate(msm_port
->clk
);
1616 dev_info(&pdev
->dev
, "uartclk = %d\n", port
->uartclk
);
1618 resource
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1619 if (unlikely(!resource
))
1621 port
->mapbase
= resource
->start
;
1623 irq
= platform_get_irq(pdev
, 0);
1624 if (unlikely(irq
< 0))
1628 platform_set_drvdata(pdev
, port
);
1630 return uart_add_one_port(&msm_uart_driver
, port
);
1633 static int msm_serial_remove(struct platform_device
*pdev
)
1635 struct uart_port
*port
= platform_get_drvdata(pdev
);
1637 uart_remove_one_port(&msm_uart_driver
, port
);
1642 static const struct of_device_id msm_match_table
[] = {
1643 { .compatible
= "qcom,msm-uart" },
1644 { .compatible
= "qcom,msm-uartdm" },
1648 static struct platform_driver msm_platform_driver
= {
1649 .remove
= msm_serial_remove
,
1650 .probe
= msm_serial_probe
,
1652 .name
= "msm_serial",
1653 .of_match_table
= msm_match_table
,
1657 static int __init
msm_serial_init(void)
1661 ret
= uart_register_driver(&msm_uart_driver
);
1665 ret
= platform_driver_register(&msm_platform_driver
);
1667 uart_unregister_driver(&msm_uart_driver
);
1669 pr_info("msm_serial: driver initialized\n");
1674 static void __exit
msm_serial_exit(void)
1676 platform_driver_unregister(&msm_platform_driver
);
1677 uart_unregister_driver(&msm_uart_driver
);
1680 module_init(msm_serial_init
);
1681 module_exit(msm_serial_exit
);
1683 MODULE_AUTHOR("Robert Love <rlove@google.com>");
1684 MODULE_DESCRIPTION("Driver for msm7x serial device");
1685 MODULE_LICENSE("GPL");