Newer
Older
barebox / arch / mips / mach-xburst / serial.c
@Antony Pavlov Antony Pavlov on 8 May 2013 1 KB MIPS: xburst: use common serial code
/*
 * Copyright (C) 2013 Antony Pavlov <antonynpavlov@gmail.com>
 *
 * Based on the linux kernel JZ4740 serial support:
 * Copyright (C) 2010, Lars-Peter Clausen <lars@metafoo.de>
 *
 * This file is part of barebox.
 * See file CREDITS for list of people who contributed to this project.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2
 * as published by the Free Software Foundation.
 *
 * 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.
 *
 */

#include <common.h>
#include <ns16550.h>
#include <io.h>
#include <mach/devices.h>

#define JZ_UART_SHIFT	2

#define ier		(1 << JZ_UART_SHIFT)
#define fcr		(2 << JZ_UART_SHIFT)

static void jz_serial_reg_write(unsigned int val, unsigned long base,
	unsigned char reg_offset)
{
	switch (reg_offset) {
	case fcr:
		val |= 0x10; /* Enable uart module */
		break;
	case ier:
		val |= (val & 0x4) << 2;
		break;
	default:
		break;
	}

	writeb(val & 0xff, (void *)(base + reg_offset));
}

struct device_d *jz_add_uart(int id, unsigned long base, unsigned int clock)
{
	struct NS16550_plat *serial_plat;

	serial_plat = xzalloc(sizeof(*serial_plat));

	serial_plat->shift = JZ_UART_SHIFT;
	serial_plat->reg_write = &jz_serial_reg_write;
	serial_plat->clock = clock;

	return add_ns16550_device(id, base, 8 << JZ_UART_SHIFT,
			IORESOURCE_MEM_8BIT, serial_plat);
}