123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 |
- /*!
- \file gd32e23x_exti.h
- \brief definitions for the EXTI
-
- \version 2019-02-19, V1.0.0, firmware for GD32E23x
- \version 2020-12-12, V1.1.0, firmware for GD32E23x
- */
- /*
- 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.
- */
- #ifndef GD32E23X_EXTI_H
- #define GD32E23X_EXTI_H
- #include "gd32e23x.h"
- /* EXTI definitions */
- #define EXTI EXTI_BASE
- /* registers definitions */
- #define EXTI_INTEN REG32(EXTI + 0x00000000U) /*!< interrupt enable register */
- #define EXTI_EVEN REG32(EXTI + 0x00000004U) /*!< event enable register */
- #define EXTI_RTEN REG32(EXTI + 0x00000008U) /*!< rising edge trigger enable register */
- #define EXTI_FTEN REG32(EXTI + 0x0000000CU) /*!< falling trigger enable register */
- #define EXTI_SWIEV REG32(EXTI + 0x00000010U) /*!< software interrupt event register */
- #define EXTI_PD REG32(EXTI + 0x00000014U) /*!< pending register */
- /* bits definitions */
- /* EXTI_INTEN */
- #define EXTI_INTEN_INTEN0 BIT(0) /*!< interrupt from line 0 */
- #define EXTI_INTEN_INTEN1 BIT(1) /*!< interrupt from line 1 */
- #define EXTI_INTEN_INTEN2 BIT(2) /*!< interrupt from line 2 */
- #define EXTI_INTEN_INTEN3 BIT(3) /*!< interrupt from line 3 */
- #define EXTI_INTEN_INTEN4 BIT(4) /*!< interrupt from line 4 */
- #define EXTI_INTEN_INTEN5 BIT(5) /*!< interrupt from line 5 */
- #define EXTI_INTEN_INTEN6 BIT(6) /*!< interrupt from line 6 */
- #define EXTI_INTEN_INTEN7 BIT(7) /*!< interrupt from line 7 */
- #define EXTI_INTEN_INTEN8 BIT(8) /*!< interrupt from line 8 */
- #define EXTI_INTEN_INTEN9 BIT(9) /*!< interrupt from line 9 */
- #define EXTI_INTEN_INTEN10 BIT(10) /*!< interrupt from line 10 */
- #define EXTI_INTEN_INTEN11 BIT(11) /*!< interrupt from line 11 */
- #define EXTI_INTEN_INTEN12 BIT(12) /*!< interrupt from line 12 */
- #define EXTI_INTEN_INTEN13 BIT(13) /*!< interrupt from line 13 */
- #define EXTI_INTEN_INTEN14 BIT(14) /*!< interrupt from line 14 */
- #define EXTI_INTEN_INTEN15 BIT(15) /*!< interrupt from line 15 */
- #define EXTI_INTEN_INTEN16 BIT(16) /*!< interrupt from line 16 */
- #define EXTI_INTEN_INTEN17 BIT(17) /*!< interrupt from line 17 */
- #define EXTI_INTEN_INTEN18 BIT(18) /*!< interrupt from line 18 */
- #define EXTI_INTEN_INTEN19 BIT(19) /*!< interrupt from line 19 */
- #define EXTI_INTEN_INTEN20 BIT(20) /*!< interrupt from line 20 */
- #define EXTI_INTEN_INTEN21 BIT(21) /*!< interrupt from line 21 */
- #define EXTI_INTEN_INTEN22 BIT(22) /*!< interrupt from line 22 */
- #define EXTI_INTEN_INTEN23 BIT(23) /*!< interrupt from line 23 */
- #define EXTI_INTEN_INTEN24 BIT(24) /*!< interrupt from line 24 */
- #define EXTI_INTEN_INTEN25 BIT(25) /*!< interrupt from line 25 */
- #define EXTI_INTEN_INTEN26 BIT(26) /*!< interrupt from line 26 */
- #define EXTI_INTEN_INTEN27 BIT(27) /*!< interrupt from line 27 */
- /* EXTI_EVEN */
- #define EXTI_EVEN_EVEN0 BIT(0) /*!< event from line 0 */
- #define EXTI_EVEN_EVEN1 BIT(1) /*!< event from line 1 */
- #define EXTI_EVEN_EVEN2 BIT(2) /*!< event from line 2 */
- #define EXTI_EVEN_EVEN3 BIT(3) /*!< event from line 3 */
- #define EXTI_EVEN_EVEN4 BIT(4) /*!< event from line 4 */
- #define EXTI_EVEN_EVEN5 BIT(5) /*!< event from line 5 */
- #define EXTI_EVEN_EVEN6 BIT(6) /*!< event from line 6 */
- #define EXTI_EVEN_EVEN7 BIT(7) /*!< event from line 7 */
- #define EXTI_EVEN_EVEN8 BIT(8) /*!< event from line 8 */
- #define EXTI_EVEN_EVEN9 BIT(9) /*!< event from line 9 */
- #define EXTI_EVEN_EVEN10 BIT(10) /*!< event from line 10 */
- #define EXTI_EVEN_EVEN11 BIT(11) /*!< event from line 11 */
- #define EXTI_EVEN_EVEN12 BIT(12) /*!< event from line 12 */
- #define EXTI_EVEN_EVEN13 BIT(13) /*!< event from line 13 */
- #define EXTI_EVEN_EVEN14 BIT(14) /*!< event from line 14 */
- #define EXTI_EVEN_EVEN15 BIT(15) /*!< event from line 15 */
- #define EXTI_EVEN_EVEN16 BIT(16) /*!< event from line 16 */
- #define EXTI_EVEN_EVEN17 BIT(17) /*!< event from line 17 */
- #define EXTI_EVEN_EVEN18 BIT(18) /*!< event from line 18 */
- #define EXTI_EVEN_EVEN19 BIT(19) /*!< event from line 19 */
- #define EXTI_EVEN_EVEN20 BIT(20) /*!< event from line 20 */
- #define EXTI_EVEN_EVEN21 BIT(21) /*!< event from line 21 */
- #define EXTI_EVEN_EVEN22 BIT(22) /*!< event from line 22 */
- #define EXTI_EVEN_EVEN23 BIT(23) /*!< event from line 23 */
- #define EXTI_EVEN_EVEN24 BIT(24) /*!< event from line 24 */
- #define EXTI_EVEN_EVEN25 BIT(25) /*!< event from line 25 */
- #define EXTI_EVEN_EVEN26 BIT(26) /*!< event from line 26 */
- #define EXTI_EVEN_EVEN27 BIT(27) /*!< event from line 27 */
- /* EXTI_RTEN */
- #define EXTI_RTEN_RTEN0 BIT(0) /*!< rising edge from line 0 */
- #define EXTI_RTEN_RTEN1 BIT(1) /*!< rising edge from line 1 */
- #define EXTI_RTEN_RTEN2 BIT(2) /*!< rising edge from line 2 */
- #define EXTI_RTEN_RTEN3 BIT(3) /*!< rising edge from line 3 */
- #define EXTI_RTEN_RTEN4 BIT(4) /*!< rising edge from line 4 */
- #define EXTI_RTEN_RTEN5 BIT(5) /*!< rising edge from line 5 */
- #define EXTI_RTEN_RTEN6 BIT(6) /*!< rising edge from line 6 */
- #define EXTI_RTEN_RTEN7 BIT(7) /*!< rising edge from line 7 */
- #define EXTI_RTEN_RTEN8 BIT(8) /*!< rising edge from line 8 */
- #define EXTI_RTEN_RTEN9 BIT(9) /*!< rising edge from line 9 */
- #define EXTI_RTEN_RTEN10 BIT(10) /*!< rising edge from line 10 */
- #define EXTI_RTEN_RTEN11 BIT(11) /*!< rising edge from line 11 */
- #define EXTI_RTEN_RTEN12 BIT(12) /*!< rising edge from line 12 */
- #define EXTI_RTEN_RTEN13 BIT(13) /*!< rising edge from line 13 */
- #define EXTI_RTEN_RTEN14 BIT(14) /*!< rising edge from line 14 */
- #define EXTI_RTEN_RTEN15 BIT(15) /*!< rising edge from line 15 */
- #define EXTI_RTEN_RTEN16 BIT(16) /*!< rising edge from line 16 */
- #define EXTI_RTEN_RTEN17 BIT(17) /*!< rising edge from line 17 */
- #define EXTI_RTEN_RTEN19 BIT(19) /*!< rising edge from line 19 */
- #define EXTI_RTEN_RTEN21 BIT(21) /*!< rising edge from line 21 */
- /* EXTI_FTEN */
- #define EXTI_FTEN_FTEN0 BIT(0) /*!< falling edge from line 0 */
- #define EXTI_FTEN_FTEN1 BIT(1) /*!< falling edge from line 1 */
- #define EXTI_FTEN_FTEN2 BIT(2) /*!< falling edge from line 2 */
- #define EXTI_FTEN_FTEN3 BIT(3) /*!< falling edge from line 3 */
- #define EXTI_FTEN_FTEN4 BIT(4) /*!< falling edge from line 4 */
- #define EXTI_FTEN_FTEN5 BIT(5) /*!< falling edge from line 5 */
- #define EXTI_FTEN_FTEN6 BIT(6) /*!< falling edge from line 6 */
- #define EXTI_FTEN_FTEN7 BIT(7) /*!< falling edge from line 7 */
- #define EXTI_FTEN_FTEN8 BIT(8) /*!< falling edge from line 8 */
- #define EXTI_FTEN_FTEN9 BIT(9) /*!< falling edge from line 9 */
- #define EXTI_FTEN_FTEN10 BIT(10) /*!< falling edge from line 10 */
- #define EXTI_FTEN_FTEN11 BIT(11) /*!< falling edge from line 11 */
- #define EXTI_FTEN_FTEN12 BIT(12) /*!< falling edge from line 12 */
- #define EXTI_FTEN_FTEN13 BIT(13) /*!< falling edge from line 13 */
- #define EXTI_FTEN_FTEN14 BIT(14) /*!< falling edge from line 14 */
- #define EXTI_FTEN_FTEN15 BIT(15) /*!< falling edge from line 15 */
- #define EXTI_FTEN_FTEN16 BIT(16) /*!< falling edge from line 16 */
- #define EXTI_FTEN_FTEN17 BIT(17) /*!< falling edge from line 17 */
- #define EXTI_FTEN_FTEN19 BIT(19) /*!< falling edge from line 19 */
- #define EXTI_FTEN_FTEN21 BIT(21) /*!< falling edge from line 21 */
- /* EXTI_SWIEV */
- #define EXTI_SWIEV_SWIEV0 BIT(0) /*!< software interrupt/event request from line 0 */
- #define EXTI_SWIEV_SWIEV1 BIT(1) /*!< software interrupt/event request from line 1 */
- #define EXTI_SWIEV_SWIEV2 BIT(2) /*!< software interrupt/event request from line 2 */
- #define EXTI_SWIEV_SWIEV3 BIT(3) /*!< software interrupt/event request from line 3 */
- #define EXTI_SWIEV_SWIEV4 BIT(4) /*!< software interrupt/event request from line 4 */
- #define EXTI_SWIEV_SWIEV5 BIT(5) /*!< software interrupt/event request from line 5 */
- #define EXTI_SWIEV_SWIEV6 BIT(6) /*!< software interrupt/event request from line 6 */
- #define EXTI_SWIEV_SWIEV7 BIT(7) /*!< software interrupt/event request from line 7 */
- #define EXTI_SWIEV_SWIEV8 BIT(8) /*!< software interrupt/event request from line 8 */
- #define EXTI_SWIEV_SWIEV9 BIT(9) /*!< software interrupt/event request from line 9 */
- #define EXTI_SWIEV_SWIEV10 BIT(10) /*!< software interrupt/event request from line 10 */
- #define EXTI_SWIEV_SWIEV11 BIT(11) /*!< software interrupt/event request from line 11 */
- #define EXTI_SWIEV_SWIEV12 BIT(12) /*!< software interrupt/event request from line 12 */
- #define EXTI_SWIEV_SWIEV13 BIT(13) /*!< software interrupt/event request from line 13 */
- #define EXTI_SWIEV_SWIEV14 BIT(14) /*!< software interrupt/event request from line 14 */
- #define EXTI_SWIEV_SWIEV15 BIT(15) /*!< software interrupt/event request from line 15 */
- #define EXTI_SWIEV_SWIEV16 BIT(16) /*!< software interrupt/event request from line 16 */
- #define EXTI_SWIEV_SWIEV17 BIT(17) /*!< software interrupt/event request from line 17 */
- #define EXTI_SWIEV_SWIEV19 BIT(19) /*!< software interrupt/event request from line 19 */
- #define EXTI_SWIEV_SWIEV21 BIT(21) /*!< software interrupt/event request from line 21 */
- /* EXTI_PD */
- #define EXTI_PD_PD0 BIT(0) /*!< interrupt/event pending status from line 0 */
- #define EXTI_PD_PD1 BIT(1) /*!< interrupt/event pending status from line 1 */
- #define EXTI_PD_PD2 BIT(2) /*!< interrupt/event pending status from line 2 */
- #define EXTI_PD_PD3 BIT(3) /*!< interrupt/event pending status from line 3 */
- #define EXTI_PD_PD4 BIT(4) /*!< interrupt/event pending status from line 4 */
- #define EXTI_PD_PD5 BIT(5) /*!< interrupt/event pending status from line 5 */
- #define EXTI_PD_PD6 BIT(6) /*!< interrupt/event pending status from line 6 */
- #define EXTI_PD_PD7 BIT(7) /*!< interrupt/event pending status from line 7 */
- #define EXTI_PD_PD8 BIT(8) /*!< interrupt/event pending status from line 8 */
- #define EXTI_PD_PD9 BIT(9) /*!< interrupt/event pending status from line 9 */
- #define EXTI_PD_PD10 BIT(10) /*!< interrupt/event pending status from line 10 */
- #define EXTI_PD_PD11 BIT(11) /*!< interrupt/event pending status from line 11 */
- #define EXTI_PD_PD12 BIT(12) /*!< interrupt/event pending status from line 12 */
- #define EXTI_PD_PD13 BIT(13) /*!< interrupt/event pending status from line 13 */
- #define EXTI_PD_PD14 BIT(14) /*!< interrupt/event pending status from line 14 */
- #define EXTI_PD_PD15 BIT(15) /*!< interrupt/event pending status from line 15 */
- #define EXTI_PD_PD16 BIT(16) /*!< interrupt/event pending status from line 16 */
- #define EXTI_PD_PD17 BIT(17) /*!< interrupt/event pending status from line 17 */
- #define EXTI_PD_PD19 BIT(19) /*!< interrupt/event pending status from line 19 */
- #define EXTI_PD_PD21 BIT(21) /*!< interrupt/event pending status from line 21 */
- /* constants definitions */
- /* EXTI line number */
- typedef enum
- {
- EXTI_0 = BIT(0), /*!< EXTI line 0 */
- EXTI_1 = BIT(1), /*!< EXTI line 1 */
- EXTI_2 = BIT(2), /*!< EXTI line 2 */
- EXTI_3 = BIT(3), /*!< EXTI line 3 */
- EXTI_4 = BIT(4), /*!< EXTI line 4 */
- EXTI_5 = BIT(5), /*!< EXTI line 5 */
- EXTI_6 = BIT(6), /*!< EXTI line 6 */
- EXTI_7 = BIT(7), /*!< EXTI line 7 */
- EXTI_8 = BIT(8), /*!< EXTI line 8 */
- EXTI_9 = BIT(9), /*!< EXTI line 9 */
- EXTI_10 = BIT(10), /*!< EXTI line 10 */
- EXTI_11 = BIT(11), /*!< EXTI line 11 */
- EXTI_12 = BIT(12), /*!< EXTI line 12 */
- EXTI_13 = BIT(13), /*!< EXTI line 13 */
- EXTI_14 = BIT(14), /*!< EXTI line 14 */
- EXTI_15 = BIT(15), /*!< EXTI line 15 */
- EXTI_16 = BIT(16), /*!< EXTI line 16 */
- EXTI_17 = BIT(17), /*!< EXTI line 17 */
- EXTI_18 = BIT(18), /*!< EXTI line 18 */
- EXTI_19 = BIT(19), /*!< EXTI line 19 */
- EXTI_20 = BIT(20), /*!< EXTI line 20 */
- EXTI_21 = BIT(21), /*!< EXTI line 21 */
- EXTI_22 = BIT(22), /*!< EXTI line 22 */
- EXTI_23 = BIT(23), /*!< EXTI line 23 */
- EXTI_24 = BIT(24), /*!< EXTI line 24 */
- EXTI_25 = BIT(25), /*!< EXTI line 25 */
- EXTI_26 = BIT(26), /*!< EXTI line 26 */
- EXTI_27 = BIT(27), /*!< EXTI line 27 */
- }exti_line_enum;
- /* external interrupt and event */
- typedef enum
- {
- EXTI_INTERRUPT = 0, /*!< EXTI interrupt mode */
- EXTI_EVENT /*!< EXTI event mode */
- }exti_mode_enum;
- /* interrupt trigger mode */
- typedef enum
- {
- EXTI_TRIG_RISING = 0, /*!< EXTI rising edge trigger */
- EXTI_TRIG_FALLING, /*!< EXTI falling edge trigger */
- EXTI_TRIG_BOTH, /*!< EXTI rising and falling edge trigger */
- EXTI_TRIG_NONE /*!< without rising edge or falling edge trigger */
- }exti_trig_type_enum;
- /* function declarations */
- /* initialization functions */
- /* reset the value of all EXTI registers with initial values */
- void exti_deinit(void);
- /* initialize EXTI line x */
- void exti_init(exti_line_enum linex, exti_mode_enum mode, exti_trig_type_enum trig_type);
- /* enable functions */
- /* enable the interrupts from EXTI line x */
- void exti_interrupt_enable(exti_line_enum linex);
- /* disable the interrupts from EXTI line x */
- void exti_interrupt_disable(exti_line_enum linex);
- /* enable the events from EXTI line x */
- void exti_event_enable(exti_line_enum linex);
- /* disable the events from EXTI line x */
- void exti_event_disable(exti_line_enum linex);
- /* interrupt & flag functions */
- /* enable EXTI software interrupt event */
- void exti_software_interrupt_enable(exti_line_enum linex);
- /* disable EXTI software interrupt event */
- void exti_software_interrupt_disable(exti_line_enum linex);
- /* get EXTI line x pending flag */
- FlagStatus exti_flag_get(exti_line_enum linex);
- /* clear EXTI lines pending flag */
- void exti_flag_clear(exti_line_enum linex);
- /* get EXTI lines flag when the interrupt flag is set */
- FlagStatus exti_interrupt_flag_get(exti_line_enum linex);
- /* clear EXTI lines pending flag */
- void exti_interrupt_flag_clear(exti_line_enum linex);
- #endif /* GD32E23X_EXTI_H */
|