|
|
|
/*
|
|
|
|
* Author: Xilinx, Inc.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" AS A
|
|
|
|
* COURTESY TO YOU. BY PROVIDING THIS DESIGN, CODE, OR INFORMATION AS
|
|
|
|
* ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, APPLICATION OR STANDARD,
|
|
|
|
* XILINX IS MAKING NO REPRESENTATION THAT THIS IMPLEMENTATION IS FREE
|
|
|
|
* FROM ANY CLAIMS OF INFRINGEMENT, AND YOU ARE RESPONSIBLE FOR OBTAINING
|
|
|
|
* ANY THIRD PARTY RIGHTS YOU MAY REQUIRE FOR YOUR IMPLEMENTATION.
|
|
|
|
* XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO
|
|
|
|
* THE ADEQUACY OF THE IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY
|
|
|
|
* WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM
|
|
|
|
* CLAIMS OF INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Xilinx hardware products are not intended for use in life support
|
|
|
|
* appliances, devices, or systems. Use in such applications is
|
|
|
|
* expressly prohibited.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* (c) Copyright 2002-2004 Xilinx Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* 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.,
|
|
|
|
* 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
|
|
|
#include <asm/u-boot.h>
|
|
|
|
#include <asm/processor.h>
|
|
|
|
#include <command.h>
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
|
|
|
|
#define USE_CHAN1 \
|
|
|
|
((defined XPAR_UARTNS550_0_BASEADDR) && (defined CONFIG_SYS_INIT_CHAN1))
|
|
|
|
#define USE_CHAN2 \
|
|
|
|
((defined XPAR_UARTNS550_1_BASEADDR) && (defined CONFIG_SYS_INIT_CHAN2))
|
|
|
|
|
|
|
|
#if USE_CHAN1
|
|
|
|
#include <ns16550.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if USE_CHAN1
|
|
|
|
const NS16550_t COM_PORTS[] = { (NS16550_t) (XPAR_UARTNS550_0_BASEADDR + 3)
|
|
|
|
#if USE_CHAN2
|
|
|
|
, (NS16550_t) (XPAR_UARTNS550_1_BASEADDR + 3)
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
int
|
|
|
|
serial_init(void)
|
|
|
|
{
|
|
|
|
#if USE_CHAN1
|
|
|
|
int clock_divisor;
|
|
|
|
|
|
|
|
clock_divisor = XPAR_UARTNS550_0_CLOCK_FREQ_HZ / 16 / gd->baudrate;
|
|
|
|
(void) NS16550_init(COM_PORTS[0], clock_divisor);
|
|
|
|
#if USE_CHAN2
|
|
|
|
clock_divisor = XPAR_UARTNS550_1_CLOCK_FREQ_HZ / 16 / gd->baudrate;
|
|
|
|
(void) NS16550_init(COM_PORTS[1], clock_divisor);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
serial_putc(const char c)
|
|
|
|
{
|
|
|
|
if (c == '\n')
|
|
|
|
NS16550_putc(COM_PORTS[CONFIG_SYS_DUART_CHAN], '\r');
|
|
|
|
|
|
|
|
NS16550_putc(COM_PORTS[CONFIG_SYS_DUART_CHAN], c);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
serial_getc(void)
|
|
|
|
{
|
|
|
|
return NS16550_getc(COM_PORTS[CONFIG_SYS_DUART_CHAN]);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
serial_tstc(void)
|
|
|
|
{
|
|
|
|
return NS16550_tstc(COM_PORTS[CONFIG_SYS_DUART_CHAN]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
serial_setbrg(void)
|
|
|
|
{
|
|
|
|
#if USE_CHAN1
|
|
|
|
int clock_divisor;
|
|
|
|
|
|
|
|
clock_divisor = XPAR_UARTNS550_0_CLOCK_FREQ_HZ / 16 / gd->baudrate;
|
|
|
|
NS16550_reinit(COM_PORTS[0], clock_divisor);
|
|
|
|
#if USE_CHAN2
|
|
|
|
clock_divisor = XPAR_UARTNS550_1_CLOCK_FREQ_HZ / 16 / gd->baudrate;
|
|
|
|
NS16550_reinit(COM_PORTS[1], clock_divisor);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
serial_puts(const char *s)
|
|
|
|
{
|
|
|
|
while (*s) {
|
|
|
|
serial_putc(*s++);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(CONFIG_CMD_KGDB)
|
|
|
|
void
|
|
|
|
kgdb_serial_init(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
putDebugChar(int c)
|
|
|
|
{
|
|
|
|
serial_putc(c);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
putDebugStr(const char *str)
|
|
|
|
{
|
|
|
|
serial_puts(str);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
getDebugChar(void)
|
|
|
|
{
|
|
|
|
return serial_getc();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
kgdb_interruptible(int yes)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
#endif
|