atmel_serial.c 74.4 KB
Newer Older
1
/*
2
 *  Driver for Atmel AT91 / AT32 Serial ports
3 4 5 6 7
 *  Copyright (C) 2003 Rick Bronson
 *
 *  Based on drivers/char/serial_sa1100.c, by Deep Blue Solutions Ltd.
 *  Based on drivers/char/serial.c, by Linus Torvalds, Theodore Ts'o.
 *
C
Chip Coldwell 已提交
8 9
 *  DMA support added by Chip Coldwell.
 *
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/slab.h>
#include <linux/init.h>
#include <linux/serial.h>
30
#include <linux/clk.h>
31 32 33
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/tty_flip.h>
34
#include <linux/platform_device.h>
35 36
#include <linux/of.h>
#include <linux/of_device.h>
37
#include <linux/of_gpio.h>
C
Chip Coldwell 已提交
38
#include <linux/dma-mapping.h>
39
#include <linux/dmaengine.h>
40
#include <linux/atmel_pdc.h>
41
#include <linux/atmel_serial.h>
42
#include <linux/uaccess.h>
43
#include <linux/platform_data/atmel.h>
44
#include <linux/timer.h>
45
#include <linux/gpio.h>
46 47
#include <linux/gpio/consumer.h>
#include <linux/err.h>
48
#include <linux/irq.h>
49
#include <linux/suspend.h>
50 51

#include <asm/io.h>
52
#include <asm/ioctls.h>
53

C
Chip Coldwell 已提交
54 55 56 57
#define PDC_BUFFER_SIZE		512
/* Revisit: We should calculate this based on the actual port settings */
#define PDC_RX_TIMEOUT		(3 * 10)		/* 3 bytes */

58 59 60 61 62 63 64 65 66
/* The minium number of data FIFOs should be able to contain */
#define ATMEL_MIN_FIFO_SIZE	8
/*
 * These two offsets are substracted from the RX FIFO size to define the RTS
 * high and low thresholds
 */
#define ATMEL_RTS_HIGH_OFFSET	16
#define ATMEL_RTS_LOW_OFFSET	20

67
#if defined(CONFIG_SERIAL_ATMEL_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
68 69 70 71 72
#define SUPPORT_SYSRQ
#endif

#include <linux/serial_core.h>

73 74
#include "serial_mctrl_gpio.h"

75 76 77
static void atmel_start_rx(struct uart_port *port);
static void atmel_stop_rx(struct uart_port *port);

78
#ifdef CONFIG_SERIAL_ATMEL_TTYAT
79 80 81 82

/* Use device name ttyAT, major 204 and minor 154-169.  This is necessary if we
 * should coexist with the 8250 driver, such as if we have an external 16C550
 * UART. */
83
#define SERIAL_ATMEL_MAJOR	204
84
#define MINOR_START		154
85
#define ATMEL_DEVICENAME	"ttyAT"
86 87 88 89 90

#else

/* Use device name ttyS, major 4, minor 64-68.  This is the usual serial port
 * name, but it is legally reserved for the 8250 driver. */
91
#define SERIAL_ATMEL_MAJOR	TTY_MAJOR
92
#define MINOR_START		64
93
#define ATMEL_DEVICENAME	"ttyS"
94 95 96

#endif

97
#define ATMEL_ISR_PASS_LIMIT	256
98

C
Chip Coldwell 已提交
99 100 101 102 103 104 105
struct atmel_dma_buffer {
	unsigned char	*buf;
	dma_addr_t	dma_addr;
	unsigned int	dma_size;
	unsigned int	ofs;
};

106 107 108 109 110
struct atmel_uart_char {
	u16		status;
	u16		ch;
};

111 112 113 114 115 116
/*
 * Be careful, the real size of the ring buffer is
 * sizeof(atmel_uart_char) * ATMEL_SERIAL_RINGSIZE. It means that ring buffer
 * can contain up to 1024 characters in PIO mode and up to 4096 characters in
 * DMA mode.
 */
117 118
#define ATMEL_SERIAL_RINGSIZE 1024

119 120 121 122 123 124
/*
 * at91: 6 USARTs and one DBGU port (SAM9260)
 * avr32: 4
 */
#define ATMEL_MAX_UART		7

125 126 127
/*
 * We wrap our port structure around the generic uart_port.
 */
128
struct atmel_uart_port {
129 130
	struct uart_port	uart;		/* uart */
	struct clk		*clk;		/* uart clock */
131 132
	int			may_wakeup;	/* cached value of device_may_wakeup for times we need to disable it */
	u32			backup_imr;	/* IMR saved during suspend */
133
	int			break_active;	/* break being received */
134

E
Elen Song 已提交
135
	bool			use_dma_rx;	/* enable DMA receiver */
136
	bool			use_pdc_rx;	/* enable PDC receiver */
C
Chip Coldwell 已提交
137 138 139
	short			pdc_rx_idx;	/* current PDC RX buffer */
	struct atmel_dma_buffer	pdc_rx[2];	/* PDC receier */

E
Elen Song 已提交
140
	bool			use_dma_tx;     /* enable DMA transmitter */
141
	bool			use_pdc_tx;	/* enable PDC transmitter */
C
Chip Coldwell 已提交
142 143
	struct atmel_dma_buffer	pdc_tx;		/* PDC transmitter */

E
Elen Song 已提交
144
	spinlock_t			lock_tx;	/* port lock */
E
Elen Song 已提交
145
	spinlock_t			lock_rx;	/* port lock */
E
Elen Song 已提交
146
	struct dma_chan			*chan_tx;
E
Elen Song 已提交
147
	struct dma_chan			*chan_rx;
E
Elen Song 已提交
148
	struct dma_async_tx_descriptor	*desc_tx;
E
Elen Song 已提交
149
	struct dma_async_tx_descriptor	*desc_rx;
E
Elen Song 已提交
150
	dma_cookie_t			cookie_tx;
E
Elen Song 已提交
151
	dma_cookie_t			cookie_rx;
E
Elen Song 已提交
152
	struct scatterlist		sg_tx;
E
Elen Song 已提交
153
	struct scatterlist		sg_rx;
154 155
	struct tasklet_struct	tasklet_rx;
	struct tasklet_struct	tasklet_tx;
156
	atomic_t		tasklet_shutdown;
157
	unsigned int		irq_status_prev;
158
	unsigned int		tx_len;
159 160

	struct circ_buf		rx_ring;
161

162
	struct mctrl_gpios	*gpios;
163
	unsigned int		tx_done_mask;
164 165 166
	u32			fifo_size;
	u32			rts_high;
	u32			rts_low;
167
	bool			ms_irq_enabled;
168
	u32			rtor;	/* address of receiver timeout register if it exists */
169
	bool			has_frac_baudrate;
170 171
	bool			has_hw_timer;
	struct timer_list	uart_timer;
172 173 174 175 176 177

	bool			suspended;
	unsigned int		pending;
	unsigned int		pending_status;
	spinlock_t		lock_suspended;

178 179 180 181 182 183
	int (*prepare_rx)(struct uart_port *port);
	int (*prepare_tx)(struct uart_port *port);
	void (*schedule_rx)(struct uart_port *port);
	void (*schedule_tx)(struct uart_port *port);
	void (*release_rx)(struct uart_port *port);
	void (*release_tx)(struct uart_port *port);
184 185
};

186
static struct atmel_uart_port atmel_ports[ATMEL_MAX_UART];
187
static DECLARE_BITMAP(atmel_ports_in_use, ATMEL_MAX_UART);
188

189
#ifdef SUPPORT_SYSRQ
190
static struct console atmel_console;
191 192
#endif

193 194 195 196 197 198 199 200
#if defined(CONFIG_OF)
static const struct of_device_id atmel_serial_dt_ids[] = {
	{ .compatible = "atmel,at91rm9200-usart" },
	{ .compatible = "atmel,at91sam9260-usart" },
	{ /* sentinel */ }
};
#endif

201 202 203 204 205 206
static inline struct atmel_uart_port *
to_atmel_uart_port(struct uart_port *uart)
{
	return container_of(uart, struct atmel_uart_port, uart);
}

207 208 209 210 211 212 213 214 215 216
static inline u32 atmel_uart_readl(struct uart_port *port, u32 reg)
{
	return __raw_readl(port->membase + reg);
}

static inline void atmel_uart_writel(struct uart_port *port, u32 reg, u32 value)
{
	__raw_writel(value, port->membase + reg);
}

217 218 219 220 221 222 223 224 225
#ifdef CONFIG_AVR32

/* AVR32 cannot handle 8 or 16bit I/O accesses but only 32bit I/O accesses */
static inline u8 atmel_uart_read_char(struct uart_port *port)
{
	return __raw_readl(port->membase + ATMEL_US_RHR);
}

static inline void atmel_uart_write_char(struct uart_port *port, u8 value)
226
{
227
	__raw_writel(value, port->membase + ATMEL_US_THR);
228 229
}

230 231 232
#else

static inline u8 atmel_uart_read_char(struct uart_port *port)
233
{
234
	return __raw_readb(port->membase + ATMEL_US_RHR);
235 236
}

237 238 239 240 241 242 243
static inline void atmel_uart_write_char(struct uart_port *port, u8 value)
{
	__raw_writeb(value, port->membase + ATMEL_US_THR);
}

#endif

C
Chip Coldwell 已提交
244
#ifdef CONFIG_SERIAL_ATMEL_PDC
245
static bool atmel_use_pdc_rx(struct uart_port *port)
C
Chip Coldwell 已提交
246
{
247
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
C
Chip Coldwell 已提交
248

249
	return atmel_port->use_pdc_rx;
C
Chip Coldwell 已提交
250 251
}

252
static bool atmel_use_pdc_tx(struct uart_port *port)
C
Chip Coldwell 已提交
253
{
254
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
C
Chip Coldwell 已提交
255

256
	return atmel_port->use_pdc_tx;
C
Chip Coldwell 已提交
257 258
}
#else
259
static bool atmel_use_pdc_rx(struct uart_port *port)
C
Chip Coldwell 已提交
260 261 262 263
{
	return false;
}

264
static bool atmel_use_pdc_tx(struct uart_port *port)
C
Chip Coldwell 已提交
265 266 267 268 269
{
	return false;
}
#endif

E
Elen Song 已提交
270 271 272 273 274 275 276
static bool atmel_use_dma_tx(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

	return atmel_port->use_dma_tx;
}

E
Elen Song 已提交
277 278 279 280 281 282 283
static bool atmel_use_dma_rx(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

	return atmel_port->use_dma_rx;
}

284 285 286 287 288 289 290
static bool atmel_use_fifo(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

	return atmel_port->fifo_size;
}

291 292 293 294 295 296 297
static void atmel_tasklet_schedule(struct atmel_uart_port *atmel_port,
				   struct tasklet_struct *t)
{
	if (!atomic_read(&atmel_port->tasklet_shutdown))
		tasklet_schedule(t);
}

298 299 300 301 302
static unsigned int atmel_get_lines_status(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	unsigned int status, ret = 0;

303
	status = atmel_uart_readl(port, ATMEL_US_CSR);
304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341

	mctrl_gpio_get(atmel_port->gpios, &ret);

	if (!IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(atmel_port->gpios,
						UART_GPIO_CTS))) {
		if (ret & TIOCM_CTS)
			status &= ~ATMEL_US_CTS;
		else
			status |= ATMEL_US_CTS;
	}

	if (!IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(atmel_port->gpios,
						UART_GPIO_DSR))) {
		if (ret & TIOCM_DSR)
			status &= ~ATMEL_US_DSR;
		else
			status |= ATMEL_US_DSR;
	}

	if (!IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(atmel_port->gpios,
						UART_GPIO_RI))) {
		if (ret & TIOCM_RI)
			status &= ~ATMEL_US_RI;
		else
			status |= ATMEL_US_RI;
	}

	if (!IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(atmel_port->gpios,
						UART_GPIO_DCD))) {
		if (ret & TIOCM_CD)
			status &= ~ATMEL_US_DCD;
		else
			status |= ATMEL_US_DCD;
	}

	return status;
}

342
/* Enable or disable the rs485 support */
343 344
static int atmel_config_rs485(struct uart_port *port,
			      struct serial_rs485 *rs485conf)
345 346 347 348 349
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	unsigned int mode;

	/* Disable interrupts */
350
	atmel_uart_writel(port, ATMEL_US_IDR, atmel_port->tx_done_mask);
351

352
	mode = atmel_uart_readl(port, ATMEL_US_MR);
353 354 355 356

	/* Resetting serial mode to RS232 (0x0) */
	mode &= ~ATMEL_US_USMODE;

357
	port->rs485 = *rs485conf;
358 359 360 361

	if (rs485conf->flags & SER_RS485_ENABLED) {
		dev_dbg(port->dev, "Setting UART to RS485\n");
		atmel_port->tx_done_mask = ATMEL_US_TXEMPTY;
362 363
		atmel_uart_writel(port, ATMEL_US_TTGR,
				  rs485conf->delay_rts_after_send);
364 365 366
		mode |= ATMEL_US_USMODE_RS485;
	} else {
		dev_dbg(port->dev, "Setting UART to RS232\n");
367
		if (atmel_use_pdc_tx(port))
368 369 370 371 372
			atmel_port->tx_done_mask = ATMEL_US_ENDTX |
				ATMEL_US_TXBUFE;
		else
			atmel_port->tx_done_mask = ATMEL_US_TXRDY;
	}
373
	atmel_uart_writel(port, ATMEL_US_MR, mode);
374 375

	/* Enable interrupts */
376
	atmel_uart_writel(port, ATMEL_US_IER, atmel_port->tx_done_mask);
377

378
	return 0;
379 380
}

381 382 383
/*
 * Return TIOCSER_TEMT when transmitter FIFO and Shift register is empty.
 */
384
static u_int atmel_tx_empty(struct uart_port *port)
385
{
386 387 388
	return (atmel_uart_readl(port, ATMEL_US_CSR) & ATMEL_US_TXEMPTY) ?
		TIOCSER_TEMT :
		0;
389 390 391 392 393
}

/*
 * Set state of the modem control output lines
 */
394
static void atmel_set_mctrl(struct uart_port *port, u_int mctrl)
395 396
{
	unsigned int control = 0;
397
	unsigned int mode = atmel_uart_readl(port, ATMEL_US_MR);
398
	unsigned int rts_paused, rts_ready;
399
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
400

401 402
	/* override mode to RS485 if needed, otherwise keep the current mode */
	if (port->rs485.flags & SER_RS485_ENABLED) {
403 404
		atmel_uart_writel(port, ATMEL_US_TTGR,
				  port->rs485.delay_rts_after_send);
405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423
		mode &= ~ATMEL_US_USMODE;
		mode |= ATMEL_US_USMODE_RS485;
	}

	/* set the RTS line state according to the mode */
	if ((mode & ATMEL_US_USMODE) == ATMEL_US_USMODE_HWHS) {
		/* force RTS line to high level */
		rts_paused = ATMEL_US_RTSEN;

		/* give the control of the RTS line back to the hardware */
		rts_ready = ATMEL_US_RTSDIS;
	} else {
		/* force RTS line to high level */
		rts_paused = ATMEL_US_RTSDIS;

		/* force RTS line to low level */
		rts_ready = ATMEL_US_RTSEN;
	}

424
	if (mctrl & TIOCM_RTS)
425
		control |= rts_ready;
426
	else
427
		control |= rts_paused;
428 429

	if (mctrl & TIOCM_DTR)
430
		control |= ATMEL_US_DTREN;
431
	else
432
		control |= ATMEL_US_DTRDIS;
433

434
	atmel_uart_writel(port, ATMEL_US_CR, control);
435

436 437
	mctrl_gpio_set(atmel_port->gpios, mctrl);

438
	/* Local loopback mode? */
439
	mode &= ~ATMEL_US_CHMODE;
440
	if (mctrl & TIOCM_LOOP)
441
		mode |= ATMEL_US_CHMODE_LOC_LOOP;
442
	else
443
		mode |= ATMEL_US_CHMODE_NORMAL;
444

445
	atmel_uart_writel(port, ATMEL_US_MR, mode);
446 447 448 449 450
}

/*
 * Get state of the modem control input lines
 */
451
static u_int atmel_get_mctrl(struct uart_port *port)
452
{
453 454
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	unsigned int ret = 0, status;
455

456
	status = atmel_uart_readl(port, ATMEL_US_CSR);
457 458 459 460

	/*
	 * The control signals are active low.
	 */
461
	if (!(status & ATMEL_US_DCD))
462
		ret |= TIOCM_CD;
463
	if (!(status & ATMEL_US_CTS))
464
		ret |= TIOCM_CTS;
465
	if (!(status & ATMEL_US_DSR))
466
		ret |= TIOCM_DSR;
467
	if (!(status & ATMEL_US_RI))
468 469
		ret |= TIOCM_RI;

470
	return mctrl_gpio_get(atmel_port->gpios, &ret);
471 472 473 474 475
}

/*
 * Stop transmitting.
 */
476
static void atmel_stop_tx(struct uart_port *port)
477
{
478 479
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

480
	if (atmel_use_pdc_tx(port)) {
C
Chip Coldwell 已提交
481
		/* disable PDC transmit */
482
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTDIS);
483 484
	}
	/* Disable interrupts */
485
	atmel_uart_writel(port, ATMEL_US_IDR, atmel_port->tx_done_mask);
486

487 488
	if ((port->rs485.flags & SER_RS485_ENABLED) &&
	    !(port->rs485.flags & SER_RS485_RX_DURING_TX))
489
		atmel_start_rx(port);
490 491 492 493 494
}

/*
 * Start transmitting.
 */
495
static void atmel_start_tx(struct uart_port *port)
496
{
497 498
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

499 500 501 502 503
	if (atmel_use_pdc_tx(port) && (atmel_uart_readl(port, ATMEL_PDC_PTSR)
				       & ATMEL_PDC_TXTEN))
		/* The transmitter is already running.  Yes, we
		   really need this.*/
		return;
C
Chip Coldwell 已提交
504

505
	if (atmel_use_pdc_tx(port) || atmel_use_dma_tx(port))
506 507
		if ((port->rs485.flags & SER_RS485_ENABLED) &&
		    !(port->rs485.flags & SER_RS485_RX_DURING_TX))
508 509
			atmel_stop_rx(port);

510
	if (atmel_use_pdc_tx(port))
C
Chip Coldwell 已提交
511
		/* re-enable PDC transmit */
512
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTEN);
513

514
	/* Enable interrupts */
515
	atmel_uart_writel(port, ATMEL_US_IER, atmel_port->tx_done_mask);
516 517 518 519 520 521 522
}

/*
 * start receiving - port is in process of being opened.
 */
static void atmel_start_rx(struct uart_port *port)
{
523 524
	/* reset status and receiver */
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
525

526
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RXEN);
527

528
	if (atmel_use_pdc_rx(port)) {
529
		/* enable PDC controller */
530 531 532 533
		atmel_uart_writel(port, ATMEL_US_IER,
				  ATMEL_US_ENDRX | ATMEL_US_TIMEOUT |
				  port->read_status_mask);
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_RXTEN);
534
	} else {
535
		atmel_uart_writel(port, ATMEL_US_IER, ATMEL_US_RXRDY);
536
	}
537 538 539 540 541
}

/*
 * Stop receiving - port is in process of being closed.
 */
542
static void atmel_stop_rx(struct uart_port *port)
543
{
544
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RXDIS);
545

546
	if (atmel_use_pdc_rx(port)) {
C
Chip Coldwell 已提交
547
		/* disable PDC receive */
548 549 550 551
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_RXTDIS);
		atmel_uart_writel(port, ATMEL_US_IDR,
				  ATMEL_US_ENDRX | ATMEL_US_TIMEOUT |
				  port->read_status_mask);
552
	} else {
553
		atmel_uart_writel(port, ATMEL_US_IDR, ATMEL_US_RXRDY);
554
	}
555 556 557 558 559
}

/*
 * Enable modem status interrupts
 */
560
static void atmel_enable_ms(struct uart_port *port)
561
{
562 563 564 565 566 567 568 569 570 571 572
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	uint32_t ier = 0;

	/*
	 * Interrupt should not be enabled twice
	 */
	if (atmel_port->ms_irq_enabled)
		return;

	atmel_port->ms_irq_enabled = true;

573
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_CTS))
574 575
		ier |= ATMEL_US_CTSIC;

576
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_DSR))
577 578
		ier |= ATMEL_US_DSRIC;

579
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_RI))
580 581
		ier |= ATMEL_US_RIIC;

582
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_DCD))
583 584
		ier |= ATMEL_US_DCDIC;

585
	atmel_uart_writel(port, ATMEL_US_IER, ier);
586 587

	mctrl_gpio_enable_ms(atmel_port->gpios);
588 589
}

590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605
/*
 * Disable modem status interrupts
 */
static void atmel_disable_ms(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	uint32_t idr = 0;

	/*
	 * Interrupt should not be disabled twice
	 */
	if (!atmel_port->ms_irq_enabled)
		return;

	atmel_port->ms_irq_enabled = false;

606 607 608
	mctrl_gpio_disable_ms(atmel_port->gpios);

	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_CTS))
609 610
		idr |= ATMEL_US_CTSIC;

611
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_DSR))
612 613
		idr |= ATMEL_US_DSRIC;

614
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_RI))
615 616
		idr |= ATMEL_US_RIIC;

617
	if (!mctrl_gpio_to_gpiod(atmel_port->gpios, UART_GPIO_DCD))
618 619
		idr |= ATMEL_US_DCDIC;

620
	atmel_uart_writel(port, ATMEL_US_IDR, idr);
621 622
}

623 624 625
/*
 * Control the transmission of a break signal
 */
626
static void atmel_break_ctl(struct uart_port *port, int break_state)
627 628
{
	if (break_state != 0)
629 630
		/* start break */
		atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STTBRK);
631
	else
632 633
		/* stop break */
		atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STPBRK);
634 635
}

636 637 638 639 640 641 642
/*
 * Stores the incoming character in the ring buffer
 */
static void
atmel_buffer_rx_char(struct uart_port *port, unsigned int status,
		     unsigned int ch)
{
643
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660
	struct circ_buf *ring = &atmel_port->rx_ring;
	struct atmel_uart_char *c;

	if (!CIRC_SPACE(ring->head, ring->tail, ATMEL_SERIAL_RINGSIZE))
		/* Buffer overflow, ignore char */
		return;

	c = &((struct atmel_uart_char *)ring->buf)[ring->head];
	c->status	= status;
	c->ch		= ch;

	/* Make sure the character is stored before we update head. */
	smp_wmb();

	ring->head = (ring->head + 1) & (ATMEL_SERIAL_RINGSIZE - 1);
}

C
Chip Coldwell 已提交
661 662 663 664 665 666
/*
 * Deal with parity, framing and overrun errors.
 */
static void atmel_pdc_rxerr(struct uart_port *port, unsigned int status)
{
	/* clear error */
667
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
C
Chip Coldwell 已提交
668 669 670 671 672 673 674 675 676 677 678 679 680 681

	if (status & ATMEL_US_RXBRK) {
		/* ignore side-effect */
		status &= ~(ATMEL_US_PARE | ATMEL_US_FRAME);
		port->icount.brk++;
	}
	if (status & ATMEL_US_PARE)
		port->icount.parity++;
	if (status & ATMEL_US_FRAME)
		port->icount.frame++;
	if (status & ATMEL_US_OVRE)
		port->icount.overrun++;
}

682 683 684
/*
 * Characters received (called from interrupt handler)
 */
685
static void atmel_rx_chars(struct uart_port *port)
686
{
687
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
688
	unsigned int status, ch;
689

690
	status = atmel_uart_readl(port, ATMEL_US_CSR);
691
	while (status & ATMEL_US_RXRDY) {
692
		ch = atmel_uart_read_char(port);
693 694 695 696 697

		/*
		 * note that the error handling code is
		 * out of the main execution path
		 */
698 699 700
		if (unlikely(status & (ATMEL_US_PARE | ATMEL_US_FRAME
				       | ATMEL_US_OVRE | ATMEL_US_RXBRK)
			     || atmel_port->break_active)) {
701

R
Remy Bohmer 已提交
702
			/* clear error */
703
			atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
704

705 706 707
			if (status & ATMEL_US_RXBRK
			    && !atmel_port->break_active) {
				atmel_port->break_active = 1;
708 709
				atmel_uart_writel(port, ATMEL_US_IER,
						  ATMEL_US_RXBRK);
710 711 712 713 714 715 716 717
			} else {
				/*
				 * This is either the end-of-break
				 * condition or we've received at
				 * least one character without RXBRK
				 * being set. In both cases, the next
				 * RXBRK will indicate start-of-break.
				 */
718 719
				atmel_uart_writel(port, ATMEL_US_IDR,
						  ATMEL_US_RXBRK);
720 721
				status &= ~ATMEL_US_RXBRK;
				atmel_port->break_active = 0;
722
			}
723 724
		}

725
		atmel_buffer_rx_char(port, status, ch);
726
		status = atmel_uart_readl(port, ATMEL_US_CSR);
727 728
	}

729
	atmel_tasklet_schedule(atmel_port, &atmel_port->tasklet_rx);
730 731 732
}

/*
733 734
 * Transmit characters (called from tasklet with TXRDY interrupt
 * disabled)
735
 */
736
static void atmel_tx_chars(struct uart_port *port)
737
{
A
Alan Cox 已提交
738
	struct circ_buf *xmit = &port->state->xmit;
739
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
740

741 742
	if (port->x_char &&
	    (atmel_uart_readl(port, ATMEL_US_CSR) & atmel_port->tx_done_mask)) {
743
		atmel_uart_write_char(port, port->x_char);
744 745 746
		port->icount.tx++;
		port->x_char = 0;
	}
747
	if (uart_circ_empty(xmit) || uart_tx_stopped(port))
748 749
		return;

750 751
	while (atmel_uart_readl(port, ATMEL_US_CSR) &
	       atmel_port->tx_done_mask) {
752
		atmel_uart_write_char(port, xmit->buf[xmit->tail]);
753 754 755 756 757 758 759 760 761
		xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1);
		port->icount.tx++;
		if (uart_circ_empty(xmit))
			break;
	}

	if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
		uart_write_wakeup(port);

762
	if (!uart_circ_empty(xmit))
763
		/* Enable interrupts */
764 765
		atmel_uart_writel(port, ATMEL_US_IER,
				  atmel_port->tx_done_mask);
766 767
}

E
Elen Song 已提交
768 769 770 771 772 773 774 775 776 777 778 779
static void atmel_complete_tx_dma(void *arg)
{
	struct atmel_uart_port *atmel_port = arg;
	struct uart_port *port = &atmel_port->uart;
	struct circ_buf *xmit = &port->state->xmit;
	struct dma_chan *chan = atmel_port->chan_tx;
	unsigned long flags;

	spin_lock_irqsave(&port->lock, flags);

	if (chan)
		dmaengine_terminate_all(chan);
780
	xmit->tail += atmel_port->tx_len;
E
Elen Song 已提交
781 782
	xmit->tail &= UART_XMIT_SIZE - 1;

783
	port->icount.tx += atmel_port->tx_len;
E
Elen Song 已提交
784 785 786 787 788 789 790 791 792 793

	spin_lock_irq(&atmel_port->lock_tx);
	async_tx_ack(atmel_port->desc_tx);
	atmel_port->cookie_tx = -EINVAL;
	atmel_port->desc_tx = NULL;
	spin_unlock_irq(&atmel_port->lock_tx);

	if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
		uart_write_wakeup(port);

794 795 796 797 798
	/*
	 * xmit is a circular buffer so, if we have just send data from
	 * xmit->tail to the end of xmit->buf, now we have to transmit the
	 * remaining data from the beginning of xmit->buf to xmit->head.
	 */
E
Elen Song 已提交
799
	if (!uart_circ_empty(xmit))
800
		atmel_tasklet_schedule(atmel_port, &atmel_port->tasklet_tx);
E
Elen Song 已提交
801 802 803 804 805 806 807 808 809 810 811 812 813

	spin_unlock_irqrestore(&port->lock, flags);
}

static void atmel_release_tx_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct dma_chan *chan = atmel_port->chan_tx;

	if (chan) {
		dmaengine_terminate_all(chan);
		dma_release_channel(chan);
		dma_unmap_sg(port->dev, &atmel_port->sg_tx, 1,
814
				DMA_TO_DEVICE);
E
Elen Song 已提交
815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830
	}

	atmel_port->desc_tx = NULL;
	atmel_port->chan_tx = NULL;
	atmel_port->cookie_tx = -EINVAL;
}

/*
 * Called from tasklet with TXRDY interrupt is disabled.
 */
static void atmel_tx_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct circ_buf *xmit = &port->state->xmit;
	struct dma_chan *chan = atmel_port->chan_tx;
	struct dma_async_tx_descriptor *desc;
831 832 833
	struct scatterlist sgl[2], *sg, *sg_tx = &atmel_port->sg_tx;
	unsigned int tx_len, part1_len, part2_len, sg_len;
	dma_addr_t phys_addr;
E
Elen Song 已提交
834 835 836 837 838 839 840 841 842 843 844 845 846 847 848

	/* Make sure we have an idle channel */
	if (atmel_port->desc_tx != NULL)
		return;

	if (!uart_circ_empty(xmit) && !uart_tx_stopped(port)) {
		/*
		 * DMA is idle now.
		 * Port xmit buffer is already mapped,
		 * and it is one page... Just adjust
		 * offsets and lengths. Since it is a circular buffer,
		 * we have to transmit till the end, and then the rest.
		 * Take the port lock to get a
		 * consistent xmit buffer state.
		 */
849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884
		tx_len = CIRC_CNT_TO_END(xmit->head,
					 xmit->tail,
					 UART_XMIT_SIZE);

		if (atmel_port->fifo_size) {
			/* multi data mode */
			part1_len = (tx_len & ~0x3); /* DWORD access */
			part2_len = (tx_len & 0x3); /* BYTE access */
		} else {
			/* single data (legacy) mode */
			part1_len = 0;
			part2_len = tx_len; /* BYTE access only */
		}

		sg_init_table(sgl, 2);
		sg_len = 0;
		phys_addr = sg_dma_address(sg_tx) + xmit->tail;
		if (part1_len) {
			sg = &sgl[sg_len++];
			sg_dma_address(sg) = phys_addr;
			sg_dma_len(sg) = part1_len;

			phys_addr += part1_len;
		}

		if (part2_len) {
			sg = &sgl[sg_len++];
			sg_dma_address(sg) = phys_addr;
			sg_dma_len(sg) = part2_len;
		}

		/*
		 * save tx_len so atmel_complete_tx_dma() will increase
		 * xmit->tail correctly
		 */
		atmel_port->tx_len = tx_len;
E
Elen Song 已提交
885 886

		desc = dmaengine_prep_slave_sg(chan,
887 888
					       sgl,
					       sg_len,
889 890 891
					       DMA_MEM_TO_DEV,
					       DMA_PREP_INTERRUPT |
					       DMA_CTRL_ACK);
E
Elen Song 已提交
892 893 894 895 896
		if (!desc) {
			dev_err(port->dev, "Failed to send via dma!\n");
			return;
		}

897
		dma_sync_sg_for_device(port->dev, sg_tx, 1, DMA_TO_DEVICE);
E
Elen Song 已提交
898 899 900 901 902 903 904

		atmel_port->desc_tx = desc;
		desc->callback = atmel_complete_tx_dma;
		desc->callback_param = atmel_port;
		atmel_port->cookie_tx = dmaengine_submit(desc);

	} else {
905
		if (port->rs485.flags & SER_RS485_ENABLED) {
E
Elen Song 已提交
906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933
			/* DMA done, stop TX, start RX for RS485 */
			atmel_start_rx(port);
		}
	}

	if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
		uart_write_wakeup(port);
}

static int atmel_prepare_tx_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	dma_cap_mask_t		mask;
	struct dma_slave_config config;
	int ret, nent;

	dma_cap_zero(mask);
	dma_cap_set(DMA_SLAVE, mask);

	atmel_port->chan_tx = dma_request_slave_channel(port->dev, "tx");
	if (atmel_port->chan_tx == NULL)
		goto chan_err;
	dev_info(port->dev, "using %s for tx DMA transfers\n",
		dma_chan_name(atmel_port->chan_tx));

	spin_lock_init(&atmel_port->lock_tx);
	sg_init_table(&atmel_port->sg_tx, 1);
	/* UART circular tx buffer is an aligned page. */
934
	BUG_ON(!PAGE_ALIGNED(port->state->xmit.buf));
E
Elen Song 已提交
935 936 937
	sg_set_page(&atmel_port->sg_tx,
			virt_to_page(port->state->xmit.buf),
			UART_XMIT_SIZE,
938
			(unsigned long)port->state->xmit.buf & ~PAGE_MASK);
E
Elen Song 已提交
939 940 941
	nent = dma_map_sg(port->dev,
				&atmel_port->sg_tx,
				1,
942
				DMA_TO_DEVICE);
E
Elen Song 已提交
943 944 945 946 947

	if (!nent) {
		dev_dbg(port->dev, "need to release resource of dma\n");
		goto chan_err;
	} else {
948
		dev_dbg(port->dev, "%s: mapped %d@%p to %pad\n", __func__,
E
Elen Song 已提交
949 950
			sg_dma_len(&atmel_port->sg_tx),
			port->state->xmit.buf,
951
			&sg_dma_address(&atmel_port->sg_tx));
E
Elen Song 已提交
952 953 954 955 956
	}

	/* Configure the slave DMA */
	memset(&config, 0, sizeof(config));
	config.direction = DMA_MEM_TO_DEV;
957 958 959
	config.dst_addr_width = (atmel_port->fifo_size) ?
				DMA_SLAVE_BUSWIDTH_4_BYTES :
				DMA_SLAVE_BUSWIDTH_1_BYTE;
E
Elen Song 已提交
960
	config.dst_addr = port->mapbase + ATMEL_US_THR;
961
	config.dst_maxburst = 1;
E
Elen Song 已提交
962

963 964
	ret = dmaengine_slave_config(atmel_port->chan_tx,
				     &config);
E
Elen Song 已提交
965 966 967 968 969 970 971 972 973 974 975 976 977 978 979
	if (ret) {
		dev_err(port->dev, "DMA tx slave configuration failed\n");
		goto chan_err;
	}

	return 0;

chan_err:
	dev_err(port->dev, "TX channel not available, switch to pio\n");
	atmel_port->use_dma_tx = 0;
	if (atmel_port->chan_tx)
		atmel_release_tx_dma(port);
	return -EINVAL;
}

E
Elen Song 已提交
980 981 982 983 984
static void atmel_complete_rx_dma(void *arg)
{
	struct uart_port *port = arg;
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

985
	atmel_tasklet_schedule(atmel_port, &atmel_port->tasklet_rx);
E
Elen Song 已提交
986 987 988 989 990 991 992 993 994 995 996
}

static void atmel_release_rx_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct dma_chan *chan = atmel_port->chan_rx;

	if (chan) {
		dmaengine_terminate_all(chan);
		dma_release_channel(chan);
		dma_unmap_sg(port->dev, &atmel_port->sg_rx, 1,
997
				DMA_FROM_DEVICE);
E
Elen Song 已提交
998 999 1000 1001 1002 1003 1004 1005 1006 1007
	}

	atmel_port->desc_rx = NULL;
	atmel_port->chan_rx = NULL;
	atmel_port->cookie_rx = -EINVAL;
}

static void atmel_rx_from_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1008
	struct tty_port *tport = &port->state->port;
E
Elen Song 已提交
1009 1010 1011 1012
	struct circ_buf *ring = &atmel_port->rx_ring;
	struct dma_chan *chan = atmel_port->chan_rx;
	struct dma_tx_state state;
	enum dma_status dmastat;
1013
	size_t count;
E
Elen Song 已提交
1014 1015 1016


	/* Reset the UART timeout early so that we don't miss one */
1017
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STTTO);
E
Elen Song 已提交
1018 1019 1020 1021 1022 1023
	dmastat = dmaengine_tx_status(chan,
				atmel_port->cookie_rx,
				&state);
	/* Restart a new tasklet if DMA status is error */
	if (dmastat == DMA_ERROR) {
		dev_dbg(port->dev, "Get residue error, restart tasklet\n");
1024
		atmel_uart_writel(port, ATMEL_US_IER, ATMEL_US_TIMEOUT);
1025
		atmel_tasklet_schedule(atmel_port, &atmel_port->tasklet_rx);
E
Elen Song 已提交
1026 1027 1028
		return;
	}

1029 1030 1031 1032
	/* CPU claims ownership of RX DMA buffer */
	dma_sync_sg_for_cpu(port->dev,
			    &atmel_port->sg_rx,
			    1,
1033
			    DMA_FROM_DEVICE);
1034 1035 1036 1037 1038 1039 1040 1041 1042 1043

	/*
	 * ring->head points to the end of data already written by the DMA.
	 * ring->tail points to the beginning of data to be read by the
	 * framework.
	 * The current transfer size should not be larger than the dma buffer
	 * length.
	 */
	ring->head = sg_dma_len(&atmel_port->sg_rx) - state.residue;
	BUG_ON(ring->head > sg_dma_len(&atmel_port->sg_rx));
E
Elen Song 已提交
1044
	/*
1045 1046 1047 1048 1049 1050 1051 1052 1053 1054
	 * At this point ring->head may point to the first byte right after the
	 * last byte of the dma buffer:
	 * 0 <= ring->head <= sg_dma_len(&atmel_port->sg_rx)
	 *
	 * However ring->tail must always points inside the dma buffer:
	 * 0 <= ring->tail <= sg_dma_len(&atmel_port->sg_rx) - 1
	 *
	 * Since we use a ring buffer, we have to handle the case
	 * where head is lower than tail. In such a case, we first read from
	 * tail to the end of the buffer then reset tail.
E
Elen Song 已提交
1055
	 */
1056 1057
	if (ring->head < ring->tail) {
		count = sg_dma_len(&atmel_port->sg_rx) - ring->tail;
E
Elen Song 已提交
1058

1059 1060 1061 1062
		tty_insert_flip_string(tport, ring->buf + ring->tail, count);
		ring->tail = 0;
		port->icount.rx += count;
	}
E
Elen Song 已提交
1063

1064 1065 1066
	/* Finally we read data from tail to head */
	if (ring->tail < ring->head) {
		count = ring->head - ring->tail;
E
Elen Song 已提交
1067

1068 1069 1070 1071 1072
		tty_insert_flip_string(tport, ring->buf + ring->tail, count);
		/* Wrap ring->head if needed */
		if (ring->head >= sg_dma_len(&atmel_port->sg_rx))
			ring->head = 0;
		ring->tail = ring->head;
E
Elen Song 已提交
1073 1074 1075
		port->icount.rx += count;
	}

1076 1077 1078 1079
	/* USART retreives ownership of RX DMA buffer */
	dma_sync_sg_for_device(port->dev,
			       &atmel_port->sg_rx,
			       1,
1080
			       DMA_FROM_DEVICE);
1081 1082 1083 1084 1085 1086 1087 1088 1089

	/*
	 * Drop the lock here since it might end up calling
	 * uart_start(), which takes the lock.
	 */
	spin_unlock(&port->lock);
	tty_flip_buffer_push(tport);
	spin_lock(&port->lock);

1090
	atmel_uart_writel(port, ATMEL_US_IER, ATMEL_US_TIMEOUT);
E
Elen Song 已提交
1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115
}

static int atmel_prepare_rx_dma(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct dma_async_tx_descriptor *desc;
	dma_cap_mask_t		mask;
	struct dma_slave_config config;
	struct circ_buf		*ring;
	int ret, nent;

	ring = &atmel_port->rx_ring;

	dma_cap_zero(mask);
	dma_cap_set(DMA_CYCLIC, mask);

	atmel_port->chan_rx = dma_request_slave_channel(port->dev, "rx");
	if (atmel_port->chan_rx == NULL)
		goto chan_err;
	dev_info(port->dev, "using %s for rx DMA transfers\n",
		dma_chan_name(atmel_port->chan_rx));

	spin_lock_init(&atmel_port->lock_rx);
	sg_init_table(&atmel_port->sg_rx, 1);
	/* UART circular rx buffer is an aligned page. */
1116
	BUG_ON(!PAGE_ALIGNED(ring->buf));
E
Elen Song 已提交
1117
	sg_set_page(&atmel_port->sg_rx,
1118
		    virt_to_page(ring->buf),
1119
		    sizeof(struct atmel_uart_char) * ATMEL_SERIAL_RINGSIZE,
1120
		    (unsigned long)ring->buf & ~PAGE_MASK);
1121 1122 1123 1124
	nent = dma_map_sg(port->dev,
			  &atmel_port->sg_rx,
			  1,
			  DMA_FROM_DEVICE);
E
Elen Song 已提交
1125 1126 1127 1128 1129

	if (!nent) {
		dev_dbg(port->dev, "need to release resource of dma\n");
		goto chan_err;
	} else {
1130
		dev_dbg(port->dev, "%s: mapped %d@%p to %pad\n", __func__,
E
Elen Song 已提交
1131 1132
			sg_dma_len(&atmel_port->sg_rx),
			ring->buf,
1133
			&sg_dma_address(&atmel_port->sg_rx));
E
Elen Song 已提交
1134 1135 1136 1137 1138 1139 1140
	}

	/* Configure the slave DMA */
	memset(&config, 0, sizeof(config));
	config.direction = DMA_DEV_TO_MEM;
	config.src_addr_width = DMA_SLAVE_BUSWIDTH_1_BYTE;
	config.src_addr = port->mapbase + ATMEL_US_RHR;
1141
	config.src_maxburst = 1;
E
Elen Song 已提交
1142

1143 1144
	ret = dmaengine_slave_config(atmel_port->chan_rx,
				     &config);
E
Elen Song 已提交
1145 1146 1147 1148 1149 1150 1151 1152 1153
	if (ret) {
		dev_err(port->dev, "DMA rx slave configuration failed\n");
		goto chan_err;
	}
	/*
	 * Prepare a cyclic dma transfer, assign 2 descriptors,
	 * each one is half ring buffer size
	 */
	desc = dmaengine_prep_dma_cyclic(atmel_port->chan_rx,
1154 1155 1156 1157 1158
					 sg_dma_address(&atmel_port->sg_rx),
					 sg_dma_len(&atmel_port->sg_rx),
					 sg_dma_len(&atmel_port->sg_rx)/2,
					 DMA_DEV_TO_MEM,
					 DMA_PREP_INTERRUPT);
E
Elen Song 已提交
1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173
	desc->callback = atmel_complete_rx_dma;
	desc->callback_param = port;
	atmel_port->desc_rx = desc;
	atmel_port->cookie_rx = dmaengine_submit(desc);

	return 0;

chan_err:
	dev_err(port->dev, "RX channel not available, switch to pio\n");
	atmel_port->use_dma_rx = 0;
	if (atmel_port->chan_rx)
		atmel_release_rx_dma(port);
	return -EINVAL;
}

1174 1175 1176 1177 1178
static void atmel_uart_timer_callback(unsigned long data)
{
	struct uart_port *port = (void *)data;
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

1179 1180 1181 1182 1183
	if (!atomic_read(&atmel_port->tasklet_shutdown)) {
		tasklet_schedule(&atmel_port->tasklet_rx);
		mod_timer(&atmel_port->uart_timer,
			  jiffies + uart_poll_timeout(port));
	}
1184 1185
}

R
Remy Bohmer 已提交
1186 1187 1188 1189 1190 1191
/*
 * receive interrupt handler.
 */
static void
atmel_handle_receive(struct uart_port *port, unsigned int pending)
{
1192
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
R
Remy Bohmer 已提交
1193

1194
	if (atmel_use_pdc_rx(port)) {
C
Chip Coldwell 已提交
1195 1196 1197 1198 1199 1200 1201 1202
		/*
		 * PDC receive. Just schedule the tasklet and let it
		 * figure out the details.
		 *
		 * TODO: We're not handling error flags correctly at
		 * the moment.
		 */
		if (pending & (ATMEL_US_ENDRX | ATMEL_US_TIMEOUT)) {
1203 1204
			atmel_uart_writel(port, ATMEL_US_IDR,
					  (ATMEL_US_ENDRX | ATMEL_US_TIMEOUT));
1205 1206
			atmel_tasklet_schedule(atmel_port,
					       &atmel_port->tasklet_rx);
C
Chip Coldwell 已提交
1207 1208 1209 1210 1211 1212 1213
		}

		if (pending & (ATMEL_US_RXBRK | ATMEL_US_OVRE |
				ATMEL_US_FRAME | ATMEL_US_PARE))
			atmel_pdc_rxerr(port, pending);
	}

E
Elen Song 已提交
1214 1215
	if (atmel_use_dma_rx(port)) {
		if (pending & ATMEL_US_TIMEOUT) {
1216 1217
			atmel_uart_writel(port, ATMEL_US_IDR,
					  ATMEL_US_TIMEOUT);
1218 1219
			atmel_tasklet_schedule(atmel_port,
					       &atmel_port->tasklet_rx);
E
Elen Song 已提交
1220 1221 1222
		}
	}

R
Remy Bohmer 已提交
1223 1224 1225 1226 1227 1228 1229 1230
	/* Interrupt receive */
	if (pending & ATMEL_US_RXRDY)
		atmel_rx_chars(port);
	else if (pending & ATMEL_US_RXBRK) {
		/*
		 * End of break detected. If it came along with a
		 * character, atmel_rx_chars will handle it.
		 */
1231 1232
		atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
		atmel_uart_writel(port, ATMEL_US_IDR, ATMEL_US_RXBRK);
R
Remy Bohmer 已提交
1233 1234 1235 1236 1237
		atmel_port->break_active = 0;
	}
}

/*
1238
 * transmit interrupt handler. (Transmit is IRQF_NODELAY safe)
R
Remy Bohmer 已提交
1239 1240 1241 1242
 */
static void
atmel_handle_transmit(struct uart_port *port, unsigned int pending)
{
1243
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1244

1245 1246
	if (pending & atmel_port->tx_done_mask) {
		/* Either PDC or interrupt transmission */
1247 1248
		atmel_uart_writel(port, ATMEL_US_IDR,
				  atmel_port->tx_done_mask);
1249
		atmel_tasklet_schedule(atmel_port, &atmel_port->tasklet_tx);
1250
	}
R
Remy Bohmer 已提交
1251 1252 1253 1254 1255 1256 1257 1258 1259
}

/*
 * status flags interrupt handler.
 */
static void
atmel_handle_status(struct uart_port *port, unsigned int pending,
		    unsigned int status)
{
1260
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1261
	unsigned int status_change;
1262

R
Remy Bohmer 已提交
1263
	if (pending & (ATMEL_US_RIIC | ATMEL_US_DSRIC | ATMEL_US_DCDIC
1264
				| ATMEL_US_CTSIC)) {
1265
		status_change = status ^ atmel_port->irq_status_prev;
1266
		atmel_port->irq_status_prev = status;
1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281

		if (status_change & (ATMEL_US_RI | ATMEL_US_DSR
					| ATMEL_US_DCD | ATMEL_US_CTS)) {
			/* TODO: All reads to CSR will clear these interrupts! */
			if (status_change & ATMEL_US_RI)
				port->icount.rng++;
			if (status_change & ATMEL_US_DSR)
				port->icount.dsr++;
			if (status_change & ATMEL_US_DCD)
				uart_handle_dcd_change(port, !(status & ATMEL_US_DCD));
			if (status_change & ATMEL_US_CTS)
				uart_handle_cts_change(port, !(status & ATMEL_US_CTS));

			wake_up_interruptible(&port->state->port.delta_msr_wait);
		}
1282
	}
R
Remy Bohmer 已提交
1283 1284
}

1285 1286 1287
/*
 * Interrupt handler
 */
1288
static irqreturn_t atmel_interrupt(int irq, void *dev_id)
1289 1290
{
	struct uart_port *port = dev_id;
1291
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1292
	unsigned int status, pending, mask, pass_counter = 0;
1293

1294 1295
	spin_lock(&atmel_port->lock_suspended);

C
Chip Coldwell 已提交
1296
	do {
1297
		status = atmel_get_lines_status(port);
1298
		mask = atmel_uart_readl(port, ATMEL_US_IMR);
1299
		pending = status & mask;
C
Chip Coldwell 已提交
1300 1301 1302
		if (!pending)
			break;

1303 1304 1305
		if (atmel_port->suspended) {
			atmel_port->pending |= pending;
			atmel_port->pending_status = status;
1306
			atmel_uart_writel(port, ATMEL_US_IDR, mask);
1307 1308 1309 1310
			pm_system_wakeup();
			break;
		}

R
Remy Bohmer 已提交
1311 1312 1313
		atmel_handle_receive(port, pending);
		atmel_handle_status(port, pending, status);
		atmel_handle_transmit(port, pending);
C
Chip Coldwell 已提交
1314
	} while (pass_counter++ < ATMEL_ISR_PASS_LIMIT);
1315

1316 1317
	spin_unlock(&atmel_port->lock_suspended);

1318
	return pass_counter ? IRQ_HANDLED : IRQ_NONE;
C
Chip Coldwell 已提交
1319
}
1320

1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331
static void atmel_release_tx_pdc(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct atmel_dma_buffer *pdc = &atmel_port->pdc_tx;

	dma_unmap_single(port->dev,
			 pdc->dma_addr,
			 pdc->dma_size,
			 DMA_TO_DEVICE);
}

C
Chip Coldwell 已提交
1332 1333 1334
/*
 * Called from tasklet with ENDTX and TXBUFE interrupts disabled.
 */
1335
static void atmel_tx_pdc(struct uart_port *port)
C
Chip Coldwell 已提交
1336
{
1337
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
A
Alan Cox 已提交
1338
	struct circ_buf *xmit = &port->state->xmit;
C
Chip Coldwell 已提交
1339 1340 1341
	struct atmel_dma_buffer *pdc = &atmel_port->pdc_tx;
	int count;

1342
	/* nothing left to transmit? */
1343
	if (atmel_uart_readl(port, ATMEL_PDC_TCR))
1344 1345
		return;

C
Chip Coldwell 已提交
1346 1347 1348 1349 1350 1351
	xmit->tail += pdc->ofs;
	xmit->tail &= UART_XMIT_SIZE - 1;

	port->icount.tx += pdc->ofs;
	pdc->ofs = 0;

1352
	/* more to transmit - setup next transfer */
C
Chip Coldwell 已提交
1353

1354
	/* disable PDC transmit */
1355
	atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTDIS);
1356

I
Itai Levi 已提交
1357
	if (!uart_circ_empty(xmit) && !uart_tx_stopped(port)) {
C
Chip Coldwell 已提交
1358 1359 1360 1361 1362 1363 1364 1365
		dma_sync_single_for_device(port->dev,
					   pdc->dma_addr,
					   pdc->dma_size,
					   DMA_TO_DEVICE);

		count = CIRC_CNT_TO_END(xmit->head, xmit->tail, UART_XMIT_SIZE);
		pdc->ofs = count;

1366 1367 1368
		atmel_uart_writel(port, ATMEL_PDC_TPR,
				  pdc->dma_addr + xmit->tail);
		atmel_uart_writel(port, ATMEL_PDC_TCR, count);
1369
		/* re-enable PDC transmit */
1370
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTEN);
1371
		/* Enable interrupts */
1372 1373
		atmel_uart_writel(port, ATMEL_US_IER,
				  atmel_port->tx_done_mask);
1374
	} else {
1375 1376
		if ((port->rs485.flags & SER_RS485_ENABLED) &&
		    !(port->rs485.flags & SER_RS485_RX_DURING_TX)) {
1377 1378 1379
			/* DMA done, stop TX, start RX for RS485 */
			atmel_start_rx(port);
		}
1380
	}
C
Chip Coldwell 已提交
1381 1382 1383

	if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
		uart_write_wakeup(port);
1384 1385
}

1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402
static int atmel_prepare_tx_pdc(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	struct atmel_dma_buffer *pdc = &atmel_port->pdc_tx;
	struct circ_buf *xmit = &port->state->xmit;

	pdc->buf = xmit->buf;
	pdc->dma_addr = dma_map_single(port->dev,
					pdc->buf,
					UART_XMIT_SIZE,
					DMA_TO_DEVICE);
	pdc->dma_size = UART_XMIT_SIZE;
	pdc->ofs = 0;

	return 0;
}

1403 1404
static void atmel_rx_from_ring(struct uart_port *port)
{
1405
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466
	struct circ_buf *ring = &atmel_port->rx_ring;
	unsigned int flg;
	unsigned int status;

	while (ring->head != ring->tail) {
		struct atmel_uart_char c;

		/* Make sure c is loaded after head. */
		smp_rmb();

		c = ((struct atmel_uart_char *)ring->buf)[ring->tail];

		ring->tail = (ring->tail + 1) & (ATMEL_SERIAL_RINGSIZE - 1);

		port->icount.rx++;
		status = c.status;
		flg = TTY_NORMAL;

		/*
		 * note that the error handling code is
		 * out of the main execution path
		 */
		if (unlikely(status & (ATMEL_US_PARE | ATMEL_US_FRAME
				       | ATMEL_US_OVRE | ATMEL_US_RXBRK))) {
			if (status & ATMEL_US_RXBRK) {
				/* ignore side-effect */
				status &= ~(ATMEL_US_PARE | ATMEL_US_FRAME);

				port->icount.brk++;
				if (uart_handle_break(port))
					continue;
			}
			if (status & ATMEL_US_PARE)
				port->icount.parity++;
			if (status & ATMEL_US_FRAME)
				port->icount.frame++;
			if (status & ATMEL_US_OVRE)
				port->icount.overrun++;

			status &= port->read_status_mask;

			if (status & ATMEL_US_RXBRK)
				flg = TTY_BREAK;
			else if (status & ATMEL_US_PARE)
				flg = TTY_PARITY;
			else if (status & ATMEL_US_FRAME)
				flg = TTY_FRAME;
		}


		if (uart_handle_sysrq_char(port, c.ch))
			continue;

		uart_insert_char(port, status, ATMEL_US_OVRE, c.ch, flg);
	}

	/*
	 * Drop the lock here since it might end up calling
	 * uart_start(), which takes the lock.
	 */
	spin_unlock(&port->lock);
J
Jiri Slaby 已提交
1467
	tty_flip_buffer_push(&port->state->port);
1468 1469 1470
	spin_lock(&port->lock);
}

1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486
static void atmel_release_rx_pdc(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	int i;

	for (i = 0; i < 2; i++) {
		struct atmel_dma_buffer *pdc = &atmel_port->pdc_rx[i];

		dma_unmap_single(port->dev,
				 pdc->dma_addr,
				 pdc->dma_size,
				 DMA_FROM_DEVICE);
		kfree(pdc->buf);
	}
}

1487
static void atmel_rx_from_pdc(struct uart_port *port)
C
Chip Coldwell 已提交
1488
{
1489
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
J
Jiri Slaby 已提交
1490
	struct tty_port *tport = &port->state->port;
C
Chip Coldwell 已提交
1491 1492 1493 1494 1495 1496 1497 1498
	struct atmel_dma_buffer *pdc;
	int rx_idx = atmel_port->pdc_rx_idx;
	unsigned int head;
	unsigned int tail;
	unsigned int count;

	do {
		/* Reset the UART timeout early so that we don't miss one */
1499
		atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STTTO);
C
Chip Coldwell 已提交
1500 1501

		pdc = &atmel_port->pdc_rx[rx_idx];
1502
		head = atmel_uart_readl(port, ATMEL_PDC_RPR) - pdc->dma_addr;
C
Chip Coldwell 已提交
1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528
		tail = pdc->ofs;

		/* If the PDC has switched buffers, RPR won't contain
		 * any address within the current buffer. Since head
		 * is unsigned, we just need a one-way comparison to
		 * find out.
		 *
		 * In this case, we just need to consume the entire
		 * buffer and resubmit it for DMA. This will clear the
		 * ENDRX bit as well, so that we can safely re-enable
		 * all interrupts below.
		 */
		head = min(head, pdc->dma_size);

		if (likely(head != tail)) {
			dma_sync_single_for_cpu(port->dev, pdc->dma_addr,
					pdc->dma_size, DMA_FROM_DEVICE);

			/*
			 * head will only wrap around when we recycle
			 * the DMA buffer, and when that happens, we
			 * explicitly set tail to 0. So head will
			 * always be greater than tail.
			 */
			count = head - tail;

J
Jiri Slaby 已提交
1529 1530
			tty_insert_flip_string(tport, pdc->buf + pdc->ofs,
						count);
C
Chip Coldwell 已提交
1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544

			dma_sync_single_for_device(port->dev, pdc->dma_addr,
					pdc->dma_size, DMA_FROM_DEVICE);

			port->icount.rx += count;
			pdc->ofs = head;
		}

		/*
		 * If the current buffer is full, we need to check if
		 * the next one contains any additional data.
		 */
		if (head >= pdc->dma_size) {
			pdc->ofs = 0;
1545 1546
			atmel_uart_writel(port, ATMEL_PDC_RNPR, pdc->dma_addr);
			atmel_uart_writel(port, ATMEL_PDC_RNCR, pdc->dma_size);
C
Chip Coldwell 已提交
1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557

			rx_idx = !rx_idx;
			atmel_port->pdc_rx_idx = rx_idx;
		}
	} while (head >= pdc->dma_size);

	/*
	 * Drop the lock here since it might end up calling
	 * uart_start(), which takes the lock.
	 */
	spin_unlock(&port->lock);
J
Jiri Slaby 已提交
1558
	tty_flip_buffer_push(tport);
C
Chip Coldwell 已提交
1559 1560
	spin_lock(&port->lock);

1561 1562
	atmel_uart_writel(port, ATMEL_US_IER,
			  ATMEL_US_ENDRX | ATMEL_US_TIMEOUT);
C
Chip Coldwell 已提交
1563 1564
}

1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594
static int atmel_prepare_rx_pdc(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	int i;

	for (i = 0; i < 2; i++) {
		struct atmel_dma_buffer *pdc = &atmel_port->pdc_rx[i];

		pdc->buf = kmalloc(PDC_BUFFER_SIZE, GFP_KERNEL);
		if (pdc->buf == NULL) {
			if (i != 0) {
				dma_unmap_single(port->dev,
					atmel_port->pdc_rx[0].dma_addr,
					PDC_BUFFER_SIZE,
					DMA_FROM_DEVICE);
				kfree(atmel_port->pdc_rx[0].buf);
			}
			atmel_port->use_pdc_rx = 0;
			return -ENOMEM;
		}
		pdc->dma_addr = dma_map_single(port->dev,
						pdc->buf,
						PDC_BUFFER_SIZE,
						DMA_FROM_DEVICE);
		pdc->dma_size = PDC_BUFFER_SIZE;
		pdc->ofs = 0;
	}

	atmel_port->pdc_rx_idx = 0;

1595 1596
	atmel_uart_writel(port, ATMEL_PDC_RPR, atmel_port->pdc_rx[0].dma_addr);
	atmel_uart_writel(port, ATMEL_PDC_RCR, PDC_BUFFER_SIZE);
1597

1598 1599 1600
	atmel_uart_writel(port, ATMEL_PDC_RNPR,
			  atmel_port->pdc_rx[1].dma_addr);
	atmel_uart_writel(port, ATMEL_PDC_RNCR, PDC_BUFFER_SIZE);
1601 1602 1603 1604

	return 0;
}

1605 1606 1607
/*
 * tasklet handling tty stuff outside the interrupt handler.
 */
1608
static void atmel_tasklet_rx_func(unsigned long data)
1609 1610
{
	struct uart_port *port = (struct uart_port *)data;
1611
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1612 1613 1614

	/* The interrupt handler does not take the lock */
	spin_lock(&port->lock);
1615
	atmel_port->schedule_rx(port);
1616 1617
	spin_unlock(&port->lock);
}
1618

1619 1620 1621 1622 1623 1624 1625 1626
static void atmel_tasklet_tx_func(unsigned long data)
{
	struct uart_port *port = (struct uart_port *)data;
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

	/* The interrupt handler does not take the lock */
	spin_lock(&port->lock);
	atmel_port->schedule_tx(port);
1627 1628 1629
	spin_unlock(&port->lock);
}

1630
static void atmel_init_property(struct atmel_uart_port *atmel_port,
1631 1632 1633
				struct platform_device *pdev)
{
	struct device_node *np = pdev->dev.of_node;
J
Jingoo Han 已提交
1634
	struct atmel_uart_data *pdata = dev_get_platdata(&pdev->dev);
1635 1636 1637

	if (np) {
		/* DMA/PDC usage specification */
1638 1639
		if (of_property_read_bool(np, "atmel,use-dma-rx")) {
			if (of_property_read_bool(np, "dmas")) {
1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650
				atmel_port->use_dma_rx  = true;
				atmel_port->use_pdc_rx  = false;
			} else {
				atmel_port->use_dma_rx  = false;
				atmel_port->use_pdc_rx  = true;
			}
		} else {
			atmel_port->use_dma_rx  = false;
			atmel_port->use_pdc_rx  = false;
		}

1651 1652
		if (of_property_read_bool(np, "atmel,use-dma-tx")) {
			if (of_property_read_bool(np, "dmas")) {
1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672
				atmel_port->use_dma_tx  = true;
				atmel_port->use_pdc_tx  = false;
			} else {
				atmel_port->use_dma_tx  = false;
				atmel_port->use_pdc_tx  = true;
			}
		} else {
			atmel_port->use_dma_tx  = false;
			atmel_port->use_pdc_tx  = false;
		}

	} else {
		atmel_port->use_pdc_rx  = pdata->use_dma_rx;
		atmel_port->use_pdc_tx  = pdata->use_dma_tx;
		atmel_port->use_dma_rx  = false;
		atmel_port->use_dma_tx  = false;
	}

}

1673
static void atmel_init_rs485(struct uart_port *port,
1674 1675 1676
				struct platform_device *pdev)
{
	struct device_node *np = pdev->dev.of_node;
J
Jingoo Han 已提交
1677
	struct atmel_uart_data *pdata = dev_get_platdata(&pdev->dev);
1678 1679

	if (np) {
J
Jiri Slaby 已提交
1680
		struct serial_rs485 *rs485conf = &port->rs485;
1681 1682 1683 1684 1685 1686 1687
		u32 rs485_delay[2];
		/* rs485 properties */
		if (of_property_read_u32_array(np, "rs485-rts-delay",
					rs485_delay, 2) == 0) {
			rs485conf->delay_rts_before_send = rs485_delay[0];
			rs485conf->delay_rts_after_send = rs485_delay[1];
			rs485conf->flags = 0;
J
Jiri Slaby 已提交
1688
		}
1689 1690 1691 1692 1693 1694 1695 1696

		if (of_get_property(np, "rs485-rx-during-tx", NULL))
			rs485conf->flags |= SER_RS485_RX_DURING_TX;

		if (of_get_property(np, "linux,rs485-enabled-at-boot-time",
								NULL))
			rs485conf->flags |= SER_RS485_ENABLED;
	} else {
1697
		port->rs485       = pdata->rs485;
1698 1699 1700 1701
	}

}

1702 1703 1704 1705
static void atmel_set_ops(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

E
Elen Song 已提交
1706 1707 1708 1709 1710
	if (atmel_use_dma_rx(port)) {
		atmel_port->prepare_rx = &atmel_prepare_rx_dma;
		atmel_port->schedule_rx = &atmel_rx_from_dma;
		atmel_port->release_rx = &atmel_release_rx_dma;
	} else if (atmel_use_pdc_rx(port)) {
1711 1712 1713 1714 1715 1716 1717 1718 1719
		atmel_port->prepare_rx = &atmel_prepare_rx_pdc;
		atmel_port->schedule_rx = &atmel_rx_from_pdc;
		atmel_port->release_rx = &atmel_release_rx_pdc;
	} else {
		atmel_port->prepare_rx = NULL;
		atmel_port->schedule_rx = &atmel_rx_from_ring;
		atmel_port->release_rx = NULL;
	}

E
Elen Song 已提交
1720 1721 1722 1723 1724
	if (atmel_use_dma_tx(port)) {
		atmel_port->prepare_tx = &atmel_prepare_tx_dma;
		atmel_port->schedule_tx = &atmel_tx_dma;
		atmel_port->release_tx = &atmel_release_tx_dma;
	} else if (atmel_use_pdc_tx(port)) {
1725 1726 1727 1728 1729 1730 1731 1732 1733 1734
		atmel_port->prepare_tx = &atmel_prepare_tx_pdc;
		atmel_port->schedule_tx = &atmel_tx_pdc;
		atmel_port->release_tx = &atmel_release_tx_pdc;
	} else {
		atmel_port->prepare_tx = NULL;
		atmel_port->schedule_tx = &atmel_tx_chars;
		atmel_port->release_tx = NULL;
	}
}

1735 1736 1737
/*
 * Get ip name usart or uart
 */
1738
static void atmel_get_ip_name(struct uart_port *port)
1739 1740
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1741
	int name = atmel_uart_readl(port, ATMEL_US_NAME);
1742
	u32 version;
1743
	u32 usart, dbgu_uart, new_uart;
1744 1745 1746
	/* ASCII decoding for IP version */
	usart = 0x55534152;	/* USAR(T) */
	dbgu_uart = 0x44424755;	/* DBGU */
1747
	new_uart = 0x55415254;	/* UART */
1748

1749 1750 1751 1752 1753
	/*
	 * Only USART devices from at91sam9260 SOC implement fractional
	 * baudrate.
	 */
	atmel_port->has_frac_baudrate = false;
1754
	atmel_port->has_hw_timer = false;
1755

1756 1757
	if (name == new_uart) {
		dev_dbg(port->dev, "Uart with hw timer");
1758
		atmel_port->has_hw_timer = true;
1759 1760 1761
		atmel_port->rtor = ATMEL_UA_RTOR;
	} else if (name == usart) {
		dev_dbg(port->dev, "Usart\n");
1762
		atmel_port->has_frac_baudrate = true;
1763 1764
		atmel_port->has_hw_timer = true;
		atmel_port->rtor = ATMEL_US_RTOR;
1765 1766
	} else if (name == dbgu_uart) {
		dev_dbg(port->dev, "Dbgu or uart without hw timer\n");
1767
	} else {
1768
		/* fallback for older SoCs: use version field */
1769
		version = atmel_uart_readl(port, ATMEL_US_VERSION);
1770 1771 1772 1773
		switch (version) {
		case 0x302:
		case 0x10213:
			dev_dbg(port->dev, "This version is usart\n");
1774
			atmel_port->has_frac_baudrate = true;
1775
			atmel_port->has_hw_timer = true;
1776
			atmel_port->rtor = ATMEL_US_RTOR;
1777 1778 1779 1780 1781 1782 1783 1784
			break;
		case 0x203:
		case 0x10202:
			dev_dbg(port->dev, "This version is uart\n");
			break;
		default:
			dev_err(port->dev, "Not supported ip name nor version, set to uart\n");
		}
1785 1786 1787
	}
}

1788 1789 1790
/*
 * Perform initialization and enable port for reception
 */
1791
static int atmel_startup(struct uart_port *port)
1792
{
1793
	struct platform_device *pdev = to_platform_device(port->dev);
1794
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
A
Alan Cox 已提交
1795
	struct tty_struct *tty = port->state->port.tty;
1796 1797 1798 1799 1800 1801 1802
	int retval;

	/*
	 * Ensure that no interrupts are enabled otherwise when
	 * request_irq() is called we could get stuck trying to
	 * handle an unexpected interrupt
	 */
1803
	atmel_uart_writel(port, ATMEL_US_IDR, -1);
1804
	atmel_port->ms_irq_enabled = false;
1805 1806 1807 1808

	/*
	 * Allocate the IRQ
	 */
1809 1810
	retval = request_irq(port->irq, atmel_interrupt,
			IRQF_SHARED | IRQF_COND_SUSPEND,
1811
			tty ? tty->name : "atmel_serial", port);
1812
	if (retval) {
1813
		dev_err(port->dev, "atmel_startup - Can't get irq\n");
1814 1815 1816
		return retval;
	}

1817 1818 1819 1820 1821
	atomic_set(&atmel_port->tasklet_shutdown, 0);
	tasklet_init(&atmel_port->tasklet_rx, atmel_tasklet_rx_func,
			(unsigned long)port);
	tasklet_init(&atmel_port->tasklet_tx, atmel_tasklet_tx_func,
			(unsigned long)port);
1822

C
Chip Coldwell 已提交
1823 1824 1825
	/*
	 * Initialize DMA (if necessary)
	 */
1826
	atmel_init_property(atmel_port, pdev);
1827
	atmel_set_ops(port);
1828

1829 1830 1831 1832
	if (atmel_port->prepare_rx) {
		retval = atmel_port->prepare_rx(port);
		if (retval < 0)
			atmel_set_ops(port);
C
Chip Coldwell 已提交
1833 1834
	}

1835 1836 1837 1838
	if (atmel_port->prepare_tx) {
		retval = atmel_port->prepare_tx(port);
		if (retval < 0)
			atmel_set_ops(port);
C
Chip Coldwell 已提交
1839
	}
1840

1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853
	/*
	 * Enable FIFO when available
	 */
	if (atmel_port->fifo_size) {
		unsigned int txrdym = ATMEL_US_ONE_DATA;
		unsigned int rxrdym = ATMEL_US_ONE_DATA;
		unsigned int fmr;

		atmel_uart_writel(port, ATMEL_US_CR,
				  ATMEL_US_FIFOEN |
				  ATMEL_US_RXFCLR |
				  ATMEL_US_TXFLCLR);

1854 1855 1856
		if (atmel_use_dma_tx(port))
			txrdym = ATMEL_US_FOUR_DATA;

1857 1858 1859 1860 1861 1862 1863 1864 1865 1866
		fmr = ATMEL_US_TXRDYM(txrdym) | ATMEL_US_RXRDYM(rxrdym);
		if (atmel_port->rts_high &&
		    atmel_port->rts_low)
			fmr |=	ATMEL_US_FRTSC |
				ATMEL_US_RXFTHRES(atmel_port->rts_high) |
				ATMEL_US_RXFTHRES2(atmel_port->rts_low);

		atmel_uart_writel(port, ATMEL_US_FMR, fmr);
	}

1867
	/* Save current CSR for comparison in atmel_tasklet_func() */
1868
	atmel_port->irq_status_prev = atmel_get_lines_status(port);
1869

1870 1871 1872
	/*
	 * Finally, enable the serial port
	 */
1873
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA | ATMEL_US_RSTRX);
R
Remy Bohmer 已提交
1874
	/* enable xmit & rcvr */
1875
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_TXEN | ATMEL_US_RXEN);
1876

1877 1878 1879 1880
	setup_timer(&atmel_port->uart_timer,
			atmel_uart_timer_callback,
			(unsigned long)port);

1881
	if (atmel_use_pdc_rx(port)) {
C
Chip Coldwell 已提交
1882
		/* set UART timeout */
1883
		if (!atmel_port->has_hw_timer) {
1884 1885 1886 1887
			mod_timer(&atmel_port->uart_timer,
					jiffies + uart_poll_timeout(port));
		/* set USART timeout */
		} else {
1888 1889
			atmel_uart_writel(port, atmel_port->rtor,
					  PDC_RX_TIMEOUT);
1890
			atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STTTO);
C
Chip Coldwell 已提交
1891

1892 1893
			atmel_uart_writel(port, ATMEL_US_IER,
					  ATMEL_US_ENDRX | ATMEL_US_TIMEOUT);
1894
		}
C
Chip Coldwell 已提交
1895
		/* enable PDC controller */
1896
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_RXTEN);
E
Elen Song 已提交
1897
	} else if (atmel_use_dma_rx(port)) {
1898
		/* set UART timeout */
1899
		if (!atmel_port->has_hw_timer) {
1900 1901 1902 1903
			mod_timer(&atmel_port->uart_timer,
					jiffies + uart_poll_timeout(port));
		/* set USART timeout */
		} else {
1904 1905
			atmel_uart_writel(port, atmel_port->rtor,
					  PDC_RX_TIMEOUT);
1906
			atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_STTTO);
E
Elen Song 已提交
1907

1908 1909
			atmel_uart_writel(port, ATMEL_US_IER,
					  ATMEL_US_TIMEOUT);
1910
		}
C
Chip Coldwell 已提交
1911 1912
	} else {
		/* enable receive only */
1913
		atmel_uart_writel(port, ATMEL_US_IER, ATMEL_US_RXRDY);
C
Chip Coldwell 已提交
1914
	}
1915

1916 1917 1918
	return 0;
}

1919 1920 1921 1922 1923 1924 1925 1926 1927
/*
 * Flush any TX data submitted for DMA. Called when the TX circular
 * buffer is reset.
 */
static void atmel_flush_buffer(struct uart_port *port)
{
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);

	if (atmel_use_pdc_tx(port)) {
1928
		atmel_uart_writel(port, ATMEL_PDC_TCR, 0);
1929 1930 1931 1932
		atmel_port->pdc_tx.ofs = 0;
	}
}

1933 1934 1935
/*
 * Disable the port
 */
1936
static void atmel_shutdown(struct uart_port *port)
1937
{
1938
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
1939

1940 1941 1942 1943 1944 1945
	/* Disable interrupts at device level */
	atmel_uart_writel(port, ATMEL_US_IDR, -1);

	/* Prevent spurious interrupts from scheduling the tasklet */
	atomic_inc(&atmel_port->tasklet_shutdown);

1946 1947 1948 1949 1950 1951
	/*
	 * Prevent any tasklets being scheduled during
	 * cleanup
	 */
	del_timer_sync(&atmel_port->uart_timer);

1952 1953 1954
	/* Make sure that no interrupt is on the fly */
	synchronize_irq(port->irq);

1955 1956 1957 1958
	/*
	 * Clear out any scheduled tasklets before
	 * we destroy the buffers
	 */
1959 1960
	tasklet_kill(&atmel_port->tasklet_rx);
	tasklet_kill(&atmel_port->tasklet_tx);
1961

C
Chip Coldwell 已提交
1962
	/*
1963
	 * Ensure everything is stopped and
1964
	 * disable port and break condition.
C
Chip Coldwell 已提交
1965 1966 1967 1968
	 */
	atmel_stop_rx(port);
	atmel_stop_tx(port);

1969
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
1970

C
Chip Coldwell 已提交
1971 1972 1973
	/*
	 * Shut-down the DMA.
	 */
1974 1975 1976 1977
	if (atmel_port->release_rx)
		atmel_port->release_rx(port);
	if (atmel_port->release_tx)
		atmel_port->release_tx(port);
C
Chip Coldwell 已提交
1978

1979 1980 1981 1982 1983 1984
	/*
	 * Reset ring buffer pointers
	 */
	atmel_port->rx_ring.head = 0;
	atmel_port->rx_ring.tail = 0;

1985
	/*
1986
	 * Free the interrupts
1987 1988
	 */
	free_irq(port->irq, port);
1989 1990

	atmel_port->ms_irq_enabled = false;
1991

1992
	atmel_flush_buffer(port);
1993 1994
}

1995 1996 1997
/*
 * Power / Clock management.
 */
R
Remy Bohmer 已提交
1998 1999
static void atmel_serial_pm(struct uart_port *port, unsigned int state,
			    unsigned int oldstate)
2000
{
2001
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2002

2003
	switch (state) {
R
Remy Bohmer 已提交
2004 2005 2006 2007 2008
	case 0:
		/*
		 * Enable the peripheral clock for this serial port.
		 * This is called on uart_open() or a resume event.
		 */
2009
		clk_prepare_enable(atmel_port->clk);
2010 2011

		/* re-enable interrupts if we disabled some on suspend */
2012
		atmel_uart_writel(port, ATMEL_US_IER, atmel_port->backup_imr);
R
Remy Bohmer 已提交
2013 2014
		break;
	case 3:
2015
		/* Back up the interrupt mask and disable all interrupts */
2016 2017
		atmel_port->backup_imr = atmel_uart_readl(port, ATMEL_US_IMR);
		atmel_uart_writel(port, ATMEL_US_IDR, -1);
2018

R
Remy Bohmer 已提交
2019 2020 2021 2022
		/*
		 * Disable the peripheral clock for this serial port.
		 * This is called on uart_close() or a suspend event.
		 */
2023
		clk_disable_unprepare(atmel_port->clk);
R
Remy Bohmer 已提交
2024 2025
		break;
	default:
2026
		dev_err(port->dev, "atmel_serial: unknown pm %d\n", state);
2027 2028 2029 2030 2031 2032
	}
}

/*
 * Change the port parameters
 */
R
Remy Bohmer 已提交
2033 2034
static void atmel_set_termios(struct uart_port *port, struct ktermios *termios,
			      struct ktermios *old)
2035
{
2036
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2037
	unsigned long flags;
2038
	unsigned int old_mode, mode, imr, quot, baud, div, cd, fp = 0;
2039 2040

	/* save the current mode register */
2041
	mode = old_mode = atmel_uart_readl(port, ATMEL_US_MR);
2042

2043 2044 2045
	/* reset the mode, clock divisor, parity, stop bits and data size */
	mode &= ~(ATMEL_US_USCLKS | ATMEL_US_CHRL | ATMEL_US_NBSTOP |
		  ATMEL_US_PAR | ATMEL_US_USMODE);
2046

R
Remy Bohmer 已提交
2047
	baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk / 16);
2048 2049 2050 2051

	/* byte size */
	switch (termios->c_cflag & CSIZE) {
	case CS5:
2052
		mode |= ATMEL_US_CHRL_5;
2053 2054
		break;
	case CS6:
2055
		mode |= ATMEL_US_CHRL_6;
2056 2057
		break;
	case CS7:
2058
		mode |= ATMEL_US_CHRL_7;
2059 2060
		break;
	default:
2061
		mode |= ATMEL_US_CHRL_8;
2062 2063 2064 2065 2066
		break;
	}

	/* stop bits */
	if (termios->c_cflag & CSTOPB)
2067
		mode |= ATMEL_US_NBSTOP_2;
2068 2069 2070

	/* parity */
	if (termios->c_cflag & PARENB) {
R
Remy Bohmer 已提交
2071 2072
		/* Mark or Space parity */
		if (termios->c_cflag & CMSPAR) {
2073
			if (termios->c_cflag & PARODD)
2074
				mode |= ATMEL_US_PAR_MARK;
2075
			else
2076
				mode |= ATMEL_US_PAR_SPACE;
R
Remy Bohmer 已提交
2077
		} else if (termios->c_cflag & PARODD)
2078
			mode |= ATMEL_US_PAR_ODD;
2079
		else
2080
			mode |= ATMEL_US_PAR_EVEN;
R
Remy Bohmer 已提交
2081
	} else
2082
		mode |= ATMEL_US_PAR_NONE;
2083 2084 2085

	spin_lock_irqsave(&port->lock, flags);

2086
	port->read_status_mask = ATMEL_US_OVRE;
2087
	if (termios->c_iflag & INPCK)
2088
		port->read_status_mask |= (ATMEL_US_FRAME | ATMEL_US_PARE);
P
Peter Hurley 已提交
2089
	if (termios->c_iflag & (IGNBRK | BRKINT | PARMRK))
2090
		port->read_status_mask |= ATMEL_US_RXBRK;
2091

2092
	if (atmel_use_pdc_rx(port))
C
Chip Coldwell 已提交
2093
		/* need to enable error interrupts */
2094
		atmel_uart_writel(port, ATMEL_US_IER, port->read_status_mask);
C
Chip Coldwell 已提交
2095

2096 2097 2098 2099 2100
	/*
	 * Characters to ignore
	 */
	port->ignore_status_mask = 0;
	if (termios->c_iflag & IGNPAR)
2101
		port->ignore_status_mask |= (ATMEL_US_FRAME | ATMEL_US_PARE);
2102
	if (termios->c_iflag & IGNBRK) {
2103
		port->ignore_status_mask |= ATMEL_US_RXBRK;
2104 2105 2106 2107 2108
		/*
		 * If we're ignoring parity and break indicators,
		 * ignore overruns too (for real raw support).
		 */
		if (termios->c_iflag & IGNPAR)
2109
			port->ignore_status_mask |= ATMEL_US_OVRE;
2110
	}
R
Remy Bohmer 已提交
2111
	/* TODO: Ignore all characters if CREAD is set.*/
2112 2113 2114 2115

	/* update the per-port timeout */
	uart_update_timeout(port, termios->c_cflag, baud);

2116 2117 2118 2119 2120
	/*
	 * save/disable interrupts. The tty layer will ensure that the
	 * transmitter is empty if requested by the caller, so there's
	 * no need to wait for it here.
	 */
2121 2122
	imr = atmel_uart_readl(port, ATMEL_US_IMR);
	atmel_uart_writel(port, ATMEL_US_IDR, -1);
2123 2124

	/* disable receiver and transmitter */
2125
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_TXDIS | ATMEL_US_RXDIS);
2126

2127
	/* mode */
2128
	if (port->rs485.flags & SER_RS485_ENABLED) {
2129 2130
		atmel_uart_writel(port, ATMEL_US_TTGR,
				  port->rs485.delay_rts_after_send);
2131
		mode |= ATMEL_US_USMODE_RS485;
2132 2133
	} else if (termios->c_cflag & CRTSCTS) {
		/* RS232 with hardware handshake (RTS/CTS) */
2134 2135 2136 2137 2138 2139
		if (atmel_use_dma_rx(port) && !atmel_use_fifo(port)) {
			dev_info(port->dev, "not enabling hardware flow control because DMA is used");
			termios->c_cflag &= ~CRTSCTS;
		} else {
			mode |= ATMEL_US_USMODE_HWHS;
		}
2140 2141 2142
	} else {
		/* RS232 without hadware handshake */
		mode |= ATMEL_US_USMODE_NORMAL;
2143 2144
	}

2145
	/* set the mode, clock divisor, parity, stop bits and data size */
2146
	atmel_uart_writel(port, ATMEL_US_MR, mode);
2147

2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162
	/*
	 * when switching the mode, set the RTS line state according to the
	 * new mode, otherwise keep the former state
	 */
	if ((old_mode & ATMEL_US_USMODE) != (mode & ATMEL_US_USMODE)) {
		unsigned int rts_state;

		if ((mode & ATMEL_US_USMODE) == ATMEL_US_USMODE_HWHS) {
			/* let the hardware control the RTS line */
			rts_state = ATMEL_US_RTSDIS;
		} else {
			/* force RTS line to low level */
			rts_state = ATMEL_US_RTSEN;
		}

2163
		atmel_uart_writel(port, ATMEL_US_CR, rts_state);
2164 2165
	}

2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188
	/*
	 * Set the baud rate:
	 * Fractional baudrate allows to setup output frequency more
	 * accurately. This feature is enabled only when using normal mode.
	 * baudrate = selected clock / (8 * (2 - OVER) * (CD + FP / 8))
	 * Currently, OVER is always set to 0 so we get
	 * baudrate = selected clock (16 * (CD + FP / 8))
	 */
	if (atmel_port->has_frac_baudrate &&
	    (mode & ATMEL_US_USMODE) == ATMEL_US_USMODE_NORMAL) {
		div = DIV_ROUND_CLOSEST(port->uartclk, baud);
		cd = div / 16;
		fp = DIV_ROUND_CLOSEST(div % 16, 2);
	} else {
		cd = uart_get_divisor(port, baud);
	}

	if (cd > 65535) {	/* BRGR is 16-bit, so switch to slower clock */
		cd /= 8;
		mode |= ATMEL_US_USCLKS_MCK_DIV8;
	}
	quot = cd | fp << ATMEL_US_FP_OFFSET;

2189 2190 2191
	atmel_uart_writel(port, ATMEL_US_BRGR, quot);
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA | ATMEL_US_RSTRX);
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_TXEN | ATMEL_US_RXEN);
2192 2193

	/* restore interrupts */
2194
	atmel_uart_writel(port, ATMEL_US_IER, imr);
2195 2196 2197

	/* CTS flow-control and modem-status interrupts */
	if (UART_ENABLE_MS(port, termios->c_cflag))
2198 2199 2200
		atmel_enable_ms(port);
	else
		atmel_disable_ms(port);
2201 2202 2203 2204

	spin_unlock_irqrestore(&port->lock, flags);
}

2205
static void atmel_set_ldisc(struct uart_port *port, struct ktermios *termios)
2206
{
2207
	if (termios->c_line == N_PPS) {
2208
		port->flags |= UPF_HARDPPS_CD;
2209
		spin_lock_irq(&port->lock);
2210
		atmel_enable_ms(port);
2211
		spin_unlock_irq(&port->lock);
2212 2213
	} else {
		port->flags &= ~UPF_HARDPPS_CD;
2214 2215 2216 2217 2218
		if (!UART_ENABLE_MS(port, termios->c_cflag)) {
			spin_lock_irq(&port->lock);
			atmel_disable_ms(port);
			spin_unlock_irq(&port->lock);
		}
2219 2220 2221
	}
}

2222 2223 2224
/*
 * Return string describing the specified port
 */
2225
static const char *atmel_type(struct uart_port *port)
2226
{
2227
	return (port->type == PORT_ATMEL) ? "ATMEL_SERIAL" : NULL;
2228 2229 2230 2231 2232
}

/*
 * Release the memory region(s) being used by 'port'.
 */
2233
static void atmel_release_port(struct uart_port *port)
2234
{
2235 2236 2237 2238 2239 2240 2241 2242 2243
	struct platform_device *pdev = to_platform_device(port->dev);
	int size = pdev->resource[0].end - pdev->resource[0].start + 1;

	release_mem_region(port->mapbase, size);

	if (port->flags & UPF_IOREMAP) {
		iounmap(port->membase);
		port->membase = NULL;
	}
2244 2245 2246 2247 2248
}

/*
 * Request the memory region(s) being used by 'port'.
 */
2249
static int atmel_request_port(struct uart_port *port)
2250
{
2251 2252 2253
	struct platform_device *pdev = to_platform_device(port->dev);
	int size = pdev->resource[0].end - pdev->resource[0].start + 1;

2254
	if (!request_mem_region(port->mapbase, size, "atmel_serial"))
2255 2256 2257 2258 2259 2260 2261 2262 2263
		return -EBUSY;

	if (port->flags & UPF_IOREMAP) {
		port->membase = ioremap(port->mapbase, size);
		if (port->membase == NULL) {
			release_mem_region(port->mapbase, size);
			return -ENOMEM;
		}
	}
2264

2265
	return 0;
2266 2267 2268 2269 2270
}

/*
 * Configure/autoconfigure the port.
 */
2271
static void atmel_config_port(struct uart_port *port, int flags)
2272 2273
{
	if (flags & UART_CONFIG_TYPE) {
2274
		port->type = PORT_ATMEL;
2275
		atmel_request_port(port);
2276 2277 2278 2279 2280 2281
	}
}

/*
 * Verify the new serial_struct (for TIOCSSERIAL).
 */
2282
static int atmel_verify_port(struct uart_port *port, struct serial_struct *ser)
2283 2284
{
	int ret = 0;
2285
	if (ser->type != PORT_UNKNOWN && ser->type != PORT_ATMEL)
2286 2287 2288 2289 2290 2291 2292
		ret = -EINVAL;
	if (port->irq != ser->irq)
		ret = -EINVAL;
	if (ser->io_type != SERIAL_IO_MEM)
		ret = -EINVAL;
	if (port->uartclk / 16 != ser->baud_base)
		ret = -EINVAL;
2293
	if (port->mapbase != (unsigned long)ser->iomem_base)
2294 2295 2296 2297 2298 2299 2300 2301
		ret = -EINVAL;
	if (port->iobase != ser->port)
		ret = -EINVAL;
	if (ser->hub6 != 0)
		ret = -EINVAL;
	return ret;
}

2302 2303 2304
#ifdef CONFIG_CONSOLE_POLL
static int atmel_poll_get_char(struct uart_port *port)
{
2305
	while (!(atmel_uart_readl(port, ATMEL_US_CSR) & ATMEL_US_RXRDY))
2306 2307
		cpu_relax();

2308
	return atmel_uart_read_char(port);
2309 2310 2311 2312
}

static void atmel_poll_put_char(struct uart_port *port, unsigned char ch)
{
2313
	while (!(atmel_uart_readl(port, ATMEL_US_CSR) & ATMEL_US_TXRDY))
2314 2315
		cpu_relax();

2316
	atmel_uart_write_char(port, ch);
2317 2318 2319
}
#endif

2320
static const struct uart_ops atmel_pops = {
2321 2322 2323 2324 2325 2326 2327 2328 2329 2330
	.tx_empty	= atmel_tx_empty,
	.set_mctrl	= atmel_set_mctrl,
	.get_mctrl	= atmel_get_mctrl,
	.stop_tx	= atmel_stop_tx,
	.start_tx	= atmel_start_tx,
	.stop_rx	= atmel_stop_rx,
	.enable_ms	= atmel_enable_ms,
	.break_ctl	= atmel_break_ctl,
	.startup	= atmel_startup,
	.shutdown	= atmel_shutdown,
2331
	.flush_buffer	= atmel_flush_buffer,
2332
	.set_termios	= atmel_set_termios,
2333
	.set_ldisc	= atmel_set_ldisc,
2334 2335 2336 2337 2338 2339
	.type		= atmel_type,
	.release_port	= atmel_release_port,
	.request_port	= atmel_request_port,
	.config_port	= atmel_config_port,
	.verify_port	= atmel_verify_port,
	.pm		= atmel_serial_pm,
2340 2341 2342 2343
#ifdef CONFIG_CONSOLE_POLL
	.poll_get_char	= atmel_poll_get_char,
	.poll_put_char	= atmel_poll_put_char,
#endif
2344 2345
};

2346 2347 2348
/*
 * Configure the port from the platform device resource info.
 */
2349
static int atmel_init_port(struct atmel_uart_port *atmel_port,
R
Remy Bohmer 已提交
2350
				      struct platform_device *pdev)
2351
{
2352
	int ret;
2353
	struct uart_port *port = &atmel_port->uart;
J
Jingoo Han 已提交
2354
	struct atmel_uart_data *pdata = dev_get_platdata(&pdev->dev);
2355

2356 2357
	atmel_init_property(atmel_port, pdev);
	atmel_set_ops(port);
2358

2359
	atmel_init_rs485(port, pdev);
2360

2361 2362 2363 2364 2365
	port->iotype		= UPIO_MEM;
	port->flags		= UPF_BOOT_AUTOCONF;
	port->ops		= &atmel_pops;
	port->fifosize		= 1;
	port->dev		= &pdev->dev;
2366 2367
	port->mapbase	= pdev->resource[0].start;
	port->irq	= pdev->resource[1].start;
2368
	port->rs485_config	= atmel_config_rs485;
2369

2370 2371
	memset(&atmel_port->rx_ring, 0, sizeof(atmel_port->rx_ring));

2372
	if (pdata && pdata->regs) {
2373
		/* Already mapped by setup code */
2374
		port->membase = pdata->regs;
2375
	} else {
2376 2377 2378
		port->flags	|= UPF_IOREMAP;
		port->membase	= NULL;
	}
2379

R
Remy Bohmer 已提交
2380 2381
	/* for console, the clock could already be configured */
	if (!atmel_port->clk) {
2382
		atmel_port->clk = clk_get(&pdev->dev, "usart");
2383 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393
		if (IS_ERR(atmel_port->clk)) {
			ret = PTR_ERR(atmel_port->clk);
			atmel_port->clk = NULL;
			return ret;
		}
		ret = clk_prepare_enable(atmel_port->clk);
		if (ret) {
			clk_put(atmel_port->clk);
			atmel_port->clk = NULL;
			return ret;
		}
2394
		port->uartclk = clk_get_rate(atmel_port->clk);
2395
		clk_disable_unprepare(atmel_port->clk);
2396
		/* only enable clock when USART is in use */
2397
	}
C
Chip Coldwell 已提交
2398

2399
	/* Use TXEMPTY for interrupt when rs485 else TXRDY or ENDTX|TXBUFE */
2400
	if (port->rs485.flags & SER_RS485_ENABLED)
2401
		atmel_port->tx_done_mask = ATMEL_US_TXEMPTY;
2402
	else if (atmel_use_pdc_tx(port)) {
C
Chip Coldwell 已提交
2403
		port->fifosize = PDC_BUFFER_SIZE;
2404 2405 2406 2407
		atmel_port->tx_done_mask = ATMEL_US_ENDTX | ATMEL_US_TXBUFE;
	} else {
		atmel_port->tx_done_mask = ATMEL_US_TXRDY;
	}
2408 2409

	return 0;
2410 2411
}

2412 2413
struct platform_device *atmel_default_console_device;	/* the serial console device */

2414
#ifdef CONFIG_SERIAL_ATMEL_CONSOLE
2415
static void atmel_console_putchar(struct uart_port *port, int ch)
2416
{
2417
	while (!(atmel_uart_readl(port, ATMEL_US_CSR) & ATMEL_US_TXRDY))
2418
		cpu_relax();
2419
	atmel_uart_write_char(port, ch);
2420
}
2421 2422 2423 2424

/*
 * Interrupts are disabled on entering
 */
2425
static void atmel_console_write(struct console *co, const char *s, u_int count)
2426
{
2427
	struct uart_port *port = &atmel_ports[co->index].uart;
2428
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2429
	unsigned int status, imr;
2430
	unsigned int pdc_tx;
2431 2432

	/*
R
Remy Bohmer 已提交
2433
	 * First, save IMR and then disable interrupts
2434
	 */
2435 2436 2437
	imr = atmel_uart_readl(port, ATMEL_US_IMR);
	atmel_uart_writel(port, ATMEL_US_IDR,
			  ATMEL_US_RXRDY | atmel_port->tx_done_mask);
2438

2439
	/* Store PDC transmit status and disable it */
2440 2441
	pdc_tx = atmel_uart_readl(port, ATMEL_PDC_PTSR) & ATMEL_PDC_TXTEN;
	atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTDIS);
2442

2443
	uart_console_write(port, s, count, atmel_console_putchar);
2444 2445

	/*
R
Remy Bohmer 已提交
2446 2447
	 * Finally, wait for transmitter to become empty
	 * and restore IMR
2448 2449
	 */
	do {
2450
		status = atmel_uart_readl(port, ATMEL_US_CSR);
2451
	} while (!(status & ATMEL_US_TXRDY));
2452 2453 2454

	/* Restore PDC transmit status */
	if (pdc_tx)
2455
		atmel_uart_writel(port, ATMEL_PDC_PTCR, ATMEL_PDC_TXTEN);
2456

R
Remy Bohmer 已提交
2457
	/* set interrupts back the way they were */
2458
	atmel_uart_writel(port, ATMEL_US_IER, imr);
2459 2460 2461
}

/*
R
Remy Bohmer 已提交
2462 2463
 * If the port was already initialised (eg, by a boot loader),
 * try to determine the current setup.
2464
 */
R
Remy Bohmer 已提交
2465 2466
static void __init atmel_console_get_options(struct uart_port *port, int *baud,
					     int *parity, int *bits)
2467 2468 2469
{
	unsigned int mr, quot;

2470 2471 2472 2473
	/*
	 * If the baud rate generator isn't running, the port wasn't
	 * initialized by the boot loader.
	 */
2474
	quot = atmel_uart_readl(port, ATMEL_US_BRGR) & ATMEL_US_CD;
2475 2476
	if (!quot)
		return;
2477

2478
	mr = atmel_uart_readl(port, ATMEL_US_MR) & ATMEL_US_CHRL;
2479
	if (mr == ATMEL_US_CHRL_8)
2480 2481 2482 2483
		*bits = 8;
	else
		*bits = 7;

2484
	mr = atmel_uart_readl(port, ATMEL_US_MR) & ATMEL_US_PAR;
2485
	if (mr == ATMEL_US_PAR_EVEN)
2486
		*parity = 'e';
2487
	else if (mr == ATMEL_US_PAR_ODD)
2488 2489
		*parity = 'o';

2490 2491 2492 2493 2494 2495 2496
	/*
	 * The serial core only rounds down when matching this to a
	 * supported baud rate. Make sure we don't end up slightly
	 * lower than one of those, as it would make us fall through
	 * to a much lower baud rate than we really want.
	 */
	*baud = port->uartclk / (16 * (quot - 1));
2497 2498
}

2499
static int __init atmel_console_setup(struct console *co, char *options)
2500
{
2501
	int ret;
2502
	struct uart_port *port = &atmel_ports[co->index].uart;
2503 2504 2505 2506 2507
	int baud = 115200;
	int bits = 8;
	int parity = 'n';
	int flow = 'n';

R
Remy Bohmer 已提交
2508 2509
	if (port->membase == NULL) {
		/* Port not initialized yet - delay setup */
2510
		return -ENODEV;
R
Remy Bohmer 已提交
2511
	}
2512

2513 2514 2515
	ret = clk_prepare_enable(atmel_ports[co->index].clk);
	if (ret)
		return ret;
2516

2517 2518 2519
	atmel_uart_writel(port, ATMEL_US_IDR, -1);
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA | ATMEL_US_RSTRX);
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_TXEN | ATMEL_US_RXEN);
2520 2521 2522 2523

	if (options)
		uart_parse_options(options, &baud, &parity, &bits, &flow);
	else
2524
		atmel_console_get_options(port, &baud, &parity, &bits);
2525 2526 2527 2528

	return uart_set_options(port, co, baud, parity, bits, flow);
}

2529
static struct uart_driver atmel_uart;
2530

2531 2532 2533
static struct console atmel_console = {
	.name		= ATMEL_DEVICENAME,
	.write		= atmel_console_write,
2534
	.device		= uart_console_device,
2535
	.setup		= atmel_console_setup,
2536 2537
	.flags		= CON_PRINTBUFFER,
	.index		= -1,
2538
	.data		= &atmel_uart,
2539 2540
};

2541
#define ATMEL_CONSOLE_DEVICE	(&atmel_console)
2542

2543 2544 2545
/*
 * Early console initialization (before VM subsystem initialized).
 */
2546
static int __init atmel_console_init(void)
2547
{
2548
	int ret;
2549
	if (atmel_default_console_device) {
2550
		struct atmel_uart_data *pdata =
J
Jingoo Han 已提交
2551
			dev_get_platdata(&atmel_default_console_device->dev);
2552
		int id = pdata->num;
2553
		struct atmel_uart_port *atmel_port = &atmel_ports[id];
2554

2555 2556
		atmel_port->backup_imr = 0;
		atmel_port->uart.line = id;
2557

2558
		add_preferred_console(ATMEL_DEVICENAME, id, NULL);
2559
		ret = atmel_init_port(atmel_port, atmel_default_console_device);
2560 2561
		if (ret)
			return ret;
2562
		register_console(&atmel_console);
2563
	}
2564 2565 2566

	return 0;
}
R
Remy Bohmer 已提交
2567

2568
console_initcall(atmel_console_init);
2569

2570 2571 2572
/*
 * Late console initialization.
 */
2573
static int __init atmel_late_console_init(void)
2574
{
R
Remy Bohmer 已提交
2575 2576
	if (atmel_default_console_device
	    && !(atmel_console.flags & CON_ENABLED))
2577
		register_console(&atmel_console);
2578 2579 2580

	return 0;
}
R
Remy Bohmer 已提交
2581

2582
core_initcall(atmel_late_console_init);
2583

2584 2585 2586 2587 2588
static inline bool atmel_is_console_port(struct uart_port *port)
{
	return port->cons && port->cons->index == port->line;
}

2589
#else
2590
#define ATMEL_CONSOLE_DEVICE	NULL
2591 2592 2593 2594 2595

static inline bool atmel_is_console_port(struct uart_port *port)
{
	return false;
}
2596 2597
#endif

2598
static struct uart_driver atmel_uart = {
R
Remy Bohmer 已提交
2599 2600 2601 2602 2603 2604 2605
	.owner		= THIS_MODULE,
	.driver_name	= "atmel_serial",
	.dev_name	= ATMEL_DEVICENAME,
	.major		= SERIAL_ATMEL_MAJOR,
	.minor		= MINOR_START,
	.nr		= ATMEL_MAX_UART,
	.cons		= ATMEL_CONSOLE_DEVICE,
2606 2607
};

2608
#ifdef CONFIG_PM
2609 2610 2611 2612 2613 2614 2615 2616 2617
static bool atmel_serial_clk_will_stop(void)
{
#ifdef CONFIG_ARCH_AT91
	return at91_suspend_entering_slow_clock();
#else
	return false;
#endif
}

R
Remy Bohmer 已提交
2618 2619
static int atmel_serial_suspend(struct platform_device *pdev,
				pm_message_t state)
2620
{
2621
	struct uart_port *port = platform_get_drvdata(pdev);
2622
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2623

2624 2625
	if (atmel_is_console_port(port) && console_suspend_enabled) {
		/* Drain the TX shifter */
2626 2627
		while (!(atmel_uart_readl(port, ATMEL_US_CSR) &
			 ATMEL_US_TXEMPTY))
2628 2629 2630
			cpu_relax();
	}

2631 2632
	/* we can not wake up if we're running on slow clock */
	atmel_port->may_wakeup = device_may_wakeup(&pdev->dev);
2633 2634 2635 2636 2637 2638
	if (atmel_serial_clk_will_stop()) {
		unsigned long flags;

		spin_lock_irqsave(&atmel_port->lock_suspended, flags);
		atmel_port->suspended = true;
		spin_unlock_irqrestore(&atmel_port->lock_suspended, flags);
2639
		device_set_wakeup_enable(&pdev->dev, 0);
2640
	}
2641 2642

	uart_suspend_port(&atmel_uart, port);
2643

2644 2645
	return 0;
}
2646

2647
static int atmel_serial_resume(struct platform_device *pdev)
2648 2649
{
	struct uart_port *port = platform_get_drvdata(pdev);
2650
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662
	unsigned long flags;

	spin_lock_irqsave(&atmel_port->lock_suspended, flags);
	if (atmel_port->pending) {
		atmel_handle_receive(port, atmel_port->pending);
		atmel_handle_status(port, atmel_port->pending,
				    atmel_port->pending_status);
		atmel_handle_transmit(port, atmel_port->pending);
		atmel_port->pending = 0;
	}
	atmel_port->suspended = false;
	spin_unlock_irqrestore(&atmel_port->lock_suspended, flags);
2663

2664 2665
	uart_resume_port(&atmel_uart, port);
	device_set_wakeup_enable(&pdev->dev, atmel_port->may_wakeup);
2666 2667 2668

	return 0;
}
2669
#else
2670 2671
#define atmel_serial_suspend NULL
#define atmel_serial_resume NULL
2672
#endif
2673

2674
static void atmel_serial_probe_fifos(struct atmel_uart_port *atmel_port,
2675 2676
				     struct platform_device *pdev)
{
2677 2678 2679
	atmel_port->fifo_size = 0;
	atmel_port->rts_low = 0;
	atmel_port->rts_high = 0;
2680 2681 2682

	if (of_property_read_u32(pdev->dev.of_node,
				 "atmel,fifo-size",
2683
				 &atmel_port->fifo_size))
2684 2685
		return;

2686
	if (!atmel_port->fifo_size)
2687 2688
		return;

2689 2690
	if (atmel_port->fifo_size < ATMEL_MIN_FIFO_SIZE) {
		atmel_port->fifo_size = 0;
2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702
		dev_err(&pdev->dev, "Invalid FIFO size\n");
		return;
	}

	/*
	 * 0 <= rts_low <= rts_high <= fifo_size
	 * Once their CTS line asserted by the remote peer, some x86 UARTs tend
	 * to flush their internal TX FIFO, commonly up to 16 data, before
	 * actually stopping to send new data. So we try to set the RTS High
	 * Threshold to a reasonably high value respecting this 16 data
	 * empirical rule when possible.
	 */
2703 2704 2705 2706
	atmel_port->rts_high = max_t(int, atmel_port->fifo_size >> 1,
			       atmel_port->fifo_size - ATMEL_RTS_HIGH_OFFSET);
	atmel_port->rts_low  = max_t(int, atmel_port->fifo_size >> 2,
			       atmel_port->fifo_size - ATMEL_RTS_LOW_OFFSET);
2707 2708

	dev_info(&pdev->dev, "Using FIFO (%u data)\n",
2709
		 atmel_port->fifo_size);
2710
	dev_dbg(&pdev->dev, "RTS High Threshold : %2u data\n",
2711
		atmel_port->rts_high);
2712
	dev_dbg(&pdev->dev, "RTS Low Threshold  : %2u data\n",
2713
		atmel_port->rts_low);
2714 2715
}

B
Bill Pemberton 已提交
2716
static int atmel_serial_probe(struct platform_device *pdev)
2717
{
2718
	struct atmel_uart_port *atmel_port;
2719
	struct device_node *np = pdev->dev.of_node;
J
Jingoo Han 已提交
2720
	struct atmel_uart_data *pdata = dev_get_platdata(&pdev->dev);
2721
	void *data;
2722
	int ret = -ENODEV;
2723
	bool rs485_enabled;
2724

2725
	BUILD_BUG_ON(ATMEL_SERIAL_RINGSIZE & (ATMEL_SERIAL_RINGSIZE - 1));
2726

2727 2728 2729 2730 2731
	if (np)
		ret = of_alias_get_id(np, "serial");
	else
		if (pdata)
			ret = pdata->num;
2732 2733

	if (ret < 0)
2734
		/* port id not found in platform data nor device-tree aliases:
2735
		 * auto-enumerate it */
2736
		ret = find_first_zero_bit(atmel_ports_in_use, ATMEL_MAX_UART);
2737

2738
	if (ret >= ATMEL_MAX_UART) {
2739 2740 2741 2742
		ret = -ENODEV;
		goto err;
	}

2743
	if (test_and_set_bit(ret, atmel_ports_in_use)) {
2744 2745 2746 2747 2748
		/* port already in use */
		ret = -EBUSY;
		goto err;
	}

2749 2750 2751 2752
	atmel_port = &atmel_ports[ret];
	atmel_port->backup_imr = 0;
	atmel_port->uart.line = ret;
	atmel_serial_probe_fifos(atmel_port, pdev);
2753

2754
	atomic_set(&atmel_port->tasklet_shutdown, 0);
2755
	spin_lock_init(&atmel_port->lock_suspended);
2756

2757
	ret = atmel_init_port(atmel_port, pdev);
2758
	if (ret)
2759
		goto err_clear_bit;
2760

2761 2762 2763
	atmel_port->gpios = mctrl_gpio_init(&atmel_port->uart, 0);
	if (IS_ERR(atmel_port->gpios)) {
		ret = PTR_ERR(atmel_port->gpios);
2764 2765 2766
		goto err_clear_bit;
	}

2767
	if (!atmel_use_pdc_rx(&atmel_port->uart)) {
C
Chip Coldwell 已提交
2768
		ret = -ENOMEM;
2769 2770
		data = kmalloc(sizeof(struct atmel_uart_char)
				* ATMEL_SERIAL_RINGSIZE, GFP_KERNEL);
C
Chip Coldwell 已提交
2771 2772
		if (!data)
			goto err_alloc_ring;
2773
		atmel_port->rx_ring.buf = data;
C
Chip Coldwell 已提交
2774
	}
2775

2776
	rs485_enabled = atmel_port->uart.rs485.flags & SER_RS485_ENABLED;
2777

2778
	ret = uart_add_one_port(&atmel_uart, &atmel_port->uart);
2779 2780 2781
	if (ret)
		goto err_add_port;

2782
#ifdef CONFIG_SERIAL_ATMEL_CONSOLE
2783
	if (atmel_is_console_port(&atmel_port->uart)
2784 2785 2786
			&& ATMEL_CONSOLE_DEVICE->flags & CON_ENABLED) {
		/*
		 * The serial core enabled the clock for us, so undo
2787
		 * the clk_prepare_enable() in atmel_console_setup()
2788
		 */
2789
		clk_disable_unprepare(atmel_port->clk);
2790
	}
2791
#endif
2792

2793
	device_init_wakeup(&pdev->dev, 1);
2794
	platform_set_drvdata(pdev, atmel_port);
2795

2796 2797 2798 2799
	/*
	 * The peripheral clock has been disabled by atmel_init_port():
	 * enable it before accessing I/O registers
	 */
2800
	clk_prepare_enable(atmel_port->clk);
2801

2802
	if (rs485_enabled) {
2803
		atmel_uart_writel(&atmel_port->uart, ATMEL_US_MR,
2804
				  ATMEL_US_USMODE_NORMAL);
2805 2806
		atmel_uart_writel(&atmel_port->uart, ATMEL_US_CR,
				  ATMEL_US_RTSEN);
2807 2808
	}

2809 2810 2811
	/*
	 * Get port name of usart or uart
	 */
2812
	atmel_get_ip_name(&atmel_port->uart);
2813

2814 2815 2816 2817
	/*
	 * The peripheral clock can now safely be disabled till the port
	 * is used
	 */
2818
	clk_disable_unprepare(atmel_port->clk);
2819

2820 2821 2822
	return 0;

err_add_port:
2823 2824
	kfree(atmel_port->rx_ring.buf);
	atmel_port->rx_ring.buf = NULL;
2825
err_alloc_ring:
2826 2827 2828
	if (!atmel_is_console_port(&atmel_port->uart)) {
		clk_put(atmel_port->clk);
		atmel_port->clk = NULL;
2829
	}
2830
err_clear_bit:
2831
	clear_bit(atmel_port->uart.line, atmel_ports_in_use);
2832
err:
2833 2834 2835
	return ret;
}

2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850
/*
 * Even if the driver is not modular, it makes sense to be able to
 * unbind a device: there can be many bound devices, and there are
 * situations where dynamic binding and unbinding can be useful.
 *
 * For example, a connected device can require a specific firmware update
 * protocol that needs bitbanging on IO lines, but use the regular serial
 * port in the normal case.
 */
static int atmel_serial_remove(struct platform_device *pdev)
{
	struct uart_port *port = platform_get_drvdata(pdev);
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
	int ret = 0;

2851 2852
	tasklet_kill(&atmel_port->tasklet_rx);
	tasklet_kill(&atmel_port->tasklet_tx);
2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869

	device_init_wakeup(&pdev->dev, 0);

	ret = uart_remove_one_port(&atmel_uart, port);

	kfree(atmel_port->rx_ring.buf);

	/* "port" is allocated statically, so we shouldn't free it */

	clear_bit(port->line, atmel_ports_in_use);

	clk_put(atmel_port->clk);
	atmel_port->clk = NULL;

	return ret;
}

2870 2871
static struct platform_driver atmel_serial_driver = {
	.probe		= atmel_serial_probe,
2872
	.remove		= atmel_serial_remove,
2873 2874
	.suspend	= atmel_serial_suspend,
	.resume		= atmel_serial_resume,
2875
	.driver		= {
2876 2877
		.name			= "atmel_usart",
		.of_match_table		= of_match_ptr(atmel_serial_dt_ids),
2878 2879 2880
	},
};

2881
static int __init atmel_serial_init(void)
2882 2883 2884
{
	int ret;

2885
	ret = uart_register_driver(&atmel_uart);
2886 2887 2888
	if (ret)
		return ret;

2889
	ret = platform_driver_register(&atmel_serial_driver);
2890
	if (ret)
2891
		uart_unregister_driver(&atmel_uart);
2892 2893 2894

	return ret;
}
2895
device_initcall(atmel_serial_init);