Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/evbarm/stand/board On-chip EP93xx UART support



details:   https://anonhg.NetBSD.org/src/rev/c6db7dc95030
branches:  trunk
changeset: 572204:c6db7dc95030
user:      joff <joff%NetBSD.org@localhost>
date:      Fri Dec 24 10:34:27 2004 +0000

description:
On-chip EP93xx UART support

diffstat:

 sys/arch/evbarm/stand/board/epcom.c |  95 +++++++++++++++++++++++++++++++++++++
 1 files changed, 95 insertions(+), 0 deletions(-)

diffs (99 lines):

diff -r d0c8de3c73f7 -r c6db7dc95030 sys/arch/evbarm/stand/board/epcom.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/evbarm/stand/board/epcom.c       Fri Dec 24 10:34:27 2004 +0000
@@ -0,0 +1,95 @@
+/*     $NetBSD: epcom.c,v 1.1 2004/12/24 10:34:27 joff Exp $   */
+
+/*
+ * Copyright (c) 2004 Jesse Off
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed for the NetBSD Project by
+ *     Wasabi Systems, Inc.
+ * 4. The name of Wasabi Systems, Inc. may not be used to endorse
+ *    or promote products derived from this software without specific prior
+ *    written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL WASABI SYSTEMS, INC
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/* 
+ * This file provides the cons_init() function and console I/O routines
+ * for boards that use the ep93xx ARM SoC UARTs
+ */
+
+#include <sys/types.h>
+#include <arm/ep93xx/epcomreg.h>
+#include <arm/ep93xx/ep93xxreg.h>
+#include <lib/libsa/stand.h>
+
+#include "board.h"
+
+#define SCADDR (EP93XX_APB_HWBASE + EP93XX_APB_SYSCON)
+#define        EPCOM_READ(x)           *((__volatile uint32_t *) (CONADDR + (EPCOM_ ## x)))
+#define        EPCOM_WRITE(x, v)       *((__volatile uint32_t *) \
+                                       (CONADDR + (EPCOM_ ## x))) = (v)
+#define        SYSCON_READ(x)          *((__volatile uint32_t *) \
+                                       (SCADDR + (EP93XX_SYSCON_ ## x)))
+#define        SYSCON_WRITE(x, v)      *((__volatile uint32_t *) \
+                                       (SCADDR + (EP93XX_SYSCON_ ## x))) = (v)
+
+#define        ISSET(t,f)      ((t) & (f))
+
+void
+cons_init(void)
+{
+       unsigned long baud, pwrcnt;
+
+       while(!ISSET(EPCOM_READ(Flag), Flag_TXFE));
+
+       /* Make UART base freq 7Mhz */
+       pwrcnt = SYSCON_READ(PwrCnt);
+       pwrcnt &= ~(PwrCnt_UARTBAUD);
+       SYSCON_WRITE(PwrCnt, pwrcnt);
+
+       baud = EPCOMSPEED2BRD(CONSPEED);
+       EPCOM_WRITE(LinCtrlLow, baud & 0xff);
+       EPCOM_WRITE(LinCtrlMid, baud >> 8);
+       EPCOM_WRITE(LinCtrlHigh, LinCtrlHigh_FEN|LinCtrlHigh_WLEN);
+}
+
+int
+getchar(void)
+{
+       while(!ISSET(EPCOM_READ(Flag), Flag_RXFE));
+       return (EPCOM_READ(Data) & 0xff);
+}
+
+void
+putchar(int c)
+{
+       while(ISSET(EPCOM_READ(Flag), Flag_TXFF));
+
+       if (c == '\n') {
+               while(!ISSET(EPCOM_READ(Flag), Flag_TXFE));
+               EPCOM_WRITE(Data, '\r');
+       } 
+
+       EPCOM_WRITE(Data, c);
+}



Home | Main Index | Thread Index | Old Index