12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- /*!
- \file readme.txt
- \brief description of the TIMERs cascade synchro demo for gd32f30x
- \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.
- */
- This demo is based on the GD32307C-EVAL-V1.1 board, it shows how to synchronize
- TIMER peripherals in cascade mode.
-
- In this example three timers are used:
- 1/TIMER1 is configured as master timer:
- - PWM mode is used
- - The TIMER1 update event is used as trigger output
- 2/TIMER2 is slave for TIMER1 and master for TIMER0,
- - PWM mode is used
- - The ITI0(TIMER1) is used as input trigger
- - External clock mode is used,the counter counts on the rising edges of
- the selected trigger.
- - The TIMER2 update event is used as trigger output.
- 3/TIMER0 is slave for TIMER2,
- - PWM mode is used
- - The ITI1(TIMER2) is used as input trigger
- - External clock mode is used,the counter counts on the rising edges of
- the selected trigger.
-
- The TIMERxCLK is fixed to 168 MHz, the TIMER1 counter clock is :
- 120MHz/6000= 20 KHz.
- The master timer TIMER1 is running at TIMER1 frequency :
- TIMER1 frequency = (TIMER1 counter clock)/ (TIMER1 period + 1) = 5 Hz
- and the duty cycle = TIMER1_CH0CC/(TIMER1_CAR + 1) = 50%
- The TIMER2 is running:
- - At (TIMER1 frequency)/ (TIMER2 period + 1) = 2.5 Hz and a duty cycle
- equal to TIMER2_CH0CC/(TIMER2_CAR + 1) = 50%
- The TIMER0 is running:
- - At (TIMER2 frequency)/ (TIMER0 period + 1) = 1.25 Hz and a duty cycle
- equal to TIMER0_CH0CC/(TIMER0_CAR + 1) = 50%
-
|