| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213 |
- /*****************************************************************************
- * Copyright (c) 2019, Nations Technologies Inc.
- *
- * All rights reserved.
- * ****************************************************************************
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the disclaimer below.
- *
- * Nations' name may not be used to endorse or promote products derived from
- * this software without specific prior written permission.
- *
- * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY NATIONS "AS IS" AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
- * DISCLAIMED. IN NO EVENT SHALL NATIONS 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.
- * ****************************************************************************/
- /**
- * @file n32g45x_opamp.h
- * @author Nations
- * @version v1.0.1
- *
- * @copyright Copyright (c) 2019, Nations Technologies Inc. All rights reserved.
- */
- #ifndef __N32G45X_OPAMPMP_H__
- #define __N32G45X_OPAMPMP_H__
- #ifdef __cplusplus
- extern "C" {
- #endif
- #include "n32g45x.h"
- #include <stdbool.h>
- /** @addtogroup N32G45X_StdPeriph_Driver
- * @{
- */
- /** @addtogroup OPAMP
- * @{
- */
- /** @addtogroup OPAMP_Exported_Constants
- * @{
- */
- typedef enum
- {
- OPAMP1 = 0,
- OPAMP2 = 4,
- OPAMP3 = 8,
- OPAMP4 = 12,
- } OPAMPX;
- // OPAMP_CS
- typedef enum
- {
- OPAMP1_CS_VPSSEL_PA1 = (0x00L << 19),
- OPAMP1_CS_VPSSEL_PA3 = (0x01L << 19),
- OPAMP1_CS_VPSSEL_DAC2_PA5 = (0x02L << 19),
- OPAMP1_CS_VPSSEL_PA7 = (0x03L << 19),
- OPAMP2_CS_VPSSEL_PA7 = (0x00L << 19),
- OPAMP2_CS_VPSSEL_PB0 = (0x01L << 19),
- OPAMP2_CS_VPSSEL_PE8 = (0x02L << 19),
- OPAMP3_CS_VPSSEL_PC9 = (0x00L << 19),
- OPAMP3_CS_VPSSEL_PA1 = (0x01L << 19),
- OPAMP3_CS_VPSSEL_DAC2_PA5 = (0x02L << 19),
- OPAMP3_CS_VPSSEL_PC3 = (0x03L << 19),
- OPAMP4_CS_VPSSEL_PC3 = (0x00L << 19),
- OPAMP4_CS_VPSSEL_DAC1_PA4 = (0x01L << 19),
- OPAMP4_CS_VPSSEL_PC5 = (0x02L << 19),
- } OPAMP_CS_VPSSEL;
- typedef enum
- {
- OPAMP1_CS_VMSSEL_PA3 = (0x00L << 17),
- OPAMP1_CS_VMSSEL_PA2 = (0x01L << 17),
- OPAMPx_CS_VMSSEL_FLOAT = (0x03L << 17),
- OPAMP2_CS_VMSSEL_PA2 = (0x00L << 17),
- OPAMP2_CS_VMSSEL_PA5 = (0x01L << 17),
- OPAMP3_CS_VMSSEL_PC4 = (0x00L << 17),
- OPAMP3_CS_VMSSEL_PB10 = (0x01L << 17),
- OPAMP4_CS_VMSSEL_PB10 = (0x00L << 17),
- OPAMP4_CS_VMSSEL_PC9 = (0x01L << 17),
- OPAMP4_CS_VMSSEL_PD8 = (0x02L << 17),
- } OPAMP_CS_VMSSEL;
- typedef enum
- {
- OPAMP1_CS_VPSEL_PA1 = (0x00L << 8),
- OPAMP1_CS_VPSEL_PA3 = (0x01L << 8),
- OPAMP1_CS_VPSEL_DAC2_PA5 = (0x02L << 8),
- OPAMP1_CS_VPSEL_PA7 = (0x03L << 8),
- OPAMP2_CS_VPSEL_PA7 = (0x00L << 8),
- OPAMP2_CS_VPSEL_PB0 = (0x01L << 8),
- OPAMP2_CS_VPSEL_PE8 = (0x02L << 8),
- OPAMP3_CS_VPSEL_PC9 = (0x00L << 8),
- OPAMP3_CS_VPSEL_PA1 = (0x01L << 8),
- OPAMP3_CS_VPSEL_DAC2_PA5 = (0x02L << 8),
- OPAMP3_CS_VPSEL_PC3 = (0x03L << 8),
- OPAMP4_CS_VPSEL_PC3 = (0x00L << 8),
- OPAMP4_CS_VPSEL_DAC1_PA4 = (0x01L << 8),
- OPAMP4_CS_VPSEL_PC5 = (0x02L << 8),
- } OPAMP_CS_VPSEL;
- typedef enum
- {
- OPAMP1_CS_VMSEL_PA3 = (0x00L << 6),
- OPAMP1_CS_VMSEL_PA2 = (0x01L << 6),
- OPAMPx_CS_VMSEL_FLOAT = (0x03L << 6),
- OPAMP2_CS_VMSEL_PA2 = (0x00L << 6),
- OPAMP2_CS_VMSEL_PA5 = (0x01L << 6),
- OPAMP3_CS_VMSEL_PC4 = (0x00L << 6),
- OPAMP3_CS_VMSEL_PB10 = (0x01L << 6),
- OPAMP4_CS_VMSEL_PB10 = (0x00L << 6),
- OPAMP4_CS_VMSEL_PC9 = (0x01L << 6),
- OPAMP4_CS_VMSEL_PD8 = (0x02L << 6),
- } OPAMP_CS_VMSEL;
- typedef enum
- {
- OPAMP_CS_PGA_GAIN_2 = (0x00 << 3),
- OPAMP_CS_PGA_GAIN_4 = (0x01 << 3),
- OPAMP_CS_PGA_GAIN_8 = (0x02 << 3),
- OPAMP_CS_PGA_GAIN_16 = (0x03 << 3),
- OPAMP_CS_PGA_GAIN_32 = (0x04 << 3),
- } OPAMP_CS_PGA_GAIN;
- typedef enum
- {
- OPAMP_CS_EXT_OPAMP = (0x00 << 1),
- OPAMP_CS_PGA_EN = (0x02 << 1),
- OPAMP_CS_FOLLOW = (0x03 << 1),
- } OPAMP_CS_MOD;
- // bit mask
- #define OPAMP_CS_EN_MASK (0x01L << 0)
- #define OPAMP_CS_MOD_MASK (0x03L << 1)
- #define OPAMP_CS_PGA_GAIN_MASK (0x07L << 3)
- #define OPAMP_CS_VMSEL_MASK (0x03L << 6)
- #define OPAMP_CS_VPSEL_MASK (0x07L << 8)
- #define OPAMP_CS_CALON_MASK (0x01L << 11)
- #define OPAMP_CS_TSTREF_MASK (0x01L << 13)
- #define OPAMP_CS_CALOUT_MASK (0x01L << 14)
- #define OPAMP_CS_RANGE_MASK (0x01L << 15)
- #define OPAMP_CS_TCMEN_MASK (0x01L << 16)
- #define OPAMP_CS_VMSEL_SECOND_MASK (0x03L << 17)
- #define OPAMP_CS_VPSEL_SECOND_MASK (0x07L << 19)
- /** @addtogroup OPAMP_LOCK
- * @{
- */
- #define OPAMP_LOCK_1 0x01L
- #define OPAMP_LOCK_2 0x02L
- #define OPAMP_LOCK_3 0x04L
- #define OPAMP_LOCK_4 0x08L
- /**
- * @}
- */
- /**
- * @}
- */
- /**
- * @brief OPAMP Init structure definition
- */
- typedef struct
- {
- FunctionalState TimeAutoMuxEn; /*call ENABLE or DISABLE */
- FunctionalState HighVolRangeEn; /*call ENABLE or DISABLE ,low range VDDA < 2.4V,high range VDDA >= 2.4V*/
- OPAMP_CS_PGA_GAIN Gain; /*see @EM_PGA_GAIN */
- OPAMP_CS_MOD Mod; /*see @EM_OPAMP_MOD*/
- } OPAMP_InitType;
- /** @addtogroup OPAMP_Exported_Functions
- * @{
- */
- void OPAMP_DeInit(void);
- void OPAMP_StructInit(OPAMP_InitType* OPAMP_InitStruct);
- void OPAMP_Init(OPAMPX OPAMPx, OPAMP_InitType* OPAMP_InitStruct);
- void OPAMP_Enable(OPAMPX OPAMPx, FunctionalState en);
- void OPAMP_SetPgaGain(OPAMPX OPAMPx, OPAMP_CS_PGA_GAIN Gain);
- void OPAMP_SetVpSecondSel(OPAMPX OPAMPx, OPAMP_CS_VPSSEL VpSSel);
- void OPAMP_SetVmSecondSel(OPAMPX OPAMPx, OPAMP_CS_VMSSEL VmSSel);
- void OPAMP_SetVpSel(OPAMPX OPAMPx, OPAMP_CS_VPSEL VpSel);
- void OPAMP_SetVmSel(OPAMPX OPAMPx, OPAMP_CS_VMSEL VmSel);
- bool OPAMP_IsCalOutHigh(OPAMPX OPAMPx);
- void OPAMP_CalibrationEnable(OPAMPX OPAMPx, FunctionalState en);
- void OPAMP_SetLock(uint32_t Lock); // see @OPAMP_LOCK
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /*__N32G45X_ADC_H */
- /**
- * @}
- */
- /**
- * @}
- */
|