/*! ******************************************************************************* ** ** \file gh_uart1.h ** ** \brief UART1. ** ** Copyright: 2012 - 2013 (C) GoKe Microelectronics ShangHai Branch ** ** \attention THIS SAMPLE CODE IS PROVIDED AS IS. GOKE MICROELECTRONICS ** ACCEPTS NO RESPONSIBILITY OR LIABILITY FOR ANY ERRORS OR ** OMMISSIONS. ** ** \note Do not modify this file as it is generated automatically. ** ******************************************************************************/ #ifndef _GH_UART1_H #define _GH_UART1_H #ifdef __LINUX__ #include "reg4linux.h" #else #define FIO_ADDRESS(block,address) (address) #define FIO_MOFFSET(block,moffset) (moffset) #endif #ifndef __LINUX__ #include "gtypes.h" /* global type definitions */ #include "gh_lib_cfg.h" /* configuration */ #endif #define GH_UART1_ENABLE_DEBUG_PRINT 0 #ifdef __LINUX__ #define GH_UART1_DEBUG_PRINT_FUNCTION printk #else #define GH_UART1_DEBUG_PRINT_FUNCTION printf #endif #ifndef __LINUX__ #if GH_UART1_ENABLE_DEBUG_PRINT #include #endif #endif /* check configuration */ #ifndef GH_INLINE_LEVEL #error "GH_INLINE_LEVEL is not defined!" #endif #if GH_INLINE_LEVEL > 2 #error "GH_INLINE_LEVEL must be set 0, 1 or 2!" #endif #ifndef GH_INLINE #error "GH_INLINE is not defined!" #endif /* disable inlining for debugging */ #ifdef DEBUG #undef GH_INLINE_LEVEL #define GH_INLINE_LEVEL 0 #endif /*----------------------------------------------------------------------------*/ /* registers */ /*----------------------------------------------------------------------------*/ #define REG_UART1_RBR FIO_ADDRESS(UART1,0xA001F000) /* read */ #define REG_UART1_THR FIO_ADDRESS(UART1,0xA001F000) /* write */ #define REG_UART1_DLL FIO_ADDRESS(UART1,0xA001F000) /* read/write */ #define REG_UART1_IER FIO_ADDRESS(UART1,0xA001F004) /* read/write */ #define REG_UART1_DLH FIO_ADDRESS(UART1,0xA001F004) /* read/write */ #define REG_UART1_IIR FIO_ADDRESS(UART1,0xA001F008) /* read */ #define REG_UART1_FCR FIO_ADDRESS(UART1,0xA001F008) /* write */ #define REG_UART1_LCR FIO_ADDRESS(UART1,0xA001F00C) /* read/write */ #define REG_UART1_MCR FIO_ADDRESS(UART1,0xA001F010) /* read/write */ #define REG_UART1_LSR FIO_ADDRESS(UART1,0xA001F014) /* read */ #define REG_UART1_MSR FIO_ADDRESS(UART1,0xA001F018) /* read */ #define REG_UART1_SCR FIO_ADDRESS(UART1,0xA001F01C) /* read/write */ /*----------------------------------------------------------------------------*/ /* bit group structures */ /*----------------------------------------------------------------------------*/ typedef union { /* UART1_RBR */ U32 all; struct { U32 data : 8; U32 : 24; } bitc; } GH_UART1_RBR_S; typedef union { /* UART1_THR */ U32 all; struct { U32 data : 8; U32 : 24; } bitc; } GH_UART1_THR_S; typedef union { /* UART1_DLL */ U32 all; struct { U32 bauddivint_l : 8; U32 : 24; } bitc; } GH_UART1_DLL_S; typedef union { /* UART1_IER */ U32 all; struct { U32 erbfi : 1; U32 etbei : 1; U32 elsi : 1; U32 edssi : 1; U32 : 28; } bitc; } GH_UART1_IER_S; typedef union { /* UART1_DLH */ U32 all; struct { U32 bauddivint_h : 8; U32 : 24; } bitc; } GH_UART1_DLH_S; typedef union { /* UART1_IIR */ U32 all; struct { U32 interrupt_id : 4; U32 : 2; U32 fifos_enabled : 2; U32 : 24; } bitc; } GH_UART1_IIR_S; typedef union { /* UART1_FCR */ U32 all; struct { U32 fifo_enable : 1; U32 rcvr_fifo_reset : 1; U32 xmit_fifo_reset : 1; U32 dma_mode : 1; U32 tx_empty_trigger : 2; U32 rcvr_trigger : 2; U32 : 24; } bitc; } GH_UART1_FCR_S; typedef union { /* UART1_LCR */ U32 all; struct { U32 cls : 2; U32 stop : 1; U32 pen : 1; U32 eps : 1; U32 sticky_parity : 1; U32 breaks : 1; U32 dlab : 1; U32 : 24; } bitc; } GH_UART1_LCR_S; typedef union { /* UART1_MCR */ U32 all; struct { U32 dtr : 1; U32 rts : 1; U32 out1 : 1; U32 out2 : 1; U32 loopback : 1; U32 afce : 1; U32 sire : 1; U32 : 25; } bitc; } GH_UART1_MCR_S; typedef union { /* UART1_LSR */ U32 all; struct { U32 dr : 1; U32 oe : 1; U32 pe : 1; U32 fe : 1; U32 bi : 1; U32 : 1; U32 temt : 1; U32 : 25; } bitc; } GH_UART1_LSR_S; typedef union { /* UART1_MSR */ U32 all; struct { U32 dcts : 1; U32 ddsr : 1; U32 teri : 1; U32 ddcd : 1; U32 cts : 1; U32 dsr : 1; U32 ri : 1; U32 dcd : 1; U32 : 24; } bitc; } GH_UART1_MSR_S; typedef union { /* UART1_SCR */ U32 all; struct { U32 scr : 8; U32 : 24; } bitc; } GH_UART1_SCR_S; /*----------------------------------------------------------------------------*/ /* mirror variables */ /*----------------------------------------------------------------------------*/ extern GH_UART1_THR_S m_uart1_thr; extern GH_UART1_FCR_S m_uart1_fcr; #ifdef __cplusplus extern "C" { #endif /*----------------------------------------------------------------------------*/ /* register UART1_RBR (read) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Reads the register 'UART1_RBR'. */ U32 GH_UART1_get_RBR(void); /*! \brief Reads the bit group 'Data' of register 'UART1_RBR'. */ U8 GH_UART1_get_RBR_Data(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE U32 GH_UART1_get_RBR(void) { U32 value = (*(volatile U32 *)REG_UART1_RBR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_RBR] --> 0x%08x\n", REG_UART1_RBR,value); #endif return value; } GH_INLINE U8 GH_UART1_get_RBR_Data(void) { GH_UART1_RBR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_RBR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_RBR_Data] --> 0x%08x\n", REG_UART1_RBR,value); #endif return tmp_value.bitc.data; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_THR (write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL < 2 /*! \brief Writes the register 'UART1_THR'. */ void GH_UART1_set_THR(U32 data); /*! \brief Reads the mirror variable of the register 'UART1_THR'. */ U32 GH_UART1_getm_THR(void); /*! \brief Writes the bit group 'Data' of register 'UART1_THR'. */ void GH_UART1_set_THR_Data(U8 data); /*! \brief Reads the bit group 'Data' from the mirror variable of register 'UART1_THR'. */ U8 GH_UART1_getm_THR_Data(void); #else /* GH_INLINE_LEVEL < 2 */ GH_INLINE void GH_UART1_set_THR(U32 data) { m_uart1_thr.all = data; *(volatile U32 *)REG_UART1_THR = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_THR] <-- 0x%08x\n", REG_UART1_THR,data,data); #endif } GH_INLINE U32 GH_UART1_getm_THR(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_THR] --> 0x%08x\n", m_uart1_thr.all); #endif return m_uart1_thr.all; } GH_INLINE void GH_UART1_set_THR_Data(U8 data) { m_uart1_thr.bitc.data = data; *(volatile U32 *)REG_UART1_THR = m_uart1_thr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_THR_Data] <-- 0x%08x\n", REG_UART1_THR,m_uart1_thr.all,m_uart1_thr.all); #endif } GH_INLINE U8 GH_UART1_getm_THR_Data(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_THR_Data] --> 0x%08x\n", m_uart1_thr.bitc.data); #endif return m_uart1_thr.bitc.data; } #endif /* GH_INLINE_LEVEL < 2 */ /*----------------------------------------------------------------------------*/ /* register UART1_DLL (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_DLL'. */ void GH_UART1_set_DLL(U32 data); /*! \brief Reads the register 'UART1_DLL'. */ U32 GH_UART1_get_DLL(void); /*! \brief Writes the bit group 'BaudDivint_L' of register 'UART1_DLL'. */ void GH_UART1_set_DLL_BaudDivint_L(U8 data); /*! \brief Reads the bit group 'BaudDivint_L' of register 'UART1_DLL'. */ U8 GH_UART1_get_DLL_BaudDivint_L(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_DLL(U32 data) { *(volatile U32 *)REG_UART1_DLL = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_DLL] <-- 0x%08x\n", REG_UART1_DLL,data,data); #endif } GH_INLINE U32 GH_UART1_get_DLL(void) { U32 value = (*(volatile U32 *)REG_UART1_DLL); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_DLL] --> 0x%08x\n", REG_UART1_DLL,value); #endif return value; } GH_INLINE void GH_UART1_set_DLL_BaudDivint_L(U8 data) { GH_UART1_DLL_S d; d.all = *(volatile U32 *)REG_UART1_DLL; d.bitc.bauddivint_l = data; *(volatile U32 *)REG_UART1_DLL = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_DLL_BaudDivint_L] <-- 0x%08x\n", REG_UART1_DLL,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_DLL_BaudDivint_L(void) { GH_UART1_DLL_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_DLL); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_DLL_BaudDivint_L] --> 0x%08x\n", REG_UART1_DLL,value); #endif return tmp_value.bitc.bauddivint_l; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_IER (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_IER'. */ void GH_UART1_set_IER(U32 data); /*! \brief Reads the register 'UART1_IER'. */ U32 GH_UART1_get_IER(void); /*! \brief Writes the bit group 'erbfi' of register 'UART1_IER'. */ void GH_UART1_set_IER_erbfi(U8 data); /*! \brief Reads the bit group 'erbfi' of register 'UART1_IER'. */ U8 GH_UART1_get_IER_erbfi(void); /*! \brief Writes the bit group 'etbei' of register 'UART1_IER'. */ void GH_UART1_set_IER_etbei(U8 data); /*! \brief Reads the bit group 'etbei' of register 'UART1_IER'. */ U8 GH_UART1_get_IER_etbei(void); /*! \brief Writes the bit group 'elsi' of register 'UART1_IER'. */ void GH_UART1_set_IER_elsi(U8 data); /*! \brief Reads the bit group 'elsi' of register 'UART1_IER'. */ U8 GH_UART1_get_IER_elsi(void); /*! \brief Writes the bit group 'edssi' of register 'UART1_IER'. */ void GH_UART1_set_IER_edssi(U8 data); /*! \brief Reads the bit group 'edssi' of register 'UART1_IER'. */ U8 GH_UART1_get_IER_edssi(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_IER(U32 data) { *(volatile U32 *)REG_UART1_IER = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_IER] <-- 0x%08x\n", REG_UART1_IER,data,data); #endif } GH_INLINE U32 GH_UART1_get_IER(void) { U32 value = (*(volatile U32 *)REG_UART1_IER); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IER] --> 0x%08x\n", REG_UART1_IER,value); #endif return value; } GH_INLINE void GH_UART1_set_IER_erbfi(U8 data) { GH_UART1_IER_S d; d.all = *(volatile U32 *)REG_UART1_IER; d.bitc.erbfi = data; *(volatile U32 *)REG_UART1_IER = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_IER_erbfi] <-- 0x%08x\n", REG_UART1_IER,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_IER_erbfi(void) { GH_UART1_IER_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IER); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IER_erbfi] --> 0x%08x\n", REG_UART1_IER,value); #endif return tmp_value.bitc.erbfi; } GH_INLINE void GH_UART1_set_IER_etbei(U8 data) { GH_UART1_IER_S d; d.all = *(volatile U32 *)REG_UART1_IER; d.bitc.etbei = data; *(volatile U32 *)REG_UART1_IER = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_IER_etbei] <-- 0x%08x\n", REG_UART1_IER,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_IER_etbei(void) { GH_UART1_IER_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IER); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IER_etbei] --> 0x%08x\n", REG_UART1_IER,value); #endif return tmp_value.bitc.etbei; } GH_INLINE void GH_UART1_set_IER_elsi(U8 data) { GH_UART1_IER_S d; d.all = *(volatile U32 *)REG_UART1_IER; d.bitc.elsi = data; *(volatile U32 *)REG_UART1_IER = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_IER_elsi] <-- 0x%08x\n", REG_UART1_IER,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_IER_elsi(void) { GH_UART1_IER_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IER); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IER_elsi] --> 0x%08x\n", REG_UART1_IER,value); #endif return tmp_value.bitc.elsi; } GH_INLINE void GH_UART1_set_IER_edssi(U8 data) { GH_UART1_IER_S d; d.all = *(volatile U32 *)REG_UART1_IER; d.bitc.edssi = data; *(volatile U32 *)REG_UART1_IER = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_IER_edssi] <-- 0x%08x\n", REG_UART1_IER,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_IER_edssi(void) { GH_UART1_IER_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IER); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IER_edssi] --> 0x%08x\n", REG_UART1_IER,value); #endif return tmp_value.bitc.edssi; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_DLH (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_DLH'. */ void GH_UART1_set_DLH(U32 data); /*! \brief Reads the register 'UART1_DLH'. */ U32 GH_UART1_get_DLH(void); /*! \brief Writes the bit group 'BaudDivint_H' of register 'UART1_DLH'. */ void GH_UART1_set_DLH_BaudDivint_H(U8 data); /*! \brief Reads the bit group 'BaudDivint_H' of register 'UART1_DLH'. */ U8 GH_UART1_get_DLH_BaudDivint_H(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_DLH(U32 data) { *(volatile U32 *)REG_UART1_DLH = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_DLH] <-- 0x%08x\n", REG_UART1_DLH,data,data); #endif } GH_INLINE U32 GH_UART1_get_DLH(void) { U32 value = (*(volatile U32 *)REG_UART1_DLH); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_DLH] --> 0x%08x\n", REG_UART1_DLH,value); #endif return value; } GH_INLINE void GH_UART1_set_DLH_BaudDivint_H(U8 data) { GH_UART1_DLH_S d; d.all = *(volatile U32 *)REG_UART1_DLH; d.bitc.bauddivint_h = data; *(volatile U32 *)REG_UART1_DLH = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_DLH_BaudDivint_H] <-- 0x%08x\n", REG_UART1_DLH,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_DLH_BaudDivint_H(void) { GH_UART1_DLH_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_DLH); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_DLH_BaudDivint_H] --> 0x%08x\n", REG_UART1_DLH,value); #endif return tmp_value.bitc.bauddivint_h; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_IIR (read) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Reads the register 'UART1_IIR'. */ U32 GH_UART1_get_IIR(void); /*! \brief Reads the bit group 'interrupt_id' of register 'UART1_IIR'. */ U8 GH_UART1_get_IIR_interrupt_id(void); /*! \brief Reads the bit group 'fifos_enabled' of register 'UART1_IIR'. */ U8 GH_UART1_get_IIR_fifos_enabled(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE U32 GH_UART1_get_IIR(void) { U32 value = (*(volatile U32 *)REG_UART1_IIR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IIR] --> 0x%08x\n", REG_UART1_IIR,value); #endif return value; } GH_INLINE U8 GH_UART1_get_IIR_interrupt_id(void) { GH_UART1_IIR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IIR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IIR_interrupt_id] --> 0x%08x\n", REG_UART1_IIR,value); #endif return tmp_value.bitc.interrupt_id; } GH_INLINE U8 GH_UART1_get_IIR_fifos_enabled(void) { GH_UART1_IIR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_IIR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_IIR_fifos_enabled] --> 0x%08x\n", REG_UART1_IIR,value); #endif return tmp_value.bitc.fifos_enabled; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_FCR (write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL < 2 /*! \brief Writes the register 'UART1_FCR'. */ void GH_UART1_set_FCR(U32 data); /*! \brief Reads the mirror variable of the register 'UART1_FCR'. */ U32 GH_UART1_getm_FCR(void); /*! \brief Writes the bit group 'FIFO_Enable' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_FIFO_Enable(U8 data); /*! \brief Reads the bit group 'FIFO_Enable' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_FIFO_Enable(void); /*! \brief Writes the bit group 'RCVR_FIFO_Reset' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_RCVR_FIFO_Reset(U8 data); /*! \brief Reads the bit group 'RCVR_FIFO_Reset' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_RCVR_FIFO_Reset(void); /*! \brief Writes the bit group 'XMIT_FIFO_Reset' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_XMIT_FIFO_Reset(U8 data); /*! \brief Reads the bit group 'XMIT_FIFO_Reset' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_XMIT_FIFO_Reset(void); /*! \brief Writes the bit group 'DMA_Mode' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_DMA_Mode(U8 data); /*! \brief Reads the bit group 'DMA_Mode' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_DMA_Mode(void); /*! \brief Writes the bit group 'TX_Empty_Trigger' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_TX_Empty_Trigger(U8 data); /*! \brief Reads the bit group 'TX_Empty_Trigger' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_TX_Empty_Trigger(void); /*! \brief Writes the bit group 'RCVR_Trigger' of register 'UART1_FCR'. */ void GH_UART1_set_FCR_RCVR_Trigger(U8 data); /*! \brief Reads the bit group 'RCVR_Trigger' from the mirror variable of register 'UART1_FCR'. */ U8 GH_UART1_getm_FCR_RCVR_Trigger(void); #else /* GH_INLINE_LEVEL < 2 */ GH_INLINE void GH_UART1_set_FCR(U32 data) { m_uart1_fcr.all = data; *(volatile U32 *)REG_UART1_FCR = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR] <-- 0x%08x\n", REG_UART1_FCR,data,data); #endif } GH_INLINE U32 GH_UART1_getm_FCR(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR] --> 0x%08x\n", m_uart1_fcr.all); #endif return m_uart1_fcr.all; } GH_INLINE void GH_UART1_set_FCR_FIFO_Enable(U8 data) { m_uart1_fcr.bitc.fifo_enable = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_FIFO_Enable] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_FIFO_Enable(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_FIFO_Enable] --> 0x%08x\n", m_uart1_fcr.bitc.fifo_enable); #endif return m_uart1_fcr.bitc.fifo_enable; } GH_INLINE void GH_UART1_set_FCR_RCVR_FIFO_Reset(U8 data) { m_uart1_fcr.bitc.rcvr_fifo_reset = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_RCVR_FIFO_Reset] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_RCVR_FIFO_Reset(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_RCVR_FIFO_Reset] --> 0x%08x\n", m_uart1_fcr.bitc.rcvr_fifo_reset); #endif return m_uart1_fcr.bitc.rcvr_fifo_reset; } GH_INLINE void GH_UART1_set_FCR_XMIT_FIFO_Reset(U8 data) { m_uart1_fcr.bitc.xmit_fifo_reset = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_XMIT_FIFO_Reset] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_XMIT_FIFO_Reset(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_XMIT_FIFO_Reset] --> 0x%08x\n", m_uart1_fcr.bitc.xmit_fifo_reset); #endif return m_uart1_fcr.bitc.xmit_fifo_reset; } GH_INLINE void GH_UART1_set_FCR_DMA_Mode(U8 data) { m_uart1_fcr.bitc.dma_mode = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_DMA_Mode] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_DMA_Mode(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_DMA_Mode] --> 0x%08x\n", m_uart1_fcr.bitc.dma_mode); #endif return m_uart1_fcr.bitc.dma_mode; } GH_INLINE void GH_UART1_set_FCR_TX_Empty_Trigger(U8 data) { m_uart1_fcr.bitc.tx_empty_trigger = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_TX_Empty_Trigger] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_TX_Empty_Trigger(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_TX_Empty_Trigger] --> 0x%08x\n", m_uart1_fcr.bitc.tx_empty_trigger); #endif return m_uart1_fcr.bitc.tx_empty_trigger; } GH_INLINE void GH_UART1_set_FCR_RCVR_Trigger(U8 data) { m_uart1_fcr.bitc.rcvr_trigger = data; *(volatile U32 *)REG_UART1_FCR = m_uart1_fcr.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_FCR_RCVR_Trigger] <-- 0x%08x\n", REG_UART1_FCR,m_uart1_fcr.all,m_uart1_fcr.all); #endif } GH_INLINE U8 GH_UART1_getm_FCR_RCVR_Trigger(void) { #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "[GH_UART1_getm_FCR_RCVR_Trigger] --> 0x%08x\n", m_uart1_fcr.bitc.rcvr_trigger); #endif return m_uart1_fcr.bitc.rcvr_trigger; } #endif /* GH_INLINE_LEVEL < 2 */ /*----------------------------------------------------------------------------*/ /* register UART1_LCR (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_LCR'. */ void GH_UART1_set_LCR(U32 data); /*! \brief Reads the register 'UART1_LCR'. */ U32 GH_UART1_get_LCR(void); /*! \brief Writes the bit group 'cls' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_cls(U8 data); /*! \brief Reads the bit group 'cls' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_cls(void); /*! \brief Writes the bit group 'stop' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_stop(U8 data); /*! \brief Reads the bit group 'stop' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_stop(void); /*! \brief Writes the bit group 'pen' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_pen(U8 data); /*! \brief Reads the bit group 'pen' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_pen(void); /*! \brief Writes the bit group 'eps' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_eps(U8 data); /*! \brief Reads the bit group 'eps' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_eps(void); /*! \brief Writes the bit group 'sticky_parity' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_sticky_parity(U8 data); /*! \brief Reads the bit group 'sticky_parity' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_sticky_parity(void); /*! \brief Writes the bit group 'breaks' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_breaks(U8 data); /*! \brief Reads the bit group 'breaks' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_breaks(void); /*! \brief Writes the bit group 'dlab' of register 'UART1_LCR'. */ void GH_UART1_set_LCR_dlab(U8 data); /*! \brief Reads the bit group 'dlab' of register 'UART1_LCR'. */ U8 GH_UART1_get_LCR_dlab(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_LCR(U32 data) { *(volatile U32 *)REG_UART1_LCR = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR] <-- 0x%08x\n", REG_UART1_LCR,data,data); #endif } GH_INLINE U32 GH_UART1_get_LCR(void) { U32 value = (*(volatile U32 *)REG_UART1_LCR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR] --> 0x%08x\n", REG_UART1_LCR,value); #endif return value; } GH_INLINE void GH_UART1_set_LCR_cls(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.cls = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_cls] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_cls(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_cls] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.cls; } GH_INLINE void GH_UART1_set_LCR_stop(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.stop = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_stop] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_stop(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_stop] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.stop; } GH_INLINE void GH_UART1_set_LCR_pen(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.pen = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_pen] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_pen(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_pen] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.pen; } GH_INLINE void GH_UART1_set_LCR_eps(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.eps = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_eps] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_eps(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_eps] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.eps; } GH_INLINE void GH_UART1_set_LCR_sticky_parity(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.sticky_parity = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_sticky_parity] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_sticky_parity(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_sticky_parity] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.sticky_parity; } GH_INLINE void GH_UART1_set_LCR_breaks(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.breaks = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_breaks] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_breaks(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_breaks] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.breaks; } GH_INLINE void GH_UART1_set_LCR_dlab(U8 data) { GH_UART1_LCR_S d; d.all = *(volatile U32 *)REG_UART1_LCR; d.bitc.dlab = data; *(volatile U32 *)REG_UART1_LCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_LCR_dlab] <-- 0x%08x\n", REG_UART1_LCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_LCR_dlab(void) { GH_UART1_LCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LCR_dlab] --> 0x%08x\n", REG_UART1_LCR,value); #endif return tmp_value.bitc.dlab; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_MCR (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_MCR'. */ void GH_UART1_set_MCR(U32 data); /*! \brief Reads the register 'UART1_MCR'. */ U32 GH_UART1_get_MCR(void); /*! \brief Writes the bit group 'dtr' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_dtr(U8 data); /*! \brief Reads the bit group 'dtr' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_dtr(void); /*! \brief Writes the bit group 'rts' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_rts(U8 data); /*! \brief Reads the bit group 'rts' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_rts(void); /*! \brief Writes the bit group 'out1' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_out1(U8 data); /*! \brief Reads the bit group 'out1' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_out1(void); /*! \brief Writes the bit group 'out2' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_out2(U8 data); /*! \brief Reads the bit group 'out2' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_out2(void); /*! \brief Writes the bit group 'loopback' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_loopback(U8 data); /*! \brief Reads the bit group 'loopback' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_loopback(void); /*! \brief Writes the bit group 'afce' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_afce(U8 data); /*! \brief Reads the bit group 'afce' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_afce(void); /*! \brief Writes the bit group 'sire' of register 'UART1_MCR'. */ void GH_UART1_set_MCR_sire(U8 data); /*! \brief Reads the bit group 'sire' of register 'UART1_MCR'. */ U8 GH_UART1_get_MCR_sire(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_MCR(U32 data) { *(volatile U32 *)REG_UART1_MCR = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR] <-- 0x%08x\n", REG_UART1_MCR,data,data); #endif } GH_INLINE U32 GH_UART1_get_MCR(void) { U32 value = (*(volatile U32 *)REG_UART1_MCR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR] --> 0x%08x\n", REG_UART1_MCR,value); #endif return value; } GH_INLINE void GH_UART1_set_MCR_dtr(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.dtr = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_dtr] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_dtr(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_dtr] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.dtr; } GH_INLINE void GH_UART1_set_MCR_rts(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.rts = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_rts] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_rts(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_rts] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.rts; } GH_INLINE void GH_UART1_set_MCR_out1(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.out1 = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_out1] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_out1(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_out1] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.out1; } GH_INLINE void GH_UART1_set_MCR_out2(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.out2 = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_out2] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_out2(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_out2] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.out2; } GH_INLINE void GH_UART1_set_MCR_loopback(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.loopback = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_loopback] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_loopback(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_loopback] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.loopback; } GH_INLINE void GH_UART1_set_MCR_afce(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.afce = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_afce] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_afce(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_afce] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.afce; } GH_INLINE void GH_UART1_set_MCR_sire(U8 data) { GH_UART1_MCR_S d; d.all = *(volatile U32 *)REG_UART1_MCR; d.bitc.sire = data; *(volatile U32 *)REG_UART1_MCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_MCR_sire] <-- 0x%08x\n", REG_UART1_MCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_MCR_sire(void) { GH_UART1_MCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MCR_sire] --> 0x%08x\n", REG_UART1_MCR,value); #endif return tmp_value.bitc.sire; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_LSR (read) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Reads the register 'UART1_LSR'. */ U32 GH_UART1_get_LSR(void); /*! \brief Reads the bit group 'dr' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_dr(void); /*! \brief Reads the bit group 'oe' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_oe(void); /*! \brief Reads the bit group 'pe' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_pe(void); /*! \brief Reads the bit group 'fe' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_fe(void); /*! \brief Reads the bit group 'bi' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_bi(void); /*! \brief Reads the bit group 'temt' of register 'UART1_LSR'. */ U8 GH_UART1_get_LSR_temt(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE U32 GH_UART1_get_LSR(void) { U32 value = (*(volatile U32 *)REG_UART1_LSR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR] --> 0x%08x\n", REG_UART1_LSR,value); #endif return value; } GH_INLINE U8 GH_UART1_get_LSR_dr(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_dr] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.dr; } GH_INLINE U8 GH_UART1_get_LSR_oe(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_oe] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.oe; } GH_INLINE U8 GH_UART1_get_LSR_pe(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_pe] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.pe; } GH_INLINE U8 GH_UART1_get_LSR_fe(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_fe] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.fe; } GH_INLINE U8 GH_UART1_get_LSR_bi(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_bi] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.bi; } GH_INLINE U8 GH_UART1_get_LSR_temt(void) { GH_UART1_LSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_LSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_LSR_temt] --> 0x%08x\n", REG_UART1_LSR,value); #endif return tmp_value.bitc.temt; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_MSR (read) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Reads the register 'UART1_MSR'. */ U32 GH_UART1_get_MSR(void); /*! \brief Reads the bit group 'dcts' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_dcts(void); /*! \brief Reads the bit group 'ddsr' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_ddsr(void); /*! \brief Reads the bit group 'teri' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_teri(void); /*! \brief Reads the bit group 'ddcd' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_ddcd(void); /*! \brief Reads the bit group 'cts' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_cts(void); /*! \brief Reads the bit group 'dsr' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_dsr(void); /*! \brief Reads the bit group 'ri' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_ri(void); /*! \brief Reads the bit group 'dcd' of register 'UART1_MSR'. */ U8 GH_UART1_get_MSR_dcd(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE U32 GH_UART1_get_MSR(void) { U32 value = (*(volatile U32 *)REG_UART1_MSR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR] --> 0x%08x\n", REG_UART1_MSR,value); #endif return value; } GH_INLINE U8 GH_UART1_get_MSR_dcts(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_dcts] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.dcts; } GH_INLINE U8 GH_UART1_get_MSR_ddsr(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_ddsr] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.ddsr; } GH_INLINE U8 GH_UART1_get_MSR_teri(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_teri] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.teri; } GH_INLINE U8 GH_UART1_get_MSR_ddcd(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_ddcd] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.ddcd; } GH_INLINE U8 GH_UART1_get_MSR_cts(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_cts] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.cts; } GH_INLINE U8 GH_UART1_get_MSR_dsr(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_dsr] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.dsr; } GH_INLINE U8 GH_UART1_get_MSR_ri(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_ri] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.ri; } GH_INLINE U8 GH_UART1_get_MSR_dcd(void) { GH_UART1_MSR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_MSR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_MSR_dcd] --> 0x%08x\n", REG_UART1_MSR,value); #endif return tmp_value.bitc.dcd; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* register UART1_SCR (read/write) */ /*----------------------------------------------------------------------------*/ #if GH_INLINE_LEVEL == 0 /*! \brief Writes the register 'UART1_SCR'. */ void GH_UART1_set_SCR(U32 data); /*! \brief Reads the register 'UART1_SCR'. */ U32 GH_UART1_get_SCR(void); /*! \brief Writes the bit group 'scr' of register 'UART1_SCR'. */ void GH_UART1_set_SCR_scr(U8 data); /*! \brief Reads the bit group 'scr' of register 'UART1_SCR'. */ U8 GH_UART1_get_SCR_scr(void); #else /* GH_INLINE_LEVEL == 0 */ GH_INLINE void GH_UART1_set_SCR(U32 data) { *(volatile U32 *)REG_UART1_SCR = data; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_SCR] <-- 0x%08x\n", REG_UART1_SCR,data,data); #endif } GH_INLINE U32 GH_UART1_get_SCR(void) { U32 value = (*(volatile U32 *)REG_UART1_SCR); #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_SCR] --> 0x%08x\n", REG_UART1_SCR,value); #endif return value; } GH_INLINE void GH_UART1_set_SCR_scr(U8 data) { GH_UART1_SCR_S d; d.all = *(volatile U32 *)REG_UART1_SCR; d.bitc.scr = data; *(volatile U32 *)REG_UART1_SCR = d.all; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_UART1_set_SCR_scr] <-- 0x%08x\n", REG_UART1_SCR,d.all,d.all); #endif } GH_INLINE U8 GH_UART1_get_SCR_scr(void) { GH_UART1_SCR_S tmp_value; U32 value = (*(volatile U32 *)REG_UART1_SCR); tmp_value.all = value; #if GH_UART1_ENABLE_DEBUG_PRINT GH_UART1_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_UART1_get_SCR_scr] --> 0x%08x\n", REG_UART1_SCR,value); #endif return tmp_value.bitc.scr; } #endif /* GH_INLINE_LEVEL == 0 */ /*----------------------------------------------------------------------------*/ /* init function */ /*----------------------------------------------------------------------------*/ /*! \brief Initialises the registers and mirror variables. */ void GH_UART1_init(void); #ifdef __cplusplus } #endif #endif /* _GH_UART1_H */ /*----------------------------------------------------------------------------*/ /* end of file */ /*----------------------------------------------------------------------------*/