Color Oled(SSD1331) connect to STMicroelectronics Nucleo-F466

Dependencies:   ssd1331

Committer:
kadonotakashi
Date:
Wed Oct 10 00:33:53 2018 +0000
Revision:
0:8fdf9a60065b
how to make mbed librry

Who changed what in which revision?

UserRevisionLine numberNew contents of line
kadonotakashi 0:8fdf9a60065b 1 /*
kadonotakashi 0:8fdf9a60065b 2 * Copyright (c) 2015, Freescale Semiconductor, Inc.
kadonotakashi 0:8fdf9a60065b 3 * All rights reserved.
kadonotakashi 0:8fdf9a60065b 4 *
kadonotakashi 0:8fdf9a60065b 5 * Redistribution and use in source and binary forms, with or without modification,
kadonotakashi 0:8fdf9a60065b 6 * are permitted provided that the following conditions are met:
kadonotakashi 0:8fdf9a60065b 7 *
kadonotakashi 0:8fdf9a60065b 8 * o Redistributions of source code must retain the above copyright notice, this list
kadonotakashi 0:8fdf9a60065b 9 * of conditions and the following disclaimer.
kadonotakashi 0:8fdf9a60065b 10 *
kadonotakashi 0:8fdf9a60065b 11 * o Redistributions in binary form must reproduce the above copyright notice, this
kadonotakashi 0:8fdf9a60065b 12 * list of conditions and the following disclaimer in the documentation and/or
kadonotakashi 0:8fdf9a60065b 13 * other materials provided with the distribution.
kadonotakashi 0:8fdf9a60065b 14 *
kadonotakashi 0:8fdf9a60065b 15 * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
kadonotakashi 0:8fdf9a60065b 16 * contributors may be used to endorse or promote products derived from this
kadonotakashi 0:8fdf9a60065b 17 * software without specific prior written permission.
kadonotakashi 0:8fdf9a60065b 18 *
kadonotakashi 0:8fdf9a60065b 19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
kadonotakashi 0:8fdf9a60065b 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
kadonotakashi 0:8fdf9a60065b 21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
kadonotakashi 0:8fdf9a60065b 22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
kadonotakashi 0:8fdf9a60065b 23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
kadonotakashi 0:8fdf9a60065b 24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
kadonotakashi 0:8fdf9a60065b 25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
kadonotakashi 0:8fdf9a60065b 26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
kadonotakashi 0:8fdf9a60065b 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
kadonotakashi 0:8fdf9a60065b 28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
kadonotakashi 0:8fdf9a60065b 29 */
kadonotakashi 0:8fdf9a60065b 30
kadonotakashi 0:8fdf9a60065b 31 #include "fsl_cmp.h"
kadonotakashi 0:8fdf9a60065b 32
kadonotakashi 0:8fdf9a60065b 33 /*******************************************************************************
kadonotakashi 0:8fdf9a60065b 34 * Prototypes
kadonotakashi 0:8fdf9a60065b 35 ******************************************************************************/
kadonotakashi 0:8fdf9a60065b 36 /*!
kadonotakashi 0:8fdf9a60065b 37 * @brief Get instance number for CMP module.
kadonotakashi 0:8fdf9a60065b 38 *
kadonotakashi 0:8fdf9a60065b 39 * @param base CMP peripheral base address
kadonotakashi 0:8fdf9a60065b 40 */
kadonotakashi 0:8fdf9a60065b 41 static uint32_t CMP_GetInstance(CMP_Type *base);
kadonotakashi 0:8fdf9a60065b 42
kadonotakashi 0:8fdf9a60065b 43 /*******************************************************************************
kadonotakashi 0:8fdf9a60065b 44 * Variables
kadonotakashi 0:8fdf9a60065b 45 ******************************************************************************/
kadonotakashi 0:8fdf9a60065b 46 /*! @brief Pointers to CMP bases for each instance. */
kadonotakashi 0:8fdf9a60065b 47 static CMP_Type *const s_cmpBases[] = CMP_BASE_PTRS;
kadonotakashi 0:8fdf9a60065b 48 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
kadonotakashi 0:8fdf9a60065b 49 /*! @brief Pointers to CMP clocks for each instance. */
kadonotakashi 0:8fdf9a60065b 50 static const clock_ip_name_t s_cmpClocks[] = CMP_CLOCKS;
kadonotakashi 0:8fdf9a60065b 51 #endif /* FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL */
kadonotakashi 0:8fdf9a60065b 52
kadonotakashi 0:8fdf9a60065b 53 /*******************************************************************************
kadonotakashi 0:8fdf9a60065b 54 * Codes
kadonotakashi 0:8fdf9a60065b 55 ******************************************************************************/
kadonotakashi 0:8fdf9a60065b 56 static uint32_t CMP_GetInstance(CMP_Type *base)
kadonotakashi 0:8fdf9a60065b 57 {
kadonotakashi 0:8fdf9a60065b 58 uint32_t instance;
kadonotakashi 0:8fdf9a60065b 59
kadonotakashi 0:8fdf9a60065b 60 /* Find the instance index from base address mappings. */
kadonotakashi 0:8fdf9a60065b 61 for (instance = 0; instance < FSL_FEATURE_SOC_CMP_COUNT; instance++)
kadonotakashi 0:8fdf9a60065b 62 {
kadonotakashi 0:8fdf9a60065b 63 if (s_cmpBases[instance] == base)
kadonotakashi 0:8fdf9a60065b 64 {
kadonotakashi 0:8fdf9a60065b 65 break;
kadonotakashi 0:8fdf9a60065b 66 }
kadonotakashi 0:8fdf9a60065b 67 }
kadonotakashi 0:8fdf9a60065b 68
kadonotakashi 0:8fdf9a60065b 69 assert(instance < FSL_FEATURE_SOC_CMP_COUNT);
kadonotakashi 0:8fdf9a60065b 70
kadonotakashi 0:8fdf9a60065b 71 return instance;
kadonotakashi 0:8fdf9a60065b 72 }
kadonotakashi 0:8fdf9a60065b 73
kadonotakashi 0:8fdf9a60065b 74 void CMP_Init(CMP_Type *base, const cmp_config_t *config)
kadonotakashi 0:8fdf9a60065b 75 {
kadonotakashi 0:8fdf9a60065b 76 assert(NULL != config);
kadonotakashi 0:8fdf9a60065b 77
kadonotakashi 0:8fdf9a60065b 78 uint8_t tmp8;
kadonotakashi 0:8fdf9a60065b 79
kadonotakashi 0:8fdf9a60065b 80 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
kadonotakashi 0:8fdf9a60065b 81 /* Enable the clock. */
kadonotakashi 0:8fdf9a60065b 82 CLOCK_EnableClock(s_cmpClocks[CMP_GetInstance(base)]);
kadonotakashi 0:8fdf9a60065b 83 #endif /* FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL */
kadonotakashi 0:8fdf9a60065b 84
kadonotakashi 0:8fdf9a60065b 85 /* Configure. */
kadonotakashi 0:8fdf9a60065b 86 CMP_Enable(base, false); /* Disable the CMP module during configuring. */
kadonotakashi 0:8fdf9a60065b 87 /* CMPx_CR1. */
kadonotakashi 0:8fdf9a60065b 88 tmp8 = base->CR1 & ~(CMP_CR1_PMODE_MASK | CMP_CR1_INV_MASK | CMP_CR1_COS_MASK | CMP_CR1_OPE_MASK);
kadonotakashi 0:8fdf9a60065b 89 if (config->enableHighSpeed)
kadonotakashi 0:8fdf9a60065b 90 {
kadonotakashi 0:8fdf9a60065b 91 tmp8 |= CMP_CR1_PMODE_MASK;
kadonotakashi 0:8fdf9a60065b 92 }
kadonotakashi 0:8fdf9a60065b 93 if (config->enableInvertOutput)
kadonotakashi 0:8fdf9a60065b 94 {
kadonotakashi 0:8fdf9a60065b 95 tmp8 |= CMP_CR1_INV_MASK;
kadonotakashi 0:8fdf9a60065b 96 }
kadonotakashi 0:8fdf9a60065b 97 if (config->useUnfilteredOutput)
kadonotakashi 0:8fdf9a60065b 98 {
kadonotakashi 0:8fdf9a60065b 99 tmp8 |= CMP_CR1_COS_MASK;
kadonotakashi 0:8fdf9a60065b 100 }
kadonotakashi 0:8fdf9a60065b 101 if (config->enablePinOut)
kadonotakashi 0:8fdf9a60065b 102 {
kadonotakashi 0:8fdf9a60065b 103 tmp8 |= CMP_CR1_OPE_MASK;
kadonotakashi 0:8fdf9a60065b 104 }
kadonotakashi 0:8fdf9a60065b 105 #if defined(FSL_FEATURE_CMP_HAS_TRIGGER_MODE) && FSL_FEATURE_CMP_HAS_TRIGGER_MODE
kadonotakashi 0:8fdf9a60065b 106 if (config->enableTriggerMode)
kadonotakashi 0:8fdf9a60065b 107 {
kadonotakashi 0:8fdf9a60065b 108 tmp8 |= CMP_CR1_TRIGM_MASK;
kadonotakashi 0:8fdf9a60065b 109 }
kadonotakashi 0:8fdf9a60065b 110 else
kadonotakashi 0:8fdf9a60065b 111 {
kadonotakashi 0:8fdf9a60065b 112 tmp8 &= ~CMP_CR1_TRIGM_MASK;
kadonotakashi 0:8fdf9a60065b 113 }
kadonotakashi 0:8fdf9a60065b 114 #endif /* FSL_FEATURE_CMP_HAS_TRIGGER_MODE */
kadonotakashi 0:8fdf9a60065b 115 base->CR1 = tmp8;
kadonotakashi 0:8fdf9a60065b 116
kadonotakashi 0:8fdf9a60065b 117 /* CMPx_CR0. */
kadonotakashi 0:8fdf9a60065b 118 tmp8 = base->CR0 & ~CMP_CR0_HYSTCTR_MASK;
kadonotakashi 0:8fdf9a60065b 119 tmp8 |= CMP_CR0_HYSTCTR(config->hysteresisMode);
kadonotakashi 0:8fdf9a60065b 120 base->CR0 = tmp8;
kadonotakashi 0:8fdf9a60065b 121
kadonotakashi 0:8fdf9a60065b 122 CMP_Enable(base, config->enableCmp); /* Enable the CMP module after configured or not. */
kadonotakashi 0:8fdf9a60065b 123 }
kadonotakashi 0:8fdf9a60065b 124
kadonotakashi 0:8fdf9a60065b 125 void CMP_Deinit(CMP_Type *base)
kadonotakashi 0:8fdf9a60065b 126 {
kadonotakashi 0:8fdf9a60065b 127 /* Disable the CMP module. */
kadonotakashi 0:8fdf9a60065b 128 CMP_Enable(base, false);
kadonotakashi 0:8fdf9a60065b 129
kadonotakashi 0:8fdf9a60065b 130 #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
kadonotakashi 0:8fdf9a60065b 131 /* Disable the clock. */
kadonotakashi 0:8fdf9a60065b 132 CLOCK_DisableClock(s_cmpClocks[CMP_GetInstance(base)]);
kadonotakashi 0:8fdf9a60065b 133 #endif /* FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL */
kadonotakashi 0:8fdf9a60065b 134 }
kadonotakashi 0:8fdf9a60065b 135
kadonotakashi 0:8fdf9a60065b 136 void CMP_GetDefaultConfig(cmp_config_t *config)
kadonotakashi 0:8fdf9a60065b 137 {
kadonotakashi 0:8fdf9a60065b 138 assert(NULL != config);
kadonotakashi 0:8fdf9a60065b 139
kadonotakashi 0:8fdf9a60065b 140 config->enableCmp = true; /* Enable the CMP module after initialization. */
kadonotakashi 0:8fdf9a60065b 141 config->hysteresisMode = kCMP_HysteresisLevel0;
kadonotakashi 0:8fdf9a60065b 142 config->enableHighSpeed = false;
kadonotakashi 0:8fdf9a60065b 143 config->enableInvertOutput = false;
kadonotakashi 0:8fdf9a60065b 144 config->useUnfilteredOutput = false;
kadonotakashi 0:8fdf9a60065b 145 config->enablePinOut = false;
kadonotakashi 0:8fdf9a60065b 146 #if defined(FSL_FEATURE_CMP_HAS_TRIGGER_MODE) && FSL_FEATURE_CMP_HAS_TRIGGER_MODE
kadonotakashi 0:8fdf9a60065b 147 config->enableTriggerMode = false;
kadonotakashi 0:8fdf9a60065b 148 #endif /* FSL_FEATURE_CMP_HAS_TRIGGER_MODE */
kadonotakashi 0:8fdf9a60065b 149 }
kadonotakashi 0:8fdf9a60065b 150
kadonotakashi 0:8fdf9a60065b 151 void CMP_SetInputChannels(CMP_Type *base, uint8_t positiveChannel, uint8_t negativeChannel)
kadonotakashi 0:8fdf9a60065b 152 {
kadonotakashi 0:8fdf9a60065b 153 uint8_t tmp8 = base->MUXCR;
kadonotakashi 0:8fdf9a60065b 154
kadonotakashi 0:8fdf9a60065b 155 tmp8 &= ~(CMP_MUXCR_PSEL_MASK | CMP_MUXCR_MSEL_MASK);
kadonotakashi 0:8fdf9a60065b 156 tmp8 |= CMP_MUXCR_PSEL(positiveChannel) | CMP_MUXCR_MSEL(negativeChannel);
kadonotakashi 0:8fdf9a60065b 157 base->MUXCR = tmp8;
kadonotakashi 0:8fdf9a60065b 158 }
kadonotakashi 0:8fdf9a60065b 159
kadonotakashi 0:8fdf9a60065b 160 #if defined(FSL_FEATURE_CMP_HAS_DMA) && FSL_FEATURE_CMP_HAS_DMA
kadonotakashi 0:8fdf9a60065b 161 void CMP_EnableDMA(CMP_Type *base, bool enable)
kadonotakashi 0:8fdf9a60065b 162 {
kadonotakashi 0:8fdf9a60065b 163 uint8_t tmp8 = base->SCR & ~(CMP_SCR_CFR_MASK | CMP_SCR_CFF_MASK); /* To avoid change the w1c bits. */
kadonotakashi 0:8fdf9a60065b 164
kadonotakashi 0:8fdf9a60065b 165 if (enable)
kadonotakashi 0:8fdf9a60065b 166 {
kadonotakashi 0:8fdf9a60065b 167 tmp8 |= CMP_SCR_DMAEN_MASK;
kadonotakashi 0:8fdf9a60065b 168 }
kadonotakashi 0:8fdf9a60065b 169 else
kadonotakashi 0:8fdf9a60065b 170 {
kadonotakashi 0:8fdf9a60065b 171 tmp8 &= ~CMP_SCR_DMAEN_MASK;
kadonotakashi 0:8fdf9a60065b 172 }
kadonotakashi 0:8fdf9a60065b 173 base->SCR = tmp8;
kadonotakashi 0:8fdf9a60065b 174 }
kadonotakashi 0:8fdf9a60065b 175 #endif /* FSL_FEATURE_CMP_HAS_DMA */
kadonotakashi 0:8fdf9a60065b 176
kadonotakashi 0:8fdf9a60065b 177 void CMP_SetFilterConfig(CMP_Type *base, const cmp_filter_config_t *config)
kadonotakashi 0:8fdf9a60065b 178 {
kadonotakashi 0:8fdf9a60065b 179 assert(NULL != config);
kadonotakashi 0:8fdf9a60065b 180
kadonotakashi 0:8fdf9a60065b 181 uint8_t tmp8;
kadonotakashi 0:8fdf9a60065b 182
kadonotakashi 0:8fdf9a60065b 183 #if defined(FSL_FEATURE_CMP_HAS_EXTERNAL_SAMPLE_SUPPORT) && FSL_FEATURE_CMP_HAS_EXTERNAL_SAMPLE_SUPPORT
kadonotakashi 0:8fdf9a60065b 184 /* Choose the clock source for sampling. */
kadonotakashi 0:8fdf9a60065b 185 if (config->enableSample)
kadonotakashi 0:8fdf9a60065b 186 {
kadonotakashi 0:8fdf9a60065b 187 base->CR1 |= CMP_CR1_SE_MASK; /* Choose the external SAMPLE clock. */
kadonotakashi 0:8fdf9a60065b 188 }
kadonotakashi 0:8fdf9a60065b 189 else
kadonotakashi 0:8fdf9a60065b 190 {
kadonotakashi 0:8fdf9a60065b 191 base->CR1 &= ~CMP_CR1_SE_MASK; /* Choose the internal divided bus clock. */
kadonotakashi 0:8fdf9a60065b 192 }
kadonotakashi 0:8fdf9a60065b 193 #endif /* FSL_FEATURE_CMP_HAS_EXTERNAL_SAMPLE_SUPPORT */
kadonotakashi 0:8fdf9a60065b 194 /* Set the filter count. */
kadonotakashi 0:8fdf9a60065b 195 tmp8 = base->CR0 & ~CMP_CR0_FILTER_CNT_MASK;
kadonotakashi 0:8fdf9a60065b 196 tmp8 |= CMP_CR0_FILTER_CNT(config->filterCount);
kadonotakashi 0:8fdf9a60065b 197 base->CR0 = tmp8;
kadonotakashi 0:8fdf9a60065b 198 /* Set the filter period. It is used as the divider to bus clock. */
kadonotakashi 0:8fdf9a60065b 199 base->FPR = CMP_FPR_FILT_PER(config->filterPeriod);
kadonotakashi 0:8fdf9a60065b 200 }
kadonotakashi 0:8fdf9a60065b 201
kadonotakashi 0:8fdf9a60065b 202 void CMP_SetDACConfig(CMP_Type *base, const cmp_dac_config_t *config)
kadonotakashi 0:8fdf9a60065b 203 {
kadonotakashi 0:8fdf9a60065b 204 uint8_t tmp8 = 0U;
kadonotakashi 0:8fdf9a60065b 205
kadonotakashi 0:8fdf9a60065b 206 if (NULL == config)
kadonotakashi 0:8fdf9a60065b 207 {
kadonotakashi 0:8fdf9a60065b 208 /* Passing "NULL" as input parameter means no available configuration. So the DAC feature is disabled.*/
kadonotakashi 0:8fdf9a60065b 209 base->DACCR = 0U;
kadonotakashi 0:8fdf9a60065b 210 return;
kadonotakashi 0:8fdf9a60065b 211 }
kadonotakashi 0:8fdf9a60065b 212 /* CMPx_DACCR. */
kadonotakashi 0:8fdf9a60065b 213 tmp8 |= CMP_DACCR_DACEN_MASK; /* Enable the internal DAC. */
kadonotakashi 0:8fdf9a60065b 214 if (kCMP_VrefSourceVin2 == config->referenceVoltageSource)
kadonotakashi 0:8fdf9a60065b 215 {
kadonotakashi 0:8fdf9a60065b 216 tmp8 |= CMP_DACCR_VRSEL_MASK;
kadonotakashi 0:8fdf9a60065b 217 }
kadonotakashi 0:8fdf9a60065b 218 tmp8 |= CMP_DACCR_VOSEL(config->DACValue);
kadonotakashi 0:8fdf9a60065b 219
kadonotakashi 0:8fdf9a60065b 220 base->DACCR = tmp8;
kadonotakashi 0:8fdf9a60065b 221 }
kadonotakashi 0:8fdf9a60065b 222
kadonotakashi 0:8fdf9a60065b 223 void CMP_EnableInterrupts(CMP_Type *base, uint32_t mask)
kadonotakashi 0:8fdf9a60065b 224 {
kadonotakashi 0:8fdf9a60065b 225 uint8_t tmp8 = base->SCR & ~(CMP_SCR_CFR_MASK | CMP_SCR_CFF_MASK); /* To avoid change the w1c bits. */
kadonotakashi 0:8fdf9a60065b 226
kadonotakashi 0:8fdf9a60065b 227 if (0U != (kCMP_OutputRisingInterruptEnable & mask))
kadonotakashi 0:8fdf9a60065b 228 {
kadonotakashi 0:8fdf9a60065b 229 tmp8 |= CMP_SCR_IER_MASK;
kadonotakashi 0:8fdf9a60065b 230 }
kadonotakashi 0:8fdf9a60065b 231 if (0U != (kCMP_OutputFallingInterruptEnable & mask))
kadonotakashi 0:8fdf9a60065b 232 {
kadonotakashi 0:8fdf9a60065b 233 tmp8 |= CMP_SCR_IEF_MASK;
kadonotakashi 0:8fdf9a60065b 234 }
kadonotakashi 0:8fdf9a60065b 235 base->SCR = tmp8;
kadonotakashi 0:8fdf9a60065b 236 }
kadonotakashi 0:8fdf9a60065b 237
kadonotakashi 0:8fdf9a60065b 238 void CMP_DisableInterrupts(CMP_Type *base, uint32_t mask)
kadonotakashi 0:8fdf9a60065b 239 {
kadonotakashi 0:8fdf9a60065b 240 uint8_t tmp8 = base->SCR & ~(CMP_SCR_CFR_MASK | CMP_SCR_CFF_MASK); /* To avoid change the w1c bits. */
kadonotakashi 0:8fdf9a60065b 241
kadonotakashi 0:8fdf9a60065b 242 if (0U != (kCMP_OutputRisingInterruptEnable & mask))
kadonotakashi 0:8fdf9a60065b 243 {
kadonotakashi 0:8fdf9a60065b 244 tmp8 &= ~CMP_SCR_IER_MASK;
kadonotakashi 0:8fdf9a60065b 245 }
kadonotakashi 0:8fdf9a60065b 246 if (0U != (kCMP_OutputFallingInterruptEnable & mask))
kadonotakashi 0:8fdf9a60065b 247 {
kadonotakashi 0:8fdf9a60065b 248 tmp8 &= ~CMP_SCR_IEF_MASK;
kadonotakashi 0:8fdf9a60065b 249 }
kadonotakashi 0:8fdf9a60065b 250 base->SCR = tmp8;
kadonotakashi 0:8fdf9a60065b 251 }
kadonotakashi 0:8fdf9a60065b 252
kadonotakashi 0:8fdf9a60065b 253 uint32_t CMP_GetStatusFlags(CMP_Type *base)
kadonotakashi 0:8fdf9a60065b 254 {
kadonotakashi 0:8fdf9a60065b 255 uint32_t ret32 = 0U;
kadonotakashi 0:8fdf9a60065b 256
kadonotakashi 0:8fdf9a60065b 257 if (0U != (CMP_SCR_CFR_MASK & base->SCR))
kadonotakashi 0:8fdf9a60065b 258 {
kadonotakashi 0:8fdf9a60065b 259 ret32 |= kCMP_OutputRisingEventFlag;
kadonotakashi 0:8fdf9a60065b 260 }
kadonotakashi 0:8fdf9a60065b 261 if (0U != (CMP_SCR_CFF_MASK & base->SCR))
kadonotakashi 0:8fdf9a60065b 262 {
kadonotakashi 0:8fdf9a60065b 263 ret32 |= kCMP_OutputFallingEventFlag;
kadonotakashi 0:8fdf9a60065b 264 }
kadonotakashi 0:8fdf9a60065b 265 if (0U != (CMP_SCR_COUT_MASK & base->SCR))
kadonotakashi 0:8fdf9a60065b 266 {
kadonotakashi 0:8fdf9a60065b 267 ret32 |= kCMP_OutputAssertEventFlag;
kadonotakashi 0:8fdf9a60065b 268 }
kadonotakashi 0:8fdf9a60065b 269 return ret32;
kadonotakashi 0:8fdf9a60065b 270 }
kadonotakashi 0:8fdf9a60065b 271
kadonotakashi 0:8fdf9a60065b 272 void CMP_ClearStatusFlags(CMP_Type *base, uint32_t mask)
kadonotakashi 0:8fdf9a60065b 273 {
kadonotakashi 0:8fdf9a60065b 274 uint8_t tmp8 = base->SCR & ~(CMP_SCR_CFR_MASK | CMP_SCR_CFF_MASK); /* To avoid change the w1c bits. */
kadonotakashi 0:8fdf9a60065b 275
kadonotakashi 0:8fdf9a60065b 276 if (0U != (kCMP_OutputRisingEventFlag & mask))
kadonotakashi 0:8fdf9a60065b 277 {
kadonotakashi 0:8fdf9a60065b 278 tmp8 |= CMP_SCR_CFR_MASK;
kadonotakashi 0:8fdf9a60065b 279 }
kadonotakashi 0:8fdf9a60065b 280 if (0U != (kCMP_OutputFallingEventFlag & mask))
kadonotakashi 0:8fdf9a60065b 281 {
kadonotakashi 0:8fdf9a60065b 282 tmp8 |= CMP_SCR_CFF_MASK;
kadonotakashi 0:8fdf9a60065b 283 }
kadonotakashi 0:8fdf9a60065b 284 base->SCR = tmp8;
kadonotakashi 0:8fdf9a60065b 285 }