]> granicus.if.org Git - esp-idf/commitdiff
Modify gpio.h and ledc.h
authorWangjialin <wangjialin@espressif.com>
Tue, 1 Nov 2016 03:48:32 +0000 (11:48 +0800)
committerIvan Grokhotkov <ivan@espressif.com>
Tue, 1 Nov 2016 14:35:42 +0000 (22:35 +0800)
components/driver/include/driver/gpio.h
components/driver/include/driver/ledc.h

index 001be2a39d8df65ee63ebda8027890483764ae1c..7106489d6c4dda226ded30c43887e651cf339f23 100644 (file)
 extern "C" {
 #endif
 
-#define GPIO_SEL_0              (BIT(0))                         /* Pin 0 selected */
-#define GPIO_SEL_1              (BIT(1))                         /* Pin 1 selected */
-#define GPIO_SEL_2              (BIT(2))                         /* Pin 2 selected */
-#define GPIO_SEL_3              (BIT(3))                         /* Pin 3 selected */
-#define GPIO_SEL_4              (BIT(4))                         /* Pin 4 selected */
-#define GPIO_SEL_5              (BIT(5))                         /* Pin 5 selected */
-#define GPIO_SEL_6              (BIT(6))                         /* Pin 6 selected */
-#define GPIO_SEL_7              (BIT(7))                         /* Pin 7 selected */
-#define GPIO_SEL_8              (BIT(8))                         /* Pin 8 selected */
-#define GPIO_SEL_9              (BIT(9))                         /* Pin 9 selected */
-#define GPIO_SEL_10             (BIT(10))                        /* Pin 10 selected */
-#define GPIO_SEL_11             (BIT(11))                        /* Pin 11 selected */
-#define GPIO_SEL_12             (BIT(12))                        /* Pin 12 selected */
-#define GPIO_SEL_13             (BIT(13))                        /* Pin 13 selected */
-#define GPIO_SEL_14             (BIT(14))                        /* Pin 14 selected */
-#define GPIO_SEL_15             (BIT(15))                        /* Pin 15 selected */
-#define GPIO_SEL_16             (BIT(16))                        /* Pin 16 selected */
-#define GPIO_SEL_17             (BIT(17))                        /* Pin 17 selected */
-#define GPIO_SEL_18             (BIT(18))                        /* Pin 18 selected */
-#define GPIO_SEL_19             (BIT(19))                        /* Pin 19 selected */
-
-#define GPIO_SEL_21             (BIT(21))                        /* Pin 21 selected */
-#define GPIO_SEL_22             (BIT(22))                        /* Pin 22 selected */
-#define GPIO_SEL_23             (BIT(23))                        /* Pin 23 selected */
-
-#define GPIO_SEL_25             (BIT(25))                        /* Pin 25 selected */
-#define GPIO_SEL_26             (BIT(26))                        /* Pin 26 selected */
-#define GPIO_SEL_27             (BIT(27))                        /* Pin 27 selected */
-
-#define GPIO_SEL_32             ((uint64_t)(((uint64_t)1)<<32))  /* Pin 32 selected */
-#define GPIO_SEL_33             ((uint64_t)(((uint64_t)1)<<33))  /* Pin 33 selected */
-#define GPIO_SEL_34             ((uint64_t)(((uint64_t)1)<<34))  /* Pin 34 selected */
-#define GPIO_SEL_35             ((uint64_t)(((uint64_t)1)<<35))  /* Pin 35 selected */
-#define GPIO_SEL_36             ((uint64_t)(((uint64_t)1)<<36))  /* Pin 36 selected */
-#define GPIO_SEL_37             ((uint64_t)(((uint64_t)1)<<37))  /* Pin 37 selected */
-#define GPIO_SEL_38             ((uint64_t)(((uint64_t)1)<<38))  /* Pin 38 selected */
-#define GPIO_SEL_39             ((uint64_t)(((uint64_t)1)<<39))  /* Pin 39 selected */
+#define GPIO_SEL_0              (BIT(0))                         /*!< Pin 0 selected */
+#define GPIO_SEL_1              (BIT(1))                         /*!< Pin 1 selected */
+#define GPIO_SEL_2              (BIT(2))                         /*!< Pin 2 selected */
+#define GPIO_SEL_3              (BIT(3))                         /*!< Pin 3 selected */
+#define GPIO_SEL_4              (BIT(4))                         /*!< Pin 4 selected */
+#define GPIO_SEL_5              (BIT(5))                         /*!< Pin 5 selected */
+#define GPIO_SEL_6              (BIT(6))                         /*!< Pin 6 selected */
+#define GPIO_SEL_7              (BIT(7))                         /*!< Pin 7 selected */
+#define GPIO_SEL_8              (BIT(8))                         /*!< Pin 8 selected */
+#define GPIO_SEL_9              (BIT(9))                         /*!< Pin 9 selected */
+#define GPIO_SEL_10             (BIT(10))                        /*!< Pin 10 selected */
+#define GPIO_SEL_11             (BIT(11))                        /*!< Pin 11 selected */
+#define GPIO_SEL_12             (BIT(12))                        /*!< Pin 12 selected */
+#define GPIO_SEL_13             (BIT(13))                        /*!< Pin 13 selected */
+#define GPIO_SEL_14             (BIT(14))                        /*!< Pin 14 selected */
+#define GPIO_SEL_15             (BIT(15))                        /*!< Pin 15 selected */
+#define GPIO_SEL_16             (BIT(16))                        /*!< Pin 16 selected */
+#define GPIO_SEL_17             (BIT(17))                        /*!< Pin 17 selected */
+#define GPIO_SEL_18             (BIT(18))                        /*!< Pin 18 selected */
+#define GPIO_SEL_19             (BIT(19))                        /*!< Pin 19 selected */
+
+#define GPIO_SEL_21             (BIT(21))                        /*!< Pin 21 selected */
+#define GPIO_SEL_22             (BIT(22))                        /*!< Pin 22 selected */
+#define GPIO_SEL_23             (BIT(23))                        /*!< Pin 23 selected */
+
+#define GPIO_SEL_25             (BIT(25))                        /*!< Pin 25 selected */
+#define GPIO_SEL_26             (BIT(26))                        /*!< Pin 26 selected */
+#define GPIO_SEL_27             (BIT(27))                        /*!< Pin 27 selected */
+
+#define GPIO_SEL_32             ((uint64_t)(((uint64_t)1)<<32))  /*!< Pin 32 selected */
+#define GPIO_SEL_33             ((uint64_t)(((uint64_t)1)<<33))  /*!< Pin 33 selected */
+#define GPIO_SEL_34             ((uint64_t)(((uint64_t)1)<<34))  /*!< Pin 34 selected */
+#define GPIO_SEL_35             ((uint64_t)(((uint64_t)1)<<35))  /*!< Pin 35 selected */
+#define GPIO_SEL_36             ((uint64_t)(((uint64_t)1)<<36))  /*!< Pin 36 selected */
+#define GPIO_SEL_37             ((uint64_t)(((uint64_t)1)<<37))  /*!< Pin 37 selected */
+#define GPIO_SEL_38             ((uint64_t)(((uint64_t)1)<<38))  /*!< Pin 38 selected */
+#define GPIO_SEL_39             ((uint64_t)(((uint64_t)1)<<39))  /*!< Pin 39 selected */
 
 #define GPIO_PIN_REG_0          PERIPHS_IO_MUX_GPIO0_U
 #define GPIO_PIN_REG_1          PERIPHS_IO_MUX_U0TXD_U
@@ -117,47 +117,47 @@ extern const uint32_t GPIO_PIN_MUX_REG[GPIO_PIN_COUNT];
 #define GPIO_IS_VALID_OUTPUT_GPIO(gpio_num)      ((GPIO_IS_VALID_GPIO(gpio_num)) && (gpio_num < 34))         //to decide whether it can be a valid GPIO number of output mode
 
 typedef enum {
-    GPIO_NUM_0 = 0,
-    GPIO_NUM_1 = 1,
-    GPIO_NUM_2 = 2,
-    GPIO_NUM_3 = 3,
-    GPIO_NUM_4 = 4,
-    GPIO_NUM_5 = 5,
-    GPIO_NUM_6 = 6,
-    GPIO_NUM_7 = 7,
-    GPIO_NUM_8 = 8,
-    GPIO_NUM_9 = 9,
-    GPIO_NUM_10 = 10,
-    GPIO_NUM_11 = 11,
-    GPIO_NUM_12 = 12,
-    GPIO_NUM_13 = 13,
-    GPIO_NUM_14 = 14,
-    GPIO_NUM_15 = 15,
-    GPIO_NUM_16 = 16,
-    GPIO_NUM_17 = 17,
-    GPIO_NUM_18 = 18,
-    GPIO_NUM_19 = 19,
-
-    GPIO_NUM_21 = 21,
-    GPIO_NUM_22 = 22,
-    GPIO_NUM_23 = 23,
-
-    GPIO_NUM_25 = 25,
-    GPIO_NUM_26 = 26,
-    GPIO_NUM_27 = 27,
-
-    GPIO_NUM_32 = 32,
-    GPIO_NUM_33 = 33,
-    GPIO_NUM_34 = 34, /*input mode only */
-    GPIO_NUM_35 = 35, /*input mode only */
-    GPIO_NUM_36 = 36, /*input mode only */
-    GPIO_NUM_37 = 37, /*input mode only */
-    GPIO_NUM_38 = 38, /*input mode only */
-    GPIO_NUM_39 = 39, /*input mode only */
+    GPIO_NUM_0 = 0,     /*!< GPIO0, input and output */
+    GPIO_NUM_1 = 1,     /*!< GPIO1, input and output */
+    GPIO_NUM_2 = 2,     /*!< GPIO2, input and output */
+    GPIO_NUM_3 = 3,     /*!< GPIO3, input and output */
+    GPIO_NUM_4 = 4,     /*!< GPIO4, input and output */
+    GPIO_NUM_5 = 5,     /*!< GPIO5, input and output */
+    GPIO_NUM_6 = 6,     /*!< GPIO6, input and output */
+    GPIO_NUM_7 = 7,     /*!< GPIO7, input and output */
+    GPIO_NUM_8 = 8,     /*!< GPIO8, input and output */
+    GPIO_NUM_9 = 9,     /*!< GPIO9, input and output */
+    GPIO_NUM_10 = 10,   /*!< GPIO10, input and output */
+    GPIO_NUM_11 = 11,   /*!< GPIO11, input and output */
+    GPIO_NUM_12 = 12,   /*!< GPIO12, input and output */
+    GPIO_NUM_13 = 13,   /*!< GPIO13, input and output */
+    GPIO_NUM_14 = 14,   /*!< GPIO14, input and output */
+    GPIO_NUM_15 = 15,   /*!< GPIO15, input and output */
+    GPIO_NUM_16 = 16,   /*!< GPIO16, input and output */
+    GPIO_NUM_17 = 17,   /*!< GPIO17, input and output */
+    GPIO_NUM_18 = 18,   /*!< GPIO18, input and output */
+    GPIO_NUM_19 = 19,   /*!< GPIO19, input and output */
+
+    GPIO_NUM_21 = 21,   /*!< GPIO21, input and output */
+    GPIO_NUM_22 = 22,   /*!< GPIO22, input and output */
+    GPIO_NUM_23 = 23,   /*!< GPIO23, input and output */
+
+    GPIO_NUM_25 = 25,   /*!< GPIO25, input and output */
+    GPIO_NUM_26 = 26,   /*!< GPIO26, input and output */
+    GPIO_NUM_27 = 27,   /*!< GPIO27, input and output */
+
+    GPIO_NUM_32 = 32,   /*!< GPIO32, input and output */
+    GPIO_NUM_33 = 33,   /*!< GPIO32, input and output */
+    GPIO_NUM_34 = 34,   /*!< GPIO34, input mode only */
+    GPIO_NUM_35 = 35,   /*!< GPIO35, input mode only */
+    GPIO_NUM_36 = 36,   /*!< GPIO36, input mode only */
+    GPIO_NUM_37 = 37,   /*!< GPIO37, input mode only */
+    GPIO_NUM_38 = 38,   /*!< GPIO38, input mode only */
+    GPIO_NUM_39 = 39,   /*!< GPIO39, input mode only */
 } gpio_num_t;
 
 typedef enum {
-    GPIO_INTR_DISABLE = 0,     /*!< disable GPIO interrupt                             */
+    GPIO_INTR_DISABLE = 0,     /*!< Disable GPIO interrupt                             */
     GPIO_INTR_POSEDGE = 1,     /*!< GPIO interrupt type : rising edge                  */
     GPIO_INTR_NEGEDGE = 2,     /*!< GPIO interrupt type : falling edge                 */
     GPIO_INTR_ANYEDGE = 3,     /*!< GPIO interrupt type : both rising and falling edge */
@@ -175,13 +175,13 @@ typedef enum {
 } gpio_mode_t;
 
 typedef enum {
-    GPIO_PULLUP_DISABLE = 0x0,     /*!< disable GPIO pull-up resistor */
-    GPIO_PULLUP_ENABLE = 0x1,      /*!< enable GPIO pull-up resistor */
+    GPIO_PULLUP_DISABLE = 0x0,     /*!< Disable GPIO pull-up resistor */
+    GPIO_PULLUP_ENABLE = 0x1,      /*!< Enable GPIO pull-up resistor */
 } gpio_pullup_t;
 
 typedef enum {
-    GPIO_PULLDOWN_DISABLE = 0x0,   /*!< disable GPIO pull-down resistor */
-    GPIO_PULLDOWN_ENABLE = 0x1,    /*!< enable GPIO pull-down resistor  */
+    GPIO_PULLDOWN_DISABLE = 0x0,   /*!< Disable GPIO pull-down resistor */
+    GPIO_PULLDOWN_ENABLE = 0x1,    /*!< Enable GPIO pull-down resistor  */
 } gpio_pulldown_t;
 
 typedef struct {
@@ -192,12 +192,6 @@ typedef struct {
     gpio_int_type_t intr_type;      /*!< GPIO interrupt type                                  */
 } gpio_config_t;
 
-typedef enum {
-    GPIO_LOW_LEVEL = 0,
-    GPIO_HIGH_LEVEL = 1,
-    GPIO_LEVEL_ERR,
-} gpio_level_t;
-
 typedef enum {
     GPIO_PULLUP_ONLY,               /*!< Pad pull up            */
     GPIO_PULLDOWN_ONLY,             /*!< Pad pull down          */
@@ -207,252 +201,248 @@ typedef enum {
 
 typedef void (*gpio_event_callback)(gpio_num_t gpio_intr_num);
 
-/** \defgroup Driver_APIs Driver APIs
- * @brief Driver APIs
- */
-
-/** @addtogroup Driver_APIs
- * @{
- */
-
-/** \defgroup GPIO_Driver_APIs GPIO Driver APIs
- * @brief GPIO APIs
- */
-
-/** @addtogroup GPIO_Driver_APIs
- * @{
- */
-
 /**
- * @brief      GPIO common configuration
+ * @brief GPIO common configuration
  *
- * Use this Function ,Configure GPIO's Mode,pull-up,PullDown,IntrType
+ *        Configure GPIO's Mode,pull-up,PullDown,IntrType
  *
- * @param[in]  pGPIOConfig
- *             pGPIOConfig.pin_bit_mask   : Configure GPIO pins bits,set this parameter with bit mask.
- *                                              If you want to configure GPIO34 and GPIO16, pin_bit_mask=GPIO_Pin_16|GPIO_Pin_34;
- *             pGPIOConfig.mode           : Configure GPIO mode,such as output ,input...
- *             pGPIOConfig.pull_up_en     : Enable or Disable pull-up
- *             pGPIOConfig.pull_down_en   : Enable or Disable pull-down
- *             pGPIOConfig.intr_type : Configure GPIO interrupt trigger type
- * @return     ESP_OK: success ;
- *             ESP_ERR_INVALID_ARG: parameter error
- *             ESP_FAIL : GPIO error
+ * @param  pGPIOConfig Pointer to GPIO configure struct
+ *
+ * @return
+ *     - ESP_OK success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t gpio_config(gpio_config_t *pGPIOConfig);
 
 
 /**
- * @brief      GPIO set interrupt trigger type
+ * @brief  GPIO set interrupt trigger type
  *
- * @param[in]  gpio_num : GPIO number.
- *                            If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
- * @param[in]  intr_type: interrupt type, select from gpio_int_type_t
+ * @param  gpio_num GPIO number. If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  intr_type Interrupt type, select from gpio_int_type_t
  *
- * @return     ESP_OK   : success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK  Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t gpio_set_intr_type(gpio_num_t gpio_num, gpio_int_type_t intr_type);
 
 /**
- * @brief      enable GPIO module interrupt signal
+ * @brief  Enable GPIO module interrupt signal
  *
- * @param[in]  gpio_num : GPIO number.
- *                            If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  gpio_num GPIO number. If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
  *
- * @return     ESP_OK   : success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t gpio_intr_enable(gpio_num_t gpio_num);
 
 /**
- * @brief      disable GPIO module interrupt signal
+ * @brief  Disable GPIO module interrupt signal
  *
- * @param[in]  gpio_num : GPIO number.
- *                            If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  gpio_num GPIO number. If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
  *
- * @return     ESP_OK   : success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t gpio_intr_disable(gpio_num_t gpio_num);
 
 /**
- * @brief      GPIO set output level
+ * @brief  GPIO set output level
  *
- * @param[in]  gpio_num : GPIO number.
- *                            If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
- * @param[in]  level    : Output level. 0: low ; 1: high
+ * @param  gpio_num GPIO number. If you want to set output level of GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  level Output level. 0: low ; 1: high
  *
- * @return     ESP_OK   : success
- *             ESP_FAIL : GPIO error
+ * @return
+ *     - ESP_OK Success
+ *     - GPIO_IS_VALID_GPIO GPIO number error
  *
  */
 esp_err_t gpio_set_level(gpio_num_t gpio_num, uint32_t level);
 
 /**
- * @brief      GPIO get input level
+ * @brief  GPIO get input level
  *
- * @param[in]  gpio_num : GPIO number.
- *                            If you want to get level of pin GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  gpio_num GPIO number. If you want to get level of pin GPIO16, gpio_num should be GPIO_NUM_16 (16);
  *
- * @return     0  : the GPIO input level is 0
- *              1  : the GPIO input level is 1
+ * @return
+ *     - 0 the GPIO input level is 0
+ *     - 1 the GPIO input level is 1
  *
  */
 int gpio_get_level(gpio_num_t gpio_num);
 
 /**
- * @brief      GPIO set direction
+ * @brief       GPIO set direction
  *
  * Configure GPIO direction,such as output_only,input_only,output_and_input
  *
- * @param[in]  gpio_num : Configure GPIO pins number,it should be GPIO number.
- *                            If you want to set direction of GPIO16, gpio_num should be GPIO_NUM_16 (16);
- * @param[in]  mode     : Configure GPIO direction,such as output_only,input_only,...
+ * @param  gpio_num  Configure GPIO pins number, it should be GPIO number. If you want to set direction of GPIO16, gpio_num should be GPIO_NUM_16 (16);
+ * @param  mode GPIO direction
  *
- * @return     ESP_OK   : success
- *             ESP_ERR_INVALID_ARG : fail
- *             ESP_FAIL : GPIO error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG GPIO error
  *
  */
 esp_err_t gpio_set_direction(gpio_num_t gpio_num, gpio_mode_t mode);
 
 /**
- * @brief      GPIO set pull
+ * @brief  GPIO set pull
  *
  * User this Function,configure GPIO pull mode,such as pull-up,pull-down
  *
- * @param[in]  gpio_num : Configure GPIO pins number,it should be GPIO number.
- *                            If you want to set pull up or down mode for GPIO16,gpio_num should be GPIO_NUM_16 (16);
- * @param[in]  pull     : Configure GPIO pull up/down mode,such as pullup_only,pulldown_only,pullup_and_pulldown,...
+ * @param  gpio_num GPIO number. If you want to set pull up or down mode for GPIO16,gpio_num should be GPIO_NUM_16 (16);
+ * @param  pull GPIO pull up/down mode.
  *
- * @return     ESP_OK   : success
- *              ESP_ERR_INVALID_ARG : fail
- *              ESP_FAIL : GPIO error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG : Parameter error
  *
  */
 esp_err_t gpio_set_pull_mode(gpio_num_t gpio_num, gpio_pull_mode_t pull);
 
 /**
-  * @brief  enable GPIO wake-up function.
+  * @brief enable GPIO wake-up function.
   *
-  * @param  gpio_num : GPIO number.
+  * @param gpio_num GPIO number.
   *
-  * @param  intr_type : only GPIO_INTR_LOLEVEL\GPIO_INTR_HILEVEL can be used
+  * @param intr_type GPIO wake-up type. Only GPIO_INTR_LOLEVEL\GPIO_INTR_HILEVEL can be used
   *
-  * @return ESP_OK: success
-  *         ESP_ERR_INVALID_ARG: parameter error
+  * @return
+  *     - ESP_OK Success
+  *     - ESP_ERR_INVALID_ARG Parameter error
   */
 esp_err_t gpio_wakeup_enable(gpio_num_t gpio_num, gpio_int_type_t intr_type);
 
 /**
-  * @brief  disable GPIO wake-up function.
+  * @brief Disable GPIO wake-up function.
   *
-  * @param  gpio_num: GPIO number
+  * @param gpio_num GPIO number
   *
-  * @return ESP_OK: success
-  *         ESP_ERR_INVALID_ARG: parameter error
+  * @return
+  *     - ESP_OK Success
+  *     - ESP_ERR_INVALID_ARG Parameter error
   */
 esp_err_t gpio_wakeup_disable(gpio_num_t gpio_num);
 
 /**
  * @brief   register GPIO interrupt handler, the handler is an ISR.
  *          The handler will be attached to the same CPU core that this function is running on.
+ *          @note
  *          Users should know that which CPU is running and then pick a INUM that is not used by system.
  *          We can find the information of INUM and interrupt level in soc.h.
- *          TODO: to move INUM options to menu_config
- * @param   gpio_intr_num    : GPIO interrupt number,check the info in soc.h, and please see the core-isa.h for more details
- * @param   (*fn)(void* )    : interrupt handler function.
- *                                          Note that the handler function MUST be defined with attribution of "IRAM_ATTR".
- * @param   arg              : parameter for handler function
- *
- * @return  ESP_OK : success ;
- *          ESP_FAIL: gpio error
+ *
+ * @param  gpio_intr_num  GPIO interrupt number,check the info in soc.h, and please see the core-isa.h for more details
+ * @param  fn  Interrupt handler function.
+ *
+ *         @note
+ *         Note that the handler function MUST be defined with attribution of "IRAM_ATTR".
+ *
+ * @param  arg  Parameter for handler function
+ *
+ * @return
+ *     - ESP_OK Success ;
+ *     - ESP_ERR_INVALID_ARG GPIO error
  */
 esp_err_t gpio_isr_register(uint32_t gpio_intr_num, void (*fn)(void*), void * arg);
 
 /**
  * ***************        ATTENTION       ********************/
 /**
- *
- * Each GPIO has its own separate configuration register, so we do not use
- * a lock to serialize access to them. This works under the assumption that
- * no situation will occur where two tasks try to configure the same GPIO
- * pin simultaneously. It is up to the application developer to guarantee this.
+ *@attention
+ *     Each GPIO has its own separate configuration register, so we do not use
+ *     a lock to serialize access to them. This works under the assumption that
+ *     no situation will occur where two tasks try to configure the same GPIO
+ *     pin simultaneously. It is up to the application developer to guarantee this.
  */
 
-
-/*----------EXAMPLE TO CONIFGURE GPIO AS OUTPUT ------------ */
-/*     gpio_config_t io_conf;
+/**
+ *----------EXAMPLE TO CONIFGURE GPIO AS OUTPUT ------------ *
+ * @code{c}
+ *     gpio_config_t io_conf;
  *     io_conf.intr_type = GPIO_INTR_DISABLE;             //disable interrupt
  *     io_conf.mode = GPIO_MODE_OUTPUT;                       //set as output mode
  *     io_conf.pin_bit_mask = GPIO_SEL_18 | GPIO_SEL_19;      //bit mask of the pins that you want to set,e.g.GPIO18/19
  *     io_conf.pull_down_en = 0;                              //disable pull-down mode
  *     io_conf.pull_up_en = 0;                                //disable pull-up mode
  *     gpio_config(&io_conf);                                 //configure GPIO with the given settings
+ * @endcode
  **/
-/*----------EXAMPLE TO CONIFGURE GPIO AS OUTPUT ------------ */
-/*     io_conf.intr_type = GPIO_INTR_POSEDGE;             //set posedge interrupt
+
+/**
+ *----------EXAMPLE TO CONIFGURE GPIO AS OUTPUT ------------ *
+ * @code{c}
+ *     io_conf.intr_type = GPIO_INTR_POSEDGE;             //set posedge interrupt
  *     io_conf.mode = GPIO_MODE_INPUT;                        //set as input
  *     io_conf.pin_bit_mask = GPIO_SEL_4 | GPIO_SEL_5;        //bit mask of the pins that you want to set, e.g.,GPIO4/5
  *     io_conf.pull_down_en = 0;                              //disable pull-down mode
  *     io_conf.pull_up_en = 1;                                //enable pull-up mode
  *     gpio_config(&io_conf);                                 //configure GPIO with the given settings
- *----------EXAMPLE TO SET ISR HANDLER ----------------------*/
-/*     gpio_isr_register(18,gpio_intr_test,NULL);    //hook the isr handler for GPIO interrupt
- *                                                            //the first parameter is INUM, you can pick one form interrupt level 1/2 which is not used by the system.
- *                                                            //NOTE1:user should arrange the INUMs that used, better not to use a same INUM for different interrupt.
- *                                                            //NOTE2:do not pick the INUM that already occupied by the system.
- *                                                            //NOTE3:refer to soc.h to check which INUMs that can be used.
- *-------------EXAMPLE OF HANDLER FUNCTION-------------------*/
-/*#include "esp_attr.h"
- * void IRAM_ATTR gpio_intr_test(void* arg)
- *{
- *  //GPIO intr process
- *  ets_printf("in gpio_intr\n");
- *  uint32_t gpio_num = 0;
- *  uint32_t gpio_intr_status = READ_PERI_REG(GPIO_STATUS_REG);   //read status to get interrupt status for GPIO0-31
- *  uint32_t gpio_intr_status_h = READ_PERI_REG(GPIO_STATUS1_REG);//read status1 to get interrupt status for GPIO32-39
- *  SET_PERI_REG_MASK(GPIO_STATUS_W1TC_REG, gpio_intr_status);    //Clear intr for gpio0-gpio31
- *  SET_PERI_REG_MASK(GPIO_STATUS1_W1TC_REG, gpio_intr_status_h); //Clear intr for gpio32-39
- *  do {
- *      if(gpio_num < 32) {
- *          if(gpio_intr_status & BIT(gpio_num)) { //gpio0-gpio31
- *              ets_printf("Intr GPIO%d ,val: %d\n",gpio_num,gpio_get_level(gpio_num));
- *              //This is an isr handler, you should post an event to process it in RTOS queue.
- *          }
- *      } else {
- *          if(gpio_intr_status_h & BIT(gpio_num - 32)) {
- *              ets_printf("Intr GPIO%d, val : %d\n",gpio_num,gpio_get_level(gpio_num));
- *              //This is an isr handler, you should post an event to process it in RTOS queue.
- *          }
- *      }
- *  } while(++gpio_num < GPIO_PIN_COUNT);
- *}
- *----EXAMPLE OF I2C CONFIG AND PICK SIGNAL FOR IO MATRIX---*/
-/*     gpio_config_t io_conf;
- *     io_conf.intr_type = GPIO_INTR_DISABLE;                 //disable interrupt
- *     io_conf.mode = GPIO_MODE_INPUT_OUTPUT_OD;              //set as output mode
- *     io_conf.pin_bit_mask = GPIO_SEL_21 | GPIO_SEL_22;      //bit mask of the pins that you want to set,e.g.GPIO21/22
- *     io_conf.pull_down_en = 0;                              //disable pull-down mode
- *     io_conf.pull_up_en = 1;                                //enable pull-up mode
- *     gpio_config(&io_conf);                                 //configure GPIO with the given settings
- *     gpio_matrix_out(21, EXT_I2C_SCL_O_IDX, 0,  0);         //set output signal for io_matrix
- *     gpio_matrix_out(22, EXT_I2C_SDA_O_IDX, 0,  0);         //set output signal for io_matrix
- *     gpio_matrix_in( 22, EXT_I2C_SDA_I_IDX, 0);             //set input signal for io_matrix
- *
+ * @endcode
  */
-
 /**
- * @}
+ *----------EXAMPLE TO SET ISR HANDLER ----------------------
+ * @code{c}
+ * //the first parameter is INUM, you can pick one form interrupt level 1/2 which is not used by the system.
+ * gpio_isr_register(18,gpio_intr_test,NULL);    //hook the isr handler for GPIO interrupt
+ * @endcode
+ * @note
+ *     1. user should arrange the INUMs that used, better not to use a same INUM for different interrupt.
+ *     2. do not pick the INUM that already occupied by the system.
+ *     3. refer to soc.h to check which INUMs that can be used.
+ */
+/**
+ *-------------EXAMPLE OF HANDLER FUNCTION-------------------*
+ * @code{c}
+ * #include "esp_attr.h"
+ * void IRAM_ATTR gpio_intr_test(void* arg)
+ * {
+ *     //GPIO intr process
+ *     ets_printf("in gpio_intr\n");
+ *     uint32_t gpio_num = 0;
+ *     uint32_t gpio_intr_status = READ_PERI_REG(GPIO_STATUS_REG);   //read status to get interrupt status for GPIO0-31
+ *     uint32_t gpio_intr_status_h = READ_PERI_REG(GPIO_STATUS1_REG);//read status1 to get interrupt status for GPIO32-39
+ *     SET_PERI_REG_MASK(GPIO_STATUS_W1TC_REG, gpio_intr_status);    //Clear intr for gpio0-gpio31
+ *     SET_PERI_REG_MASK(GPIO_STATUS1_W1TC_REG, gpio_intr_status_h); //Clear intr for gpio32-39
+ *     do {
+ *         if(gpio_num < 32) {
+ *             if(gpio_intr_status & BIT(gpio_num)) { //gpio0-gpio31
+ *                 ets_printf("Intr GPIO%d ,val: %d\n",gpio_num,gpio_get_level(gpio_num));
+ *                 //This is an isr handler, you should post an event to process it in RTOS queue.
+ *             }
+ *         } else {
+ *             if(gpio_intr_status_h & BIT(gpio_num - 32)) {
+ *                 ets_printf("Intr GPIO%d, val : %d\n",gpio_num,gpio_get_level(gpio_num));
+ *                 //This is an isr handler, you should post an event to process it in RTOS queue.
+ *             }
+ *         }
+ *     } while(++gpio_num < GPIO_PIN_COUNT);
+ * }
+ * @endcode
  */
 
 /**
- * @}
+ *----EXAMPLE OF I2C CONFIG AND PICK SIGNAL FOR IO MATRIX---*
+ * @code{c}
+ * gpio_config_t io_conf;
+ * io_conf.intr_type = GPIO_INTR_DISABLE;                 //disable interrupt
+ * io_conf.mode = GPIO_MODE_INPUT_OUTPUT_OD;              //set as output mode
+ * io_conf.pin_bit_mask = GPIO_SEL_21 | GPIO_SEL_22;      //bit mask of the pins that you want to set,e.g.GPIO21/22
+ * io_conf.pull_down_en = 0;                              //disable pull-down mode
+ * io_conf.pull_up_en = 1;                                //enable pull-up mode
+ * gpio_config(&io_conf);                                 //configure GPIO with the given settings
+ * gpio_matrix_out(21, EXT_I2C_SCL_O_IDX, 0,  0);         //set output signal for io_matrix
+ * gpio_matrix_out(22, EXT_I2C_SDA_O_IDX, 0,  0);         //set output signal for io_matrix
+ * gpio_matrix_in( 22, EXT_I2C_SDA_I_IDX, 0);             //set input signal for io_matrix
+ * @endcode
+ *
  */
 
 #ifdef __cplusplus
index 79a6c7f9f3a75c156c70326f84dfd936480acfda..3ab0ebff1e583afae83b7ef6d035c222de7fc3f8 100644 (file)
@@ -30,68 +30,68 @@ extern "C" {
 #define LEDC_REF_CLK_HZ (1*1000000)
 
 typedef enum {
-    LEDC_HIGH_SPEED_MODE = 0, /*LEDC high speed speed_mode */
+    LEDC_HIGH_SPEED_MODE = 0, /*!< LEDC high speed speed_mode */
     //in this version, we only support high speed speed_mode. We will access low speed speed_mode later
-    //LEDC_LOW_SPEED_MODE,    /*LEDC low speed speed_mode */
-    LEDC_SPEED_MODE_MAX,
+    //LEDC_LOW_SPEED_MODE,    /*!< LEDC low speed speed_mode */
+    LEDC_SPEED_MODE_MAX,      /*!< LEDC speed limit */
 } ledc_mode_t;
 
 typedef enum {
-    LEDC_INTR_DISABLE = 0,    /*Disable LEDC interrupt */
-    LEDC_INTR_FADE_END,       /*Enable LEDC interrupt */
+    LEDC_INTR_DISABLE = 0,    /*!< Disable LEDC interrupt */
+    LEDC_INTR_FADE_END,       /*!< Enable LEDC interrupt */
 } ledc_intr_type_t;
 
 typedef enum {
-    LEDC_DUTY_DIR_DECREASE = 0,    /*LEDC duty decrease direction */
-    LEDC_DUTY_DIR_INCREASE = 1,    /*LEDC duty increase direction */
+    LEDC_DUTY_DIR_DECREASE = 0,    /*!< LEDC duty decrease direction */
+    LEDC_DUTY_DIR_INCREASE = 1,    /*!< LEDC duty increase direction */
 } ledc_duty_direction_t;
 
 typedef enum  {
-    LEDC_REF_TICK = 0, /*LEDC timer clock divided from reference tick(1Mhz) */
-    LEDC_APB_CLK,      /*LEDC timer clock divided from APB clock(80Mhz)*/
+    LEDC_REF_TICK = 0, /*!< LEDC timer clock divided from reference tick(1Mhz) */
+    LEDC_APB_CLK,      /*!< LEDC timer clock divided from APB clock(80Mhz)*/
 } ledc_clk_src_t;
 
 typedef enum {
-    LEDC_TIMER_0 = 0, /*LEDC source timer TIMER0 */
-    LEDC_TIMER_1,     /*LEDC source timer TIMER1 */
-    LEDC_TIMER_2,     /*LEDC source timer TIMER2 */
-    LEDC_TIMER_3,     /*LEDC source timer TIMER3 */
+    LEDC_TIMER_0 = 0, /*!< LEDC source timer TIMER0 */
+    LEDC_TIMER_1,     /*!< LEDC source timer TIMER1 */
+    LEDC_TIMER_2,     /*!< LEDC source timer TIMER2 */
+    LEDC_TIMER_3,     /*!< LEDC source timer TIMER3 */
 } ledc_timer_t;
 
 typedef enum {
-    LEDC_CHANNEL_0 = 0, /*LEDC channel 0 */
-    LEDC_CHANNEL_1,     /*LEDC channel 1 */
-    LEDC_CHANNEL_2,     /*LEDC channel 2 */
-    LEDC_CHANNEL_3,     /*LEDC channel 3 */
-    LEDC_CHANNEL_4,     /*LEDC channel 4 */
-    LEDC_CHANNEL_5,     /*LEDC channel 5 */
-    LEDC_CHANNEL_6,     /*LEDC channel 6 */
-    LEDC_CHANNEL_7,     /*LEDC channel 7 */
+    LEDC_CHANNEL_0 = 0, /*!< LEDC channel 0 */
+    LEDC_CHANNEL_1,     /*!< LEDC channel 1 */
+    LEDC_CHANNEL_2,     /*!< LEDC channel 2 */
+    LEDC_CHANNEL_3,     /*!< LEDC channel 3 */
+    LEDC_CHANNEL_4,     /*!< LEDC channel 4 */
+    LEDC_CHANNEL_5,     /*!< LEDC channel 5 */
+    LEDC_CHANNEL_6,     /*!< LEDC channel 6 */
+    LEDC_CHANNEL_7,     /*!< LEDC channel 7 */
 } ledc_channel_t;
 
 typedef enum {
-    LEDC_TIMER_10_BIT = 10, /*LEDC PWM depth 10Bit */
-    LEDC_TIMER_11_BIT = 11, /*LEDC PWM depth 11Bit */
-    LEDC_TIMER_12_BIT = 12, /*LEDC PWM depth 12Bit */
-    LEDC_TIMER_13_BIT = 13, /*LEDC PWM depth 13Bit */
-    LEDC_TIMER_14_BIT = 14, /*LEDC PWM depth 14Bit */
-    LEDC_TIMER_15_BIT = 15, /*LEDC PWM depth 15Bit */
+    LEDC_TIMER_10_BIT = 10, /*!< LEDC PWM depth 10Bit */
+    LEDC_TIMER_11_BIT = 11, /*!< LEDC PWM depth 11Bit */
+    LEDC_TIMER_12_BIT = 12, /*!< LEDC PWM depth 12Bit */
+    LEDC_TIMER_13_BIT = 13, /*!< LEDC PWM depth 13Bit */
+    LEDC_TIMER_14_BIT = 14, /*!< LEDC PWM depth 14Bit */
+    LEDC_TIMER_15_BIT = 15, /*!< LEDC PWM depth 15Bit */
 } ledc_timer_bit_t;
 
 typedef struct {
-    int gpio_num;                   /*the LEDC output gpio_num, if you want to use gpio16, gpio_num = 16*/
-    ledc_mode_t speed_mode;         /*LEDC speed speed_mode, high-speed mode or low-speed mode*/
-    ledc_channel_t channel;         /*LEDC channel(0 - 7)*/
-    ledc_intr_type_t intr_type;     /*configure interrupt, Fade interrupt enable  or Fade interrupt disable*/
-    ledc_timer_t timer_sel;         /*Select the timer source of channel (0 - 3)*/
-    uint32_t duty;                  /*LEDC channel duty, the duty range is [0, (2**bit_num) - 1], */
+    int gpio_num;                   /*!< the LEDC output gpio_num, if you want to use gpio16, gpio_num = 16*/
+    ledc_mode_t speed_mode;         /*!< LEDC speed speed_mode, high-speed mode or low-speed mode*/
+    ledc_channel_t channel;         /*!< LEDC channel(0 - 7)*/
+    ledc_intr_type_t intr_type;     /*!< configure interrupt, Fade interrupt enable  or Fade interrupt disable*/
+    ledc_timer_t timer_sel;         /*!< Select the timer source of channel (0 - 3)*/
+    uint32_t duty;                  /*!< LEDC channel duty, the duty range is [0, (2**bit_num) - 1], */
 } ledc_channel_config_t;
 
 typedef struct {
-    ledc_mode_t speed_mode;         /*LEDC speed speed_mode, high-speed mode or low-speed mode*/
-    ledc_timer_bit_t bit_num;       /*LEDC channel duty depth*/
-    ledc_timer_t  timer_num;        /*The timer source of channel (0 - 3)*/
-    uint32_t freq_hz;               /*LEDC timer frequency(Hz)*/
+    ledc_mode_t speed_mode;         /*!< LEDC speed speed_mode, high-speed mode or low-speed mode*/
+    ledc_timer_bit_t bit_num;       /*!< LEDC channel duty depth*/
+    ledc_timer_t  timer_num;        /*!< The timer source of channel (0 - 3)*/
+    uint32_t freq_hz;               /*!< LEDC timer frequency(Hz)*/
 } ledc_timer_config_t;
 
 
@@ -100,15 +100,10 @@ typedef struct {
  *
  * User this Function, configure LEDC channel with the given channel/output gpio_num/interrupt/source timer/frequency(Hz)/LEDC depth
  *
- * @param[in]  ledc_channel_config_t
- *             ledc_channel_config_t.speed_mode     : LEDC speed speed_mode
- *             ledc_channel_config_t.gpio_num       : LEDC output gpio_num, if you want to use gpio16, ledc_channel_config_t.gpio_num = 16
- *             ledc_channel_config_t.channel        : LEDC channel(0 - 7)
- *             ledc_channel_config_t.intr_type      : configure interrupt, Fade interrupt enable  or Fade interrupt disable
- *             ledc_channel_config_t.timer_sel      : Select the timer source of channel (0 - 3), high speed channel must bind with high speed timer.
- *             ledc_channel_config_t.duty           : LEDC channel duty, the duty range is [0, (2**timer_bit_num) - 1],
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @param  ledc_conf Pointer of LEDC channel configure struct
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t ledc_channel_config(ledc_channel_config_t* ledc_conf);
@@ -118,14 +113,13 @@ esp_err_t ledc_channel_config(ledc_channel_config_t* ledc_conf);
  *
  * User this Function, configure LEDC timer with the given source timer/frequency(Hz)/bit_num
  *
- * @param[in]  ledc_timer_config_t
- *             ledc_timer_config_t.speed_mode     : LEDC speed speed_mode
- *             ledc_timer_config_t.timer_num      : Select the timer source of channel (0 - 3)
- *             ledc_timer_config_t.freq_hz        : LEDC channel frequency(Hz),
- *             ledc_timer_config_t.bit_num        : LEDC channel duty depth
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
- *             ESP_FAIL: Can not find a proper pre-divider number base on the given frequency and the current bit_num.
+ * @param  timer_conf Pointer of LEDC timer configure struct
+ *
+ *
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_FAIL Can not find a proper pre-divider number base on the given frequency and the current bit_num.
  *
  */
 esp_err_t ledc_timer_config(ledc_timer_config_t* timer_conf);
@@ -136,12 +130,13 @@ esp_err_t ledc_timer_config(ledc_timer_config_t* timer_conf);
  * Call this function to activate the LEDC updated parameters.
  * After ledc_set_duty, ledc_set_fade, we need to call this function to update the settings.
  *
- * @param[in]  speed_mode : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel    : LEDC channel(0-7), select from ledc_channel_t
+ * @param  channel LEDC channel(0-7), select from ledc_channel_t
  *
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  *
  */
 esp_err_t ledc_update_duty(ledc_mode_t speed_mode, ledc_channel_t channel);
@@ -151,12 +146,13 @@ esp_err_t ledc_update_duty(ledc_mode_t speed_mode, ledc_channel_t channel);
  *
  * Disable LEDC output, and set idle level
  *
- * @param[in]  speed_mode   : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel      : LEDC channel(0-7), select from ledc_channel_t
+ * @param  channel LEDC channel(0-7), select from ledc_channel_t
  *
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  */
 esp_err_t ledc_stop(ledc_mode_t speed_mode, ledc_channel_t channel, uint32_t idle_level);
 
@@ -165,27 +161,29 @@ esp_err_t ledc_stop(ledc_mode_t speed_mode, ledc_channel_t channel, uint32_t idl
  *
  * Set LEDC frequency(Hz)
  *
- * @param[in]  speed_mode  : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_num   : LEDC timer index(0-3), select from ledc_timer_t
+ * @param  timer_num LEDC timer index(0-3), select from ledc_timer_t
  *
- * @param[in]  freq_hz     : set the LEDC frequency
+ * @param  freq_hz Set the LEDC frequency
  *
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
- *             ESP_FAIL: Can not find a proper pre-divider number base on the given frequency and the current bit_num.
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_FAIL Can not find a proper pre-divider number base on the given frequency and the current bit_num.
  */
 esp_err_t ledc_set_freq(ledc_mode_t speed_mode, ledc_timer_t timer_num, uint32_t freq_hz);
 
 /**
  * @brief      LEDC get channel frequency(Hz)
  *
- * @param[in]  speed_mode  : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_num   : LEDC timer index(0-3), select from ledc_timer_t
+ * @param timer_num LEDC timer index(0-3), select from ledc_timer_t
  *
- * @return    0      :  error
- *            others :  current LEDC frequency
+ * @return
+ *     - 0  error
+ *     - Others Current LEDC frequency
  *
  */
 uint32_t ledc_get_freq(ledc_mode_t speed_mode, ledc_timer_t timer_num);
@@ -195,27 +193,29 @@ uint32_t ledc_get_freq(ledc_mode_t speed_mode, ledc_timer_t timer_num);
  *
  * Set LEDC duty, After the function calls the ledc_update_duty function, the function can take effect.
  *
- * @param[in]  speed_mode  : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel     : LEDC channel(0-7), select from ledc_channel_t
+ * @param channel LEDC channel(0-7), select from ledc_channel_t
  *
- * @param[in]  duty        : set the LEDC duty, the duty range is [0, (2**bit_num) - 1]
+ * @param duty Set the LEDC duty, the duty range is [0, (2**bit_num) - 1]
  *
- * @return     ESP_OK:  success
- *             ESP_ERR_INVALID_ARG: parameter error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  */
 esp_err_t ledc_set_duty(ledc_mode_t speed_mode, ledc_channel_t channel, uint32_t duty);
 
 /**
  * @brief      LEDC get duty
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel : LEDC channel(0-7), select from ledc_channel_t
+ * @param channel LEDC channel(0-7), select from ledc_channel_t
  *
  *
- * @return     -1: parameter error
- *             other value: current LEDC duty
+ * @return
+ *     - (-1) parameter error
+ *     - Others Current LEDC duty
  *
  */
 int ledc_get_duty(ledc_mode_t speed_mode, ledc_channel_t channel);
@@ -225,22 +225,23 @@ int ledc_get_duty(ledc_mode_t speed_mode, ledc_channel_t channel);
  *
  * Set LEDC gradient, After the function calls the ledc_update_duty function, the function can take effect.
  *
- * @param[in]  speed_mode           : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel              : LEDC channel(0-7), select from ledc_channel_t
+ * @param  channel LEDC channel(0-7), select from ledc_channel_t
  *
- * @param[in]  duty                 : set the start of the gradient duty, the duty range is [0, (2**bit_num) - 1]
+ * @param  duty Set the start of the gradient duty, the duty range is [0, (2**bit_num) - 1]
  *
- * @param[in]  gradule_direction    : set the direction of the gradient
+ * @param  gradule_direction Set the direction of the gradient
  *
- * @param[in]  step_num             : set the number of the gradient
+ * @param  step_num Set the number of the gradient
  *
- * @param[in]  duty_cyle_num        : set how many LEDC tick each time the gradient lasts
+ * @param  duty_cyle_num Set how many LEDC tick each time the gradient lasts
  *
- * @param[in]  duty_scale           : set gradient change amplitude
+ * @param  duty_scale Set gradient change amplitude
  *
- * @return     ESP_OK               : success
- *             ESP_ERR_INVALID_ARG  : parameter error
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Parameter error
  */
 esp_err_t ledc_set_fade(ledc_mode_t speed_mode, uint32_t channel, uint32_t duty, ledc_duty_direction_t gradule_direction,
                         uint32_t step_num, uint32_t duty_cyle_num, uint32_t duty_scale);
@@ -248,34 +249,37 @@ esp_err_t ledc_set_fade(ledc_mode_t speed_mode, uint32_t channel, uint32_t duty,
 /**
  * @brief   register LEDC interrupt handler, the handler is an ISR.
  *          The handler will be attached to the same CPU core that this function is running on.
- *          Users should know that which CPU is running and then pick a INUM that is not used by system.
- *          We can find the information of INUM and interrupt level in soc.h.
- *          TODO: to move INUM options to menu_config
- * @param[in]   uint32_t ledc_intr_num    : LEDC interrupt number, check the info in soc.h, and please see the core-isa.h for more details
- * @param[in]   void (* fn)(void* )       : interrupt handler function.
- *                                          Note that the handler function MUST be defined with attribution of "IRAM_ATTR".
- * @param[in]   void * arg                : parameter for handler function
- *
- * @return      ESP_OK                    : success ;
- *              ESP_ERR_INVALID_ARG       : function ptr error.
+ * @note
+ *     Users should know that which CPU is running and then pick a INUM that is not used by system.
+ *     We can find the information of INUM and interrupt level in soc.h.
+ * @param   ledc_intr_num  LEDC interrupt number, check the info in soc.h, and please see the core-isa.h for more details
+ * @param   fn Interrupt handler function.
+ * @note
+ *     Note that the handler function MUST be defined with attribution of "IRAM_ATTR".
+ * @param   arg Parameter for handler function
+ *
+ * @return
+ *     - ESP_OK Success
+ *     - ESP_ERR_INVALID_ARG Function pointer error.
  */
 esp_err_t ledc_isr_register(uint32_t ledc_intr_num, void (*fn)(void*), void * arg);
 
 /**
  * @brief      configure LEDC settings
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_sel     : timer index(0-3), there are 4 timers in LEDC module
+ * @param  timer_sel  Timer index(0-3), there are 4 timers in LEDC module
  *
- * @param[in]  div_num       : timer clock divide number, the timer clock is divided from the selected clock source
+ * @param  div_num Timer clock divide number, the timer clock is divided from the selected clock source
  *
- * @param[in]  bit_num       : the count number of one period, counter range is 0 ~ ((2 ** bit_num) - 1)
+ * @param  bit_num The count number of one period, counter range is 0 ~ ((2 ** bit_num) - 1)
  *
- * @param[in]  clk_src       : select LEDC source clock.
+ * @param  clk_src Select LEDC source clock.
  *
- * @return     -1: parameter error
- *             other value: current LEDC duty
+ * @return
+ *     - (-1) Parameter error
+ *     - Other Current LEDC duty
  *
  */
 esp_err_t ledc_timer_set(ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t div_num, uint32_t bit_num, ledc_clk_src_t clk_src);
@@ -283,13 +287,14 @@ esp_err_t ledc_timer_set(ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_
 /**
  * @brief      reset LEDC timer
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_sel     : LEDC timer index(0-3), select from ledc_timer_t
+ * @param  timer_sel LEDC timer index(0-3), select from ledc_timer_t
  *
  *
- * @return     ESP_ERR_INVALID_ARG: parameter error
- *             ESP_OK: success
+ * @return
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_OK Success
  *
  */
 esp_err_t ledc_timer_rst(ledc_mode_t speed_mode, uint32_t timer_sel);
@@ -297,13 +302,14 @@ esp_err_t ledc_timer_rst(ledc_mode_t speed_mode, uint32_t timer_sel);
 /**
  * @brief      pause LEDC timer counter
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode  Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_sel     : LEDC timer index(0-3), select from ledc_timer_t
+ * @param  timer_sel LEDC timer index(0-3), select from ledc_timer_t
  *
  *
- * @return     ESP_ERR_INVALID_ARG: parameter error
- *             ESP_OK: success
+ * @return
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_OK Success
  *
  */
 esp_err_t ledc_timer_pause(ledc_mode_t speed_mode, uint32_t timer_sel);
@@ -311,13 +317,14 @@ esp_err_t ledc_timer_pause(ledc_mode_t speed_mode, uint32_t timer_sel);
 /**
  * @brief      pause LEDC timer resume
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  timer_sel     : LEDC timer index(0-3), select from ledc_timer_t
+ * @param  timer_sel LEDC timer index(0-3), select from ledc_timer_t
  *
  *
- * @return     ESP_ERR_INVALID_ARG: parameter error
- *             ESP_OK: success
+ * @return
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_OK Success
  *
  */
 esp_err_t ledc_timer_resume(ledc_mode_t speed_mode, uint32_t timer_sel);
@@ -325,15 +332,16 @@ esp_err_t ledc_timer_resume(ledc_mode_t speed_mode, uint32_t timer_sel);
 /**
  * @brief      bind LEDC channel with the selected timer
  *
- * @param[in]  speed_mode    : select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
+ * @param  speed_mode Select the LEDC speed_mode, high-speed mode and low-speed mode, now we only support high-speed mode. We will access low-speed mode in next version
  *
- * @param[in]  channel       : LEDC channel index(0-7), select from ledc_channel_t
+ * @param  channel LEDC channel index(0-7), select from ledc_channel_t
  *
- * @param[in]  timer_idx     : LEDC timer index(0-3), select from ledc_timer_t
+ * @param  timer_idx LEDC timer index(0-3), select from ledc_timer_t
  *
  *
- * @return     ESP_ERR_INVALID_ARG: parameter error
- *             ESP_OK: success
+ * @return
+ *     - ESP_ERR_INVALID_ARG Parameter error
+ *     - ESP_OK Success
  *
  */
 esp_err_t ledc_bind_channel_timer(ledc_mode_t speed_mode, uint32_t channel, uint32_t timer_idx);
@@ -342,44 +350,56 @@ esp_err_t ledc_bind_channel_timer(ledc_mode_t speed_mode, uint32_t channel, uint
  *
  *
  * ----------------EXAMPLE OF LEDC SETTING ---------------------
- *     //1. enable LEDC
- *     periph_module_enable(PERIPH_LEDC_MODULE);                //enable LEDC module, or you can not set any register of it.
- *
- *     //2. set LEDC timer
- *     ledc_timer_config_t timer_conf = {
- *         .bit_num = LEDC_TIMER_12_BIT,                        //set timer counter bit number
- *         .freq_hz = 1000,                                     //set frequency of pwm, here, 1000Hz
- *         .speed_mode = LEDC_HIGH_SPEED_MODE                   //timer mode,
- *         .timer_num = LEDC_TIMER_0,                           //timer number
- *     };
- *     ledc_timer_config(&timer_conf);                          //setup timer.
- *
- *     //3. set LEDC channel
- *     ledc_channel_config_t ledc_conf = {
- *         .channel = LEDC_CHANNEL_0;                           //set LEDC channel 0
- *         .duty = 1000;                                        //set the duty for initialization.(duty range is 0 ~ ((2**bit_num)-1)
- *         .gpio_num = 16;                                      //GPIO number
- *         .intr_type = LEDC_INTR_FADE_END;                     //GPIO INTR TYPE, as an example, we enable fade_end interrupt here.
- *         .speed_mode = LEDC_HIGH_SPEED_MODE;                  //set LEDC mode, from ledc_mode_t
- *         .timer_sel = LEDC_TIMER_0;                            //set LEDC timer source, if different channel use one timer, the frequency and bit_num of these channels should be the same
- *     }
- *     ledc_channel_config(&ledc_conf);                                 //setup the configuration
+ * @code{c}
+ * //1. enable LEDC
+ * //enable LEDC module, or you can not set any register of it.
+ * periph_module_enable(PERIPH_LEDC_MODULE);
+ * @endcode
+ *
+ * @code{c}
+ * //2. set LEDC timer
+ * ledc_timer_config_t timer_conf = {
+ *     .bit_num = LEDC_TIMER_12_BIT,                        //set timer counter bit number
+ *     .freq_hz = 1000,                                     //set frequency of pwm, here, 1000Hz
+ *     .speed_mode = LEDC_HIGH_SPEED_MODE,                  //timer mode,
+ *     .timer_num = LEDC_TIMER_0,                           //timer number
+ * };
+ * ledc_timer_config(&timer_conf);                          //setup timer.
+ * @endcode
+ *
+ * @code{c}
+ * //3. set LEDC channel
+ * ledc_channel_config_t ledc_conf = {
+ *     .channel = LEDC_CHANNEL_0;                           //set LEDC channel 0
+ *     .duty = 1000;                                        //set the duty for initialization.(duty range is 0 ~ ((2**bit_num)-1)
+ *     .gpio_num = 16;                                      //GPIO number
+ *     .intr_type = LEDC_INTR_FADE_END;                     //GPIO INTR TYPE, as an example, we enable fade_end interrupt here.
+ *     .speed_mode = LEDC_HIGH_SPEED_MODE;                  //set LEDC mode, from ledc_mode_t
+ *     .timer_sel = LEDC_TIMER_0;                           //set LEDC timer source, if different channel use one timer, the frequency and bit_num of these channels should be the same
+ * }
+ * ledc_channel_config(&ledc_conf);                         //setup the configuration
  *
  * ----------------EXAMPLE OF SETTING DUTY --- -----------------
- *     uint32_t ledc_channel = LEDC_CHANNEL_0;                  //LEDC channel(0-73)
- *     uint32_t duty = 2000;                                    //duty range is 0 ~ ((2**bit_num)-1)
- *     LEDC_set_duty(LEDC_HIGH_SPEED_MODE, ledc_channel, duty); //set speed mode, channel, and duty.
- *     ledc_update_duty(LEDC_HIGH_SPEED_MODE, ledc_channel);    //after set duty, we need to call ledc_update_duty to update the settings.
- *
+ * @code{c}
+ * uint32_t ledc_channel = LEDC_CHANNEL_0;                  //LEDC channel(0-73)
+ * uint32_t duty = 2000;                                    //duty range is 0 ~ ((2**bit_num)-1)
+ * LEDC_set_duty(LEDC_HIGH_SPEED_MODE, ledc_channel, duty); //set speed mode, channel, and duty.
+ * ledc_update_duty(LEDC_HIGH_SPEED_MODE, ledc_channel);    //after set duty, we need to call ledc_update_duty to update the settings.
+ * @endcode
  *
  * ----------------EXAMPLE OF LEDC INTERRUPT ------------------
- *     //we have fade_end interrupt and counter overflow interrupt. we just give an example of fade_end interrupt here.
- *     ledc_isr_register(18, ledc_isr_handler, NULL);           //hook the isr handler for LEDC interrupt
- *                                                              //the first parameter is INUM, you can pick one form interrupt level 1/2 which is not used by the system.
- *                                                              //NOTE1:user should arrange the INUMs that used, better not to use a same INUM for different interrupt source.
- *                                                              //NOTE2:do not pick the INUM that already occupied by the system.
- *                                                              //NOTE3:refer to soc.h to check which INUMs that can be used.
+ * @code{c}
+ * //we have fade_end interrupt and counter overflow interrupt. we just give an example of fade_end interrupt here.
+ * ledc_isr_register(18, ledc_isr_handler, NULL);           //hook the isr handler for LEDC interrupt
+ * @endcode
+ * @note
+ *     1. the first parameter is INUM, you can pick one form interrupt level 1/2 which is not used by the system.
+ *     2. user should arrange the INUMs that used, better not to use a same INUM for different interrupt source.
+ *     3. do not pick the INUM that already occupied by the system.
+ *     4. refer to soc.h to check which INUMs that can be used.
+ *
  * ----------------EXAMPLE OF INTERRUPT HANDLER ---------------
+ * @code{c}
  * #include "esp_attr.h"
  * void IRAM_ATTR ledc_isr_handler(void* arg)                   //we should add 'IRAM_ATTR' attribution when we declare the isr function
  * {
@@ -391,7 +411,7 @@ esp_err_t ledc_bind_channel_timer(ledc_mode_t speed_mode, uint32_t channel, uint
  *
  *    LEDC.int_clr.val = intr_st;                               //clear LEDC interrupt status.
  * }
- *
+ * @endcode
  *
  *--------------------------END OF EXAMPLE --------------------------
  */