Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2780ad42 authored by Tobias Klauser's avatar Tobias Klauser Committed by Greg Kroah-Hartman
Browse files

tty: serial: altera_uart: Use port->regshift to store bus shift



Use the regshift member of struct uart_port to store the address stride
from platform data. This way we can save one dereference per call of
altera_uart_readl and altera_uart_writel.

This also allows us to use the driver without platform data, which is
needed for device tree support in the Nios2 port.

Acked-by: default avatarAnton Vorontsov <cbouatmailru@gmail.com>
Signed-off-by: default avatarTobias Klauser <tklauser@distanz.ch>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent e96fabd8
Loading
Loading
Loading
Loading
+7 −7
Original line number Original line Diff line number Diff line
@@ -86,16 +86,12 @@ struct altera_uart {


static u32 altera_uart_readl(struct uart_port *port, int reg)
static u32 altera_uart_readl(struct uart_port *port, int reg)
{
{
	struct altera_uart_platform_uart *platp = port->private_data;
	return readl(port->membase + (reg << port->regshift));

	return readl(port->membase + (reg << platp->bus_shift));
}
}


static void altera_uart_writel(struct uart_port *port, u32 dat, int reg)
static void altera_uart_writel(struct uart_port *port, u32 dat, int reg)
{
{
	struct altera_uart_platform_uart *platp = port->private_data;
	writel(dat, port->membase + (reg << port->regshift));

	writel(dat, port->membase + (reg << platp->bus_shift));
}
}


static unsigned int altera_uart_tx_empty(struct uart_port *port)
static unsigned int altera_uart_tx_empty(struct uart_port *port)
@@ -546,13 +542,17 @@ static int __devinit altera_uart_probe(struct platform_device *pdev)
	if (!port->membase)
	if (!port->membase)
		return -ENOMEM;
		return -ENOMEM;


	if (platp)
		port->regshift = platp->bus_shift;
	else
		port->regshift = 0;

	port->line = i;
	port->line = i;
	port->type = PORT_ALTERA_UART;
	port->type = PORT_ALTERA_UART;
	port->iotype = SERIAL_IO_MEM;
	port->iotype = SERIAL_IO_MEM;
	port->uartclk = platp->uartclk;
	port->uartclk = platp->uartclk;
	port->ops = &altera_uart_ops;
	port->ops = &altera_uart_ops;
	port->flags = UPF_BOOT_AUTOCONF;
	port->flags = UPF_BOOT_AUTOCONF;
	port->private_data = platp;


	uart_add_one_port(&altera_uart_driver, port);
	uart_add_one_port(&altera_uart_driver, port);