| /**************************************************************************** |
| * boards/arm/stm32wl5/nucleo-wl55jc/src/stm32_boot.c |
| * |
| * 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 <debug.h> |
| |
| #include <nuttx/arch.h> |
| #include <nuttx/board.h> |
| #include <nuttx/spi/spi.h> |
| |
| #include <arch/board/board.h> |
| |
| #ifdef CONFIG_VIDEO_FB |
| #include <nuttx/video/fb.h> |
| #endif |
| |
| #include "arm_internal.h" |
| #include "nucleo-wl55jc.h" |
| |
| /**************************************************************************** |
| * Pre-processor Definitions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Private Data |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Public Functions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Name: stm32wl5_board_initialize |
| * |
| * Description: |
| * All STM32WL5 architectures must provide the following entry point. |
| * This entry point is called early in the initialization -- after all |
| * memory has been configured and mapped but before any devices have been |
| * initialized. |
| * |
| ****************************************************************************/ |
| |
| void stm32wl5_board_initialize(void) |
| { |
| /* Configure on-board LEDs, which are always enabled */ |
| |
| board_leds_initialize(); |
| } |
| |
| /**************************************************************************** |
| * 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 immediately after up_initialize() is called and just before the |
| * initial application is started. This additional initialization phase |
| * may be used, for example, to initialize board-specific device drivers. |
| * |
| ****************************************************************************/ |
| |
| #ifdef CONFIG_BOARD_LATE_INITIALIZE |
| void board_late_initialize(void) |
| { |
| #if defined(CONFIG_VIDEO_FB) |
| int ret; |
| #endif |
| |
| #if defined(CONFIG_STM32WL5_SPI1) || defined(CONFIG_STM32WL5_SPI2S2) |
| stm32wl5_spidev_initialize(); |
| #endif |
| |
| #if defined(CONFIG_LCD_SSD1680) && !defined(CONFIG_VIDEO_FB) |
| board_lcd_initialize(); |
| #endif |
| |
| #ifdef CONFIG_VIDEO_FB |
| ret = fb_register(0, 0); |
| if (ret < 0) |
| { |
| syslog(LOG_ERR, "ERROR: fb_register() failed: %d\n", ret); |
| } |
| #endif |
| |
| /* Perform NSH initialization here instead of from the NSH. This |
| * alternative NSH initialization is necessary when NSH is ran in |
| * user-space but the initialization function must run in kernel space. |
| */ |
| |
| #if defined(CONFIG_NSH_LIBRARY) && !defined(CONFIG_NSH_ARCHINIT) |
| board_app_initialize(0); |
| #endif |
| } |
| #endif |