| /**************************************************************************** |
| * boards/arm/imx6/sabre-6quad/src/imx_boardinit.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 <stdint.h> |
| |
| #include <nuttx/board.h> |
| #include <arch/board/board.h> |
| |
| #include "chip.h" |
| #include "arm_internal.h" |
| #include "imx_boot.h" |
| #include "sabre-6quad.h" |
| |
| /**************************************************************************** |
| * Pre-processor Definitions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Private Functions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Public Functions |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Name: imx_memory_initialize |
| * |
| * Description: |
| * All i.MX6 architectures must provide the following entry point. This |
| * entry point is called early in the initialization before memory has |
| * been configured. This board-specific function is responsible for |
| * configuring any on-board memories. |
| * |
| * Logic in imx_memory_initialize must be careful to avoid using any |
| * global variables because those will be uninitialized at the time this |
| * function is called. |
| * |
| * Input Parameters: |
| * None |
| * |
| * Returned Value: |
| * None |
| * |
| ****************************************************************************/ |
| |
| void imx_memory_initialize(void) |
| { |
| /* SDRAM was initialized by a bootloader in the supported configurations. */ |
| } |
| |
| /**************************************************************************** |
| * Name: imx_board_initialize |
| * |
| * Description: |
| * All i.MX6 architectures must provide the following entry point. This |
| * entry point is called in the initialization phase -- after |
| * imx_memory_initialize and after all memory has been configured and |
| * mapped but before any devices have been initialized. |
| * |
| * Input Parameters: |
| * None |
| * |
| * Returned Value: |
| * None |
| * |
| ****************************************************************************/ |
| |
| void imx_board_initialize(void) |
| { |
| #ifdef CONFIG_ARCH_LEDS |
| /* Configure on-board LEDs if LED support has been selected. */ |
| |
| board_autoled_initialize(); |
| #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 immediately after up_intitialize() 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) |
| { |
| /* Perform board initialization */ |
| |
| imx_bringup(); |
| } |
| #endif /* CONFIG_BOARD_LATE_INITIALIZE */ |