forked from apache/nuttx
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
boards/risc-v/eic7700x/starpro64: Add support for PINE64 StarPro64 SB…
…C (ESWIN EIC7700X SoC) This PR adds support for the PINE64 StarPro64 64-bit RISC-V SBC, based on ESWIN EIC7700X SoC. Most of the code was derived from NuttX for Milk-V Duo S (SOPHGO SG2000). The modified code is explained here: https://lupyuen.github.io/articles/starpro64#appendix-port-nuttx-to-starpro64 Modified Files: boards/Kconfig: Added StarPro64 board New Files in boards/risc-v/eic7700x/starpro64: src/eic7700x_appinit.c: Startup Code include/board.h: StarPro64 Definitions include/board_memorymap.h: Memory Map src/etc/init.d/rc.sysinit, rcS: Startup Script src/.gitignore: Ignore the tmp filesystem scripts/ld.script: Linker Script scripts/Make.defs: StarPro64 Makefile src/Makefile: StarPro64 Makefile Kconfig: StarPro64 Config configs/nsh/defconfig: Build Config for starpro64:nsh Signed-off-by: Lup Yuen Lee <[email protected]>
- Loading branch information
Showing
12 changed files
with
718 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
# | ||
# This file is autogenerated: PLEASE DO NOT EDIT IT. | ||
# | ||
# You can use "make menuconfig" to make any modifications to the installed .config file. | ||
# You can then do "make savedefconfig" to generate a new defconfig file that includes your | ||
# modifications. | ||
# | ||
# CONFIG_DISABLE_OS_API is not set | ||
# CONFIG_NSH_DISABLE_LOSMART is not set | ||
CONFIG_16550_ADDRWIDTH=0 | ||
CONFIG_16550_REGINCR=4 | ||
CONFIG_16550_UART0=y | ||
CONFIG_16550_UART0_BASE=0x50900000 | ||
CONFIG_16550_UART0_CLOCK=198144000 | ||
CONFIG_16550_UART0_IRQ=125 | ||
CONFIG_16550_UART0_SERIAL_CONSOLE=y | ||
CONFIG_16550_UART=y | ||
CONFIG_16550_WAIT_LCR=y | ||
CONFIG_ARCH="risc-v" | ||
CONFIG_ARCH_ADDRENV=y | ||
CONFIG_ARCH_BOARD="starpro64" | ||
CONFIG_ARCH_BOARD_EIC7700X_STARPRO64=y | ||
CONFIG_ARCH_CHIP="eic7700x" | ||
CONFIG_ARCH_CHIP_EIC7700X=y | ||
CONFIG_ARCH_DATA_NPAGES=128 | ||
CONFIG_ARCH_DATA_VBASE=0xC0100000 | ||
CONFIG_ARCH_HEAP_NPAGES=128 | ||
CONFIG_ARCH_HEAP_VBASE=0xC0200000 | ||
CONFIG_ARCH_INTERRUPTSTACK=2048 | ||
CONFIG_ARCH_KERNEL_STACKSIZE=3072 | ||
CONFIG_ARCH_PGPOOL_MAPPING=y | ||
CONFIG_ARCH_PGPOOL_PBASE=0x80600000 | ||
CONFIG_ARCH_PGPOOL_SIZE=4194304 | ||
CONFIG_ARCH_PGPOOL_VBASE=0x80600000 | ||
CONFIG_ARCH_RISCV=y | ||
CONFIG_ARCH_STACKDUMP=y | ||
CONFIG_ARCH_TEXT_NPAGES=128 | ||
CONFIG_ARCH_TEXT_VBASE=0xC0000000 | ||
CONFIG_ARCH_USE_MMU=y | ||
CONFIG_ARCH_USE_MPU=y | ||
CONFIG_ARCH_USE_S_MODE=y | ||
CONFIG_BOARDCTL_ROMDISK=y | ||
CONFIG_BOARD_LATE_INITIALIZE=y | ||
CONFIG_BOARD_LOOPSPERMSEC=1120 | ||
CONFIG_BUILD_KERNEL=y | ||
CONFIG_DEBUG_ASSERTIONS=y | ||
CONFIG_DEBUG_ASSERTIONS_EXPRESSION=y | ||
CONFIG_DEBUG_FEATURES=y | ||
CONFIG_DEBUG_FULLOPT=y | ||
CONFIG_DEBUG_SYMBOLS=y | ||
CONFIG_ELF=y | ||
CONFIG_EXAMPLES_HELLO=m | ||
CONFIG_FS_PROCFS=y | ||
CONFIG_FS_ROMFS=y | ||
CONFIG_IDLETHREAD_STACKSIZE=3072 | ||
CONFIG_INIT_FILEPATH="/system/bin/init" | ||
CONFIG_INIT_MOUNT=y | ||
CONFIG_INIT_MOUNT_FLAGS=0x1 | ||
CONFIG_INIT_MOUNT_TARGET="/system/bin" | ||
CONFIG_INIT_STACKSIZE=3072 | ||
CONFIG_INTELHEX_BINARY=y | ||
CONFIG_LIBC_ENVPATH=y | ||
CONFIG_LIBC_EXECFUNCS=y | ||
CONFIG_LIBC_MEMSET_64BIT=y | ||
CONFIG_LIBC_MEMSET_OPTSPEED=y | ||
CONFIG_LIBC_PERROR_STDOUT=y | ||
CONFIG_LIBC_STRERROR=y | ||
CONFIG_MM_PGALLOC=y | ||
CONFIG_NFILE_DESCRIPTORS_PER_BLOCK=6 | ||
CONFIG_NSH_ARCHINIT=y | ||
CONFIG_NSH_FILEIOSIZE=512 | ||
CONFIG_NSH_FILE_APPS=y | ||
CONFIG_NSH_READLINE=y | ||
CONFIG_PATH_INITIAL="/system/bin" | ||
CONFIG_RAM_SIZE=1048576 | ||
CONFIG_RAM_START=0x80200000 | ||
CONFIG_RAW_BINARY=y | ||
CONFIG_READLINE_CMD_HISTORY=y | ||
CONFIG_RR_INTERVAL=200 | ||
CONFIG_SCHED_HAVE_PARENT=y | ||
CONFIG_SCHED_LPWORK=y | ||
CONFIG_SCHED_WAITPID=y | ||
CONFIG_SERIAL_UART_ARCH_MMIO=y | ||
CONFIG_STACK_COLORATION=y | ||
CONFIG_START_MONTH=12 | ||
CONFIG_START_YEAR=2021 | ||
CONFIG_SYMTAB_ORDEREDBYNAME=y | ||
CONFIG_SYSTEM_NSH=y | ||
CONFIG_SYSTEM_NSH_PROGNAME="init" | ||
CONFIG_TESTING_GETPRIME=y | ||
CONFIG_TESTING_OSTEST=y | ||
CONFIG_USEC_PER_TICK=1000 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
/**************************************************************************** | ||
* boards/risc-v/eic7700x/starpro64/include/board.h | ||
* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* Licensed to the Apache Software Foundation (ASF) under one or more | ||
* contributor license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright ownership. The | ||
* ASF licenses this file to you under the Apache License, Version 2.0 (the | ||
* "License"); you may not use this file except in compliance with the | ||
* License. You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||
* License for the specific language governing permissions and limitations | ||
* under the License. | ||
* | ||
****************************************************************************/ | ||
|
||
#ifndef __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_H | ||
#define __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_H | ||
|
||
/**************************************************************************** | ||
* Included Files | ||
****************************************************************************/ | ||
|
||
#include <nuttx/config.h> | ||
|
||
/**************************************************************************** | ||
* Pre-processor Definitions | ||
****************************************************************************/ | ||
|
||
#define LED_STARTED 0 /* N/A */ | ||
#define LED_HEAPALLOCATE 1 /* N/A */ | ||
#define LED_IRQSENABLED 2 /* N/A */ | ||
#define LED_STACKCREATED 3 /* N/A */ | ||
#define LED_INIRQ 4 /* N/A */ | ||
#define LED_SIGNAL 5 /* N/A */ | ||
#define LED_ASSERTION 6 /* N/A */ | ||
#define LED_PANIC 7 /* N/A */ | ||
#define LED_CPU 8 /* LED */ | ||
|
||
/**************************************************************************** | ||
* Public Types | ||
****************************************************************************/ | ||
|
||
#ifndef __ASSEMBLY__ | ||
|
||
/**************************************************************************** | ||
* Public Data | ||
****************************************************************************/ | ||
|
||
#undef EXTERN | ||
#if defined(__cplusplus) | ||
#define EXTERN extern "C" | ||
extern "C" | ||
{ | ||
#else | ||
#define EXTERN extern | ||
#endif | ||
|
||
/**************************************************************************** | ||
* Public Function Prototypes | ||
****************************************************************************/ | ||
|
||
/**************************************************************************** | ||
* Name: eic7700x_boardinitialize | ||
****************************************************************************/ | ||
|
||
void eic7700x_boardinitialize(void); | ||
|
||
#undef EXTERN | ||
#if defined(__cplusplus) | ||
} | ||
#endif | ||
#endif /* __ASSEMBLY__ */ | ||
#endif /* __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_H */ |
85 changes: 85 additions & 0 deletions
85
boards/risc-v/eic7700x/starpro64/include/board_memorymap.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
/**************************************************************************** | ||
* boards/risc-v/eic7700x/starpro64/include/board_memorymap.h | ||
* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* Licensed to the Apache Software Foundation (ASF) under one or more | ||
* contributor license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright ownership. The | ||
* ASF licenses this file to you under the Apache License, Version 2.0 (the | ||
* "License"); you may not use this file except in compliance with the | ||
* License. You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||
* License for the specific language governing permissions and limitations | ||
* under the License. | ||
* | ||
****************************************************************************/ | ||
|
||
#ifndef __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_MEMORYMAP_H | ||
#define __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_MEMORYMAP_H | ||
|
||
/**************************************************************************** | ||
* Included Files | ||
****************************************************************************/ | ||
|
||
#include <stdint.h> | ||
|
||
/**************************************************************************** | ||
* Pre-processor Definitions | ||
****************************************************************************/ | ||
|
||
/* Kernel code memory (RX) */ | ||
|
||
#define KFLASH_START (uintptr_t)__kflash_start | ||
#define KFLASH_SIZE (uintptr_t)__kflash_size | ||
#define KSRAM_START (uintptr_t)__ksram_start | ||
#define KSRAM_SIZE (uintptr_t)__ksram_size | ||
#define KSRAM_END (uintptr_t)__ksram_end | ||
|
||
/* Kernel RAM (RW) */ | ||
|
||
#define PGPOOL_START (uintptr_t)__pgheap_start | ||
#define PGPOOL_SIZE (uintptr_t)__pgheap_size | ||
|
||
/* Page pool (RWX) */ | ||
|
||
#define PGPOOL_START (uintptr_t)__pgheap_start | ||
#define PGPOOL_SIZE (uintptr_t)__pgheap_size | ||
#define PGPOOL_END (PGPOOL_START + PGPOOL_SIZE) | ||
|
||
/* Ramdisk (RW) */ | ||
|
||
#define RAMDISK_START (uintptr_t)__ramdisk_start | ||
#define RAMDISK_SIZE (uintptr_t)__ramdisk_size | ||
|
||
/**************************************************************************** | ||
* Public Data | ||
****************************************************************************/ | ||
|
||
/* Kernel code memory (RX) */ | ||
|
||
extern uint8_t __kflash_start[]; | ||
extern uint8_t __kflash_size[]; | ||
|
||
/* Kernel RAM (RW) */ | ||
|
||
extern uint8_t __ksram_start[]; | ||
extern uint8_t __ksram_size[]; | ||
extern uint8_t __ksram_end[]; | ||
|
||
/* Page pool (RWX) */ | ||
|
||
extern uint8_t __pgheap_start[]; | ||
extern uint8_t __pgheap_size[]; | ||
|
||
/* Ramdisk (RW) */ | ||
|
||
extern uint8_t __ramdisk_start[]; | ||
extern uint8_t __ramdisk_size[]; | ||
|
||
#endif /* __BOARDS_RISCV_EIC7700X_STARPRO64_INCLUDE_BOARD_MEMORYMAP_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
############################################################################ | ||
# boards/risc-v/eic7700x/starpro64/scripts/Make.defs | ||
# | ||
# SPDX-License-Identifier: Apache-2.0 | ||
# | ||
# Licensed to the Apache Software Foundation (ASF) under one or more | ||
# contributor license agreements. See the NOTICE file distributed with | ||
# this work for additional information regarding copyright ownership. The | ||
# ASF licenses this file to you under the Apache License, Version 2.0 (the | ||
# "License"); you may not use this file except in compliance with the | ||
# License. You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||
# License for the specific language governing permissions and limitations | ||
# under the License. | ||
# | ||
############################################################################ | ||
|
||
include $(TOPDIR)/.config | ||
include $(TOPDIR)/tools/Config.mk | ||
include $(TOPDIR)/arch/risc-v/src/common/Toolchain.defs | ||
|
||
LDSCRIPT = ld.script | ||
ARCHSCRIPT += $(BOARD_DIR)$(DELIM)scripts$(DELIM)$(LDSCRIPT) | ||
ARCHPICFLAGS = -fpic -msingle-pic-base | ||
|
||
CFLAGS := $(ARCHCFLAGS) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS) $(ARCHINCLUDES) $(ARCHDEFINES) $(EXTRAFLAGS) -pipe | ||
CPICFLAGS = $(ARCHPICFLAGS) $(CFLAGS) | ||
CXXFLAGS := $(ARCHCXXFLAGS) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS) $(ARCHXXINCLUDES) $(ARCHDEFINES) $(EXTRAFLAGS) -pipe | ||
CXXPICFLAGS = $(ARCHPICFLAGS) $(CXXFLAGS) | ||
CPPFLAGS := $(ARCHINCLUDES) $(ARCHDEFINES) $(EXTRAFLAGS) | ||
AFLAGS += $(CFLAGS) -D__ASSEMBLY__ |
Oops, something went wrong.