atmel_serial.c 74.5 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
	/* Disable modem control lines interrupts */
	atmel_disable_ms(port);

1943 1944 1945 1946 1947 1948
	/* 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);

1949 1950 1951 1952 1953 1954
	/*
	 * Prevent any tasklets being scheduled during
	 * cleanup
	 */
	del_timer_sync(&atmel_port->uart_timer);

1955 1956 1957
	/* Make sure that no interrupt is on the fly */
	synchronize_irq(port->irq);

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

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

1972
	atmel_uart_writel(port, ATMEL_US_CR, ATMEL_US_RSTSTA);
1973

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

1982 1983 1984 1985 1986 1987
	/*
	 * Reset ring buffer pointers
	 */
	atmel_port->rx_ring.head = 0;
	atmel_port->rx_ring.tail = 0;

1988
	/*
1989
	 * Free the interrupts
1990 1991
	 */
	free_irq(port->irq, port);
1992

1993
	atmel_flush_buffer(port);
1994 1995
}

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

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

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

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

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

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

2044 2045 2046
	/* 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);
2047

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

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

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

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

	spin_lock_irqsave(&port->lock, flags);

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

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

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

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

2117 2118 2119 2120 2121
	/*
	 * 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.
	 */
2122 2123
	imr = atmel_uart_readl(port, ATMEL_US_IMR);
	atmel_uart_writel(port, ATMEL_US_IDR, -1);
2124 2125

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

2128
	/* mode */
2129
	if (port->rs485.flags & SER_RS485_ENABLED) {
2130 2131
		atmel_uart_writel(port, ATMEL_US_TTGR,
				  port->rs485.delay_rts_after_send);
2132
		mode |= ATMEL_US_USMODE_RS485;
2133 2134
	} else if (termios->c_cflag & CRTSCTS) {
		/* RS232 with hardware handshake (RTS/CTS) */
2135 2136 2137 2138 2139 2140
		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;
		}
2141 2142 2143
	} else {
		/* RS232 without hadware handshake */
		mode |= ATMEL_US_USMODE_NORMAL;
2144 2145
	}

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

2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163
	/*
	 * 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;
		}

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

2167 2168 2169 2170 2171 2172
	/*
	 * 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
2173 2174 2175
	 * baudrate = selected clock / (16 * (CD + FP / 8))
	 * then
	 * 8 CD + FP = selected clock / (2 * baudrate)
2176 2177 2178
	 */
	if (atmel_port->has_frac_baudrate &&
	    (mode & ATMEL_US_USMODE) == ATMEL_US_USMODE_NORMAL) {
2179 2180 2181
		div = DIV_ROUND_CLOSEST(port->uartclk, baud * 2);
		cd = div >> 3;
		fp = div & ATMEL_US_FP_MASK;
2182 2183 2184 2185 2186 2187 2188 2189 2190 2191
	} 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;

2192 2193 2194
	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);
2195 2196

	/* restore interrupts */
2197
	atmel_uart_writel(port, ATMEL_US_IER, imr);
2198 2199 2200

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

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

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

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

/*
 * Release the memory region(s) being used by 'port'.
 */
2236
static void atmel_release_port(struct uart_port *port)
2237
{
2238 2239 2240 2241 2242 2243 2244 2245 2246
	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;
	}
2247 2248 2249 2250 2251
}

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

2257
	if (!request_mem_region(port->mapbase, size, "atmel_serial"))
2258 2259 2260 2261 2262 2263 2264 2265 2266
		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;
		}
	}
2267

2268
	return 0;
2269 2270 2271 2272 2273
}

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

/*
 * Verify the new serial_struct (for TIOCSSERIAL).
 */
2285
static int atmel_verify_port(struct uart_port *port, struct serial_struct *ser)
2286 2287
{
	int ret = 0;
2288
	if (ser->type != PORT_UNKNOWN && ser->type != PORT_ATMEL)
2289 2290 2291 2292 2293 2294 2295
		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;
2296
	if (port->mapbase != (unsigned long)ser->iomem_base)
2297 2298 2299 2300 2301 2302 2303 2304
		ret = -EINVAL;
	if (port->iobase != ser->port)
		ret = -EINVAL;
	if (ser->hub6 != 0)
		ret = -EINVAL;
	return ret;
}

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

2311
	return atmel_uart_read_char(port);
2312 2313 2314 2315
}

static void atmel_poll_put_char(struct uart_port *port, unsigned char ch)
{
2316
	while (!(atmel_uart_readl(port, ATMEL_US_CSR) & ATMEL_US_TXRDY))
2317 2318
		cpu_relax();

2319
	atmel_uart_write_char(port, ch);
2320 2321 2322
}
#endif

2323
static const struct uart_ops atmel_pops = {
2324 2325 2326 2327 2328 2329 2330 2331 2332 2333
	.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,
2334
	.flush_buffer	= atmel_flush_buffer,
2335
	.set_termios	= atmel_set_termios,
2336
	.set_ldisc	= atmel_set_ldisc,
2337 2338 2339 2340 2341 2342
	.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,
2343 2344 2345 2346
#ifdef CONFIG_CONSOLE_POLL
	.poll_get_char	= atmel_poll_get_char,
	.poll_put_char	= atmel_poll_put_char,
#endif
2347 2348
};

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

2359 2360
	atmel_init_property(atmel_port, pdev);
	atmel_set_ops(port);
2361

2362
	atmel_init_rs485(port, pdev);
2363

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

2373 2374
	memset(&atmel_port->rx_ring, 0, sizeof(atmel_port->rx_ring));

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

R
Remy Bohmer 已提交
2383 2384
	/* for console, the clock could already be configured */
	if (!atmel_port->clk) {
2385
		atmel_port->clk = clk_get(&pdev->dev, "usart");
2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396
		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;
		}
2397
		port->uartclk = clk_get_rate(atmel_port->clk);
2398
		clk_disable_unprepare(atmel_port->clk);
2399
		/* only enable clock when USART is in use */
2400
	}
C
Chip Coldwell 已提交
2401

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

	return 0;
2413 2414
}

2415 2416
struct platform_device *atmel_default_console_device;	/* the serial console device */

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

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

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

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

2446
	uart_console_write(port, s, count, atmel_console_putchar);
2447 2448

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

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

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

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

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

2481
	mr = atmel_uart_readl(port, ATMEL_US_MR) & ATMEL_US_CHRL;
2482
	if (mr == ATMEL_US_CHRL_8)
2483 2484 2485 2486
		*bits = 8;
	else
		*bits = 7;

2487
	mr = atmel_uart_readl(port, ATMEL_US_MR) & ATMEL_US_PAR;
2488
	if (mr == ATMEL_US_PAR_EVEN)
2489
		*parity = 'e';
2490
	else if (mr == ATMEL_US_PAR_ODD)
2491 2492
		*parity = 'o';

2493 2494 2495 2496 2497 2498 2499
	/*
	 * 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));
2500 2501
}

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

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

2516 2517 2518
	ret = clk_prepare_enable(atmel_ports[co->index].clk);
	if (ret)
		return ret;
2519

2520 2521 2522
	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);
2523 2524 2525 2526

	if (options)
		uart_parse_options(options, &baud, &parity, &bits, &flow);
	else
2527
		atmel_console_get_options(port, &baud, &parity, &bits);
2528 2529 2530 2531

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

2532
static struct uart_driver atmel_uart;
2533

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

2544
#define ATMEL_CONSOLE_DEVICE	(&atmel_console)
2545

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

2558 2559
		atmel_port->backup_imr = 0;
		atmel_port->uart.line = id;
2560

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

	return 0;
}
R
Remy Bohmer 已提交
2570

2571
console_initcall(atmel_console_init);
2572

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

	return 0;
}
R
Remy Bohmer 已提交
2584

2585
core_initcall(atmel_late_console_init);
2586

2587 2588 2589 2590 2591
static inline bool atmel_is_console_port(struct uart_port *port)
{
	return port->cons && port->cons->index == port->line;
}

2592
#else
2593
#define ATMEL_CONSOLE_DEVICE	NULL
2594 2595 2596 2597 2598

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

2601
static struct uart_driver atmel_uart = {
R
Remy Bohmer 已提交
2602 2603 2604 2605 2606 2607 2608
	.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,
2609 2610
};

2611
#ifdef CONFIG_PM
2612 2613 2614 2615 2616 2617 2618 2619 2620
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 已提交
2621 2622
static int atmel_serial_suspend(struct platform_device *pdev,
				pm_message_t state)
2623
{
2624
	struct uart_port *port = platform_get_drvdata(pdev);
2625
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2626

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

2634 2635
	/* we can not wake up if we're running on slow clock */
	atmel_port->may_wakeup = device_may_wakeup(&pdev->dev);
2636 2637 2638 2639 2640 2641
	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);
2642
		device_set_wakeup_enable(&pdev->dev, 0);
2643
	}
2644 2645

	uart_suspend_port(&atmel_uart, port);
2646

2647 2648
	return 0;
}
2649

2650
static int atmel_serial_resume(struct platform_device *pdev)
2651 2652
{
	struct uart_port *port = platform_get_drvdata(pdev);
2653
	struct atmel_uart_port *atmel_port = to_atmel_uart_port(port);
2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665
	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);
2666

2667 2668
	uart_resume_port(&atmel_uart, port);
	device_set_wakeup_enable(&pdev->dev, atmel_port->may_wakeup);
2669 2670 2671

	return 0;
}
2672
#else
2673 2674
#define atmel_serial_suspend NULL
#define atmel_serial_resume NULL
2675
#endif
2676

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

	if (of_property_read_u32(pdev->dev.of_node,
				 "atmel,fifo-size",
2686
				 &atmel_port->fifo_size))
2687 2688
		return;

2689
	if (!atmel_port->fifo_size)
2690 2691
		return;

2692 2693
	if (atmel_port->fifo_size < ATMEL_MIN_FIFO_SIZE) {
		atmel_port->fifo_size = 0;
2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705
		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.
	 */
2706 2707 2708 2709
	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);
2710 2711

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

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

2728
	BUILD_BUG_ON(ATMEL_SERIAL_RINGSIZE & (ATMEL_SERIAL_RINGSIZE - 1));
2729

2730 2731 2732 2733 2734
	if (np)
		ret = of_alias_get_id(np, "serial");
	else
		if (pdata)
			ret = pdata->num;
2735 2736

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

2741
	if (ret >= ATMEL_MAX_UART) {
2742 2743 2744 2745
		ret = -ENODEV;
		goto err;
	}

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

2752 2753 2754 2755
	atmel_port = &atmel_ports[ret];
	atmel_port->backup_imr = 0;
	atmel_port->uart.line = ret;
	atmel_serial_probe_fifos(atmel_port, pdev);
2756

2757
	atomic_set(&atmel_port->tasklet_shutdown, 0);
2758
	spin_lock_init(&atmel_port->lock_suspended);
2759

2760
	ret = atmel_init_port(atmel_port, pdev);
2761
	if (ret)
2762
		goto err_clear_bit;
2763

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

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

2779
	rs485_enabled = atmel_port->uart.rs485.flags & SER_RS485_ENABLED;
2780

2781
	ret = uart_add_one_port(&atmel_uart, &atmel_port->uart);
2782 2783 2784
	if (ret)
		goto err_add_port;

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

2796
	device_init_wakeup(&pdev->dev, 1);
2797
	platform_set_drvdata(pdev, atmel_port);
2798

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

2805
	if (rs485_enabled) {
2806
		atmel_uart_writel(&atmel_port->uart, ATMEL_US_MR,
2807
				  ATMEL_US_USMODE_NORMAL);
2808 2809
		atmel_uart_writel(&atmel_port->uart, ATMEL_US_CR,
				  ATMEL_US_RTSEN);
2810 2811
	}

2812 2813 2814
	/*
	 * Get port name of usart or uart
	 */
2815
	atmel_get_ip_name(&atmel_port->uart);
2816

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

2823 2824 2825
	return 0;

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

2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853
/*
 * 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;

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

	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;
}

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

2884
static int __init atmel_serial_init(void)
2885 2886 2887
{
	int ret;

2888
	ret = uart_register_driver(&atmel_uart);
2889 2890 2891
	if (ret)
		return ret;

2892
	ret = platform_driver_register(&atmel_serial_driver);
2893
	if (ret)
2894
		uart_unregister_driver(&atmel_uart);
2895 2896 2897

	return ret;
}
2898
device_initcall(atmel_serial_init);