Library to handle the X-NUCLEO-LED61A1 LED Control Expansion Board based on the LED6001 component.

Dependents:   LedDimming_LED61A1_mbedOS HelloWorld_LED61A1_mbedOS LedDimming_LED61A1 HelloWorld_LED61A1 ... more

Fork of X_NUCLEO_LED61A1 by ST Expansion SW Team

LED Control Library

Library to handle the X-NUCLEO-LED61A1 LED Control Expansion Board based on the LED6001 component.

Platform compatibility

  • NUCLEO boards have been tested with the default configuration provided by the HelloWorld_LED61A1 example.
  • NUCLEO-F070RB, NUCLEO-F072RB, NUCLEO-F091RC boards have been tested with the following patch:
    • to connect with a wire the NUCLEO’s D9 pin to the LED61A1’s D6 pin;
    • to initialize the pwm PinName variable with D9 rather than D6.
  • NUCLEO-F302R8 board has been tested with the following patch:
    • to connect with a wire the NUCLEO’s D7 pin to the LED61A1’s D6 pin;
    • to initialize the pwm PinName variable with D7 rather than D6.
  • LPCXpresso11U68 board has been tested with the limitation of using only the PWM Dimming, as it provides only one PWM channel, thus allowing just one between the PWM or Analog Dimming functionalities. It has been tested with the following patch:
    • to connect with a wire the LPCX’s D3 pin to the LED61A1’s D4 pin;
    • to connect with a wire the LPCX’s D4 pin to the LED61A1’s D6 pin;
    • to initialize the xfault_irq PinName variable with D3 rather than D4;
    • to initialize the pwm PinName variable with D4 rather than D6;
    • to initialize the analog PinName variable with NC rather than D5;
    • to disable the use of the user button in any application example as it is not available.
  • FRDM-K64F board has been tested with the following patch:
    • to disable the use of the user button in any application example as it is not available.

Files at this revision

API Documentation at this revision

Comitter:
Davidroid
Date:
Thu Dec 10 15:32:20 2015 +0000
Child:
1:eab47c592e8f
Commit message:
Library to handle the X-NUCLEO-LED61A1 LED Control Expansion Board based on the LED6001 component.

Changed in this revision

BSP/x_nucleo_led61a1_class.cpp Show annotated file Show diff for this revision Revisions of this file
BSP/x_nucleo_led61a1_class.h Show annotated file Show diff for this revision Revisions of this file
BSP/x_nucleo_led61a1_config.h Show annotated file Show diff for this revision Revisions of this file
Components/Common/led.h Show annotated file Show diff for this revision Revisions of this file
Components/Interfaces/Led_class.h Show annotated file Show diff for this revision Revisions of this file
Components/led6001/led6001.h Show annotated file Show diff for this revision Revisions of this file
Components/led6001/led6001_class.cpp Show annotated file Show diff for this revision Revisions of this file
Components/led6001/led6001_class.h Show annotated file Show diff for this revision Revisions of this file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/BSP/x_nucleo_led61a1_class.cpp	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,206 @@
+/**
+ ******************************************************************************
+ * @file    x_nucleo_led61a1_class.cpp
+ * @author  AST / Software Platforms and Cloud
+ * @version V1.0
+ * @date    December 9rd, 2015
+ * @brief   Implementation file for the X_NUCLEO_LED61A1 expansion board.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Includes ------------------------------------------------------------------*/
+
+/* ACTION 1 ------------------------------------------------------------------*
+ * Include here platform specific header files.                               *
+ *----------------------------------------------------------------------------*/        
+#include "mbed.h"
+#include "DevI2C.h"
+/* ACTION 2 ------------------------------------------------------------------*
+ * Include here expansion board specific header files.                        *
+ *----------------------------------------------------------------------------*/        
+#include "x_nucleo_led61a1_class.h"
+
+
+/* Static variables ----------------------------------------------------------*/
+
+/* Singleton instance of X_NUCLEO_LED61A1 class. */
+X_NUCLEO_LED61A1 *X_NUCLEO_LED61A1::_instance;
+
+
+/* Methods -------------------------------------------------------------------*/
+
+/**
+ * @brief Constructor.
+ * @param i2c I2C device to be used for communication.
+ */
+X_NUCLEO_LED61A1::X_NUCLEO_LED61A1(DevI2C *i2c) : dev_i2c(i2c)
+{
+    /* Instantiating the components. */
+    /* ACTION 3 --------------------------------------------------------------*
+     * Instantiate here the expansion board's components.                     *
+     *                                                                        *
+     * Example:                                                               *
+     *   component_1 = new COMPONENT_1(COMPONENT_1_I2C_ADDRESS, *dev_i2c);    *
+     *   component_2 = new COMPONENT_2(COMPONENT_2_I2C_ADDRESS, *dev_i2c);    *
+     *------------------------------------------------------------------------*/
+    led6001 = new LED6001(LED6001_I2C_ADDRESS, *dev_i2c);
+}
+
+/**
+ * @brief Getting a singleton instance of X_NUCLEO_LED61A1 class.
+ * @param i2c I2C device to be used for communication.
+ * @retval a singleton instance of X_NUCLEO_LED61A1 class.
+ */
+X_NUCLEO_LED61A1 *X_NUCLEO_LED61A1::Instance(DevI2C *i2c)
+{
+    if (_instance == NULL)
+    {
+        /* I2C communication. */
+        if (i2c == NULL)
+            i2c = new DevI2C(X_NUCLEO_LED61A1_PIN_I2C_SDA, X_NUCLEO_LED61A1_PIN_I2C_SCL);
+
+        /* Instantiating the board. */
+        _instance = new X_NUCLEO_LED61A1(i2c);
+
+        /* Initializing the components. */
+        if (!_instance->Init())
+            error("Initialization of the X_NUCLEO_LED61A1 expansion board failed.\n");
+    }
+
+    return _instance;
+}
+
+/**
+ * @brief Getting a singleton instance of X_NUCLEO_LED61A1 class.
+ * @param sda pin name of the SDA pin of the I2C device to be used for communication.
+ * @param scl pin name of the SCL pin of the I2C device to be used for communication.
+ * @retval a singleton instance of X_NUCLEO_LED61A1 class.
+ */
+X_NUCLEO_LED61A1 *X_NUCLEO_LED61A1::Instance(PinName sda, PinName scl)
+{
+    if (_instance == NULL)
+    {
+        /* I2C communication. */
+        DevI2C *i2c = new DevI2C(sda, scl);
+
+        /* Instantiating the board. */
+        _instance = new X_NUCLEO_LED61A1(i2c);
+
+        /* Initializing the components. */
+        if (!_instance->Init())
+            error("Initialization of the X_NUCLEO_LED61A1 expansion board failed.\n");
+    }
+
+    return _instance;
+}
+
+/**
+ * @brief Initializing the X_NUCLEO_LED61A1 board.
+ * @retval true if initialization is successful, false otherwise.
+ */
+bool X_NUCLEO_LED61A1::Init(void)
+{
+    /* Initializing the components. */
+    /* ACTION 4 --------------------------------------------------------------*
+     * Initialize here the expansion board's components.                      *
+     *                                                                        *
+     * Example:                                                               *
+     *   return (Init_COMPONENT_1() && Init_COMPONENT_2());                   *
+     *------------------------------------------------------------------------*/
+    return (Init_LED6001());
+}
+
+/* ACTION 5 ------------------------------------------------------------------*
+ * Implement here an initialization method for each expansion board's         *
+ * component.                                                                 *
+ *                                                                            *
+ * Example:                                                                   *
+ *   bool EXPANSION_BOARD::Init_COMPONENT_1(void)                             *
+ *   {                                                                        *
+ *     // Verifying identity.                                                 *
+ *     uint8_t id = 0;                                                        *
+ *     int ret = component_1->ReadID(&id);                                    *
+ *     if ((ret != COMPONENT_OK) || (id != I_AM_COMPONENT_1))                 *
+ *     {                                                                      *
+ *       delete component_1;                                                  *
+ *       component_1 = NULL;                                                  *
+ *       return true;                                                         *
+ *     }                                                                      *
+ *                                                                            *
+ *     // Configuration.                                                      *
+ *     INTERFACE_InitTypeDef InitStructure;                                   *
+ *     InitStructure.Property_1 = COMPONENT_1_PROPERY_1_INIT;                 *
+ *     InitStructure.Property_N = COMPONENT_1_PROPERY_N_INIT;                 *
+ *                                                                            *
+ *     // Initialization.                                                     *
+ *     if (component_1->Init(&InitStructure) != COMPONENT_OK)                 *
+ *       return false;                                                        *
+ *                                                                            *
+ *     return true;                                                           *
+ *   }                                                                        *
+ *----------------------------------------------------------------------------*/
+/**
+ * @brief  Initialize the LED6001 component.
+ * @retval true if initialization is successful, false otherwise.
+ */
+bool X_NUCLEO_LED61A1::Init_LED6001(void)
+{
+    /* Verifying identity. */
+    uint8_t id = 0;
+    int ret = led6001->ReadID(&id);
+    if ((ret != COMPONENT_OK) || (id != I_AM_LED6001))
+    {
+        delete led6001;
+        led6001 = NULL;
+        return true;
+    }
+
+    /* Configuration. */
+    LED_InitTypeDef InitStructure;
+    /* ACTION ----------------------------------------------------------------*
+     * Configure here the component's initialization structure.               *
+     *                                                                        *
+     * Example:                                                               *
+     *   InitStructure.Property_1 = COMPONENT_PROPERY_1_INIT;                 *
+     *   InitStructure.Property_N = COMPONENT_PROPERY_N_INIT;                 *
+     *------------------------------------------------------------------------*/
+
+    /* Initialization. */
+    if (led6001->Init(&InitStructure) != COMPONENT_OK)
+        return false;
+
+    return true;
+}
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/BSP/x_nucleo_led61a1_class.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,155 @@
+/**
+ ******************************************************************************
+ * @file    x_nucleo_led61a1_class.h
+ * @author  AST / Software Platforms and Cloud
+ * @version V1.0
+ * @date    December 9rd, 2015
+ * @brief   Class header file for the X_NUCLEO_LED61A1 expansion board.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+
+#ifndef __X_NUCLEO_LED61A1_CLASS_H
+#define __X_NUCLEO_LED61A1_CLASS_H
+
+
+/* Includes ------------------------------------------------------------------*/
+
+/* ACTION 1 ------------------------------------------------------------------*
+ * Include here platform specific header files.                               *
+ *----------------------------------------------------------------------------*/        
+#include "mbed.h"
+#include "DevI2C.h"
+/* ACTION 2 ------------------------------------------------------------------*
+* Include here expansion board configuration's header files.                 *
+  *----------------------------------------------------------------------------*/        
+#include "x_nucleo_led61a1_config.h"
+/* ACTION 3 ------------------------------------------------------------------*
+ * Include here expansion board's components' header files.                   *
+ *                                                                            *
+ * Example:                                                                   *
+ *   #include "component_1_class.h"                                           *
+ *   #include "component_2_class.h"                                           *
+ *----------------------------------------------------------------------------*/
+#include "led6001_class.h" 
+
+
+/* Classes -------------------------------------------------------------------*/
+
+/** Class representing a X_NUCLEO_LED61A1 board.
+ */
+class X_NUCLEO_LED61A1
+{
+public:
+
+    /*** Instance, Initialization and Destructor Methods ***/
+
+    /**
+     * @brief Getting a singleton instance of X_NUCLEO_LED61A1 class.
+     * @param i2c I2C device to be used for communication.
+     * @retval a singleton instance of X_NUCLEO_LED61A1 class.
+     */
+    static X_NUCLEO_LED61A1 *Instance(DevI2C *i2c = NULL);
+
+    /**
+     * @brief Getting a singleton instance of X_NUCLEO_LED61A1 class.
+     * @param sda pin name of the SDA pin of the I2C device to be used for communication.
+     * @param scl pin name of the SCL pin of the I2C device to be used for communication.
+     * @retval a singleton instance of X_NUCLEO_LED61A1 class.
+     */
+    static X_NUCLEO_LED61A1 *Instance(PinName sda, PinName scl);
+
+    /**
+     * @brief Initializing the X_NUCLEO_LED61A1 board.
+     * @retval true if initialization is successful, false otherwise.
+     */
+    bool Init(void);
+
+    /**
+     * @brief Destructor.
+     */
+    ~X_NUCLEO_LED61A1(void) {}
+
+
+    /*** Public Expansion Board Related Attributes ***/
+
+    /* ACTION 4 --------------------------------------------------------------*
+     * Declare here a public attribute for each expansion board's component.  *
+     * You will have to call these attributes' public methods within your     *
+     * main program.                                                          *
+     *                                                                        *
+     *   Example:                                                             *
+     *     COMPONENT_1 *component_1;                                          *
+     *     COMPONENT_2 *component_2;                                          *
+     *------------------------------------------------------------------------*/
+    LED6001 *led6001;
+
+
+protected:
+
+    /*** Protected Constructor Method ***/
+
+    /**
+     * @brief Constructor.
+     * @param i2c I2C device to be used for communication.
+     */
+    X_NUCLEO_LED61A1(DevI2C *i2c);
+
+
+    /*** Protected Expansion Board Related Initialization Methods ***/
+
+    /* ACTION 5 --------------------------------------------------------------*
+     * Declare here a protected initialization method for each expansion      *
+     * board's component.                                                     *
+     *                                                                        *
+     * Example:                                                               *
+     *   bool Init_COMPONENT_1(void);                                         *
+     *   bool Init_COMPONENT_2(void);                                         *
+     *------------------------------------------------------------------------*/
+    bool Init_LED6001(void);
+
+
+    /*** Component's Instance Variables ***/
+
+    /* Singleton instance of X_NUCLEO_LED61A1 class. */
+    static X_NUCLEO_LED61A1 *_instance;
+
+    /* IO Device. */
+    DevI2C *dev_i2c;
+};
+
+#endif // __X_NUCLEO_LED61A1_CLASS_H
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/BSP/x_nucleo_led61a1_config.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,78 @@
+/**
+ ******************************************************************************
+ * @file    x_nucleo_led61a1_config.h
+ * @author  AST / Software Platforms and Cloud
+ * @version V1.0
+ * @date    December 9rd, 2015
+ * @brief   Configuration header file for the X_NUCLEO_LED61A1 expansion board.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Define to prevent from recursive inclusion --------------------------------*/
+
+#ifndef __X_NUCLEO_LED61A1_CONFIG_H
+#define __X_NUCLEO_LED61A1_CONFIG_H
+
+
+/* Definitions ---------------------------------------------------------------*/
+
+/* ACTION --------------------------------------------------------------------*
+ * Specify here a configuration for I/O and interrupts' pins.                 *
+ *                                                                            *
+ * Example:                                                                   *
+ *   // I2C.                                                                  *
+ *   #define EXPANSION_BOARD_PIN_I2C_SCL  (D15)                               *
+ *   #define EXPANSION_BOARD_PIN_I2C_SDA  (D14)                               *
+ *                                                                            *
+ *   // SPI.                                                                  *
+ *   #define EXPANSION_BOARD_PIN_SPI_MOSI (D11)                               *
+ *   #define EXPANSION_BOARD_PIN_SPI_MISO (D12)                               *
+ *   #define EXPANSION_BOARD_PIN_SPI_SCLK (D13)                               *
+ *                                                                            *
+ *   // Interrupts.                                                           *
+ *   #define EXPANSION_BOARD_PIN_INT_1    (A2)                                *
+ *----------------------------------------------------------------------------*/
+/* I2C. */
+#define X_NUCLEO_LED61A1_PIN_I2C_SCL  (D15)
+#define X_NUCLEO_LED61A1_PIN_I2C_SDA  (D14)
+
+/* SPI. */
+#define X_NUCLEO_LED61A1_PIN_SPI_MOSI (D11)
+#define X_NUCLEO_LED61A1_PIN_SPI_MISO (D12)
+#define X_NUCLEO_LED61A1_PIN_SPI_SCLK (D13)
+
+/* Interrupts. */
+#define X_NUCLEO_LED61A1_PIN_INT_1    (A2)
+
+#endif // __X_NUCLEO_LED61A1_CONFIG_H
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Components/Common/led.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,103 @@
+/**
+ ******************************************************************************
+ * @file    led.h
+ * @author  CL
+ * @version V1.0.0
+ * @date    30-Sep-2015
+ * @brief   This header file contains the functions prototypes for the
+ *          led driver.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+#ifndef __LED_H
+#define __LED_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* Includes ------------------------------------------------------------------*/
+#include <stdint.h>
+
+/** @addtogroup BSP
+  * @{
+  */
+
+/** @addtogroup Components
+  * @{
+  */
+
+/** @addtogroup LED_DRIVER
+  * @{
+  */
+
+/** @defgroup LED_Exported_Types
+  * @{
+  */
+
+/**
+ * @brief  LED_DRIVER init structure definition
+ */
+typedef struct
+{
+  uint8_t PdimVal;
+  uint8_t AdimVal;  
+} LED_InitTypeDef;
+
+/**
+ * @brief  LED_DRIVER component id enumerator definition
+ */
+typedef enum
+{
+  LED_NONE_COMPONENT = 0,
+  LED_LED6001_COMPONENT = 1,
+} LED_ComponentTypeDef;
+
+/**
+ * @brief  LED_DRIVER driver structure definition
+ */
+typedef struct
+{
+  DrvStatusTypeDef (*Init)(LED_InitTypeDef *);
+  void (*DeInit)(void);
+  void (*SetPwmDim)(uint8_t);
+  void (*SetAnaDim)(uint8_t);
+  DrvStatusTypeDef (*FaultStatus)(void);
+} LED_DrvVTableTypeDef;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __LED_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Components/Interfaces/Led_class.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,85 @@
+/**
+ ******************************************************************************
+ * @file    Led_class.h
+ * @author  AST
+ * @version V0.0.1
+ * @date    13-April-2015
+ * @brief   This file contains the abstract class describing the interface of an
+ *          LED component.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Revision ------------------------------------------------------------------*/
+/*
+    Repository:       http://svn.x-nucleodev.codex.cro.st.com/svnroot/X-NucleoDev
+    Branch/Trunk/Tag: trunk
+    Based on:         X-CUBE-LED1/trunk/Drivers/BSP/Components/Common/led.h
+    Revision:         0
+*/
+
+
+/* Define to prevent from recursive inclusion --------------------------------*/
+
+#ifndef __LED_CLASS_H
+#define __LED_CLASS_H
+
+
+/* Includes ------------------------------------------------------------------*/
+
+#include <Component_class.h>
+
+
+/* Classes  ------------------------------------------------------------------*/
+
+/** An abstract class for Led components.
+ */
+class Led : public Component
+{
+public:
+    /* ACTION 1 --------------------------------------------------------------*
+     * Declare here the interface's methods.                                  *
+     * They should be:                                                        *
+     *   + Methods with the same name of the C component's virtual table      *
+     *     (and extended virtual table, if any)'s functions, provided that    *
+     *     the component's driver implements them (i.e.: the corresponding    *
+     *     pointer to function is not "0").                                   *
+     *                                                                        *
+     * Example:                                                               *
+     *    virtual int GetValue(float *pfData) = 0;                            *
+     *------------------------------------------------------------------------*/
+};
+
+#endif /* __LED_CLASS_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Components/led6001/led6001.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,102 @@
+/**
+ ******************************************************************************
+ * @file    led6001.h
+ * @author  CL
+ * @version V1.0.0
+ * @date    30-Sep-2015
+ * @brief   This file contains definitions for the LED6001's firmware driver.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+
+#ifndef __LED6001_H
+#define __LED6001_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/* Includes ------------------------------------------------------------------*/
+
+#include "led.h"
+
+
+/** @addtogroup BSP
+ * @{
+ */
+
+/** @addtogroup Components
+ * @{
+ */
+
+/** @addtogroup LED6001
+ * @{
+ */
+
+/** @defgroup LED6001_Exported_Defines LED6001_Exported_Defines
+ * @{
+ */
+#ifndef NULL
+#define NULL      (void *) 0
+#endif
+
+
+/**
+ * @}
+ */
+
+/** @defgroup LED6001_Imported_Functions LED6001_Imported_Functions
+ * @{
+ */
+/* LED driver IO functions */
+extern DrvStatusTypeDef LED6001_IO_Init(void);
+extern void LED6001_IO_DeInit(void);
+extern void LED6001_IO_ITConfig( void );
+extern void LED6001_SetPdimTimer(uint8_t PwmVal);
+extern void LED6001_SetAdimTimer(uint8_t PwmVal);
+/**
+ * @}
+ */
+
+   
+#define LED6001_PDIM_FULL       100
+#define LED6001_ADIM_FULL       100
+   
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __LED6001_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Components/led6001/led6001_class.cpp	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,117 @@
+/**
+ ******************************************************************************
+ * @file    led6001_class.cpp
+ * @author  CL
+ * @version V1.0.0
+ * @date    30-Sep-2015
+ * @brief   This file contains implementation of the LED6001's firmware driver.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Revision ------------------------------------------------------------------*/
+/*
+    Repository:       http://svn.x-nucleodev.codex.cro.st.com/svnroot/X-NucleoDev
+    Branch/Trunk/Tag: trunk
+    Based on:         X-CUBE-LED1/trunk/Drivers/BSP/Components/led6001/led6001.c
+    Revision:         0
+*/
+
+
+/* Includes ------------------------------------------------------------------*/
+
+#include "led6001_class.h"
+#include "led6001.h"
+
+
+/* Methods -------------------------------------------------------------------*/
+
+/**
+ * @brief  Initializing the component.
+ * @param  init Configuration settings for the LED6001 component.
+ * @retval COMPONENT_OK in case of success, an error code otherwise.
+ */
+LED_StatusTypeDef LED6001::LED6001_Init(LED_InitTypeDef *init)
+{
+  /* Configure the low level interface */
+  if(LED6001_IO_Init() != COMPONENT_OK)
+  {
+    return COMPONENT_ERROR;
+  }
+  
+  LED6001_IO_ITConfig();
+
+  return COMPONENT_OK;
+}
+
+/**
+ * @brief  Deinitializing the component.
+ * @param  None.
+ * @retval None.
+ */
+void LED6001::LED6001_DeInit(void)
+{
+  LED6001_IO_DeInit();
+}
+
+/**
+ * @brief  Setting PWM dim value.
+ * @param  value PWM dim value.
+ * @retval None.
+ */
+void LED6001::LED6001_SetPwmDim(uint8_t value)
+{
+  LED6001_SetPdimTimer(value);
+}
+
+/**
+ * @brief  Setting analog dim value.
+ * @param  value Analog dim value.
+ * @retval None.
+ */
+void LED6001::LED6001_SetAnaDim(uint8_t value)
+{
+  LED6001_SetAdimTimer(value);
+}
+
+/**
+ * @brief  Returning fault status of the component.
+ * @param  None.
+ * @retval Fault status.
+ */
+LED_StatusTypeDef LED6001::LED6001_FaultStatus(void)
+{
+  return COMPONENT_OK;
+}
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Components/led6001/led6001_class.h	Thu Dec 10 15:32:20 2015 +0000
@@ -0,0 +1,360 @@
+/**
+ ******************************************************************************
+ * @file    led6001_class.h
+ * @author  Davide Aliprandi, STMicrolectronics
+ * @version V1.0.0
+ * @date    December 9th, 2015
+ * @brief   This file contains the class of an LED6001 component.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * 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 of STMicroelectronics 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 HOLDER 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.
+ *
+ ******************************************************************************
+ */
+
+
+/* Generated with Stm32CubeTOO -----------------------------------------------*/
+
+
+/* Revision ------------------------------------------------------------------*/
+/*
+    Repository:       http://svn.x-nucleodev.codex.cro.st.com/svnroot/X-NucleoDev
+    Branch/Trunk/Tag: trunk
+    Based on:         X-CUBE-LED1/trunk/Drivers/BSP/Components/led6001/led6001.h
+    Revision:         0
+*/
+
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+
+#ifndef __LED6001_CLASS_H
+#define __LED6001_CLASS_H
+
+
+/* Includes ------------------------------------------------------------------*/
+
+/* ACTION 1 ------------------------------------------------------------------*
+ * Include here platform specific header files.                               *
+ *----------------------------------------------------------------------------*/        
+#include "mbed.h"
+#include "DevI2C.h"
+/* ACTION 2 ------------------------------------------------------------------*
+ * Include here component specific header files.                              *
+ *----------------------------------------------------------------------------*/        
+#include "led6001.h"
+/* ACTION 3 ------------------------------------------------------------------*
+ * Include here interface specific header files.                              *
+ *                                                                            *
+ * Example:                                                                   *
+ *   #include "../Interfaces/Humidity_class.h"                                *
+ *   #include "../Interfaces/Temperature_class.h"                             *
+ *----------------------------------------------------------------------------*/
+#include "../Interfaces/Led_class.h"
+
+
+/* Classes -------------------------------------------------------------------*/
+
+/**
+ * @brief Class representing a LED6001 component.
+ */
+class LED6001 : public Led
+{
+public:
+
+    /*** Constructor and Destructor Methods ***/
+
+    /**
+     * @brief Constructor.
+     * @param address I2C address of the component.
+     * @param i2c     I2C device to be used for communication.
+     */
+    LED6001(uint8_t address, DevI2C &i2c) : Led(), address(address), dev_i2c(i2c)
+    {
+        /* ACTION 4 ----------------------------------------------------------*
+         * Initialize here the component's member variables, one variable per *
+         * line.                                                              *
+         *                                                                    *
+         * Example:                                                           *
+         *   measure = 0;                                                     *
+         *   instance_id = number_of_instances++;                             *
+         *--------------------------------------------------------------------*/
+    }
+    
+    /**
+     * @brief Destructor.
+     */
+    virtual ~LED6001(void) {}
+    
+
+    /*** Public Component Related Methods ***/
+
+    /* ACTION 5 --------------------------------------------------------------*
+     * Implement here the component's public methods, as wrappers of the C    *
+     * component's functions.                                                 *
+     * They should be:                                                        *
+     *   + Methods with the same name of the C component's virtual table's    *
+     *     functions (1);                                                     *
+     *   + Methods with the same name of the C component's extended virtual   *
+     *     table's functions, if any (2).                                     *
+     *                                                                        *
+     * Example:                                                               *
+     *   virtual int GetValue(float *pData) //(1)                             *
+     *   {                                                                    *
+     *     return COMPONENT_GetValue(float *pfData);                          *
+     *   }                                                                    *
+     *                                                                        *
+     *   virtual int EnableFeature(void) //(2)                                *
+     *   {                                                                    *
+     *     return COMPONENT_EnableFeature();                                  *
+     *   }                                                                    *
+     *------------------------------------------------------------------------*/
+    /**
+     * @brief  Initializing the component.
+     * @param  init Configuration settings for the LED6001 component.
+     * @retval COMPONENT_OK in case of success, an error code otherwise.
+     */
+    virtual int Init(void *init)
+    {
+        return (int) LED6001_Init((void *) init);
+    }
+
+    /**
+     * @brief  Deinitializing the component.
+     * @param  None.
+     * @retval None.
+     */
+    virtual void DeInit(void)
+    {
+        LED6001_DeInit();
+    }
+
+    /**
+     * @brief  Setting PWM dim value.
+     * @param  value PWM dim value.
+     * @retval None.
+     */
+    virtual void SetPwmDim(uint8_t)
+    {
+        LED6001_SetPwmDim(() uint8_t);
+    }
+
+    /**
+     * @brief  Setting analog dim value.
+     * @param  value Analog dim value.
+     * @retval None.
+     */
+    virtual void SetAnaDim(uint8_t)
+    {
+        LED6001_SetAnaDim(() uint8_t);
+    }
+
+    /**
+     * @brief  Returning fault status of the component.
+     * @param  None.
+     * @retval Fault status.
+     */
+    virtual int FaultStatus(void)
+    {
+        return (int) LED6001_FaultStatus();
+    }
+
+
+    /*** Public Interrupt Related Methods ***/
+
+    /* ACTION 6 --------------------------------------------------------------*
+     * Implement here interrupt related methods, if any.                      *
+     * Note that interrupt handling is platform dependent, e.g.:              *
+     *   + mbed:                                                              *
+     *     InterruptIn feature_irq(pin); //Interrupt object.                  *
+     *     feature_irq.rise(callback);   //Attach a callback.                 *
+     *     feature_irq.mode(PullNone);   //Set interrupt mode.                *
+     *     feature_irq.enable_irq();     //Enable interrupt.                  *
+     *     feature_irq.disable_irq();    //Disable interrupt.                 *
+     *   + Arduino:                                                           *
+     *     attachInterrupt(pin, callback, RISING); //Attach a callback.       *
+     *     detachInterrupt(pin);                   //Detach a callback.       *
+     *                                                                        *
+     * Example (mbed):                                                        *
+     *   void AttachFeatureIRQ(void (*fptr) (void))                           *
+     *   {                                                                    *
+     *     feature_irq.rise(fptr);                                            *
+     *   }                                                                    *
+     *                                                                        *
+     *   void EnableFeatureIRQ(void)                                          *
+     *   {                                                                    *
+     *     feature_irq.enable_irq();                                          *
+     *   }                                                                    *
+     *                                                                        *
+     *   void DisableFeatureIRQ(void)                                         *
+     *   {                                                                    *
+     *     feature_irq.disable_irq();                                         *
+     *   }                                                                    *
+     *------------------------------------------------------------------------*/
+
+
+protected:
+
+    /*** Protected Component Related Methods ***/
+
+    /* ACTION 7 --------------------------------------------------------------*
+     * Declare here the component's specific methods.                         *
+     * They should be:                                                        *
+     *   + Methods with the same name of the C component's virtual table's    *
+     *     functions (1);                                                     *
+     *   + Methods with the same name of the C component's extended virtual   *
+     *     table's functions, if any (2);                                     *
+     *   + Helper methods, if any, like functions declared in the component's *
+     *     source files but not pointed by the component's virtual table (3). *
+     *                                                                        *
+     * Example:                                                               *
+     *   DrvStatusTypeDef COMPONENT_GetValue(float* pfData); //(1)            *
+     *   DrvStatusTypeDef COMPONENT_EnableFeature(void);     //(2)            *
+     *   DrvStatusTypeDef COMPONENT_ComputeAverage(void);    //(3)            *
+     *------------------------------------------------------------------------*/
+    LED_StatusTypeDef LED6001_Init(LED_InitTypeDef *init);
+    void LED6001_DeInit(void);
+    void LED6001_SetPwmDim(uint8_t PwmVal);
+    void LED6001_SetAnaDim(uint8_t PwmVal);
+    LED_StatusTypeDef LED6001_FaultStatus(void);
+
+
+    /*** Component's I/O Methods ***/
+
+    /**
+     * @brief      Utility function to read data from LED6001.
+     * @param[out] pBuffer pointer to the buffer to read data into.
+     * @param[in]  RegisterAddr specifies the internal address register to read from.
+     * @param[in]  NumBytesToRead number of bytes to read.
+     * @retval     COMPONENT_OK in case of success, COMPONENT_ERROR otherwise.
+     */
+    DrvStatusTypeDef Read(uint8_t* pBuffer, uint8_t RegisterAddr, uint16_t NumBytesToRead)
+    {
+        if (dev_i2c.i2c_read(pBuffer, address, RegisterAddr, NumBytesToRead) != 0)
+            return COMPONENT_ERROR;
+        return COMPONENT_OK;
+    }
+    
+    /**
+     * @brief      Utility function to write data to LED6001.
+     * @param[in]  pBuffer pointer to the buffer of data to send.
+     * @param[in]  RegisterAddr specifies the internal address register to write to.
+     * @param[in]  NumBytesToWrite number of bytes to write.
+     * @retval     COMPONENT_OK in case of success, COMPONENT_ERROR otherwise.
+     */
+    DrvStatusTypeDef Write(uint8_t* pBuffer, uint8_t RegisterAddr, uint16_t NumBytesToWrite)
+    {
+        if (dev_i2c.i2c_write(pBuffer, address, RegisterAddr, NumBytesToWrite) != 0)
+            return COMPONENT_ERROR;
+        return COMPONENT_OK;
+    }
+
+    /* ACTION 8 --------------------------------------------------------------*
+     * Implement here other I/O methods beyond those already implemented      *
+     * above, which are declared extern within the component's header file.   *
+     *------------------------------------------------------------------------*/
+    DrvStatusTypeDef LED6001_IO_Init(void)
+    {
+        /* TO BE IMPLEMENTED BY USING TARGET PLATFORM'S APIs. */
+        return (DrvStatusTypeDef) 0;
+    }
+
+    void LED6001_IO_DeInit(void)
+    {
+        /* TO BE IMPLEMENTED BY USING TARGET PLATFORM'S APIs. */
+    }
+
+    void LED6001_IO_ITConfig(void)
+    {
+        /* TO BE IMPLEMENTED BY USING TARGET PLATFORM'S APIs. */
+    }
+
+    void LED6001_SetPdimTimer(uint8_t PwmVal)
+    {
+        /* TO BE IMPLEMENTED BY USING TARGET PLATFORM'S APIs. */
+    }
+
+    void LED6001_SetAdimTimer(uint8_t PwmVal)
+    {
+        /* TO BE IMPLEMENTED BY USING TARGET PLATFORM'S APIs. */
+    }
+
+
+    /*** Component's Instance Variables ***/
+
+    /* ACTION 9 --------------------------------------------------------------*
+     * Declare here interrupt related variables, if needed.                   *
+     * Note that interrupt handling is platform dependent, see                *
+     * "Interrupt Related Methods" above.                                     *
+     *                                                                        *
+     * Example:                                                               *
+     *   + mbed:                                                              *
+     *     InterruptIn feature_irq;                                           *
+     *------------------------------------------------------------------------*/
+
+    /* ACTION 10 -------------------------------------------------------------*
+     * Declare here other pin related variables, if needed.                   *
+     *                                                                        *
+     * Example:                                                               *
+     *   + mbed:                                                              *
+     *     DigitalOut standby_reset;                                          *
+     *------------------------------------------------------------------------*/
+
+    /* ACTION 11 -------------------------------------------------------------*
+     * Declare here communication related variables, if needed.               *
+     *                                                                        *
+     * Example:                                                               *
+     *   + mbed:                                                              *
+     *     DigitalOut address;                                                *
+     *     DevI2C &dev_i2c;                                                   *
+     *------------------------------------------------------------------------*/
+    /* Configuration. */
+    DigitalOut address;
+
+    /* IO Device. */
+    DevI2C &dev_i2c;
+
+    /* ACTION 12 -------------------------------------------------------------*
+     * Declare here identity related variables, if needed.                    *
+     * Note that there should be only a unique identifier for each component, *
+     * which should be the "who_am_i" parameter.                              *
+     *------------------------------------------------------------------------*/
+    /* Identity */
+    uint8_t who_am_i;
+
+    /* ACTION 13 -------------------------------------------------------------*
+     * Declare here the component's static and non-static data, one variable  *
+     * per line.                                                              *
+     *                                                                        *
+     * Example:                                                               *
+     *   float measure;                                                       *
+     *   int instance_id;                                                     *
+     *   static int number_of_instances;                                      *
+     *------------------------------------------------------------------------*/
+};
+
+#endif // __LED6001_CLASS_H
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/