123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328 |
- /*!
- \file gd32f30x_bkp.c
- \brief BKP driver
- \version 2017-02-10, V1.0.0, firmware for GD32F30x
- \version 2018-10-10, V1.1.0, firmware for GD32F30x
- \version 2018-12-25, V2.0.0, firmware for GD32F30x
- \version 2020-09-30, V2.1.0, firmware for GD32F30x
- */
- /*
- Copyright (c) 2020, GigaDevice Semiconductor Inc.
- 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 the copyright holder 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.
- */
- #include "gd32f30x_bkp.h"
- #define TAMPER_FLAG_SHIFT ((uint8_t)8U)
- /*!
- \brief reset BKP registers
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_deinit(void)
- {
- /* reset BKP domain register*/
- rcu_bkp_reset_enable();
- rcu_bkp_reset_disable();
- }
- /*!
- \brief write BKP data register
- \param[in] register_number: refer to bkp_data_register_enum, only one parameter can be selected
- \arg BKP_DATA_x(x = 0..41): bkp data register number x
- \param[in] data: the data to be write in BKP data register
- \param[out] none
- \retval none
- */
- void bkp_write_data(bkp_data_register_enum register_number, uint16_t data)
- {
- if((register_number >= BKP_DATA_10) && (register_number <= BKP_DATA_41)){
- BKP_DATA10_41(register_number-1U) = data;
- }else if((register_number >= BKP_DATA_0) && (register_number <= BKP_DATA_9)){
- BKP_DATA0_9(register_number-1U) = data;
- }else{
- /* illegal parameters */
- }
- }
- /*!
- \brief read BKP data register
- \param[in] register_number: refer to bkp_data_register_enum, only one parameter can be selected
- \arg BKP_DATA_x(x = 0..41): bkp data register number x
- \param[out] none
- \retval data of BKP data register
- */
- uint16_t bkp_read_data(bkp_data_register_enum register_number)
- {
- uint16_t data = 0U;
-
- /* get the data from the BKP data register */
- if((register_number >= BKP_DATA_10) && (register_number <= BKP_DATA_41)){
- data = BKP_DATA10_41(register_number-1U);
- }else if((register_number >= BKP_DATA_0) && (register_number <= BKP_DATA_9)){
- data = BKP_DATA0_9(register_number-1U);
- }else{
- /* illegal parameters */
- }
- return data;
- }
- /*!
- \brief enable RTC clock calibration output
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_rtc_calibration_output_enable(void)
- {
- BKP_OCTL |= (uint16_t)BKP_OCTL_COEN;
- }
- /*!
- \brief disable RTC clock calibration output
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_rtc_calibration_output_disable(void)
- {
- BKP_OCTL &= (uint16_t)~BKP_OCTL_COEN;
- }
- /*!
- \brief enable RTC alarm or second signal output
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_rtc_signal_output_enable(void)
- {
- BKP_OCTL |= (uint16_t)BKP_OCTL_ASOEN;
- }
- /*!
- \brief disable RTC alarm or second signal output
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_rtc_signal_output_disable(void)
- {
- BKP_OCTL &= (uint16_t)~BKP_OCTL_ASOEN;
- }
- /*!
- \brief select RTC output
- \param[in] outputsel: RTC output selection
- \arg RTC_OUTPUT_ALARM_PULSE: RTC alarm pulse is selected as the RTC output
- \arg RTC_OUTPUT_SECOND_PULSE: RTC second pulse is selected as the RTC output
- \param[out] none
- \retval none
- */
- void bkp_rtc_output_select(uint16_t outputsel)
- {
- uint16_t ctl = 0U;
-
- ctl = BKP_OCTL;
- ctl &= (uint16_t)~BKP_OCTL_ROSEL;
- ctl |= outputsel;
- BKP_OCTL = ctl;
- }
- /*!
- \brief select RTC clock output
- \param[in] clocksel: RTC clock output selection
- \arg RTC_CLOCK_DIV_64: RTC clock div 64
- \arg RTC_CLOCK_DIV_1: RTC clock
- \param[out] none
- \retval none
- */
- void bkp_rtc_clock_output_select(uint16_t clocksel)
- {
- uint16_t ctl = 0U;
-
- ctl = BKP_OCTL;
- ctl &= (uint16_t)~BKP_OCTL_CCOSEL;
- ctl |= clocksel;
- BKP_OCTL = ctl;
- }
- /*!
- \brief RTC clock calibration direction
- \param[in] direction: RTC clock calibration direction
- \arg RTC_CLOCK_SLOWED_DOWN: RTC clock slow down
- \arg RTC_CLOCK_SPEED_UP: RTC clock speed up
- \param[out] none
- \retval none
- */
- void bkp_rtc_clock_calibration_direction(uint16_t direction)
- {
- uint16_t ctl = 0U;
-
- ctl = BKP_OCTL;
- ctl &= (uint16_t)~BKP_OCTL_CALDIR;
- ctl |= direction;
- BKP_OCTL = ctl;
- }
- /*!
- \brief set RTC clock calibration value
- \param[in] value: RTC clock calibration value
- \arg 0x00 - 0x7F
- \param[out] none
- \retval none
- */
- void bkp_rtc_calibration_value_set(uint8_t value)
- {
- uint16_t ctl;
-
- ctl = BKP_OCTL;
- ctl &= ~(uint16_t)BKP_OCTL_RCCV;
- ctl |= (uint16_t)OCTL_RCCV(value);
- BKP_OCTL = ctl;
- }
- /*!
- \brief enable tamper detection
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_tamper_detection_enable(void)
- {
- BKP_TPCTL |= (uint16_t)BKP_TPCTL_TPEN;
- }
- /*!
- \brief disable tamper detection
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_tamper_detection_disable(void)
- {
- BKP_TPCTL &= (uint16_t)~BKP_TPCTL_TPEN;
- }
- /*!
- \brief set tamper pin active level
- \param[in] level: tamper active level
- \arg TAMPER_PIN_ACTIVE_HIGH: the tamper pin is active high
- \arg TAMPER_PIN_ACTIVE_LOW: the tamper pin is active low
- \param[out] none
- \retval none
- */
- void bkp_tamper_active_level_set(uint16_t level)
- {
- uint16_t ctl = 0U;
-
- ctl = BKP_TPCTL;
- ctl &= (uint16_t)~BKP_TPCTL_TPAL;
- ctl |= level;
- BKP_TPCTL = ctl;
- }
- /*!
- \brief enable tamper interrupt
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_tamper_interrupt_enable(void)
- {
- BKP_TPCS |= (uint16_t)BKP_TPCS_TPIE;
- }
- /*!
- \brief disable tamper interrupt
- \param[in] none
- \param[out] none
- \retval none
- */
- void bkp_tamper_interrupt_disable(void)
- {
- BKP_TPCS &= (uint16_t)~BKP_TPCS_TPIE;
- }
- /*!
- \brief get bkp flag state
- \param[in] flag
- \arg BKP_FLAG_TAMPER: tamper event flag
- \param[out] none
- \retval FlagStatus: SET or RESET
- */
- FlagStatus bkp_flag_get(uint16_t flag)
- {
- if(RESET != (BKP_TPCS & flag)){
- return SET;
- }else{
- return RESET;
- }
- }
- /*!
- \brief clear bkp flag state
- \param[in] flag
- \arg BKP_FLAG_TAMPER: tamper event flag
- \param[out] none
- \retval none
- */
- void bkp_flag_clear(uint16_t flag)
- {
- BKP_TPCS |= (uint16_t)(flag >> TAMPER_FLAG_SHIFT);
- }
- /*!
- \brief get bkp interrupt flag state
- \param[in] flag
- \arg BKP_INT_FLAG_TAMPER: tamper interrupt flag
- \param[out] none
- \retval FlagStatus: SET or RESET
- */
- FlagStatus bkp_interrupt_flag_get(uint16_t flag)
- {
- if(RESET != (BKP_TPCS & flag)){
- return SET;
- }else{
- return RESET;
- }
- }
- /*!
- \brief clear bkp interrupt flag state
- \param[in] flag
- \arg BKP_INT_FLAG_TAMPER: tamper interrupt flag
- \param[out] none
- \retval none
- */
- void bkp_interrupt_flag_clear(uint16_t flag)
- {
- BKP_TPCS |= (uint16_t)(flag >> TAMPER_FLAG_SHIFT);
- }
|