<div dir="ltr"><br><div class="gmail_extra">Hi Peng,</div><div class="gmail_extra"><br></div><div class="gmail_extra"><div class="gmail_quote">On 17 April 2013 11:35, Peng Fan <span dir="ltr"><<a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">If any questions, you may post on the mailing list not just me.<div>My Tiny6410 board is developed by Firendly ARM. </div>
</div></blockquote><div><br></div><div style>What I have here is a Witech OK6410 [1] I see both hardware uses the same core modules, so Will it be possible for me to use this patch to run RTEMS over this SBC? </div><div style>
 <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>It's web is here: <a href="http://www.friendlyarm.net/products/tiny6410" target="_blank">http://www.friendlyarm.net/products/tiny6410</a></div>
<div>The patch now is simple, only support timer and serial, with most of</div><div>the hardware configuration done in uboot.Now, I am also trying to</div><div>add nand support. It does run on my board. You may try.</div>
</div></blockquote><div><br></div><div style>Can you document the steps to load the image into the board and also the u-boot tweaks you did somewhere in wiki? </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="ltr">
<div>Â Any problem, post it to the mailing list. Thanks.</div><div><br></div><div>Regards,</div><div>Peng.</div><div><br></div></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><br><div class="gmail_quote">
2013/4/17 Dhananjay Balan <span dir="ltr"><<a href="mailto:mb.dhananjay@gmail.com" target="_blank">mb.dhananjay@gmail.com</a>></span><br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p>Hi,<br>
I have with me an Chineese ARM SBC built around Samsung 6410. It is manufactured by witech Inc. Does this mean I can run RTEMS on it?</p>
<div class="gmail_quote"><div><div>On Apr 17, 2013 11:01 AM, "Peng Fan" <<a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a>> wrote:<br type="attribution"></div></div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
---<br>
 c/src/lib/libbsp/arm/Makefile.am          |   1 +<br>
 c/src/lib/libbsp/arm/acinclude.m4          |   2 +<br>
 c/src/lib/libbsp/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a>         |   4 +<br>
 c/src/lib/libbsp/arm/shared/startup/linkcmds.armv6 |  26 +++<br>
 c/src/lib/libbsp/arm/tiny6410/Makefile.am      |  62 ++++++<br>
 c/src/lib/libbsp/arm/tiny6410/README        |  23 ++<br>
 c/src/lib/libbsp/arm/tiny6410/bsp_specs       |  13 ++<br>
 c/src/lib/libbsp/arm/tiny6410/<a href="http://configure.ac" target="_blank">configure.ac</a>     |  23 ++<br>
 c/src/lib/libbsp/arm/tiny6410/console/uart.c    |  229 ++++++++++++++++++++<br>
 c/src/lib/libbsp/arm/tiny6410/debug/debug.c     |  60 +++++<br>
 c/src/lib/libbsp/arm/tiny6410/include/bsp.h     |  60 +++++<br>
 .../libbsp/arm/tiny6410/make/custom/tiny6410.cfg  |  21 ++<br>
 c/src/lib/libbsp/arm/tiny6410/<a href="http://preinstall.am" target="_blank">preinstall.am</a>     |  83 +++++++<br>
 c/src/lib/libbsp/arm/tiny6410/sh-hello       |  13 ++<br>
 c/src/lib/libbsp/arm/tiny6410/startup/bspidle.c   |  25 +++<br>
 c/src/lib/libbsp/arm/tiny6410/startup/bspreset.c  |  37 ++++<br>
 c/src/lib/libbsp/arm/tiny6410/startup/bspstart.c  |  83 +++++++<br>
 .../libbsp/arm/tiny6410/startup/bspstarthooks.c   |  146 +++++++++++++<br>
 c/src/lib/libbsp/arm/tiny6410/startup/linkcmds   |  25 +++<br>
 c/src/lib/libbsp/arm/tiny6410/startup/memmap.c   |  29 +++<br>
 c/src/lib/libcpu/arm/Makefile.am          |  25 +++<br>
 c/src/lib/libcpu/arm/<a href="http://configure.ac" target="_blank">configure.ac</a>          |   2 +<br>
 c/src/lib/libcpu/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a>         |  13 ++<br>
 c/src/lib/libcpu/arm/s3c64xx/clock/clockdrv.c    |  141 ++++++++++++<br>
 c/src/lib/libcpu/arm/s3c64xx/clock/support.c    |  51 +++++<br>
 c/src/lib/libcpu/arm/s3c64xx/include/s3c6410.h   |  211 ++++++++++++++++++<br>
 c/src/lib/libcpu/arm/s3c64xx/include/s3c64xx.h   |  15 ++<br>
 c/src/lib/libcpu/arm/s3c64xx/irq/irq.c       |  79 +++++++<br>
 c/src/lib/libcpu/arm/s3c64xx/irq/irq.h       |  100 +++++++++<br>
 c/src/lib/libcpu/arm/shared/include/arm-cp15.h   |  17 ++<br>
 30 files changed, 1619 insertions(+)<br>
 create mode 100644 c/src/lib/libbsp/arm/shared/startup/linkcmds.armv6<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/Makefile.am<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/README<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/bsp_specs<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/console/uart.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/debug/debug.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/include/bsp.h<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/make/custom/tiny6410.cfg<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
 create mode 100755 c/src/lib/libbsp/arm/tiny6410/sh-hello<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/bspidle.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/bspreset.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/bspstart.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/bspstarthooks.c<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/linkcmds<br>
 create mode 100644 c/src/lib/libbsp/arm/tiny6410/startup/memmap.c<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/clock/clockdrv.c<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/clock/support.c<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/include/s3c6410.h<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/include/s3c64xx.h<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/irq/irq.c<br>
 create mode 100644 c/src/lib/libcpu/arm/s3c64xx/irq/irq.h<br>
<br>
diff --git a/c/src/lib/libbsp/arm/Makefile.am b/c/src/lib/libbsp/arm/Makefile.am<br>
index 9783354..bd2ee0c 100644<br>
--- a/c/src/lib/libbsp/arm/Makefile.am<br>
+++ b/c/src/lib/libbsp/arm/Makefile.am<br>
@@ -10,6 +10,7 @@ include_bsp_HEADERS = shared/include/linker-symbols.h<br>
<br>
 dist_project_lib_DATA = shared/startup/linkcmds.base<br>
 dist_project_lib_DATA += shared/startup/linkcmds.armv4<br>
+dist_project_lib_DATA += shared/startup/linkcmds.armv6<br>
 dist_project_lib_DATA += shared/startup/linkcmds.armv7m<br>
<br>
 EXTRA_DIST =<br>
diff --git a/c/src/lib/libbsp/arm/acinclude.m4 b/c/src/lib/libbsp/arm/acinclude.m4<br>
index 9512b26..277c144 100644<br>
--- a/c/src/lib/libbsp/arm/acinclude.m4<br>
+++ b/c/src/lib/libbsp/arm/acinclude.m4<br>
@@ -30,6 +30,8 @@ AC_DEFUN([RTEMS_CHECK_BSPDIR],<br>
   AC_CONFIG_SUBDIRS([smdk2410]);;<br>
  stm32f4 )<br>
   AC_CONFIG_SUBDIRS([stm32f4]);;<br>
+ Â tiny6410 )<br>
+ Â Â AC_CONFIG_SUBDIRS([tiny6410]);;<br>
  *)<br>
   AC_MSG_ERROR([Invalid BSP]);;<br>
  esac<br>
diff --git a/c/src/lib/libbsp/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a> b/c/src/lib/libbsp/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
index 3e66ebe..75e8dfa 100644<br>
--- a/c/src/lib/libbsp/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
+++ b/c/src/lib/libbsp/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
@@ -35,6 +35,10 @@ $(PROJECT_LIB)/linkcmds.armv4: shared/startup/linkcmds.armv4 $(PROJECT_LIB)/$(di<br>
    $(INSTALL_DATA) $< $(PROJECT_LIB)/linkcmds.armv4<br>
 PREINSTALL_FILES += $(PROJECT_LIB)/linkcmds.armv4<br>
<br>
+$(PROJECT_LIB)/linkcmds.armv6: shared/startup/linkcmds.armv6 $(PROJECT_LIB)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_LIB)/linkcmds.armv6<br>
+PREINSTALL_FILES += $(PROJECT_LIB)/linkcmds.armv6<br>
+<br>
 $(PROJECT_LIB)/linkcmds.armv7m: shared/startup/linkcmds.armv7m $(PROJECT_LIB)/$(dirstamp)<br>
    $(INSTALL_DATA) $< $(PROJECT_LIB)/linkcmds.armv7m<br>
 PREINSTALL_FILES += $(PROJECT_LIB)/linkcmds.armv7m<br>
diff --git a/c/src/lib/libbsp/arm/shared/startup/linkcmds.armv6 b/c/src/lib/libbsp/arm/shared/startup/linkcmds.armv6<br>
new file mode 100644<br>
index 0000000..16fa3ef<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/shared/startup/linkcmds.armv6<br>
@@ -0,0 +1,26 @@<br>
+/**<br>
+ * @file<br>
+ *<br>
+ * @ingroup bsp_linker<br>
+ *<br>
+ * @brief Linker command file for ARMv6 architecture.<br>
+ */<br>
+<br>
+/*<br>
+ * Copyright (c) 2010 embedded brains GmbH. Â All rights reserved.<br>
+ *<br>
+ * Â embedded brains GmbH<br>
+ * Â Obere Lagerstr. 30<br>
+ * Â 82178 Puchheim<br>
+ * Â Germany<br>
+ * Â <<a href="mailto:rtems@embedded-brains.de" target="_blank">rtems@embedded-brains.de</a>><br>
+ *<br>
+ * The license and distribution terms for this file may be<br>
+ * found in the file LICENSE in this distribution or at<br>
+ * <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ */<br>
+<br>
+bsp_stack_svc_size = DEFINED (bsp_stack_svc_size) ? bsp_stack_svc_size : 4096;<br>
+bsp_stack_svc_size = ALIGN (bsp_stack_svc_size, bsp_stack_align);<br>
+<br>
+INCLUDE linkcmds.base<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/Makefile.am b/c/src/lib/libbsp/arm/tiny6410/Makefile.am<br>
new file mode 100644<br>
index 0000000..e49dc3a<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/Makefile.am<br>
@@ -0,0 +1,62 @@<br>
+ACLOCAL_AMFLAGS = -I ../../../../aclocal<br>
+<br>
+include $(top_srcdir)/../../../../automake/<a href="http://compile.am" target="_blank">compile.am</a><br>
+<br>
+include_bspdir = $(includedir)/bsp<br>
+<br>
+dist_project_lib_DATA = bsp_specs<br>
+<br>
+include_HEADERS = include/bsp.h<br>
+include_HEADERS += ../../shared/include/tm27.h<br>
+<br>
+include_bsp_HEADERS = ../shared/include/start.h<br>
+include_bsp_HEADERS += ../shared/include/linker-symbols.h<br>
+<br>
+nodist_include_HEADERS = include/bspopts.h<br>
+nodist_include_bsp_HEADERS = ../../shared/include/bootcard.h<br>
+DISTCLEANFILES = include/bspopts.h<br>
+<br>
+nodist_include_HEADERS += ../../shared/include/coverhd.h<br>
+<br>
+noinst_LIBRARIES = libbspstart.a<br>
+libbspstart_a_SOURCES = ../shared/start/start.S<br>
+#libbspstart_a_SOURCES = start/start.S<br>
+project_lib_DATA = start.$(OBJEXT)<br>
+<br>
+dist_project_lib_DATA += startup/linkcmds<br>
+<br>
+noinst_LIBRARIES += libbsp.a<br>
+libbsp_a_SOURCES =<br>
+<br>
+# startup<br>
+libbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S<br>
+libbsp_a_SOURCES += ../../shared/bsplibc.c ../../shared/bsppost.c \<br>
+ Â Â ../../shared/bsppredriverhook.c ../../shared/bspgetworkarea.c \<br>
+ Â Â ../../shared/bsppretaskinghook.c startup/bspstart.c startup/bspidle.c \<br>
+ Â Â ../../shared/bspclean.c startup/bspreset.c \<br>
+ Â Â startup/memmap.c ../../shared/bootcard.c ../../shared/sbrk.c \<br>
+ Â Â ../../shared/gnatinstallhandler.c startup/bspstarthooks.c<br>
+# low-level debug<br>
+libbsp_a_SOURCES += debug/debug.c<br>
+# console<br>
+libbsp_a_SOURCES += console/uart.c ../../shared/console.c \<br>
+   ../../shared/console_select.c  ../../shared/console_control.c \<br>
+ Â Â ../../shared/console_read.c ../../shared/console_write.c<br>
+# IRQ<br>
+include_bsp_HEADERS += ../../shared/include/irq-generic.h \<br>
+ Â Â Â ../../shared/include/irq-info.h<br>
+libbsp_a_SOURCES += ../../shared/src/irq-default-handler.c<br>
+libbsp_a_SOURCES += ../../shared/src/irq-generic.c<br>
+libbsp_a_SOURCES += ../../shared/src/irq-info.c<br>
+libbsp_a_SOURCES += ../../shared/src/irq-legacy.c<br>
+libbsp_a_SOURCES += ../../shared/src/irq-server.c<br>
+libbsp_a_SOURCES += ../../shared/src/irq-shell.c<br>
+# abort<br>
+libbsp_a_SOURCES += ../shared/abort/abort.c<br>
+<br>
+libbsp_a_LIBADD = ../../../libcpu/@RTEMS_CPU@/shared/arm920.rel \<br>
+ Â Â ../../../libcpu/@RTEMS_CPU@/s3c64xx/clock.rel \<br>
+ Â Â ../../../libcpu/@RTEMS_CPU@/s3c64xx/irq.rel<br>
+<br>
+include $(srcdir)/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
+include $(top_srcdir)/../../../../automake/<a href="http://local.am" target="_blank">local.am</a><br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/README b/c/src/lib/libbsp/arm/tiny6410/README<br>
new file mode 100644<br>
index 0000000..ae936e5<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/README<br>
@@ -0,0 +1,23 @@<br>
+This is the BSP for FriendlyARM tiny6410 board, a single board<br>
+computer using the Samsung S3C6410 SoC CPU.<br>
+S3C6410 is an arm1176jzf-s processor. About the mmu related,<br>
+still use the arm920 mmu management.This may be seperated,<br>
+for there may some difference between 920 and 1176jzf-s.<br>
+<br>
+Most of the hardware configuration is done in uboot.This maybe<br>
+migrated to rtems from uboot in future.<br>
+<br>
+Now only serial and timer is supported, other IP modules' driver<br>
+will be added in future.<br>
+<br>
+hello.exe ticker.exe nsecs.exe runs. Others have not been tested.<br>
+<br>
+How to use this bsp<br>
+1. When downloaded the source, first "bootstrap -c; bootstrap -p;<br>
+bootstrap"<br>
+2. Look at the sh-hello script to know how to configure for this bsp<br>
+4. use dnw to download the bin file to 0xC0104000<br>
+ Â Â Â Â MINI6410 # dnw 0xc0104000<br>
+ Â Â Â Â When finished download, use go command to run the bin file<br>
+ Â Â Â Â MINI6410 # go 0xc0104000<br>
+<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/bsp_specs b/c/src/lib/libbsp/arm/tiny6410/bsp_specs<br>
new file mode 100644<br>
index 0000000..082653a<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/bsp_specs<br>
@@ -0,0 +1,13 @@<br>
+%rename endfile old_endfile<br>
+%rename startfile old_startfile<br>
+%rename link old_link<br>
+<br>
+*startfile:<br>
+%{!qrtems: %(old_startfile)} \<br>
+%{!nostdlib: %{qrtems: start.o%s crti.o%s crtbegin.o%s -e _start}}<br>
+<br>
+*link:<br>
+%{!qrtems: %(old_link)} %{qrtems: -dc -dp -N}<br>
+<br>
+*endfile:<br>
+%{!qrtems: *(old_endfiles)} %{qrtems: crtend.o%s crtn.o%s }<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/<a href="http://configure.ac" target="_blank">configure.ac</a> b/c/src/lib/libbsp/arm/tiny6410/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
new file mode 100644<br>
index 0000000..11966e0<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
@@ -0,0 +1,23 @@<br>
+## Process this file with autoconf to produce a configure script.<br>
+<br>
+AC_PREREQ([2.69])<br>
+AC_INIT([rtems-c-src-lib-libbsp-arm-tiny6410],[_RTEMS_VERSION],[<a href="http://www.rtems.org/bugzilla" target="_blank">http://www.rtems.org/bugzilla</a>])<br>
+AC_CONFIG_SRCDIR([bsp_specs])<br>
+RTEMS_TOP(../../../../../..)<br>
+<br>
+RTEMS_CANONICAL_TARGET_CPU<br>
+AM_INIT_AUTOMAKE([no-define nostdinc foreign 1.12.2])<br>
+RTEMS_BSP_CONFIGURE<br>
+<br>
+RTEMS_PROG_CC_FOR_TARGET<br>
+RTEMS_CANONICALIZE_TOOLS<br>
+RTEMS_PROG_CCAS<br>
+<br>
+RTEMS_CHECK_NETWORKING<br>
+AM_CONDITIONAL(HAS_NETWORKING,test "$HAS_NETWORKING" = "yes")<br>
+<br>
+RTEMS_BSP_CLEANUP_OPTIONS(0, 1)<br>
+<br>
+# Explicitly list all Makefiles here<br>
+AC_CONFIG_FILES([Makefile])<br>
+AC_OUTPUT<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/console/uart.c b/c/src/lib/libbsp/arm/tiny6410/console/uart.c<br>
new file mode 100644<br>
index 0000000..46b5edb<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/console/uart.c<br>
@@ -0,0 +1,229 @@<br>
+/*<br>
+ * Â console driver for S3C2400 UARTs<br>
+ *<br>
+ * Â This driver uses the shared console driver in<br>
+ * Â ...../libbsp/shared/console.c<br>
+ *<br>
+ * Â If you want the driver to be interrupt driven, you<br>
+ * Â need to write the ISR, and in the ISR insert the<br>
+ * Â chars into termios's queue.<br>
+ *<br>
+ * Â Copyright (c) 2004 Cogent Computer Systems<br>
+ * Â Written by Jay Monkman <<a href="mailto:jtm@lopingdog.com" target="_blank">jtm@lopingdog.com</a>><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ *<br>
+ * 1. Modified from S3C2400 Â Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+*/<br>
+#include <bsp.h> Â Â Â Â Â Â Â Â /* Must be before libio.h */<br>
+#include <rtems/libio.h><br>
+#include <termios.h><br>
+#include <rtems/bspIo.h><br>
+<br>
+/* Put the CPU (or UART) specific header file #include here */<br>
+#include <s3c64xx.h><br>
+#include <libchip/serial.h><br>
+#include <libchip/sersupp.h><br>
+<br>
+/* How many serial ports? */<br>
+#define NUM_DEVS Â Â Â 1<br>
+<br>
+int   uart_poll_read(int minor);<br>
+<br>
+int dbg_dly;<br>
+<br>
+/* static function prototypes */<br>
+static int   uart_first_open(int major, int minor, void *arg);<br>
+static int   uart_last_close(int major, int minor, void *arg);<br>
+static int   uart_read(int minor);<br>
+static ssize_t uart_write(int minor, const char *buf, size_t len);<br>
+static void   uart_init(int minor);<br>
+static void   uart_write_polled(int minor, char c);<br>
+static int   uart_set_attributes(int minor, const struct termios *t);<br>
+<br>
+/* These are used by code in console.c */<br>
+unsigned long Console_Configuration_Count = NUM_DEVS;<br>
+<br>
+/* Pointers to functions for handling the UART. */<br>
+const console_fns uart_fns =<br>
+{<br>
+ Â Â libchip_serial_default_probe,<br>
+ Â Â uart_first_open,<br>
+ Â Â uart_last_close,<br>
+ Â Â uart_read,<br>
+ Â Â uart_write,<br>
+ Â Â uart_init,<br>
+ Â Â uart_write_polled, Â /* not used in this driver */<br>
+ Â Â uart_set_attributes,<br>
+ Â Â FALSE Â Â Â /* TRUE if interrupt driven, FALSE if not. */<br>
+};<br>
+<br>
+/*<br>
+ * There's one item in array for each UART.<br>
+ *<br>
+ * Some of these fields are marked "NOT USED". They are not used<br>
+ * by console.c, but may be used by drivers in libchip<br>
+ *<br>
+ */<br>
+console_tbl Console_Configuration_Ports[] = {<br>
+ Â Â {<br>
+ Â Â Â Â "/dev/com0", Â Â Â Â Â Â Â Â Â Â Â /* sDeviceName */<br>
+ Â Â Â Â SERIAL_CUSTOM, Â Â Â Â Â Â Â Â Â Â /* deviceType */<br>
+ Â Â Â Â &uart_fns, Â Â Â Â Â Â Â Â Â Â Â Â /* pDeviceFns */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* deviceProbe */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* pDeviceFlow */<br>
+ Â Â Â Â 0, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulMargin - NOT USED */<br>
+ Â Â Â Â 0, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulHysteresis - NOT USED */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* pDeviceParams */<br>
+ Â Â Â Â 0, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulCtrlPort1 Â - NOT USED */<br>
+ Â Â Â Â 0, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulCtrlPort2 Â - NOT USED */<br>
+     0,                 /* ulDataPort  - NOT USED */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* getRegister - NOT USED */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* setRegister - NOT USED */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* getData - NOT USED */<br>
+ Â Â Â Â NULL, Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* setData - NOT USED */<br>
+ Â Â Â Â 0, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulClock - NOT USED */<br>
+ Â Â Â Â 0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â /* ulIntVector - NOT USED */<br>
+ Â Â }<br>
+};<br>
+<br>
+/*********************************************************************/<br>
+/* Functions called via termios callbacks (i.e. the ones in uart_fns */<br>
+/*********************************************************************/<br>
+<br>
+/*<br>
+ * This is called the first time each device is opened. If the driver<br>
+ * is interrupt driven, you should enable interrupts here. Otherwise,<br>
+ * it's probably safe to do nothing.<br>
+ *<br>
+ * Since micromonitor already set up the UART, we do nothing.<br>
+ */<br>
+static int uart_first_open(int major, int minor, void *arg)<br>
+{<br>
+ Â Â return 0;<br>
+}<br>
+<br>
+<br>
+/*<br>
+ * This is called the last time each device is closed. If the driver<br>
+ * is interrupt driven, you should disable interrupts here. Otherwise,<br>
+ * it's probably safe to do nothing.<br>
+ */<br>
+static int uart_last_close(int major, int minor, void *arg)<br>
+{<br>
+ Â Â return 0;<br>
+}<br>
+<br>
+<br>
+/*<br>
+ * Read one character from UART.<br>
+ *<br>
+ * Return -1 if there's no data, otherwise return<br>
+ * the character in lowest 8 bits of returned int.<br>
+ */<br>
+static int uart_read(int minor)<br>
+{<br>
+ Â Â char c;<br>
+<br>
+ Â Â if (minor == 0) {<br>
+ Â Â Â Â if (rUTRSTAT0 & 0x1) {<br>
+ Â Â Â Â Â Â c = rURXH0 & 0xff;<br>
+ Â Â Â Â Â Â return c;<br>
+ Â Â Â Â } else {<br>
+ Â Â Â Â Â Â return -1;<br>
+ Â Â Â Â }<br>
+ Â Â } else {<br>
+ Â Â Â Â printk("Unknown console minor number: %d\n", minor);<br>
+ Â Â Â Â return -1;<br>
+ Â Â }<br>
+<br>
+}<br>
+<br>
+<br>
+/*<br>
+ * Write buffer to UART<br>
+ *<br>
+ * return 1 on success, -1 on error<br>
+ */<br>
+static ssize_t uart_write(int minor, const char *buf, size_t len)<br>
+{<br>
+ Â Â int i;<br>
+<br>
+ Â Â if (minor == 0) {<br>
+ Â Â Â Â for (i = 0; i < len; i++) {<br>
+ Â Â Â Â Â Â /* Wait for fifo to have room */<br>
+ Â Â Â Â Â Â while(!(rUTRSTAT0 & 0x2)) {<br>
+ Â Â Â Â Â Â Â Â continue;<br>
+ Â Â Â Â Â Â }<br>
+<br>
+ Â Â Â Â Â rUTXH0 = (char) buf[i];<br>
+ Â Â Â Â }<br>
+ Â Â } else {<br>
+ Â Â Â Â printk("Unknown console minor number: %d\n", minor);<br>
+ Â Â Â Â return -1;<br>
+ Â Â }<br>
+<br>
+ Â Â return 1;<br>
+}<br>
+<br>
+<br>
+/* Set up the UART. */<br>
+static void uart_init(int minor)<br>
+{<br>
+ Â Â Â int i;<br>
+ Â Â Â unsigned int reg = 0;<br>
+ Â Â Â /* Migrate the configuration from uboot in future */<br>
+ Â Â Â Uart_SendString(__func__);<br>
+}<br>
+<br>
+/* I'm not sure this is needed for the shared console driver. */<br>
+static void   uart_write_polled(int minor, char c)<br>
+{<br>
+ Â Â uart_write(minor, &c, 1);<br>
+}<br>
+<br>
+/* This is for setting baud rate, bits, etc. */<br>
+static int   uart_set_attributes(int minor, const struct termios *t)<br>
+{<br>
+ Â Â return 0;<br>
+}<br>
+<br>
+/***********************************************************************/<br>
+/*<br>
+ * The following functions are not used by TERMIOS, but other RTEMS<br>
+ * functions use them instead.<br>
+ */<br>
+/***********************************************************************/<br>
+/*<br>
+ * Read from UART. This is used in the exit code, and can't<br>
+ * rely on interrupts.<br>
+*/<br>
+int uart_poll_read(int minor)<br>
+{<br>
+ Â Â return uart_read(minor);<br>
+}<br>
+<br>
+<br>
+/*<br>
+ * Write a character to the console. This is used by printk() and<br>
+ * maybe other low level functions. It should not use interrupts or any<br>
+ * RTEMS system calls. It needs to be very simple<br>
+ */<br>
+static void _BSP_put_char( char c ) {<br>
+ Â Â uart_write_polled(0, c);<br>
+ Â Â if (c == '\n') {<br>
+ Â Â Â Â uart_write_polled(0, '\r');<br>
+ Â Â }<br>
+}<br>
+<br>
+BSP_output_char_function_type BSP_output_char = _BSP_put_char;<br>
+<br>
+static int _BSP_get_char(void)<br>
+{<br>
+ Â return uart_poll_read(0);<br>
+}<br>
+<br>
+BSP_polling_getchar_function_type BSP_poll_char = _BSP_get_char;<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/debug/debug.c b/c/src/lib/libbsp/arm/tiny6410/debug/debug.c<br>
new file mode 100644<br>
index 0000000..139b21e<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/debug/debug.c<br>
@@ -0,0 +1,60 @@<br>
+/**<br>
+ * @file<br>
+ *<br>
+ * @ingroup s3c64xx<br>
+ *<br>
+ * @brief Low level Debug code.<br>
+ */<br>
+<br>
+/*<br>
+ *<br>
+ * The license and distribution terms for this file may be<br>
+ * found in the file LICENSE in this distribution or at<br>
+ * <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ */<br>
+<br>
+#include <bsp.h><br>
+#include <s3c64xx.h><br>
+void debug_led(uint32_t val)<br>
+{<br>
+ Â Â Â uint32_t *addr = (uint32_t *)0x7f008800;<br>
+ Â Â Â *addr = val;<br>
+}<br>
+<br>
+<br>
+static void Delay(void)<br>
+{<br>
+ Â Â volatile int i;<br>
+<br>
+ Â Â for(i=0 ; i < 1000 ; i++)<br>
+ Â Â {<br>
+ Â Â }<br>
+}<br>
+void Uart_SendByte(int data)<br>
+{<br>
+ Â Â while(!(rUTRSTAT0 & 0x2)); Â //Wait until THR is empty.<br>
+ Â Â Delay();<br>
+ Â Â rUTXH0 = (unsigned char)data;<br>
+}<br>
+<br>
+void Uart_SendString(char *pt)<br>
+{<br>
+ Â Â while(*pt)<br>
+ Â Â Â Â Uart_SendByte(*pt++);<br>
+ Â Â Uart_SendByte('\r');<br>
+ Â Â Uart_SendByte('\n');<br>
+}<br>
+void printhex(unsigned int data)<br>
+{<br>
+ Â Â Â int i = 0,a = 0;<br>
+ Â Â Â for (i = 0; i < 8; i++) {<br>
+ Â Â Â Â Â Â Â a = (data>>(32-(i+1)*4))&0xf;<br>
+ Â Â Â Â Â Â Â if (((a<=9)&&(a>=0)))<br>
+ Â Â Â Â Â Â Â Â Â Â Â Uart_SendByte(a + 0x30);<br>
+ Â Â Â Â Â Â Â else if ((a <= 0xf) && (a >= 0xa))<br>
+ Â Â Â Â Â Â Â Â Â Â Â Uart_SendByte(a-0xa+0x61);<br>
+ Â Â Â }<br>
+ Â Â Â Uart_SendByte('\r');<br>
+ Â Â Â Uart_SendByte('\n');<br>
+}<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/include/bsp.h b/c/src/lib/libbsp/arm/tiny6410/include/bsp.h<br>
new file mode 100644<br>
index 0000000..699fdab<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/include/bsp.h<br>
@@ -0,0 +1,60 @@<br>
+/**<br>
+ * Â @file<br>
+ *<br>
+ * Â This include file contains definitions related to the GP32 BSP.<br>
+ */<br>
+<br>
+/*<br>
+ * Â Copyright (c) 2013<br>
+ * Â ASIC Engineering Center<br>
+ * Â Nanjing, China<br>
+ * Â <<a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a>><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ */<br>
+<br>
+#ifndef _BSP_H<br>
+#define _BSP_H<br>
+<br>
+#ifdef __cplusplus<br>
+extern "C" {<br>
+#endif<br>
+<br>
+#include <bspopts.h><br>
+#include <bsp/default-initial-extension.h><br>
+<br>
+#include <rtems.h><br>
+#include <rtems/iosupp.h><br>
+#include <rtems/console.h><br>
+#include <rtems/clockdrv.h><br>
+#include <s3c64xx.h><br>
+<br>
+#define BSP_FEATURE_IRQ_EXTENSION<br>
+<br>
+<br>
+/*functions to get the differents s3c2400 clks*/<br>
+uint32_t get_FCLK(void);<br>
+uint32_t get_HCLK(void);<br>
+uint32_t get_PCLK(void);<br>
+uint32_t get_UCLK(void);<br>
+<br>
+<br>
+<br>
+<br>
+/*<br>
+ * Â This BSP provides its own IDLE thread to override the RTEMS one.<br>
+ * Â So we prototype it and define the constant confdefs.h expects<br>
+ * Â to configure a BSP specific one.<br>
+ */<br>
+void *bsp_idle_thread(uintptr_t ignored);<br>
+<br>
+#define BSP_IDLE_TASK_BODY bsp_idle_thread<br>
+<br>
+#ifdef __cplusplus<br>
+}<br>
+#endif<br>
+<br>
+#endif /* _BSP_H */<br>
+<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/make/custom/tiny6410.cfg b/c/src/lib/libbsp/arm/tiny6410/make/custom/tiny6410.cfg<br>
new file mode 100644<br>
index 0000000..44b0ca6<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/make/custom/tiny6410.cfg<br>
@@ -0,0 +1,21 @@<br>
+#<br>
+# Â Config file for ARM S3C6410<br>
+#<br>
+<br>
+include $(RTEMS_ROOT)/make/custom/default.cfg<br>
+<br>
+RTEMS_CPU=arm<br>
+RTEMS_CPU_MODEL=s3c6410<br>
+<br>
+# Â This contains the compiler options necessary to select the CPU model<br>
+# Â and (hopefully) optimize for it.<br>
+#<br>
+CPU_CFLAGS = -mstructure-size-boundary=32 -mcpu=arm1176jzf-s -mfpu=vfp -mfloat-abi=soft -DCPU_S3C6410<br>
+<br>
+# optimize flag: typically -O2<br>
+CFLAGS_OPTIMIZE_V = -O2 -g<br>
+<br>
+define bsp-post-link<br>
+ Â Â Â $(OBJCOPY) -O binary $(basename $@).exe $(basename $@)$(DOWNEXT)<br>
+ Â Â Â $(default-bsp-post-link)<br>
+endef<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/<a href="http://preinstall.am" target="_blank">preinstall.am</a> b/c/src/lib/libbsp/arm/tiny6410/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
new file mode 100644<br>
index 0000000..ca20008<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
@@ -0,0 +1,83 @@<br>
+## Automatically generated by ampolish3 - Do not edit<br>
+<br>
+if AMPOLISH3<br>
+$(srcdir)/<a href="http://preinstall.am" target="_blank">preinstall.am</a>: Makefile.am<br>
+ Â Â Â $(AMPOLISH3) $(srcdir)/Makefile.am > $(srcdir)/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
+endif<br>
+<br>
+PREINSTALL_DIRS =<br>
+DISTCLEANFILES += $(PREINSTALL_DIRS)<br>
+<br>
+all-local: $(TMPINSTALL_FILES)<br>
+<br>
+TMPINSTALL_FILES =<br>
+CLEANFILES = $(TMPINSTALL_FILES)<br>
+<br>
+all-am: $(PREINSTALL_FILES)<br>
+<br>
+PREINSTALL_FILES =<br>
+CLEANFILES += $(PREINSTALL_FILES)<br>
+<br>
+$(PROJECT_LIB)/$(dirstamp):<br>
+ Â Â Â @$(MKDIR_P) $(PROJECT_LIB)<br>
+ Â Â Â @: > $(PROJECT_LIB)/$(dirstamp)<br>
+PREINSTALL_DIRS += $(PROJECT_LIB)/$(dirstamp)<br>
+<br>
+$(PROJECT_INCLUDE)/$(dirstamp):<br>
+ Â Â Â @$(MKDIR_P) $(PROJECT_INCLUDE)<br>
+ Â Â Â @: > $(PROJECT_INCLUDE)/$(dirstamp)<br>
+PREINSTALL_DIRS += $(PROJECT_INCLUDE)/$(dirstamp)<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/$(dirstamp):<br>
+ Â Â Â @$(MKDIR_P) $(PROJECT_INCLUDE)/bsp<br>
+ Â Â Â @: > $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+PREINSTALL_DIRS += $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+<br>
+$(PROJECT_LIB)/bsp_specs: bsp_specs $(PROJECT_LIB)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_LIB)/bsp_specs<br>
+PREINSTALL_FILES += $(PROJECT_LIB)/bsp_specs<br>
+<br>
+$(PROJECT_INCLUDE)/bsp.h: include/bsp.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp.h<br>
+<br>
+$(PROJECT_INCLUDE)/tm27.h: ../../shared/include/tm27.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/tm27.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/tm27.h<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/start.h: ../shared/include/start.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/start.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/start.h<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/linker-symbols.h: ../shared/include/linker-symbols.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/linker-symbols.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/linker-symbols.h<br>
+<br>
+$(PROJECT_INCLUDE)/bspopts.h: include/bspopts.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bspopts.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bspopts.h<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/bootcard.h: ../../shared/include/bootcard.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/bootcard.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/bootcard.h<br>
+<br>
+$(PROJECT_INCLUDE)/coverhd.h: ../../shared/include/coverhd.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/coverhd.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/coverhd.h<br>
+<br>
+$(PROJECT_LIB)/start.$(OBJEXT): start.$(OBJEXT) $(PROJECT_LIB)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_LIB)/start.$(OBJEXT)<br>
+TMPINSTALL_FILES += $(PROJECT_LIB)/start.$(OBJEXT)<br>
+<br>
+$(PROJECT_LIB)/linkcmds: startup/linkcmds $(PROJECT_LIB)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_LIB)/linkcmds<br>
+PREINSTALL_FILES += $(PROJECT_LIB)/linkcmds<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/irq-generic.h: ../../shared/include/irq-generic.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/irq-generic.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/irq-generic.h<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/irq-info.h: ../../shared/include/irq-info.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/irq-info.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/irq-info.h<br>
+<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/sh-hello b/c/src/lib/libbsp/arm/tiny6410/sh-hello<br>
new file mode 100755<br>
index 0000000..2ca81d6<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/sh-hello<br>
@@ -0,0 +1,13 @@<br>
+#!/bin/sh<br>
+mkdir build<br>
+cd build<br>
+../rtems/configure --target=arm-rtemseabi4.11 --enable-rtemsbsp="tiny6410" --enable-test=samples --disable-posix<br>
+rm `find . -name hello.exe`<br>
+gmake all<br>
+rm hello.*<br>
+rm init.*<br>
+cp  -f `find . -name hello.exe` .<br>
+cp arm-rtemseabi4.11/c/tiny6410/testsuites/samples/hello/init.o .<br>
+arm-rtemseabi4.11-objcopy -O binary -S hello.exe hello.bin<br>
+arm-rtemseabi4.11-objdump -D hello.exe > hello.s<br>
+arm-rtemseabi4.11-objdump -D init.o > init.s<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/bspidle.c b/c/src/lib/libbsp/arm/tiny6410/startup/bspidle.c<br>
new file mode 100644<br>
index 0000000..6bc8088<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/bspidle.c<br>
@@ -0,0 +1,25 @@<br>
+/*<br>
+ * Â BSP specific Idle thread<br>
+ */<br>
+<br>
+/*<br>
+ * Â Copyright (c) 2000 Canon Research Centre France SA.<br>
+ * Â Emmanuel Raguet, mailto:<a href="mailto:raguet@crf.canon.fr" target="_blank">raguet@crf.canon.fr</a><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * Â 1.Copied from gp32<br>
+ */<br>
+<br>
+#include <bsp.h><br>
+<br>
+void *bsp_idle_thread(uintptr_t ignored)<br>
+{<br>
+ Â while(1) {<br>
+ Â Â __asm__ volatile ("MCR p15,0,r0,c7,c0,4 Â Â \n");<br>
+ Â }<br>
+ Â return NULL;<br>
+}<br>
+<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/bspreset.c b/c/src/lib/libbsp/arm/tiny6410/startup/bspreset.c<br>
new file mode 100644<br>
index 0000000..0d52df7<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/bspreset.c<br>
@@ -0,0 +1,37 @@<br>
+/*<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ * Â 1. Copied from gp32<br>
+ */<br>
+<br>
+#include <bsp.h><br>
+<br>
+void bsp_reset(void)<br>
+{<br>
+ Â rtems_interrupt_level level;<br>
+ Â rtems_interrupt_disable(level);<br>
+ Â /* disable mmu, invalide i-cache and call swi #4 */<br>
+ Â __asm__ volatile(""<br>
+   "mrc   p15,0,r0,c1,c0,0  \n"<br>
+   "bic   r0,r0,#1      \n"<br>
+   "mcr   p15,0,r0,c1,c0,0  \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "mov   r0,#0       \n"<br>
+ Â Â "MCR Â Â p15,0,r0,c7,c5,0 Â \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "nop            \n"<br>
+   "swi   #4         "<br>
+ Â Â :<br>
+ Â Â :<br>
+ Â Â : "r0"<br>
+ Â );<br>
+ Â /* we should be back in bios now */<br>
+}<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/bspstart.c b/c/src/lib/libbsp/arm/tiny6410/startup/bspstart.c<br>
new file mode 100644<br>
index 0000000..09eded1<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/bspstart.c<br>
@@ -0,0 +1,83 @@<br>
+/*<br>
+ * This file contains the ARM BSP startup package. It includes application,<br>
+ * board, and monitor specific initialization and configuration. The generic CPU<br>
+ * dependent initialization has been performed before this routine is invoked.<br>
+ */<br>
+<br>
+/*<br>
+ * Â Copyright (c) 2000 Canon Research Centre France SA.<br>
+ * Â Emmanuel Raguet, mailto:<a href="mailto:raguet@crf.canon.fr" target="_blank">raguet@crf.canon.fr</a><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * Â 1. Modified from gp32 Â Â Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+<br>
+#include <bsp.h><br>
+#include <bsp/irq-generic.h><br>
+#include <rtems/bspIo.h><br>
+#include <s3c64xx.h><br>
+<br>
+/*<br>
+ * External Prototypes<br>
+ */<br>
+extern void rtems_exception_init_mngt(void);<br>
+<br>
+/*<br>
+ * Â BSP Specific Initialization in C<br>
+ */<br>
+void bsp_start_default( void )<br>
+{<br>
+ Â uint32_t cr;<br>
+ Â uint32_t pend,last;<br>
+ Â uint32_t REFCNT;<br>
+ Â uint32_t i;<br>
+<br>
+ Â /* stop RTC */<br>
+ Â rTICCNT = 0x0;<br>
+<br>
+ Â /* stop watchdog,ADC and timers */<br>
+ Â rWTCON = 0x0;<br>
+ Â rTCON = 0x0;<br>
+ Â rADCCON = 0x0;<br>
+<br>
+ Â /* disable interrupts */<br>
+ Â rVIC0_INTENCLEAR = 0x0;<br>
+ Â rVIC1_INTENCLEAR = 0x0;<br>
+ Â /* interrupt select, irq or fiq?*/<br>
+ Â rVIC0_INTSELECT = 0x0;<br>
+ Â rVIC1_INTSELECT = 0x0;<br>
+<br>
+ Â /* clear external interrupt pending*/<br>
+ Â rEINT0PEND = ~0x0; /* write 1 to clear */<br>
+<br>
+ Â /* clear pending interrupt */<br>
+ Â rVIC0_ADDRESS = 0x0;<br>
+ Â rVIC1_ADDRESS = 0x0;<br>
+<br>
+<br>
+#if 0<br>
+ Â /* system clock may be migrated to here from uboot */<br>
+ Â /* setup clocks */<br>
+#endif<br>
+<br>
+ Â Uart_SendString(__func__);<br>
+ Â /*<br>
+ Â * Init rtems exceptions management<br>
+ Â */<br>
+ Â rtems_exception_init_mngt();<br>
+<br>
+ Â /*<br>
+ Â * Init rtems interrupt management<br>
+ Â */<br>
+ Â bsp_interrupt_initialize();<br>
+}<br>
+<br>
+/*<br>
+ * Â By making this a weak alias for bsp_start_default, a brave soul<br>
+ * Â can override the actual bsp_start routine used.<br>
+ */<br>
+<br>
+void bsp_start (void) __attribute__ ((weak, alias("bsp_start_default")));<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/bspstarthooks.c b/c/src/lib/libbsp/arm/tiny6410/startup/bspstarthooks.c<br>
new file mode 100644<br>
index 0000000..31e359c<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/bspstarthooks.c<br>
@@ -0,0 +1,146 @@<br>
+/**<br>
+ * @file<br>
+ *<br>
+ * @ingroup s3c64xx<br>
+ *<br>
+ * @brief Startup code.<br>
+ */<br>
+<br>
+/*<br>
+ * Copyright (c) 2009-2011 embedded brains GmbH. Â All rights reserved.<br>
+ *<br>
+ * Â embedded brains GmbH<br>
+ * Â Obere Lagerstr. 30<br>
+ * Â 82178 Puchheim<br>
+ * Â Germany<br>
+ * Â <<a href="mailto:rtems@embedded-brains.de" target="_blank">rtems@embedded-brains.de</a>><br>
+ *<br>
+ * The license and distribution terms for this file may be<br>
+ * found in the file LICENSE in this distribution or at<br>
+ * <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * 1. Modified from lpc32xx   Peng Fan     <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+<br>
+#include <bsp.h><br>
+#include <bsp/start.h><br>
+#include <bsp/irq.h><br>
+#include <bsp/linker-symbols.h><br>
+#include <libcpu/arm-cp15.h><br>
+#include <libcpu/mmu.h><br>
+//#include <bsp/uart-output-char.h> //fanpeng<br>
+<br>
+#include <s3c64xx.h><br>
+<br>
+extern void bsp_reset(void);<br>
+<br>
+<br>
+void SWI_Handler(void)<br>
+{<br>
+ Â Â Â Uart_SendString("swi handler");<br>
+ Â Â Â while(1);<br>
+}<br>
+static BSP_START_TEXT_SECTION void clear_bss(void)<br>
+{<br>
+ Â const int *end = (const int *) bsp_section_bss_end;<br>
+ Â int *out = (int *) bsp_section_bss_begin;<br>
+<br>
+ Â /* Clear BSS */<br>
+ Â while (out != end) {<br>
+ Â Â *out = 0;<br>
+ Â Â ++out;<br>
+ Â }<br>
+}<br>
+<br>
+extern mmu_sect_map_t mem_map[];<br>
+static BSP_START_TEXT_SECTION void setup_mmu_and_cache(void)<br>
+{<br>
+ Â uint32_t ctrl = 0;<br>
+<br>
+ Â /* Disable MMU and cache, basic settings */<br>
+ Â ctrl = arm_cp15_get_control();<br>
+ Â ctrl &= ~(ARM_CP15_CTRL_I | ARM_CP15_CTRL_R | ARM_CP15_CTRL_C<br>
+ Â Â | ARM_CP15_CTRL_V | ARM_CP15_CTRL_M);<br>
+ Â ctrl |= Â ARM_CP15_CTRL_A;<br>
+ Â arm_cp15_set_control(ctrl);<br>
+<br>
+ Â arm_cp15_data_cache_clean_and_invalidate();<br>
+ Â arm_cp15_cache_invalidate(); //cache clean and invalidate ??<br>
+ Â arm_cp15_tlb_invalidate();<br>
+<br>
+ Â #ifndef S3C64XX_DISABLE_MMU<br>
+ Â Â mmu_init(mem_map);<br>
+ Â #endif<br>
+}<br>
+<br>
+static BSP_START_TEXT_SECTION void setup_pll(void)<br>
+{<br>
+}<br>
+<br>
+BSP_START_TEXT_SECTION void bsp_start_hook_0(void)<br>
+{<br>
+ Â setup_pll();<br>
+ Â setup_mmu_and_cache();<br>
+}<br>
+<br>
+static BSP_START_TEXT_SECTION void stop_dma_activities(void)<br>
+{<br>
+}<br>
+<br>
+static BSP_START_TEXT_SECTION void setup_uarts(void)<br>
+{<br>
+}<br>
+<br>
+static BSP_START_TEXT_SECTION void setup_timer(void)<br>
+{<br>
+ Â Â Â /* May be removed */<br>
+}<br>
+<br>
+/* vector_begin will be copied to address 0 */<br>
+uint32_t vector_begin[] = {<br>
+    0xe59ff018, //ldr   pc, [pc, #24]<br>
+ Â Â Â 0xe59ff018,<br>
+ Â Â Â 0xe59ff018,<br>
+ Â Â Â 0xe59ff018,<br>
+ Â Â Â 0xe59ff018,<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe59ff018,<br>
+ Â Â Â 0xe59ff018,<br>
+<br>
+ Â Â Â /***************/<br>
+ Â Â Â bsp_reset,<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+ Â Â Â 0xe320f000, //nop<br>
+};<br>
+<br>
+BSP_START_TEXT_SECTION void bsp_start_hook_1(void)<br>
+{<br>
+ Â int i = 0;<br>
+ Â stop_dma_activities();<br>
+ Â setup_uarts();<br>
+ Â setup_timer();<br>
+<br>
+ Â arm_cp15_data_cache_clean_and_invalidate();<br>
+ Â arm_cp15_cache_invalidate(); //??<br>
+<br>
+ Â /* Copy vector table to address 0*/<br>
+ Â bsp_start_memcpy(<br>
+ Â Â Â Â (int *)0,<br>
+ Â Â Â Â (const int*)vector_begin,<br>
+ Â Â Â Â (size_t)64<br>
+ Â );<br>
+<br>
+ Â /* VIC is not enabled for this vector interrupt processor,<br>
+ Â * This may be done in the future to use vector interrupt.<br>
+ Â */<br>
+<br>
+ Â /* Clear .bss section */<br>
+ Â clear_bss();<br>
+<br>
+ Â /* At this point we can use objects outside the .start section */<br>
+}<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/linkcmds b/c/src/lib/libbsp/arm/tiny6410/startup/linkcmds<br>
new file mode 100644<br>
index 0000000..dc48a57<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/linkcmds<br>
@@ -0,0 +1,25 @@<br>
+MEMORY {<br>
+ Â Â Â SDRAM_INTERRUPT : ORIGIN = 0x50000000, LENGTH = 4k<br>
+ Â Â Â SDRAM_MMU : ORIGIN = 0x50100000, LENGTH = 16k<br>
+ Â Â Â SDRAM : ORIGIN = 0x50104000, LENGTH = 128M - 1M - 16k<br>
+}<br>
+<br>
+REGION_ALIAS ("REGION_START", SDRAM);<br>
+REGION_ALIAS ("REGION_VECTOR", SDRAM);<br>
+REGION_ALIAS ("REGION_TEXT", SDRAM);<br>
+REGION_ALIAS ("REGION_TEXT_LOAD", SDRAM);<br>
+REGION_ALIAS ("REGION_RODATA", SDRAM);<br>
+REGION_ALIAS ("REGION_RODATA_LOAD", SDRAM);<br>
+REGION_ALIAS ("REGION_DATA", SDRAM);<br>
+REGION_ALIAS ("REGION_DATA_LOAD", SDRAM);<br>
+REGION_ALIAS ("REGION_FAST_TEXT", SDRAM);<br>
+REGION_ALIAS ("REGION_FAST_TEXT_LOAD", SDRAM);<br>
+REGION_ALIAS ("REGION_FAST_DATA", SDRAM);<br>
+REGION_ALIAS ("REGION_FAST_DATA_LOAD", SDRAM);<br>
+REGION_ALIAS ("REGION_BSS", SDRAM);<br>
+REGION_ALIAS ("REGION_WORK", SDRAM);<br>
+REGION_ALIAS ("REGION_STACK", SDRAM);<br>
+<br>
+_ttbl_base = ORIGIN (SDRAM_MMU);<br>
+<br>
+INCLUDE linkcmds.armv6<br>
diff --git a/c/src/lib/libbsp/arm/tiny6410/startup/memmap.c b/c/src/lib/libbsp/arm/tiny6410/startup/memmap.c<br>
new file mode 100644<br>
index 0000000..aa0b7f9<br>
--- /dev/null<br>
+++ b/c/src/lib/libbsp/arm/tiny6410/startup/memmap.c<br>
@@ -0,0 +1,29 @@<br>
+/*<br>
+ * Â s3c6410 Memory Map<br>
+ *<br>
+ * Â Copyright (c) 2004 by Cogent Computer Systems<br>
+ * Â Written by Jay Monkman <<a href="mailto:jtm@lopingdog.com" target="_blank">jtm@lopingdog.com</a>><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * Â 1. Modified from gp32 Â Â Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+#include <rtems.h><br>
+#include <libcpu/mmu.h><br>
+<br>
+/*ARM1176jzf-s consider TLB related*/<br>
+/*Here not implement 2-level page table considering tlb miss<br>
+ Â Maybe a tlb management structure should be implemented.<br>
+ Â Â Â To real time task, TLB entry is locked and should not incur<br>
+ Â Â Â TLB miss. But to non real time task, TLB miss is not cared<br>
+ Â Â Â Not sure about this. May have a try to do this in future<br>
+*/<br>
+mmu_sect_map_t mem_map[] = {<br>
+/* Â <phys addr> Â <virt addr> <size> <flags> */<br>
+ Â Â {0x00000000, 0x00000000, 4096, MMU_CACHE_NONE},<br>
+ Â Â {0x50000000, 0x00000000, 1, MMU_CACHE_NONE},<br>
+ Â Â {0x50000000, 0x50000000, 128, MMU_CACHE_NONE},<br>
+ Â Â {0x00000000, 0x00000000, Â 0, Â Â 0} Â Â Â Â Â Â Â Â Â /* The end */<br>
+};<br>
diff --git a/c/src/lib/libcpu/arm/Makefile.am b/c/src/lib/libcpu/arm/Makefile.am<br>
index e488c45..e978910 100644<br>
--- a/c/src/lib/libcpu/arm/Makefile.am<br>
+++ b/c/src/lib/libcpu/arm/Makefile.am<br>
@@ -157,6 +157,31 @@ s3c24xx_irq_rel_CPPFLAGS = $(AM_CPPFLAGS)<br>
 s3c24xx_irq_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)<br>
 endif<br>
<br>
+if s3c64xx<br>
+include_HEADERS = s3c64xx/include/s3c64xx.h s3c64xx/include/s3c6410.h<br>
+<br>
+## s3c64xx/clock<br>
+noinst_PROGRAMS += s3c64xx/clock.rel<br>
+s3c64xx_clock_rel_SOURCES = s3c64xx/clock/clockdrv.c s3c64xx/clock/support.c<br>
+s3c64xx_clock_rel_CPPFLAGS = $(AM_CPPFLAGS)<br>
+s3c64xx_clock_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)<br>
+<br>
+## s3c64xx/timer<br>
+#noinst_PROGRAMS += s3c64xx/timer.rel<br>
+#s3c64xx_timer_rel_SOURCES = s3c64xx/timer/timer.c<br>
+#s3c64xx_timer_rel_CPPFLAGS = $(AM_CPPFLAGS)<br>
+#s3c64xx_timer_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)<br>
+<br>
+## s3c64xx/interrupt<br>
+include_bsp_HEADERS += s3c64xx/irq/irq.h<br>
+<br>
+noinst_PROGRAMS += s3c64xx/irq.rel<br>
+s3c64xx_irq_rel_SOURCES = s3c64xx/irq/irq.c \<br>
+ Â Â s3c64xx/irq/irq.h<br>
+s3c64xx_irq_rel_CPPFLAGS = $(AM_CPPFLAGS)<br>
+s3c64xx_irq_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)<br>
+endif<br>
+<br>
 if lpc22xx<br>
 include_HEADERS = lpc22xx/include/lpc22xx.h<br>
<br>
diff --git a/c/src/lib/libcpu/arm/<a href="http://configure.ac" target="_blank">configure.ac</a> b/c/src/lib/libcpu/arm/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
index ae0967b..4f3ebea 100644<br>
--- a/c/src/lib/libcpu/arm/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
+++ b/c/src/lib/libcpu/arm/<a href="http://configure.ac" target="_blank">configure.ac</a><br>
@@ -23,6 +23,7 @@ AM_CONDITIONAL(shared, test "$RTEMS_CPU_MODEL" = "at91rm9200" || \<br>
            test "$RTEMS_CPU_MODEL" = "mc9328mxl" || \<br>
            test "$RTEMS_CPU_MODEL" = "s3c2410" || \<br>
            test "$RTEMS_CPU_MODEL" = "s3c2400" || \<br>
+ Â Â Â Â Â Â Â Â Â Â Â test "$RTEMS_CPU_MODEL" = "s3c6410" || \<br>
            test "$RTEMS_CPU_MODEL" = "pxa255")<br>
<br>
 AM_CONDITIONAL(at91rm9200, test "$RTEMS_CPU_MODEL" = "at91rm9200")<br>
@@ -31,6 +32,7 @@ AM_CONDITIONAL(lpc22xx, test "$RTEMS_CPU_MODEL" = "lpc22xx")<br>
 AM_CONDITIONAL(pxa255, test "$RTEMS_CPU_MODEL" = "pxa255")<br>
 AM_CONDITIONAL(s3c24xx, test "$RTEMS_CPU_MODEL" = "s3c2400" ||\<br>
             test "$RTEMS_CPU_MODEL" = "s3c2410")<br>
+AM_CONDITIONAL(s3c64xx, test "$RTEMS_CPU_MODEL" = "s3c6410")<br>
<br>
 RTEMS_AMPOLISH3<br>
<br>
diff --git a/c/src/lib/libcpu/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a> b/c/src/lib/libcpu/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
index 751a085..0a8109c 100644<br>
--- a/c/src/lib/libcpu/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
+++ b/c/src/lib/libcpu/arm/<a href="http://preinstall.am" target="_blank">preinstall.am</a><br>
@@ -113,6 +113,19 @@ $(PROJECT_INCLUDE)/bsp/irq.h: s3c24xx/irq/irq.h $(PROJECT_INCLUDE)/bsp/$(dirstam<br>
    $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/irq.h<br>
 PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/irq.h<br>
 endif<br>
+if s3c64xx<br>
+$(PROJECT_INCLUDE)/s3c64xx.h: s3c64xx/include/s3c64xx.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/s3c64xx.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/s3c64xx.h<br>
+<br>
+$(PROJECT_INCLUDE)/s3c6410.h: s3c64xx/include/s3c6410.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/s3c6410.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/s3c6410.h<br>
+<br>
+$(PROJECT_INCLUDE)/bsp/irq.h: s3c64xx/irq/irq.h $(PROJECT_INCLUDE)/bsp/$(dirstamp)<br>
+ Â Â Â $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/bsp/irq.h<br>
+PREINSTALL_FILES += $(PROJECT_INCLUDE)/bsp/irq.h<br>
+endif<br>
 if lpc22xx<br>
 $(PROJECT_INCLUDE)/lpc22xx.h: lpc22xx/include/lpc22xx.h $(PROJECT_INCLUDE)/$(dirstamp)<br>
    $(INSTALL_DATA) $< $(PROJECT_INCLUDE)/lpc22xx.h<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/clock/clockdrv.c b/c/src/lib/libcpu/arm/s3c64xx/clock/clockdrv.c<br>
new file mode 100644<br>
index 0000000..5893014<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/clock/clockdrv.c<br>
@@ -0,0 +1,141 @@<br>
+/*<br>
+ * Â S3C6410 clock specific using the System Timer<br>
+ *<br>
+ * Â This is hardware specific part of the clock driver. At the end of this<br>
+ * Â file, the generic part of the driver is #included.<br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * Â 1. modified from S3C2440 Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+<br>
+#include <rtems.h><br>
+#include <bsp/irq.h><br>
+#include <bsp.h><br>
+#include <s3c64xx.h><br>
+<br>
+void Clock_isr(rtems_irq_hdl_param arg);<br>
+static void clock_isr_on(const rtems_irq_connect_data *unused);<br>
+static void clock_isr_off(const rtems_irq_connect_data *unused);<br>
+static int clock_isr_is_on(const rtems_irq_connect_data *irq);<br>
+<br>
+rtems_irq_connect_data clock_isr_data = {<br>
+  .name  = BSP_TIMER4,<br>
+  .hdl   = Clock_isr,<br>
+ Â .handle = NULL,<br>
+  .on   = clock_isr_on,<br>
+  .off   = clock_isr_off,<br>
+  .isOn  = clock_isr_is_on,<br>
+};<br>
+<br>
+/**<br>
+ * Â Return the nanoseconds since last tick<br>
+ */<br>
+uint32_t clock_driver_get_nanoseconds_since_last_tick(void)<br>
+{<br>
+ Â return 0;<br>
+}<br>
+<br>
+#define Clock_driver_nanoseconds_since_last_tick \<br>
+ Â clock_driver_get_nanoseconds_since_last_tick<br>
+<br>
+/**<br>
+ * When we get the clock interrupt<br>
+ * Â Â - clear the interrupt bit?<br>
+ * Â Â - restart the timer?<br>
+ Â Â Â Â Clear BIT_TIMER4 interrupt; Â Â Â Â Â Â Â Â Â \<br>
+ */<br>
+#define Clock_driver_support_at_tick() Â Â Â Â Â Â Â Â \<br>
+ Â do { Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â \<br>
+ Â Â Â Â rTINT_CSTAT |= 1 << 9;\<br>
+ Â } while(0)<br>
+<br>
+/**<br>
+ * Installs the clock ISR. You shouldn't need to change this.<br>
+ */<br>
+extern uint32_t *VIC0_VECTADDR;<br>
+extern uint32_t *VIC1_VECTADDR;<br>
+#define Clock_driver_support_install_isr( _new, _old ) \<br>
+ Â do { Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â \<br>
+ Â Â _old = NULL; Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â \<br>
+ Â Â VIC0_VECTADDR[BSP_TIMER4] = _new; Â Â Â Â Â Â Â Â Â \<br>
+ Â Â rtems_interrupt_handler_install(<a href="http://clock_isr_data.name" target="_blank">clock_isr_data.name</a>,\<br>
+ Â Â Â Â Â Â Â Â Â "TICK TIMER",\<br>
+ Â Â Â Â Â Â Â Â Â RTEMS_INTERRUPT_UNIQUE,\<br>
+ Â Â Â Â Â Â Â Â Â clock_isr_data.hdl,\<br>
+ Â Â Â Â Â Â Â Â Â clock_isr_data.handle);\<br>
+ Â } while(0)<br>
+<br>
+<br>
+/**<br>
+ * Initialize the hardware for the clock<br>
+ * Â - Set the frequency<br>
+ * Â - enable it<br>
+ * Â - clear any pending interrupts<br>
+ *<br>
+ * Since you may want the clock always running, you can<br>
+ * enable interrupts here. If you do so, the clock_isr_on(),<br>
+ * clock_isr_off(), and clock_isr_is_on() functions can be<br>
+ * NOPs.<br>
+ */<br>
+/**<br>
+ * The bit and constant number should be redifined using macros<br>
+ */<br>
+#define Clock_driver_support_initialize_hardware() \<br>
+ Â do { \<br>
+ Â Â Â Â rTCON = 0x0;\<br>
+ Â Â Â Â rTINT_CSTAT |= 1 << 4;\<br>
+ Â Â Â Â bsp_interrupt_vector_enable(BSP_TIMER4);\<br>
+ Â Â Â Â rTCFG0 = 0x0101;\<br>
+ Â Â Â Â rTCFG1 = (rTCFG1 & 0xf0000) | 0x40000;\<br>
+ Â Â Â Â rTCNTB4 = 0x512d;\<br>
+ Â Â Â Â rTCON = (rTCON & ~0x00700000) | (1<<22) | (1<<21);\<br>
+ Â Â Â Â rTCON = (rTCON & ~0x00700000) | (1<<22) | (1<<20);\<br>
+ Â Â Â Â /* auto load, start Timer 4 */\<br>
+ Â Â } while (0)<br>
+<br>
+/**<br>
+ * Do whatever you need to shut the clock down and remove the<br>
+ * interrupt handler. Since this normally only gets called on<br>
+ * RTEMS shutdown, you may not need to do anything other than<br>
+ * remove the ISR.<br>
+ */<br>
+#define Clock_driver_support_shutdown_hardware() Â Â Â Â Â Â Â Â Â Â Â Â \<br>
+ Â do { Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â \<br>
+ Â Â Â Â /* Disable timer */ \<br>
+ Â Â Â Â BSP_remove_rtems_irq_handler(&clock_isr_data); Â Â Â Â Â Â Â Â Â \<br>
+ Â Â } while (0)<br>
+<br>
+/**<br>
+ * Enables clock interrupt.<br>
+ *<br>
+ * If the interrupt is always on, this can be a NOP.<br>
+ */<br>
+static void clock_isr_on(const rtems_irq_connect_data *unused)<br>
+{<br>
+}<br>
+<br>
+/**<br>
+ * Disables clock interrupts<br>
+ *<br>
+ * If the interrupt is always on, this can be a NOP.<br>
+ */<br>
+static void clock_isr_off(const rtems_irq_connect_data *unused)<br>
+{<br>
+ Â Â return;<br>
+}<br>
+<br>
+/**<br>
+ * Tests to see if clock interrupt is enabled, and returns 1 if so.<br>
+ * If interrupt is not enabled, returns 0.<br>
+ *<br>
+ * If the interrupt is always on, this always returns 1.<br>
+ */<br>
+static int clock_isr_is_on(const rtems_irq_connect_data *irq)<br>
+{<br>
+}<br>
+<br>
+/* Make sure to include this, and only at the end of the file */<br>
+#include "../../../../libbsp/shared/clockdrv_shell.h"<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/clock/support.c b/c/src/lib/libcpu/arm/s3c64xx/clock/support.c<br>
new file mode 100644<br>
index 0000000..f4a853c<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/clock/support.c<br>
@@ -0,0 +1,51 @@<br>
+/*<br>
+ * 1. Modified from S3C2440 Â Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ *<br>
+ * Note: Now the clock related setting is done in uboot.<br>
+ * Â Â Â This will be fixed in future<br>
+ */<br>
+#include <rtems.h><br>
+#include <bsp.h><br>
+#include <s3c64xx.h><br>
+<br>
+/* ------------------------------------------------------------------------- */<br>
+/* NOTE: This describes the proper use of this file.<br>
+ *<br>
+ * BSP_OSC_FREQ should be defined as the input frequency of the PLL.<br>
+ *<br>
+ * get_FCLK(), get_HCLK(), get_PCLK() and get_UCLK() return the clock of<br>
+ * the specified bus in HZ.<br>
+ */<br>
+/* ------------------------------------------------------------------------- */<br>
+<br>
+uint32_t *VIC0_VECTADDR = (uint32_t *)VIC0_VECTADDR_BASE;<br>
+uint32_t *VIC1_VECTADDR = (uint32_t *)VIC1_VECTADDR_BASE;<br>
+/* return FCLK frequency */<br>
+uint32_t get_FCLK(void)<br>
+{<br>
+ Â Â Â /* not implemented */<br>
+ Â Â Â return 0;<br>
+}<br>
+<br>
+/* return UCLK frequency */<br>
+uint32_t get_UCLK(void)<br>
+{<br>
+ Â Â Â /* not implemented */<br>
+ Â Â Â return 0;<br>
+}<br>
+<br>
+/* return HCLK frequency */<br>
+uint32_t get_HCLK(void)<br>
+{<br>
+ Â Â Â /* not implemented */<br>
+ Â Â Â return 0;<br>
+}<br>
+<br>
+/* return PCLK frequency */<br>
+uint32_t get_PCLK(void)<br>
+{<br>
+ Â Â Â /* Just return uboot configured freq.<br>
+ Â Â Â Â * Fix this in future<br>
+ Â Â Â Â */<br>
+ Â Â Â return 66000000;<br>
+}<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/include/s3c6410.h b/c/src/lib/libcpu/arm/s3c64xx/include/s3c6410.h<br>
new file mode 100644<br>
index 0000000..56b1dcd<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/include/s3c6410.h<br>
@@ -0,0 +1,211 @@<br>
+/************************************************<br>
+ * NAME Â Â : s3c6410.h<br>
+ * Version  : 4.07.2013<br>
+ *<br>
+ * for the Samsung Development Board<br>
+ ************************************************/<br>
+<br>
+#ifndef __S3C6410_H__<br>
+#define __S3C6410_H__<br>
+<br>
+#define __reg(addr) Â Â (*(volatile unsigned *)(addr))<br>
+/* UART */<br>
+#define UART_BASE Â Â Â (0x7F005000)<br>
+#define UART0_BASE Â Â (UART_BASE + 0x0)<br>
+#define UART1_BASE Â Â (UART_BASE + 0x400)<br>
+#define UART2_BASE Â Â (UART_BASE + 0x800)<br>
+#define UART2_BASE Â Â (UART_BASE + 0xC00)<br>
+<br>
+#define rULCON0 Â Â Â Â Â Â Â Â __reg(UART0_BASE + 0x00)<br>
+#define rUCON0 Â Â Â Â __reg(UART0_BASE + 0x04)<br>
+#define rUFCON0 Â Â Â Â Â Â Â Â __reg(UART0_BASE + 0x08)<br>
+#define rUMCON0 Â Â Â Â Â Â Â Â __reg(UART0_BASE + 0x0C)<br>
+#define rUTRSTAT0 Â Â Â __reg(UART0_BASE + 0x10)<br>
+#define rUERSTAT0 Â Â Â __reg(UART0_BASE + 0x14)<br>
+#define rUFSTAT0 Â Â Â __reg(UART0_BASE + 0x18)<br>
+#define rUMSTAT0 Â Â Â __reg(UART0_BASE + 0x1C)<br>
+#define rUTXH0 Â Â Â Â __reg(UART0_BASE + 0x20)<br>
+#define rURXH0 Â Â Â Â __reg(UART0_BASE + 0x24)<br>
+#define rUBRDIV0 Â Â Â __reg(UART0_BASE + 0x28)<br>
+#define rUDIVSLOT0 Â Â __reg(UART0_BASE + 0x2C)<br>
+#define rUINTP0 Â Â Â Â Â Â Â Â __reg(UART0_BASE + 0x30)<br>
+#define rUINTSP0 Â Â Â __reg(UART0_BASE + 0x34)<br>
+#define rUINTM0 Â Â Â Â Â Â Â Â __reg(UART0_BASE + 0x38)<br>
+<br>
+#define rULCON1 Â Â Â Â Â Â Â Â __reg(UART1_BASE + 0x00)<br>
+#define rUCON1 Â Â Â Â __reg(UART1_BASE + 0x04)<br>
+#define rUFCON1 Â Â Â Â Â Â Â Â __reg(UART1_BASE + 0x08)<br>
+#define rUMCON1 Â Â Â Â Â Â Â Â __reg(UART1_BASE + 0x0C)<br>
+#define rUTRSTAT1 Â Â Â __reg(UART1_BASE + 0x10)<br>
+#define rUERSTAT1 Â Â Â __reg(UART1_BASE + 0x14)<br>
+#define rUFSTAT1 Â Â Â __reg(UART1_BASE + 0x18)<br>
+#define rUMSTAT1 Â Â Â __reg(UART1_BASE + 0x1C)<br>
+#define rUTXH1 Â Â Â Â __reg(UART1_BASE + 0x20)<br>
+#define rURXH1 Â Â Â Â __reg(UART1_BASE + 0x24)<br>
+#define rUBRDIV1 Â Â Â __reg(UART1_BASE + 0x28)<br>
+#define rUDIVSLOT1 Â Â __reg(UART1_BASE + 0x2C)<br>
+#define rUINTP1 Â Â Â Â Â Â Â Â __reg(UART1_BASE + 0x30)<br>
+#define rUINTSP1 Â Â Â __reg(UART1_BASE + 0x34)<br>
+#define rUINTM1 Â Â Â Â Â Â Â Â __reg(UART1_BASE + 0x38)<br>
+<br>
+/* GPIO */<br>
+#define GPIO_BASE Â Â Â (0x7F008000)<br>
+#define GPIOA_BASE Â Â GPIO_BASE<br>
+<br>
+#define rGPKCON0 Â Â Â __reg(0x7F008800)<br>
+#define rGPKCON1 Â Â Â __reg(0x7F008804)<br>
+#define rGPKDAT Â Â Â Â Â Â Â Â __reg(0x7F008808)<br>
+#define rGPKPUD Â Â Â Â Â Â Â Â __reg(0x7F00880C)<br>
+<br>
+#define rEINT0PEND Â Â __reg(0x7F008924)<br>
+<br>
+<br>
+/* TIMER */<br>
+#define TIMER_BASE Â Â (0x7F006000)<br>
+#define rTCFG0 Â Â Â Â __reg(TIMER_BASE + 0x0)<br>
+#define rTCFG1 Â Â Â Â __reg(TIMER_BASE + 0x4)<br>
+#define rTCON Â Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x8)<br>
+#define rTCNTB0 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0xC)<br>
+#define rTCMPB0 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x10)<br>
+#define rTCNTO0 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x14)<br>
+<br>
+#define rTCNTB1 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x18)<br>
+#define rTCMPB1 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x1C)<br>
+#define rTCNTO1 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x20)<br>
+<br>
+#define rTCNTB2 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x24)<br>
+#define rTCNTO2 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x2C)<br>
+#define rTCNTB3 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x30)<br>
+#define rTCNTO3 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x38)<br>
+#define rTCNTB4 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x3C)<br>
+#define rTCNTO4 Â Â Â Â Â Â Â Â __reg(TIMER_BASE + 0x40)<br>
+<br>
+#define rTINT_CSTAT Â Â __reg(TIMER_BASE + 0x44)<br>
+<br>
+<br>
+/*<br>
+ * Interrupt<br>
+ */<br>
+/* VIC */<br>
+#define VIC0_BASE_ADDR Â Â Â Â (0x71200000)<br>
+#define VIC1_BASE_ADDR Â Â Â Â (0x71300000)<br>
+#define rVIC0_IRQSTATUS Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x0)<br>
+#define rVIC0_FIQSTATUS Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x4)<br>
+#define rVIC0_RAWINTR Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x8)<br>
+#define rVIC0_INTSELECT Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0xC)<br>
+#define rVIC0_INTENABLE Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x10)<br>
+#define rVIC0_INTENCLEAR Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x14)<br>
+#define rVIC0_SOFTINT Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x18)<br>
+#define rVIC0_SOFTINTCLEAR Â Â __reg(VIC0_BASE_ADDR + 0x1C)<br>
+#define rVIC0_PROTECTION Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0x20)<br>
+#define rVIC0_SWPPIORITYMASK Â __reg(VIC0_BASE_ADDR + 0x24)<br>
+#define rVIC0_PRIORITYDAISY Â Â __reg(VIC0_BASE_ADDR + 0x28)<br>
+#define VIC0_VECTADDR_BASE Â Â (VIC0_BASE_ADDR + 0x100)<br>
+<br>
+#define rVIC0_ADDRESS Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC0_BASE_ADDR + 0xF00)<br>
+<br>
+<br>
+<br>
+#define rVIC1_IRQSTATUS Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x0)<br>
+#define rVIC1_FIQSTATUS Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x4)<br>
+#define rVIC1_RAWINTR Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x8)<br>
+#define rVIC1_INTSELECT Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0xC)<br>
+#define rVIC1_INTENABLE Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x10)<br>
+#define rVIC1_INTENCLEAR Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x14)<br>
+#define rVIC1_SOFTINT Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x18)<br>
+#define rVIC1_SOFTINTCLEAR Â Â __reg(VIC1_BASE_ADDR + 0x1C)<br>
+#define rVIC1_PROTECTION Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0x20)<br>
+#define rVIC1_SWPPIORITYMASK Â __reg(VIC1_BASE_ADDR + 0x24)<br>
+#define rVIC1_PRIORITYDAISY Â Â __reg(VIC1_BASE_ADDR + 0x28)<br>
+#define VIC1_VECTADDR_BASE Â Â (VIC1_BASE_ADDR + 0x100)<br>
+<br>
+#define rVIC1_ADDRESS Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(VIC1_BASE_ADDR + 0xF00)<br>
+<br>
+<br>
+/* ADC */<br>
+#define rADCCON Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B000)<br>
+#define rADCTSC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B004)<br>
+#define rADCDLY Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B008)<br>
+#define rADCDAT0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B00C)<br>
+#define rADCDAT1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B010)<br>
+#define rADCUPDN Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B014)<br>
+#define rADCCLRINT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00B018)<br>
+#define rADCCLRINTPNDNUP Â Â Â Â Â Â Â __reg(0x7E00B020)<br>
+<br>
+/* WATCH DOG */<br>
+#define rWTCON Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E004000)<br>
+#define rWTDAT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E004004)<br>
+#define rWTCNT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E004008)<br>
+#define rWTCLRINT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E00400C)<br>
+<br>
+/* RTC */<br>
+#define rINTP Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E005030)<br>
+<br>
+#define rTICCNT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(0x7E005044)<br>
+<br>
+<br>
+/* NAND */<br>
+#define  NAND_BASE       0x70200000<br>
+<br>
+#define rNFCONF Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x0)<br>
+#define rNFCONT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x4)<br>
+#define rNFCNND Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x8)<br>
+#define rNFADDR Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0xC)<br>
+#define rNFDATA Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x10)<br>
+#define rNFMECCD0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x14)<br>
+#define rNFMECCD1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x18)<br>
+#define rNFSECCD Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x1C)<br>
+#define rNFSBLK Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x20)<br>
+#define rNFEBLK Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x24)<br>
+#define rNFSTAT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x28)<br>
+#define rNFECCERR0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x2C)<br>
+#define rNFECCERR1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x30)<br>
+#define rNFMECC0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x34)<br>
+#define rNFMECC1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x38)<br>
+#define rNFSECC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x3C)<br>
+#define rNFMLCBITPT Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x40)<br>
+#define rNF8ECCERR0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x44)<br>
+#define rNF8ECCERR1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x48)<br>
+#define rNF8ECCERR2 Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x4C)<br>
+#define rNFM8ECC0 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x50)<br>
+#define rNFM8ECC1 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x54)<br>
+#define rNFM8ECC2 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x58)<br>
+#define rNFM8ECC3 Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x5C)<br>
+#define rNFMLC8BITPT0 Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x60)<br>
+#define rNFMLC8BITPT1 Â Â Â Â Â Â Â Â Â __reg(NAND_BASE + 0x64)<br>
+<br>
+#define BIT0 Â Â Â Â Â Â Â Â Â 0x00000001<br>
+#define BIT1 Â Â Â Â Â Â Â Â Â 0x00000002<br>
+#define BIT2 Â Â Â Â Â Â Â Â Â 0x00000004<br>
+#define BIT3 Â Â Â Â Â Â Â Â Â 0x00000008<br>
+#define BIT4 Â Â Â Â Â Â Â Â Â 0x00000010<br>
+#define BIT5 Â Â Â Â Â Â Â Â Â 0x00000020<br>
+#define BIT6 Â Â Â Â Â Â Â Â Â 0x00000040<br>
+#define BIT7 Â Â Â Â Â Â Â Â Â 0x00000080<br>
+#define BIT8 Â Â Â Â Â Â Â Â Â 0x00000100<br>
+#define BIT9 Â Â Â Â Â Â Â Â Â 0x00000200<br>
+#define BIT10 Â Â Â Â Â Â Â Â Â 0x00000400<br>
+#define BIT11 Â Â Â Â Â Â Â Â Â 0x00000800<br>
+#define BIT12 Â Â Â Â Â Â Â Â Â 0x00001000<br>
+#define BIT13 Â Â Â Â Â Â Â Â Â 0x00002000<br>
+#define BIT14 Â Â Â Â Â Â Â Â Â 0x00004000<br>
+#define BIT15 Â Â Â Â Â Â Â Â Â 0x00008000<br>
+#define BIT16 Â Â Â Â Â Â Â Â Â 0x00010000<br>
+#define BIT17 Â Â Â Â Â Â Â Â Â 0x00020000<br>
+#define BIT18 Â Â Â Â Â Â Â Â Â 0x00040000<br>
+#define BIT19 Â Â Â Â Â Â Â Â Â 0x00080000<br>
+#define BIT20 Â Â Â Â Â Â Â Â Â 0x00100000<br>
+#define BIT21 Â Â Â Â Â Â Â Â Â 0x00200000<br>
+#define BIT22 Â Â Â Â Â Â Â Â Â 0x00400000<br>
+#define BIT23 Â Â Â Â Â Â Â Â Â 0x00800000<br>
+#define BIT24 Â Â Â Â Â Â Â Â Â 0x01000000<br>
+#define BIT25 Â Â Â Â Â Â Â Â Â 0x02000000<br>
+#define BIT26 Â Â Â Â Â Â Â Â Â 0x04000000<br>
+#define BIT27 Â Â Â Â Â Â Â Â Â 0x08000000<br>
+#define BIT28 Â Â Â Â Â Â Â Â Â 0x10000000<br>
+#define BIT29 Â Â Â Â Â Â Â Â Â 0x20000000<br>
+#define BIT30 Â Â Â Â Â Â Â Â Â 0x40000000<br>
+#define BIT31 Â Â Â Â Â Â Â Â Â 0x80000000<br>
+<br>
+<br>
+#endif /*__S3C6410_H__*/<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/include/s3c64xx.h b/c/src/lib/libcpu/arm/s3c64xx/include/s3c64xx.h<br>
new file mode 100644<br>
index 0000000..6396629<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/include/s3c64xx.h<br>
@@ -0,0 +1,15 @@<br>
+/************************************************<br>
+ * NAME Â Â : s3c64xx.h<br>
+ * Version  : 4.07.2013<br>
+ *<br>
+ * share code for different Samsung CPU<br>
+ ************************************************/<br>
+<br>
+#ifndef S3C64XX_H_<br>
+#define S3C64XX_H_<br>
+<br>
+#ifdef CPU_S3C6410<br>
+#include <s3c6410.h><br>
+#endif<br>
+<br>
+#endif /*S3C64XX_H_*/<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/irq/irq.c b/c/src/lib/libcpu/arm/s3c64xx/irq/irq.c<br>
new file mode 100644<br>
index 0000000..e0cb6d2<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/irq/irq.c<br>
@@ -0,0 +1,79 @@<br>
+/* irq.c<br>
+ *<br>
+ * Â This file contains the implementation of the function described in irq.h<br>
+ *<br>
+ * Â Copyright (c) 2010 embedded brains GmbH.<br>
+ *<br>
+ * Â CopyRight (C) 2000 Canon Research France SA.<br>
+ * Â Emmanuel Raguet, Â mailto:<a href="mailto:raguet@crf.canon.fr" target="_blank">raguet@crf.canon.fr</a><br>
+ *<br>
+ * Â The license and distribution terms for this file may be<br>
+ * Â found in the file LICENSE in this distribution or at<br>
+ * Â <a href="http://www.rtems.com/license/LICENSE" target="_blank">http://www.rtems.com/license/LICENSE</a>.<br>
+ *<br>
+ * Â 1. Modified from S3C2440 Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+<br>
+#include <rtems/score/armv4.h><br>
+<br>
+#include <bsp.h><br>
+#include <bsp/irq.h><br>
+#include <bsp/irq-generic.h><br>
+<br>
+#include <s3c64xx.h><br>
+<br>
+typedef void (*vicfunc)(void);<br>
+void bsp_interrupt_dispatch(void)<br>
+{<br>
+ Â Â Â uint32_t vector_addr0 = rVIC0_ADDRESS;<br>
+ Â Â Â uint32_t vector_addr1 = rVIC1_ADDRESS;<br>
+ Â Â Â if (vector_addr0 != 0){<br>
+ Â Â Â Â Â Â Â void (*vicfunc)(void) = (void(*)(void))rVIC0_ADDRESS;<br>
+ Â Â Â Â Â Â Â vicfunc();<br>
+ Â Â Â }<br>
+ Â Â Â rVIC0_ADDRESS = 0x0;<br>
+ Â Â Â if (vector_addr1 != 0){<br>
+ Â Â Â Â Â Â Â void (*vicfunc)(void) = (void(*)(void))rVIC1_ADDRESS;<br>
+ Â Â Â Â Â Â Â vicfunc();<br>
+ Â Â Â }<br>
+ Â Â Â rVIC1_ADDRESS = 0x0;<br>
+}<br>
+<br>
+rtems_status_code bsp_interrupt_vector_enable(rtems_vector_number vector)<br>
+{<br>
+ Â if (vector < 32)<br>
+ Â {<br>
+ Â Â Â rVIC0_INTENABLE |= 1 << vector;<br>
+ Â }<br>
+ Â else if (vector < 64)<br>
+ Â {<br>
+ Â Â Â rVIC1_INTENABLE |= 1 << (vector - 32);<br>
+ Â }<br>
+ Â else<br>
+ Â Â Â Â printk("%s failed\n", __func__);<br>
+<br>
+ Â return RTEMS_SUCCESSFUL;<br>
+}<br>
+<br>
+rtems_status_code bsp_interrupt_vector_disable(rtems_vector_number vector)<br>
+{<br>
+ Â if (vector < 32)<br>
+ Â {<br>
+ Â Â Â rVIC0_INTENCLEAR |= 1 << vector;<br>
+ Â }<br>
+ Â else if (vector < 64)<br>
+ Â {<br>
+ Â Â Â rVIC1_INTENCLEAR |= 1 << (vector - 32);<br>
+ Â }<br>
+ Â else<br>
+ Â Â Â Â printk("%s failed\n", __func__);<br>
+<br>
+ Â return RTEMS_SUCCESSFUL;<br>
+}<br>
+<br>
+rtems_status_code bsp_interrupt_facility_initialize(void)<br>
+{<br>
+ Â _CPU_ISR_install_vector(ARM_EXCEPTION_IRQ, _ARMV4_Exception_interrupt, NULL);<br>
+<br>
+ Â return RTEMS_SUCCESSFUL;<br>
+}<br>
diff --git a/c/src/lib/libcpu/arm/s3c64xx/irq/irq.h b/c/src/lib/libcpu/arm/s3c64xx/irq/irq.h<br>
new file mode 100644<br>
index 0000000..2f3ca6a<br>
--- /dev/null<br>
+++ b/c/src/lib/libcpu/arm/s3c64xx/irq/irq.h<br>
@@ -0,0 +1,100 @@<br>
+/* irq.h<br>
+ *<br>
+ * Â Copyright (c) 2010 embedded brains GmbH.<br>
+ *<br>
+ * Â CopyRight (C) 2000 Canon Research France SA.<br>
+ * Â Emmanuel Raguet, Â mailto:<a href="mailto:raguet@crf.canon.fr" target="_blank">raguet@crf.canon.fr</a><br>
+ *<br>
+ * Â Common file, merged from s3c2400/irq/irq.h and s3c2410/irq/irq.h<br>
+ *<br>
+ * Â 1. Modified from s3c2400 Â Peng Fan <a href="mailto:van.freenix@gmail.com" target="_blank">van.freenix@gmail.com</a><br>
+ */<br>
+<br>
+#ifndef _IRQ_H_<br>
+#define _IRQ_H_<br>
+<br>
+#ifndef ASM<br>
+#include <rtems.h><br>
+#include <rtems/irq.h><br>
+#include <rtems/irq-extension.h><br>
+<br>
+#include <s3c64xx.h><br>
+<br>
+#ifdef CPU_S3C6410<br>
+ Â /* possible interrupt sources */<br>
+#define BSP_EINT0 Â Â Â Â Â Â Â Â Â Â Â 0<br>
+#define BSP_EINT1 Â Â Â Â Â Â Â Â Â Â Â 1<br>
+#define BSP_RTC_TIC Â Â Â Â Â Â 2<br>
+#define BSP_CAMIF_C Â Â Â Â Â Â 3<br>
+#define BSP_CAMIF_P Â Â Â Â Â Â 4<br>
+#define     BSP_I2C1             5<br>
+#define BSP_I2S0_1_V40 6<br>
+/* 7 is reserved */<br>
+#define BSP_3D Â Â Â Â Â Â Â Â Â Â Â Â 8<br>
+#define BSP_POST0 Â Â Â Â Â Â Â Â Â Â Â 9<br>
+#define BSP_RPTATOR Â Â Â Â Â Â 10<br>
+#define BSP_2D Â Â Â Â Â Â Â Â Â Â Â Â 11<br>
+#define BSP_TVENC Â Â Â Â Â Â Â Â Â Â Â 12<br>
+#define BSP_SCALER Â Â Â Â Â Â 13<br>
+#define BSP_BATF Â Â Â Â Â Â Â Â Â Â Â 14<br>
+#define BSP_JPEG Â Â Â Â Â Â Â Â Â Â Â 15<br>
+#define BSP_MFC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 16<br>
+#define BSP_SDMA0 Â Â Â Â Â Â Â Â Â Â Â 17<br>
+#define BSP_SDMA1 Â Â Â Â Â Â Â Â Â Â Â 18<br>
+#define BSP_ARM_DMAERR 19<br>
+#define BSP_ARM_DMA Â Â Â Â Â Â 20<br>
+#define BSP_ARM_DMAS Â 21<br>
+#define BSP_KEYPAD Â Â Â Â Â Â 22<br>
+#define     BSP_TIMER0        23<br>
+#define BSP_TIMER1 Â Â Â Â Â Â 24<br>
+#define BSP_TIMER2 Â Â Â Â Â Â 25<br>
+#define BSP_WDT Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 26<br>
+#define BSP_TIMER3 Â Â Â Â Â Â 27<br>
+#define BSP_TIMER4 Â Â Â Â Â Â 28<br>
+#define BSP_LCD0 Â Â Â Â Â Â Â Â Â Â Â 29<br>
+#define BSP_LCD1 Â Â Â Â Â Â Â Â Â Â Â 30<br>
+#define BSP_LCD2 Â Â Â Â Â Â Â Â Â Â Â 31<br>
+#define BSP_EINT2 Â Â Â Â Â Â Â Â Â Â Â 32<br>
+#define BSP_EINT3 Â Â Â Â Â Â Â Â Â Â Â 33<br>
+#define BSP_PCM0 Â Â Â Â Â Â Â Â Â Â Â 34<br>
+#define BSP_PCM1 Â Â Â Â Â Â Â Â Â Â Â 35<br>
+#define BSP_AC97 Â Â Â Â Â Â Â Â Â Â Â 36<br>
+#define BSP_UART0 Â Â Â Â Â Â Â Â Â Â Â 37<br>
+#define BSP_UART1 Â Â Â Â Â Â Â Â Â Â Â 38<br>
+#define BSP_UART2 Â Â Â Â Â Â Â Â Â Â Â 39<br>
+#define BSP_UART3 Â Â Â Â Â Â Â Â Â Â Â 40<br>
+#define BSP_DMA0 Â Â Â Â Â Â Â Â Â Â Â 41<br>
+#define BSP_DMA1 Â Â Â Â Â Â Â Â Â Â Â 42<br>
+#define BSP_ONENAND0 Â 43<br>
+#define BSP_ONENAND1 Â 44<br>
+#define BSP_NFC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 45<br>
+#define BSP_CFC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 46<br>
+#define BSP_UHOST Â Â Â Â Â Â Â Â Â Â Â 47<br>
+#define BSP_SPI0 Â Â Â Â Â Â Â Â Â Â Â 48<br>
+#define BSP_SPI1 Â Â Â Â Â Â Â Â Â Â Â 49<br>
+#define BSP_HSMMC2 Â Â Â Â Â Â 49<br>
+#define BSP_I2C0 Â Â Â Â Â Â Â Â Â Â Â 50<br>
+#define BSP_HSItx            51<br>
+#define BSP_HSIrx            52<br>
+#define BSP_EINT4 Â Â Â Â Â Â Â Â Â Â Â 53<br>
+#define BSP_MSM Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 54<br>
+#define BSP_HOSTIF Â Â Â Â Â Â 55<br>
+#define BSP_HSMMC0 Â Â Â Â Â Â 56<br>
+#define BSP_HSMMC1 Â Â Â Â Â Â 57<br>
+#define BSP_OTG Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 58<br>
+#define BSP_IrDA Â Â Â Â Â Â Â Â Â Â Â 59<br>
+#define BSP_RTC_ALARM Â 60<br>
+#define BSP_SEC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 61<br>
+#define BSP_PENDNUP Â Â Â Â Â Â 62<br>
+#define BSP_ADC Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â 63<br>
+<br>
+#define BSP_MAX_INT Â Â Â Â Â Â 64<br>
+#endif<br>
+<br>
+#define BSP_INTERRUPT_VECTOR_MIN 0<br>
+<br>
+#define BSP_INTERRUPT_VECTOR_MAX (BSP_MAX_INT - 1)<br>
+<br>
+#endif /* ASM */<br>
+#endif /* _IRQ_H_ */<br>
+/* end of include file */<br>
diff --git a/c/src/lib/libcpu/arm/shared/include/arm-cp15.h b/c/src/lib/libcpu/arm/shared/include/arm-cp15.h<br>
index 3edc83f..45af5dd 100644<br>
--- a/c/src/lib/libcpu/arm/shared/include/arm-cp15.h<br>
+++ b/c/src/lib/libcpu/arm/shared/include/arm-cp15.h<br>
@@ -609,6 +609,23 @@ static inline void arm_cp15_data_cache_test_and_clean(void)<br>
  );<br>
 }<br>
<br>
+static inline void arm_cp15_data_cache_clean_and_invalidate(void)<br>
+{<br>
+ Â ARM_SWITCH_REGISTERS;<br>
+<br>
+ Â uint32_t sbz = 0;<br>
+<br>
+ Â __asm__ volatile (<br>
+ Â Â ARM_SWITCH_TO_ARM<br>
+ Â Â "mcr p15, 0, %[sbz], c7, c14, 0\n"<br>
+ Â Â ARM_SWITCH_BACK<br>
+ Â Â : ARM_SWITCH_OUTPUT<br>
+ Â Â : [sbz] "r" (sbz)<br>
+ Â Â : "memory"<br>
+ Â );<br>
+<br>
+}<br>
+<br>
 static inline void arm_cp15_data_cache_clean_and_invalidate_line(const void *mva)<br>
 {<br>
  ARM_SWITCH_REGISTERS;<br>
--<br>
1.7.10.4<br>
<br></div></div>
_______________________________________________<br>
rtems-devel mailing list<br>
<a href="mailto:rtems-devel@rtems.org" target="_blank">rtems-devel@rtems.org</a><br>
<a href="http://www.rtems.org/mailman/listinfo/rtems-devel" target="_blank">http://www.rtems.org/mailman/listinfo/rtems-devel</a><br>
</blockquote></div>
</blockquote></div><br></div>
</div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br>Regards,<br>Dhananjay M Balan,<br><div>Department Of Computer Science, </div><div>College Of Engineering, Trivandrum.</div><div><a href="http://cet.ac.in" target="_blank">http://cet.ac.in</a></div>
</div></div>