123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376 |
- /*!
- \file gd32f4xx_tli.h
- \brief definitions for the TLI
- \version 2016-08-15, V1.0.0, firmware for GD32F4xx
- \version 2018-12-12, V2.0.0, firmware for GD32F4xx
- \version 2020-09-30, V2.1.0, firmware for GD32F4xx
- */
- /*
- 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 GD32F4XX_TLI_H
- #define GD32F4XX_TLI_H
- #include "gd32f4xx.h"
- /* TLI definitions */
- #define TLI TLI_BASE /*!< TLI base address */
- /* TLI layer definitions */
- #define LAYER0 TLI_BASE /*!< TLI layer0 base address */
- #define LAYER1 (TLI_BASE+0x80) /*!< TLI layer1 base address */
- /* registers definitions */
- #define TLI_SPSZ REG32(TLI + 0x08U) /*!< TLI synchronous pulse size register */
- #define TLI_BPSZ REG32(TLI + 0x0CU) /*!< TLI back-porch size register */
- #define TLI_ASZ REG32(TLI + 0x10U) /*!< TLI active size register */
- #define TLI_TSZ REG32(TLI + 0x14U) /*!< TLI total size register */
- #define TLI_CTL REG32(TLI + 0x18U) /*!< TLI control register */
- #define TLI_RL REG32(TLI + 0x24U) /*!< TLI reload Layer register */
- #define TLI_BGC REG32(TLI + 0x2CU) /*!< TLI background color register */
- #define TLI_INTEN REG32(TLI + 0x34U) /*!< TLI interrupt enable register */
- #define TLI_INTF REG32(TLI + 0x38U) /*!< TLI interrupt flag register */
- #define TLI_INTC REG32(TLI + 0x3CU) /*!< TLI interrupt flag clear register */
- #define TLI_LM REG32(TLI + 0x40U) /*!< TLI line mark register */
- #define TLI_CPPOS REG32(TLI + 0x44U) /*!< TLI current pixel position register */
- #define TLI_STAT REG32(TLI + 0x48U) /*!< TLI status register */
- #define TLI_LxCTL(layerx) REG32((layerx) + 0x84U) /*!< TLI layer x control register */
- #define TLI_LxHPOS(layerx) REG32((layerx) + 0x88U) /*!< TLI layer x horizontal position parameters register */
- #define TLI_LxVPOS(layerx) REG32((layerx) + 0x8CU) /*!< TLI layer x vertical position parameters register */
- #define TLI_LxCKEY(layerx) REG32((layerx) + 0x90U) /*!< TLI layer x color key register */
- #define TLI_LxPPF(layerx) REG32((layerx) + 0x94U) /*!< TLI layer x packeted pixel format register */
- #define TLI_LxSA(layerx) REG32((layerx) + 0x98U) /*!< TLI layer x specified alpha register */
- #define TLI_LxDC(layerx) REG32((layerx) + 0x9CU) /*!< TLI layer x default color register */
- #define TLI_LxBLEND(layerx) REG32((layerx) + 0xA0U) /*!< TLI layer x blending register */
- #define TLI_LxFBADDR(layerx) REG32((layerx) + 0xACU) /*!< TLI layer x frame base address register */
- #define TLI_LxFLLEN(layerx) REG32((layerx) + 0xB0U) /*!< TLI layer x frame line length register */
- #define TLI_LxFTLN(layerx) REG32((layerx) + 0xB4U) /*!< TLI layer x frame total line number register */
- #define TLI_LxLUT(layerx) REG32((layerx) + 0xC4U) /*!< TLI layer x look up table register */
- /* bits definitions */
- /* TLI_SPSZ */
- #define TLI_SPSZ_VPSZ BITS(0,11) /*!< size of the vertical synchronous pulse */
- #define TLI_SPSZ_HPSZ BITS(16,27) /*!< size of the horizontal synchronous pulse */
- /* TLI_BPSZ */
- #define TLI_BPSZ_VBPSZ BITS(0,11) /*!< size of the vertical back porch plus synchronous pulse */
- #define TLI_BPSZ_HBPSZ BITS(16,27) /*!< size of the horizontal back porch plus synchronous pulse */
- /* TLI_ASZ */
- #define TLI_ASZ_VASZ BITS(0,11) /*!< size of the vertical active area width plus back porch and synchronous pulse */
- #define TLI_ASZ_HASZ BITS(16,27) /*!< size of the horizontal active area width plus back porch and synchronous pulse */
- /* TLI_SPSZ */
- #define TLI_TSZ_VTSZ BITS(0,11) /*!< vertical total size of the display, including active area, back porch, synchronous pulse and front porch */
- #define TLI_TSZ_HTSZ BITS(16,27) /*!< horizontal total size of the display, including active area, back porch, synchronous pulse and front porch */
- /* TLI_CTL */
- #define TLI_CTL_TLIEN BIT(0) /*!< TLI enable bit */
- #define TLI_CTL_BDB BITS(4,6) /*!< blue channel dither bits number */
- #define TLI_CTL_GDB BITS(8,10) /*!< green channel dither bits number */
- #define TLI_CTL_RDB BITS(12,14) /*!< red channel dither bits number */
- #define TLI_CTL_DFEN BIT(16) /*!< dither function enable */
- #define TLI_CTL_CLKPS BIT(28) /*!< pixel clock polarity selection */
- #define TLI_CTL_DEPS BIT(29) /*!< data enable polarity selection */
- #define TLI_CTL_VPPS BIT(30) /*!< vertical pulse polarity selection */
- #define TLI_CTL_HPPS BIT(31) /*!< horizontal pulse polarity selection */
- /* TLI_RL */
- #define TLI_RL_RQR BIT(0) /*!< request reload */
- #define TLI_RL_FBR BIT(1) /*!< frame blank reload */
- /* TLI_BGC */
- #define TLI_BGC_BVB BITS(0,7) /*!< background value blue */
- #define TLI_BGC_BVG BITS(8,15) /*!< background value green */
- #define TLI_BGC_BVR BITS(16,23) /*!< background value red */
- /* TLI_INTEN */
- #define TLI_INTEN_LMIE BIT(0) /*!< line mark interrupt enable */
- #define TLI_INTEN_FEIE BIT(1) /*!< FIFO error interrupt enable */
- #define TLI_INTEN_TEIE BIT(2) /*!< transaction error interrupt enable */
- #define TLI_INTEN_LCRIE BIT(3) /*!< layer configuration reloaded interrupt enable */
- /* TLI_INTF */
- #define TLI_INTF_LMF BIT(0) /*!< line mark flag */
- #define TLI_INTF_FEF BIT(1) /*!< FIFO error flag */
- #define TLI_INTF_TEF BIT(2) /*!< transaction error flag */
- #define TLI_INTF_LCRF BIT(3) /*!< layer configuration reloaded flag */
- /* TLI_INTC */
- #define TLI_INTC_LMC BIT(0) /*!< line mark flag clear */
- #define TLI_INTC_FEC BIT(1) /*!< FIFO error flag clear */
- #define TLI_INTC_TEC BIT(2) /*!< transaction error flag clear */
- #define TLI_INTC_LCRC BIT(3) /*!< layer configuration reloaded flag clear */
- /* TLI_LM */
- #define TLI_LM_LM BITS(0,10) /*!< line mark value */
- /* TLI_CPPOS */
- #define TLI_CPPOS_VPOS BITS(0,15) /*!< vertical position */
- #define TLI_CPPOS_HPOS BITS(16,31) /*!< horizontal position */
- /* TLI_STAT */
- #define TLI_STAT_VDE BIT(0) /*!< current VDE status */
- #define TLI_STAT_HDE BIT(1) /*!< current HDE status */
- #define TLI_STAT_VS BIT(2) /*!< current VS status of the TLI */
- #define TLI_STAT_HS BIT(3) /*!< current HS status of the TLI */
- /* TLI_LxCTL */
- #define TLI_LxCTL_LEN BIT(0) /*!< layer enable */
- #define TLI_LxCTL_CKEYEN BIT(1) /*!< color keying enable */
- #define TLI_LxCTL_LUTEN BIT(4) /*!< LUT enable */
- /* TLI_LxHPOS */
- #define TLI_LxHPOS_WLP BITS(0,11) /*!< window left position */
- #define TLI_LxHPOS_WRP BITS(16,27) /*!< window right position */
- /* TLI_LxVPOS */
- #define TLI_LxVPOS_WTP BITS(0,11) /*!< window top position */
- #define TLI_LxVPOS_WBP BITS(16,27) /*!< window bottom position */
- /* TLI_LxCKEY */
- #define TLI_LxCKEY_CKEYB BITS(0,7) /*!< color key blue */
- #define TLI_LxCKEY_CKEYG BITS(8,15) /*!< color key green */
- #define TLI_LxCKEY_CKEYR BITS(16,23) /*!< color key red */
- /* TLI_LxPPF */
- #define TLI_LxPPF_PPF BITS(0,2) /*!< packeted pixel format */
- /* TLI_LxSA */
- #define TLI_LxSA_SA BITS(0,7) /*!< specified alpha */
- /* TLI_LxDC */
- #define TLI_LxDC_DCB BITS(0,7) /*!< the default color blue */
- #define TLI_LxDC_DCG BITS(8,15) /*!< the default color green */
- #define TLI_LxDC_DCR BITS(16,23) /*!< the default color red */
- #define TLI_LxDC_DCA BITS(24,31) /*!< the default color alpha */
- /* TLI_LxBLEND */
- #define TLI_LxBLEND_ACF2 BITS(0,2) /*!< alpha calculation factor 2 of blending method */
- #define TLI_LxBLEND_ACF1 BITS(8,10) /*!< alpha calculation factor 1 of blending method */
- /* TLI_LxFBADDR */
- #define TLI_LxFBADDR_FBADD BITS(0,31) /*!< frame buffer base address */
- /* TLI_LxFLLEN */
- #define TLI_LxFLLEN_FLL BITS(0,13) /*!< frame line length */
- #define TLI_LxFLLEN_STDOFF BITS(16,29) /*!< frame buffer stride offset */
- /* TLI_LxFTLN */
- #define TLI_LxFTLN_FTLN BITS(0,10) /*!< frame total line number */
- /* TLI_LxLUT */
- #define TLI_LxLUT_TB BITS(0,7) /*!< blue channel of a LUT entry */
- #define TLI_LxLUT_TG BITS(8,15) /*!< green channel of a LUT entry */
- #define TLI_LxLUT_TR BITS(16,23) /*!< red channel of a LUT entry */
- #define TLI_LxLUT_TADD BITS(24,31) /*!< look up table write address */
- /* constants definitions */
- /* TLI parameter struct definitions */
- typedef struct
- {
- uint16_t synpsz_vpsz; /*!< size of the vertical synchronous pulse */
- uint16_t synpsz_hpsz; /*!< size of the horizontal synchronous pulse */
- uint16_t backpsz_vbpsz; /*!< size of the vertical back porch plus synchronous pulse */
- uint16_t backpsz_hbpsz; /*!< size of the horizontal back porch plus synchronous pulse */
- uint32_t activesz_vasz; /*!< size of the vertical active area width plus back porch and synchronous pulse */
- uint32_t activesz_hasz; /*!< size of the horizontal active area width plus back porch and synchronous pulse */
- uint32_t totalsz_vtsz; /*!< vertical total size of the display */
- uint32_t totalsz_htsz; /*!< horizontal total size of the display */
- uint32_t backcolor_red; /*!< background value red */
- uint32_t backcolor_green; /*!< background value green */
- uint32_t backcolor_blue; /*!< background value blue */
- uint32_t signalpolarity_hs; /*!< horizontal pulse polarity selection */
- uint32_t signalpolarity_vs; /*!< vertical pulse polarity selection */
- uint32_t signalpolarity_de; /*!< data enable polarity selection */
- uint32_t signalpolarity_pixelck; /*!< pixel clock polarity selection */
- }tli_parameter_struct;
- /* TLI layer parameter struct definitions */
- typedef struct
- {
- uint16_t layer_window_rightpos; /*!< window right position */
- uint16_t layer_window_leftpos; /*!< window left position */
- uint16_t layer_window_bottompos; /*!< window bottom position */
- uint16_t layer_window_toppos; /*!< window top position */
- uint32_t layer_ppf; /*!< packeted pixel format */
- uint8_t layer_sa; /*!< specified alpha */
- uint8_t layer_default_alpha; /*!< the default color alpha */
- uint8_t layer_default_red; /*!< the default color red */
- uint8_t layer_default_green; /*!< the default color green */
- uint8_t layer_default_blue; /*!< the default color blue */
- uint32_t layer_acf1; /*!< alpha calculation factor 1 of blending method */
- uint32_t layer_acf2; /*!< alpha calculation factor 2 of blending method */
- uint32_t layer_frame_bufaddr; /*!< frame buffer base address */
- uint16_t layer_frame_buf_stride_offset; /*!< frame buffer stride offset */
- uint16_t layer_frame_line_length; /*!< frame line length */
- uint16_t layer_frame_total_line_number; /*!< frame total line number */
- }tli_layer_parameter_struct;
- /* TLI layer LUT parameter struct definitions */
- typedef struct
- {
- uint32_t layer_table_addr; /*!< look up table write address */
- uint8_t layer_lut_channel_red; /*!< red channel of a LUT entry */
- uint8_t layer_lut_channel_green; /*!< green channel of a LUT entry */
- uint8_t layer_lut_channel_blue; /*!< blue channel of a LUT entry */
- }tli_layer_lut_parameter_struct;
- /* packeted pixel format */
- typedef enum
- {
- LAYER_PPF_ARGB8888, /*!< layerx pixel format ARGB8888 */
- LAYER_PPF_RGB888, /*!< layerx pixel format RGB888 */
- LAYER_PPF_RGB565, /*!< layerx pixel format RGB565 */
- LAYER_PPF_ARGB1555, /*!< layerx pixel format ARGB1555 */
- LAYER_PPF_ARGB4444, /*!< layerx pixel format ARGB4444 */
- LAYER_PPF_L8, /*!< layerx pixel format L8 */
- LAYER_PPF_AL44, /*!< layerx pixel format AL44 */
- LAYER_PPF_AL88 /*!< layerx pixel format AL88 */
- }tli_layer_ppf_enum;
- /* TLI flags */
- #define TLI_FLAG_VDE TLI_STAT_VDE /*!< current VDE status */
- #define TLI_FLAG_HDE TLI_STAT_HDE /*!< current HDE status */
- #define TLI_FLAG_VS TLI_STAT_VS /*!< current VS status of the TLI */
- #define TLI_FLAG_HS TLI_STAT_HS /*!< current HS status of the TLI */
- #define TLI_FLAG_LM BIT(0) | BIT(31) /*!< line mark interrupt flag */
- #define TLI_FLAG_FE BIT(1) | BIT(31) /*!< FIFO error interrupt flag */
- #define TLI_FLAG_TE BIT(2) | BIT(31) /*!< transaction error interrupt flag */
- #define TLI_FLAG_LCR BIT(3) | BIT(31) /*!< layer configuration reloaded interrupt flag */
- /* TLI interrupt enable or disable */
- #define TLI_INT_LM BIT(0) /*!< line mark interrupt */
- #define TLI_INT_FE BIT(1) /*!< FIFO error interrupt */
- #define TLI_INT_TE BIT(2) /*!< transaction error interrupt */
- #define TLI_INT_LCR BIT(3) /*!< layer configuration reloaded interrupt */
- /* TLI interrupt flag */
- #define TLI_INT_FLAG_LM BIT(0) /*!< line mark interrupt flag */
- #define TLI_INT_FLAG_FE BIT(1) /*!< FIFO error interrupt flag */
- #define TLI_INT_FLAG_TE BIT(2) /*!< transaction error interrupt flag */
- #define TLI_INT_FLAG_LCR BIT(3) /*!< layer configuration reloaded interrupt flag */
- /* layer reload configure */
- #define TLI_FRAME_BLANK_RELOAD_EN ((uint8_t)0x00U) /*!< the layer configuration will be reloaded at frame blank */
- #define TLI_REQUEST_RELOAD_EN ((uint8_t)0x01U) /*!< the layer configuration will be reloaded after this bit sets */
- /* dither function */
- #define TLI_DITHER_DISABLE ((uint8_t)0x00U) /*!< dither function disable */
- #define TLI_DITHER_ENABLE ((uint8_t)0x01U) /*!< dither function enable */
- /* horizontal pulse polarity selection */
- #define TLI_HSYN_ACTLIVE_LOW ((uint32_t)0x00000000U) /*!< horizontal synchronous pulse active low */
- #define TLI_HSYN_ACTLIVE_HIGHT TLI_CTL_HPPS /*!< horizontal synchronous pulse active high */
- /* vertical pulse polarity selection */
- #define TLI_VSYN_ACTLIVE_LOW ((uint32_t)0x00000000U) /*!< vertical synchronous pulse active low */
- #define TLI_VSYN_ACTLIVE_HIGHT TLI_CTL_VPPS /*!< vertical synchronous pulse active high */
- /* pixel clock polarity selection */
- #define TLI_PIXEL_CLOCK_TLI ((uint32_t)0x00000000U) /*!< pixel clock is TLI clock */
- #define TLI_PIXEL_CLOCK_INVERTEDTLI TLI_CTL_CLKPS /*!< pixel clock is inverted TLI clock */
- /* data enable polarity selection */
- #define TLI_DE_ACTLIVE_LOW ((uint32_t)0x00000000U) /*!< data enable active low */
- #define TLI_DE_ACTLIVE_HIGHT TLI_CTL_DEPS /*!< data enable active high */
- /* alpha calculation factor 1 of blending method */
- #define LxBLEND_ACF1(regval) (BITS(8,10) & ((uint32_t)(regval)<<8))
- #define LAYER_ACF1_SA LxBLEND_ACF1(4) /*!< normalization specified alpha */
- #define LAYER_ACF1_PASA LxBLEND_ACF1(6) /*!< normalization pixel alpha * normalization specified alpha */
- /* alpha calculation factor 2 of blending method */
- #define LxBLEND_ACF2(regval) (BITS(0,2) & ((uint32_t)(regval)))
- #define LAYER_ACF2_SA LxBLEND_ACF2(5) /*!< normalization specified alpha */
- #define LAYER_ACF2_PASA LxBLEND_ACF2(7) /*!< normalization pixel alpha * normalization specified alpha */
- /* function declarations */
- /* initialization functions, TLI enable or disable, TLI reload mode configuration */
- /* deinitialize TLI registers */
- void tli_deinit(void);
- /* initialize the parameters of TLI parameter structure with the default values, it is suggested
- that call this function after a tli_parameter_struct structure is defined */
- void tli_struct_para_init(tli_parameter_struct *tli_struct);
- /* initialize TLI */
- void tli_init(tli_parameter_struct *tli_struct);
- /* configure TLI dither function */
- void tli_dither_config(uint8_t dither_stat);
- /* enable TLI */
- void tli_enable(void);
- /* disable TLI */
- void tli_disable(void);
- /* configurate TLI reload mode */
- void tli_reload_config(uint8_t reload_mod);
- /* TLI layer configuration functions */
- /* initialize the parameters of TLI layer structure with the default values, it is suggested
- that call this function after a tli_layer_parameter_struct structure is defined */
- void tli_layer_struct_para_init(tli_layer_parameter_struct *layer_struct);
- /* initialize TLI layer */
- void tli_layer_init(uint32_t layerx,tli_layer_parameter_struct *layer_struct);
- /* reconfigure window position */
- void tli_layer_window_offset_modify(uint32_t layerx,uint16_t offset_x,uint16_t offset_y);
- /* initialize the parameters of TLI layer LUT structure with the default values, it is suggested
- that call this function after a tli_layer_lut_parameter_struct structure is defined */
- void tli_lut_struct_para_init(tli_layer_lut_parameter_struct *lut_struct);
- /* initialize TLI layer LUT */
- void tli_lut_init(uint32_t layerx,tli_layer_lut_parameter_struct *lut_struct);
- /* initialize TLI layer color key */
- void tli_color_key_init(uint32_t layerx,uint8_t redkey,uint8_t greenkey,uint8_t bluekey);
- /* enable TLI layer */
- void tli_layer_enable(uint32_t layerx);
- /* disable TLI layer */
- void tli_layer_disable(uint32_t layerx);
- /* enable TLI layer color keying */
- void tli_color_key_enable(uint32_t layerx);
- /* disable TLI layer color keying */
- void tli_color_key_disable(uint32_t layerx);
- /* enable TLI layer LUT */
- void tli_lut_enable(uint32_t layerx);
- /* disable TLI layer LUT */
- void tli_lut_disable(uint32_t layerx);
- /* set line mark value */
- void tli_line_mark_set(uint16_t line_num);
- /* get current displayed position */
- uint32_t tli_current_pos_get(void);
- /* flag and interrupt functions */
- /* enable TLI interrupt */
- void tli_interrupt_enable(uint32_t int_flag);
- /* disable TLI interrupt */
- void tli_interrupt_disable(uint32_t int_flag);
- /* get TLI interrupt flag */
- FlagStatus tli_interrupt_flag_get(uint32_t int_flag);
- /* clear TLI interrupt flag */
- void tli_interrupt_flag_clear(uint32_t int_flag);
- /* get TLI flag or state in TLI_INTF register or TLI_STAT register */
- FlagStatus tli_flag_get(uint32_t flag);
- #endif /* GD32F4XX_TLI_H */
|