| /**************************************************************************** |
| * boards/risc-v/eic7700x/starpro64/src/eic7700x_appinit.c |
| * |
| * 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. |
| * |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Included Files |
| ****************************************************************************/ |
| |
| #include <nuttx/config.h> |
| |
| #include <stdbool.h> |
| #include <stdio.h> |
| #include <syslog.h> |
| #include <errno.h> |
| |
| #include <nuttx/board.h> |
| #include <nuttx/drivers/ramdisk.h> |
| #include <sys/mount.h> |
| #include <sys/boardctl.h> |
| #include <arch/board/board_memorymap.h> |
| |
| /**************************************************************************** |
| * Pre-processor Definitions |
| ****************************************************************************/ |
| |
| /* RAM Disk Definition */ |
| |
| #define SECTORSIZE 512 |
| #define NSECTORS(b) (((b) + SECTORSIZE - 1) / SECTORSIZE) |
| #define RAMDISK_DEVICE_MINOR 0 |
| |
| /**************************************************************************** |
| * Private Functions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Name: mount_ramdisk |
| * |
| * Description: |
| * Mount a RAM Disk defined in ld.script to /dev/ramX. The RAM Disk |
| * contains a ROMFS filesystem with applications that can be spawned at |
| * runtime. |
| * |
| * Returned Value: |
| * OK is returned on success. |
| * -ERRORNO is returned on failure. |
| * |
| ****************************************************************************/ |
| |
| static int mount_ramdisk(void) |
| { |
| int ret; |
| struct boardioc_romdisk_s desc; |
| |
| desc.minor = RAMDISK_DEVICE_MINOR; |
| desc.nsectors = NSECTORS((ssize_t)__ramdisk_size); |
| desc.sectsize = SECTORSIZE; |
| desc.image = __ramdisk_start; |
| |
| ret = boardctl(BOARDIOC_ROMDISK, (uintptr_t)&desc); |
| if (ret < 0) |
| { |
| syslog(LOG_ERR, "Ramdisk register failed: %s\n", strerror(errno)); |
| syslog(LOG_ERR, "Ramdisk mountpoint /dev/ram%d\n", |
| RAMDISK_DEVICE_MINOR); |
| syslog(LOG_ERR, "Ramdisk length %lu, origin %lx\n", |
| (ssize_t)__ramdisk_size, (uintptr_t)__ramdisk_start); |
| } |
| |
| return ret; |
| } |
| |
| /**************************************************************************** |
| * Public Functions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Name: board_app_initialize |
| * |
| * Description: |
| * Perform architecture specific initialization |
| * |
| * Input Parameters: |
| * arg - The boardctl() argument is passed to the board_app_initialize() |
| * implementation without modification. The argument has no |
| * meaning to NuttX; the meaning of the argument is a contract |
| * between the board-specific initialization logic and the |
| * matching application logic. The value could be such things as a |
| * mode enumeration value, a set of DIP switch settings, a |
| * pointer to configuration data read from a file or serial FLASH, |
| * or whatever you would like to do with it. Every implementation |
| * should accept zero/NULL as a default configuration. |
| * |
| * Returned Value: |
| * Zero (OK) is returned on success; a negated errno value is returned on |
| * any failure to indicate the nature of the failure. |
| * |
| ****************************************************************************/ |
| |
| int board_app_initialize(uintptr_t arg) |
| { |
| #ifdef CONFIG_BOARD_LATE_INITIALIZE |
| /* Board initialization already performed by board_late_initialize() */ |
| |
| return OK; |
| #else |
| /* Perform board-specific initialization */ |
| |
| #ifdef CONFIG_NSH_ARCHINIT |
| |
| mount(NULL, "/proc", "procfs", 0, NULL); |
| |
| #endif |
| |
| return OK; |
| #endif |
| } |
| |
| /**************************************************************************** |
| * Name: board_late_initialize |
| * |
| * Description: |
| * If CONFIG_BOARD_LATE_INITIALIZE is selected, then an additional |
| * initialization call will be performed in the boot-up sequence to a |
| * function called board_late_initialize(). board_late_initialize() will |
| * be called after up_initialize() and board_early_initialize() and just |
| * before the initial application is started. This additional |
| * initialization phase may be used, for example, to initialize board- |
| * specific device drivers for which board_early_initialize() is not |
| * suitable. |
| * |
| * Waiting for events, use of I2C, SPI, etc are permissible in the context |
| * of board_late_initialize(). That is because board_late_initialize() |
| * will run on a temporary, internal kernel thread. |
| * |
| ****************************************************************************/ |
| |
| void board_late_initialize(void) |
| { |
| /* Mount the RAM Disk */ |
| |
| mount_ramdisk(); |
| |
| /* Perform board-specific initialization */ |
| |
| #ifdef CONFIG_NSH_ARCHINIT |
| |
| mount(NULL, "/proc", "procfs", 0, NULL); |
| |
| #endif |
| } |