/**************************************************************************** * configs/samd21-xplained/src/sam_autoleds.c * * Copyright (C) 2015 Gregory Nutt. All rights reserved. * Author: Gregory Nutt * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * 3. Neither the name NuttX nor the names of its contributors may be * used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************/ /* There are three LEDs on board the SAMD21 Xplained Pro board: The EDBG * controls two of the LEDs, a power LED and a status LED. There is only * one user controllable LED, a yellow LED labelled STATUS near the SAMD21 USB * connector. * * This LED is controlled by PB30 and the LED can be activated by driving PB30 * to GND. * * When CONFIG_ARCH_LEDS is defined in the NuttX configuration, NuttX will * control the LED as follows: * * SYMBOL Meaning LED * ------------------- ----------------------- ------ * LED_STARTED NuttX has been started OFF * LED_HEAPALLOCATE Heap has been allocated OFF * LED_IRQSENABLED Interrupts enabled OFF * LED_STACKCREATED Idle stack created ON * LED_INIRQ In an interrupt** N/C * LED_SIGNAL In a signal handler*** N/C * LED_ASSERTION An assertion failed N/C * LED_PANIC The system has crashed FLASH * * Thus if the LED is statically on, NuttX has successfully booted and is, * apparently, running normally. If the LED is flashing at approximately * 2Hz, then a fatal error has been detected and the system has halted. */ /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include #include #include "sam_port.h" #include "samd21-xplained.h" #ifdef CONFIG_ARCH_LEDS /**************************************************************************** * Public Functions ****************************************************************************/ /**************************************************************************** * Name: board_autoled_initialize ****************************************************************************/ void board_autoled_initialize(void) { (void)sam_configport(PORT_STATUS_LED); } /**************************************************************************** * Name: board_autoled_on ****************************************************************************/ void board_autoled_on(int led) { bool ledstate = true; switch (led) { case 0: /* LED_STARTED: NuttX has been started STATUS LED=OFF */ /* LED_HEAPALLOCATE: Heap has been allocated STATUS LED=OFF */ /* LED_IRQSENABLED: Interrupts enabled STATUS LED=OFF */ break; /* Leave ledstate == true to turn OFF */ default: case 2: /* LED_INIRQ: In an interrupt STATUS LED=N/C */ /* LED_SIGNAL: In a signal handler STATUS LED=N/C */ /* LED_ASSERTION: An assertion failed STATUS LED=N/C */ return; /* Return to leave STATUS LED unchanged */ case 3: /* LED_PANIC: The system has crashed STATUS LED=FLASH */ case 1: /* LED_STACKCREATED: Idle stack created STATUS LED=ON */ ledstate = false; /* Set ledstate == false to turn ON */ break; } sam_portwrite(PORT_STATUS_LED, ledstate); } /**************************************************************************** * Name: board_autoled_off ****************************************************************************/ void board_autoled_off(int led) { switch (led) { /* These should not happen and are ignored */ default: case 0: /* LED_STARTED: NuttX has been started STATUS LED=OFF */ /* LED_HEAPALLOCATE: Heap has been allocated STATUS LED=OFF */ /* LED_IRQSENABLED: Interrupts enabled STATUS LED=OFF */ case 1: /* LED_STACKCREATED: Idle stack created STATUS LED=ON */ /* These result in no-change */ case 2: /* LED_INIRQ: In an interrupt STATUS LED=N/C */ /* LED_SIGNAL: In a signal handler STATUS LED=N/C */ /* LED_ASSERTION: An assertion failed STATUS LED=N/C */ return; /* Return to leave STATUS LED unchanged */ /* Turn STATUS LED off set driving the output high */ case 3: /* LED_PANIC: The system has crashed STATUS LED=FLASH */ sam_portwrite(PORT_STATUS_LED, true); break; } } #endif /* CONFIG_ARCH_LEDS */