169 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
/**
 | 
						|
  ******************************************************************************
 | 
						|
  * @file    idd.h
 | 
						|
  * @author  MCD Application Team
 | 
						|
  * @version V4.0.1
 | 
						|
  * @date    21-July-2015
 | 
						|
  * @brief   This file contains all the functions prototypes for the IDD driver.
 | 
						|
  ******************************************************************************
 | 
						|
  * @attention
 | 
						|
  *
 | 
						|
  * <h2><center>© 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 __IDD_H
 | 
						|
#define __IDD_H
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
 extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
/* Includes ------------------------------------------------------------------*/
 | 
						|
#include <stdint.h>
 | 
						|
 | 
						|
/** @addtogroup BSP
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
 | 
						|
/** @addtogroup Components
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
    
 | 
						|
/** @addtogroup IDD
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
 | 
						|
/** @defgroup IDD_Exported_Types IDD Exported Types
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
 | 
						|
/** @defgroup IDD_Config_structure  IDD Configuration structure
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
typedef struct
 | 
						|
{
 | 
						|
  uint16_t AmpliGain;       /*!< Specifies ampli gain value
 | 
						|
                                 */
 | 
						|
  uint16_t VddMin;          /*!< Specifies minimum MCU VDD can reach to protect MCU from reset
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt0Value;     /*!< Specifies value of Shunt 0 if existing
 | 
						|
                                 */
 | 
						|
  uint16_t Shunt1Value;     /*!< Specifies value of Shunt 1 if existing
 | 
						|
                                 */
 | 
						|
  uint16_t Shunt2Value;     /*!< Specifies value of Shunt 2 if existing
 | 
						|
                                 */
 | 
						|
  uint16_t Shunt3Value;     /*!< Specifies value of Shunt 3 if existing
 | 
						|
                                 */
 | 
						|
  uint16_t Shunt4Value;     /*!< Specifies value of Shunt 4 if existing
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt0StabDelay; /*!< Specifies delay of Shunt 0 stabilization if existing
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt1StabDelay; /*!< Specifies delay of Shunt 1 stabilization if existing
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt2StabDelay; /*!< Specifies delay of Shunt 2 stabilization if existing
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt3StabDelay; /*!< Specifies delay of Shunt 3 stabilization if existing
 | 
						|
                                  */
 | 
						|
  uint16_t Shunt4StabDelay; /*!< Specifies delay of Shunt 4 stabilization if existing
 | 
						|
                                  */
 | 
						|
  uint8_t ShuntNbOnBoard;   /*!< Specifies number of shunts that are present on board
 | 
						|
                                 This parameter can be a value of @ref IDD_shunt_number */
 | 
						|
  uint8_t ShuntNbUsed;      /*!< Specifies number of shunts used for measurement
 | 
						|
                                 This parameter can be a value of @ref IDD_shunt_number */
 | 
						|
  uint8_t VrefMeasurement;  /*!< Specifies if Vref is automatically measured before each Idd measurement
 | 
						|
                                 This parameter can be a value of @ref IDD_Vref_Measurement */
 | 
						|
  uint8_t Calibration;      /*!< Specifies if calibration is done before each Idd measurement
 | 
						|
                                  */
 | 
						|
  uint8_t PreDelayUnit;     /*!< Specifies Pre delay unit 
 | 
						|
                                 This parameter can be a value of @ref IDD_PreDelay */
 | 
						|
  uint8_t PreDelayValue;    /*!< Specifies Pre delay value in selected unit
 | 
						|
                                  */
 | 
						|
  uint8_t MeasureNb;        /*!< Specifies number of Measure to be performed 
 | 
						|
                                 This parameter can be a value between 1 and 256 */
 | 
						|
  uint8_t DeltaDelayUnit;   /*!< Specifies Delta delay unit
 | 
						|
                                  This parameter can be a value of @ref IDD_DeltaDelay */
 | 
						|
  uint8_t DeltaDelayValue;  /*!< Specifies Delta delay between 2 measures
 | 
						|
                                  value can be between 1 and 128 */
 | 
						|
}IDD_ConfigTypeDef;
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
/** @defgroup IDD_Driver_structure  IDD Driver structure
 | 
						|
  * @{
 | 
						|
  */
 | 
						|
typedef struct
 | 
						|
{
 | 
						|
  void       (*Init)(uint16_t);
 | 
						|
  void       (*DeInit)(uint16_t);
 | 
						|
  uint16_t   (*ReadID)(uint16_t);
 | 
						|
  void       (*Reset)(uint16_t);
 | 
						|
  void       (*LowPower)(uint16_t);
 | 
						|
  void       (*WakeUp)(uint16_t);
 | 
						|
  void       (*Start)(uint16_t);
 | 
						|
  void       (*Config)(uint16_t,IDD_ConfigTypeDef);
 | 
						|
  void       (*GetValue)(uint16_t, uint32_t *);
 | 
						|
  void       (*EnableIT)(uint16_t);
 | 
						|
  void       (*ClearIT)(uint16_t);
 | 
						|
  uint8_t    (*GetITStatus)(uint16_t);
 | 
						|
  void       (*DisableIT)(uint16_t);
 | 
						|
  void       (*ErrorEnableIT)(uint16_t);
 | 
						|
  void       (*ErrorClearIT)(uint16_t);
 | 
						|
  uint8_t    (*ErrorGetITStatus)(uint16_t);
 | 
						|
  void       (*ErrorDisableIT)(uint16_t);
 | 
						|
  uint8_t    (*ErrorGetSrc)(uint16_t);
 | 
						|
  uint8_t    (*ErrorGetCode)(uint16_t);
 | 
						|
}IDD_DrvTypeDef;
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
/**
 | 
						|
  * @}
 | 
						|
  */
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 | 
						|
 | 
						|
#endif /* __IDD_H */
 | 
						|
 | 
						|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 |