summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/bfin/eZKit533
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2018-04-20 10:35:35 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2018-04-20 13:52:14 +0200
commit99648958668d3a33ee57974479b36201fe303f34 (patch)
tree6f27ea790e2823c6156e71219a4f54680263fac6 /c/src/lib/libbsp/bfin/eZKit533
parentbsps: Move start files to bsps (diff)
downloadrtems-99648958668d3a33ee57974479b36201fe303f34.tar.bz2
bsps: Move startup files to bsps
Adjust build support files to new directory layout. This patch is a part of the BSP source reorganization. Update #3285.
Diffstat (limited to 'c/src/lib/libbsp/bfin/eZKit533')
-rw-r--r--c/src/lib/libbsp/bfin/eZKit533/Makefile.am4
-rw-r--r--c/src/lib/libbsp/bfin/eZKit533/startup/bsp_specs9
-rw-r--r--c/src/lib/libbsp/bfin/eZKit533/startup/bspstart.c156
-rw-r--r--c/src/lib/libbsp/bfin/eZKit533/startup/linkcmds172
4 files changed, 2 insertions, 339 deletions
diff --git a/c/src/lib/libbsp/bfin/eZKit533/Makefile.am b/c/src/lib/libbsp/bfin/eZKit533/Makefile.am
index 46541c8be4..ef43e92795 100644
--- a/c/src/lib/libbsp/bfin/eZKit533/Makefile.am
+++ b/c/src/lib/libbsp/bfin/eZKit533/Makefile.am
@@ -3,7 +3,7 @@ ACLOCAL_AMFLAGS = -I ../../../../aclocal
include $(top_srcdir)/../../../../automake/compile.am
include $(top_srcdir)/../../bsp.am
-dist_project_lib_DATA = startup/bsp_specs
+dist_project_lib_DATA = ../../../../../../bsps/bfin/eZKit533/start/bsp_specs
noinst_PROGRAMS =
@@ -18,7 +18,7 @@ project_lib_DATA += linkcmds
project_lib_LIBRARIES = librtemsbsp.a
librtemsbsp_a_SOURCES =
-librtemsbsp_a_SOURCES += startup/bspstart.c
+librtemsbsp_a_SOURCES += ../../../../../../bsps/bfin/eZKit533/start/bspstart.c
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/bspfatal-default.c
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/sbrk.c
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/setvec.c
diff --git a/c/src/lib/libbsp/bfin/eZKit533/startup/bsp_specs b/c/src/lib/libbsp/bfin/eZKit533/startup/bsp_specs
deleted file mode 100644
index 87638cc027..0000000000
--- a/c/src/lib/libbsp/bfin/eZKit533/startup/bsp_specs
+++ /dev/null
@@ -1,9 +0,0 @@
-%rename endfile old_endfile
-%rename startfile old_startfile
-
-*startfile:
-%{!qrtems: %(old_startfile)} \
-%{!nostdlib: %{qrtems: crti.o%s crtbegin.o%s}}
-
-*endfile:
-%{!qrtems: %(old_endfile)} %{qrtems: crtend.o%s crtn.o%s}
diff --git a/c/src/lib/libbsp/bfin/eZKit533/startup/bspstart.c b/c/src/lib/libbsp/bfin/eZKit533/startup/bspstart.c
deleted file mode 100644
index 3579dd7766..0000000000
--- a/c/src/lib/libbsp/bfin/eZKit533/startup/bspstart.c
+++ /dev/null
@@ -1,156 +0,0 @@
-/* bspstart.c for eZKit533
- *
- * This routine does the bulk of the system initialisation.
- */
-
-/*
- * Copyright (c) 2006 by Atos Automacao Industrial Ltda.
- * written by Alain Schaefer <alain.schaefer@easc.ch>
- * and Antonio Giovanini <antonio@atos.com.br>
- *
- * The license and distribution terms for this file may be
- * found in the file LICENSE in this distribution or at
- * http://www.rtems.org/license/LICENSE.
- */
-
-#include <bsp.h>
-#include <bsp/bootcard.h>
-#include <cplb.h>
-#include <libcpu/interrupt.h>
-#include <rtems/sysinit.h>
-
-const unsigned int dcplbs_table[16][2] = {
- { 0xFFA00000, (PAGE_SIZE_1MB | CPLB_D_PAGE_MGMT | CPLB_WT) },
- { 0xFF900000, (PAGE_SIZE_1MB | CPLB_D_PAGE_MGMT | CPLB_WT) }, /* L1 Data B */
- { 0xFF800000, (PAGE_SIZE_1MB | CPLB_D_PAGE_MGMT | CPLB_WT) }, /* L1 Data A */
- { 0xFFB00000, (PAGE_SIZE_1MB | CPLB_DNOCACHE) },
- { 0x20300000, (PAGE_SIZE_1MB | CPLB_DNOCACHE) }, /* Async Memory Bank 3 */
- { 0x20200000, (PAGE_SIZE_1MB | CPLB_DNOCACHE) }, /* Async Memory Bank 2 (Secnd) */
- { 0x20100000, (PAGE_SIZE_1MB | CPLB_DNOCACHE) }, /* Async Memory Bank 1 (Prim B) */
- { 0x20000000, (PAGE_SIZE_1MB | CPLB_DNOCACHE) }, /* Async Memory Bank 0 (Prim A) */
-
- { 0x02400000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0x02000000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0x00C00000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0x00800000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0x00400000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0x00000000, (PAGE_SIZE_4MB | CPLB_DNOCACHE) },
- { 0xffffffff, 0xffffffff } /* end of section - termination */
-
-};
-
-
-const unsigned int _icplbs_table[16][2] = {
- { 0xFFA00000, (PAGE_SIZE_1MB | CPLB_I_PAGE_MGMT | CPLB_I_PAGE_MGMT | 0x4) }, /* L1 Code */
- { 0xEF000000, (PAGE_SIZE_1MB | CPLB_INOCACHE) }, /* AREA DE BOOT */
- { 0xFFB00000, (PAGE_SIZE_1MB | CPLB_INOCACHE) },
- { 0x20300000, (PAGE_SIZE_1MB | CPLB_INOCACHE) }, /* Async Memory Bank 3 */
- { 0x20200000, (PAGE_SIZE_1MB | CPLB_INOCACHE) }, /* Async Memory Bank 2 (Secnd) */
- { 0x20100000, (PAGE_SIZE_1MB | CPLB_INOCACHE) }, /* Async Memory Bank 1 (Prim B) */
- { 0x20000000, (PAGE_SIZE_1MB | CPLB_INOCACHE) }, /* Async Memory Bank 0 (Prim A) */
-
- { 0x02400000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0x02000000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0x00C00000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0x00800000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0x00400000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0x00000000, (PAGE_SIZE_4MB | CPLB_INOCACHE) },
- { 0xffffffff, 0xffffffff } /* end of section - termination */
-
-};
-
-/*
- * Init_PLL
- *
- * Routine to initialize the PLL. The Ezkit uses a 27 Mhz XTAL.
- * See "../eZKit533/include/bsp.h" for more information.
- */
-static void Init_PLL (void)
-{
- unsigned int n;
-
- /* Configure PLL registers */
- *((uint16_t*)PLL_LOCKCNT) = 0x1000;
- *((uint16_t*)PLL_DIV) = PLL_CSEL|PLL_SSEL;
- *((uint16_t*)PLL_CTL) = PLL_MSEL|PLL_DF;
-
- /* Commands to set PLL values */
- __asm__ ("cli r0;");
- __asm__ ("idle;");
- __asm__ ("sti r0;");
-
- /* Delay for PLL stabilization */
- for (n=0; n<200; n++) {}
-}
-
-/*
- * Init_EBIU
- *
- * Configure extern memory
- */
-static void Init_EBIU (void)
-{
- /* Configure FLASH */
- *((uint32_t*)EBIU_AMBCTL0) = 0x7bb07bb0L;
- *((uint32_t*)EBIU_AMBCTL1) = 0x7bb07bb0L;
- *((uint16_t*)EBIU_AMGCTL) = 0x000f;
-
- /* Configure SDRAM
- *((uint32_t*)EBIU_SDGCTL) = 0x0091998d;
- *((uint16_t*)EBIU_SDBCTL) = 0x0013;
- *((uint16_t*)EBIU_SDRRC) = 0x0817;
- */
-}
-
-/*
- * Init_Flags
- *
- * Enable LEDs port
- */
-static void Init_Flags(void)
-{
- *((uint16_t*)FIO_INEN) = 0x0100;
- *((uint16_t*)FIO_DIR) = 0x0000;
- *((uint16_t*)FIO_EDGE) = 0x0100;
- *((uint16_t*)FIO_MASKA_D) = 0x0100;
-
- *((uint8_t*)FlashA_PortB_Dir) = 0x3f;
- *((uint8_t*)FlashA_PortB_Data) = 0x00;
-}
-
-RTEMS_SYSINIT_ITEM(
- bfin_interrupt_init,
- RTEMS_SYSINIT_BSP_PRE_DRIVERS,
- RTEMS_SYSINIT_ORDER_MIDDLE
-);
-
-void bsp_start( void )
-{
- /* BSP Hardware Initialization*/
- Init_RTC(); /* Blackfin Real Time Clock initialization */
- Init_PLL(); /* PLL initialization */
- Init_EBIU(); /* EBIU initialization */
- Init_Flags(); /* GPIO initialization */
-
- int i=0;
- for (i=5;i<16;i++) {
- set_vector((rtems_isr_entry)bfin_null_isr, i, 1);
- }
-}
-
-/*
- * Helper Function to use the EzKits LEDS.
- * Can be used by the Application.
- */
-void setLED (uint8_t value)
-{
- *((uint8_t*)FlashA_PortB_Data) = value;
-}
-
-/*
- * Helper Function to use the EzKits LEDS
- */
-uint8_t getLED (void)
-{
- return *((uint8_t*)FlashA_PortB_Data);
-}
diff --git a/c/src/lib/libbsp/bfin/eZKit533/startup/linkcmds b/c/src/lib/libbsp/bfin/eZKit533/startup/linkcmds
deleted file mode 100644
index e66a599e1f..0000000000
--- a/c/src/lib/libbsp/bfin/eZKit533/startup/linkcmds
+++ /dev/null
@@ -1,172 +0,0 @@
-OUTPUT_FORMAT("elf32-bfin", "elf32-bfin",
- "elf32-bfin")
-
-OUTPUT_ARCH(bfin)
-ENTRY(__start)
-STARTUP(start.o)
-
-/*
- * Declare some sizes.
- */
-_RamBase = DEFINED(_RamBase) ? _RamBase : 0x0;
-_RamSize = DEFINED(_RamSize) ? _RamSize : 0x01000000;
-_HeapSize = DEFINED(_HeapSize) ? _HeapSize : 0x0;
-_StackSize = DEFINED(_StackSize) ? _StackSize : 0x1000;
-
-MEMORY
-{
- sdram(rwx) : ORIGIN = 0x00001000, LENGTH = 0x01000000
- l1code(rwx) : ORIGIN = 0xffa08000, LENGTH = 0x00008000
- l1data(rwx) : ORIGIN = 0xff804000, LENGTH = 0x00004000
-}
-
-SECTIONS
-{
-
- .l1code :
- {
- /*jump.o (.text)*/
- } > l1code
-
- .init :
- {
- KEEP (*(.init))
- } > sdram /*=0*/
-
- .text :
- {
- CREATE_OBJECT_SYMBOLS
- *(.text)
- *(.rodata*)
- *(.gnu.linkonce.r*)
-
- /*
- * Special FreeBSD sysctl sections.
- */
- . = ALIGN (16);
- ___start_set_sysctl_set = .;
- *(set_sysctl_*);
- ___stop_set_sysctl_set = ABSOLUTE(.);
- *(set_domain_*);
- *(set_pseudo_*);
-
- _etext = .;
-
- ___CTOR_LIST__ = .;
- LONG((___CTOR_END__ - ___CTOR_LIST__) / 4 - 2)
- *(.ctors)
- LONG(0)
- ___CTOR_END__ = .;
- ___DTOR_LIST__ = .;
- LONG((___DTOR_END__ - ___DTOR_LIST__) / 4 - 2)
- *(.dtors)
- LONG(0)
- ___DTOR_END__ = .;
- } > sdram
-
- .tdata : {
- __TLS_Data_begin = .;
- *(.tdata .tdata.* .gnu.linkonce.td.*)
- __TLS_Data_end = .;
- } > sdram
-
- .tbss : {
- __TLS_BSS_begin = .;
- *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon)
- __TLS_BSS_end = .;
- } > sdram
-
- __TLS_Data_size = __TLS_Data_end - __TLS_Data_begin;
- __TLS_Data_begin = __TLS_Data_size != 0 ? __TLS_Data_begin : __TLS_BSS_begin;
- __TLS_Data_end = __TLS_Data_size != 0 ? __TLS_Data_end : __TLS_BSS_begin;
- __TLS_BSS_size = __TLS_BSS_end - __TLS_BSS_begin;
- __TLS_Size = __TLS_BSS_end - __TLS_Data_begin;
- __TLS_Alignment = MAX (ALIGNOF (.tdata), ALIGNOF (.tbss));
-
- .fini :
- {
- KEEP (*(.fini))
- } > sdram /*=0*/
-
- .data :
- {
- *(.data)
- KEEP (*(SORT(.rtemsrwset.*)))
- *(.jcr)
- *(.gnu.linkonce.d*)
- CONSTRUCTORS
- _edata = .;
- } > sdram
-
- .eh_frame : { *(.eh_frame) } > sdram
- .data1 : { *(.data1) } > sdram
- .eh_frame : { *(.eh_frame) } > sdram
- .gcc_except_table : { *(.gcc_except_table*) } > sdram
-
- .rodata :
- {
- *(.rodata)
- *(.rodata.*)
- KEEP (*(SORT(.rtemsroset.*)))
- *(.gnu.linkonce.r*)
- } > sdram
-
-
- .bss :
- {
- _bss_start = .;
- _clear_start = .;
- *(.bss)
- *(.gnu.linkonce.b.*)
- *(COMMON)
- . = ALIGN (64);
- _stack_init = .;
- . += _StackSize;
- _clear_end = .;
- _WorkAreaBase = .;
- _end = .;
- __end = .;
- } > sdram
-
-/* Debugging stuff follows */
-
- /* Stabs debugging sections. */
- .stab 0 : { *(.stab) }
- .stabstr 0 : { *(.stabstr) }
- .stab.excl 0 : { *(.stab.excl) }
- .stab.exclstr 0 : { *(.stab.exclstr) }
- .stab.index 0 : { *(.stab.index) }
- .stab.indexstr 0 : { *(.stab.indexstr) }
- .comment 0 : { *(.comment) }
- /* DWARF debug sections.
- Symbols in the DWARF debugging sections are relative to the beginning
- of the section so we begin them at 0. */
- /* DWARF 1 */
- .debug 0 : { *(.debug) }
- .line 0 : { *(.line) }
- /* GNU DWARF 1 extensions */
- .debug_srcinfo 0 : { *(.debug_srcinfo) }
- .debug_sfnames 0 : { *(.debug_sfnames) }
- /* DWARF 1.1 and DWARF 2 */
- .debug_aranges 0 : { *(.debug_aranges) }
- .debug_pubnames 0 : { *(.debug_pubnames) }
- /* DWARF 2 */
- .debug_info 0 : { *(.debug_info) }
- .debug_abbrev 0 : { *(.debug_abbrev) }
- .debug_line 0 : { *(.debug_line) }
- .debug_frame 0 : { *(.debug_frame) }
- .debug_str 0 : { *(.debug_str) }
- .debug_loc 0 : { *(.debug_loc) }
- .debug_macinfo 0 : { *(.debug_macinfo) }
- /* SGI/MIPS DWARF 2 extensions */
- .debug_weaknames 0 : { *(.debug_weaknames) }
- .debug_funcnames 0 : { *(.debug_funcnames) }
- .debug_typenames 0 : { *(.debug_typenames) }
- .debug_varnames 0 : { *(.debug_varnames) }
- /*.stack 0x80000 : { _stack = .; *(.stack) }*/
- /* These must appear regardless of . */
-}
-
-__HeapSize = _HeapSize;
-__edata = _edata;
-__etext = _etext;