4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-15 11:09:24 +08:00

557 lines
21 KiB
C
Raw Normal View History

2018-03-04 08:21:19 +08:00
/*!
*******************************************************************************
**
** \file gh_efuse.h
**
** \brief EFUSE controller.
**
** 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_EFUSE_H
#define _GH_EFUSE_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_EFUSE_ENABLE_DEBUG_PRINT 0
#ifdef __LINUX__
#define GH_EFUSE_DEBUG_PRINT_FUNCTION printk
#else
#define GH_EFUSE_DEBUG_PRINT_FUNCTION printf
#endif
#ifndef __LINUX__
#if GH_EFUSE_ENABLE_DEBUG_PRINT
#include <stdio.h>
#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_EFUSE_KEY FIO_ADDRESS(EFUSE,0x90001000) /* read */
#define REG_EFUSE_DATA FIO_ADDRESS(EFUSE,0x90001010) /* read */
#define REG_EFUSE_USER_DATA FIO_ADDRESS(EFUSE,0x90001014) /* read */
#define REG_EFUSE_CTRL FIO_ADDRESS(EFUSE,0x90001100) /* read/write */
#define REG_EFUSE_BOOT FIO_ADDRESS(EFUSE,0x90001104) /* read/write */
/*----------------------------------------------------------------------------*/
/* bit group structures */
/*----------------------------------------------------------------------------*/
typedef union { /* EFUSE_Data */
U32 all;
struct {
U32 boot_mode_sel : 1;
U32 engine_sel : 1;
U32 user_data : 30;
} bitc;
} GH_EFUSE_DATA_S;
typedef union { /* EFUSE_CTRL */
U32 all;
struct {
U32 wr_progen_high_cnt : 9;
U32 wr_progen_low_cnt : 6;
U32 wr_addr_setup_cnt : 4;
U32 rd_addr_setup_cnt : 3;
U32 rd_prchg_setup_cnt : 2;
U32 rd_prchg_hold_cnt : 2;
U32 rd_sense_hold_cnt : 3;
U32 wait_rd_addr_update_cnt : 3;
} bitc;
} GH_EFUSE_CTRL_S;
typedef union { /* EFUSE_BOOT */
U32 all;
struct {
U32 en : 1;
U32 rd_ok : 1;
U32 : 30;
} bitc;
} GH_EFUSE_BOOT_S;
/*----------------------------------------------------------------------------*/
/* mirror variables */
/*----------------------------------------------------------------------------*/
#ifdef __cplusplus
extern "C" {
#endif
/*----------------------------------------------------------------------------*/
/* register EFUSE_KEY (read) */
/*----------------------------------------------------------------------------*/
#if GH_INLINE_LEVEL == 0
/*! \brief Reads the register 'EFUSE_KEY'. */
U32 GH_EFUSE_get_KEY(U8 index);
#else /* GH_INLINE_LEVEL == 0 */
GH_INLINE U32 GH_EFUSE_get_KEY(U8 index)
{
U32 value = (*(volatile U32 *)(REG_EFUSE_KEY + index * FIO_MOFFSET(EFUSE,0x00000004)));
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_KEY] --> 0x%08x\n",
(REG_EFUSE_KEY + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return value;
}
#endif /* GH_INLINE_LEVEL == 0 */
/*----------------------------------------------------------------------------*/
/* register EFUSE_Data (read) */
/*----------------------------------------------------------------------------*/
#if GH_INLINE_LEVEL == 0
/*! \brief Reads the register 'EFUSE_Data'. */
U32 GH_EFUSE_get_Data(U8 index);
/*! \brief Reads the bit group 'boot_mode_sel' of register 'EFUSE_Data'. */
U8 GH_EFUSE_get_Data_boot_mode_sel(U8 index);
/*! \brief Reads the bit group 'engine_sel' of register 'EFUSE_Data'. */
U8 GH_EFUSE_get_Data_engine_sel(U8 index);
/*! \brief Reads the bit group 'User_Data' of register 'EFUSE_Data'. */
U32 GH_EFUSE_get_Data_User_Data(U8 index);
#else /* GH_INLINE_LEVEL == 0 */
GH_INLINE U32 GH_EFUSE_get_Data(U8 index)
{
U32 value = (*(volatile U32 *)(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)));
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_Data] --> 0x%08x\n",
(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return value;
}
GH_INLINE U8 GH_EFUSE_get_Data_boot_mode_sel(U8 index)
{
GH_EFUSE_DATA_S tmp_value;
U32 value = (*(volatile U32 *)(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)));
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_Data_boot_mode_sel] --> 0x%08x\n",
(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return tmp_value.bitc.boot_mode_sel;
}
GH_INLINE U8 GH_EFUSE_get_Data_engine_sel(U8 index)
{
GH_EFUSE_DATA_S tmp_value;
U32 value = (*(volatile U32 *)(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)));
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_Data_engine_sel] --> 0x%08x\n",
(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return tmp_value.bitc.engine_sel;
}
GH_INLINE U32 GH_EFUSE_get_Data_User_Data(U8 index)
{
GH_EFUSE_DATA_S tmp_value;
U32 value = (*(volatile U32 *)(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)));
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_Data_User_Data] --> 0x%08x\n",
(REG_EFUSE_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return tmp_value.bitc.user_data;
}
#endif /* GH_INLINE_LEVEL == 0 */
/*----------------------------------------------------------------------------*/
/* register EFUSE_User_Data (read) */
/*----------------------------------------------------------------------------*/
#if GH_INLINE_LEVEL == 0
/*! \brief Reads the register 'EFUSE_User_Data'. */
U32 GH_EFUSE_get_User_Data(U8 index);
#else /* GH_INLINE_LEVEL == 0 */
GH_INLINE U32 GH_EFUSE_get_User_Data(U8 index)
{
U32 value = (*(volatile U32 *)(REG_EFUSE_USER_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)));
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_User_Data] --> 0x%08x\n",
(REG_EFUSE_USER_DATA + index * FIO_MOFFSET(EFUSE,0x00000004)),value);
#endif
return value;
}
#endif /* GH_INLINE_LEVEL == 0 */
/*----------------------------------------------------------------------------*/
/* register EFUSE_CTRL (read/write) */
/*----------------------------------------------------------------------------*/
#if GH_INLINE_LEVEL == 0
/*! \brief Writes the register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL(U32 data);
/*! \brief Reads the register 'EFUSE_CTRL'. */
U32 GH_EFUSE_get_CTRL(void);
/*! \brief Writes the bit group 'wr_progen_high_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_wr_progen_high_cnt(U16 data);
/*! \brief Reads the bit group 'wr_progen_high_cnt' of register 'EFUSE_CTRL'. */
U16 GH_EFUSE_get_CTRL_wr_progen_high_cnt(void);
/*! \brief Writes the bit group 'wr_progen_low_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_wr_progen_low_cnt(U8 data);
/*! \brief Reads the bit group 'wr_progen_low_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_wr_progen_low_cnt(void);
/*! \brief Writes the bit group 'wr_addr_setup_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_wr_addr_setup_cnt(U8 data);
/*! \brief Reads the bit group 'wr_addr_setup_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_wr_addr_setup_cnt(void);
/*! \brief Writes the bit group 'rd_addr_setup_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_rd_addr_setup_cnt(U8 data);
/*! \brief Reads the bit group 'rd_addr_setup_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_rd_addr_setup_cnt(void);
/*! \brief Writes the bit group 'rd_prchg_setup_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_rd_prchg_setup_cnt(U8 data);
/*! \brief Reads the bit group 'rd_prchg_setup_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_rd_prchg_setup_cnt(void);
/*! \brief Writes the bit group 'rd_prchg_hold_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_rd_prchg_hold_cnt(U8 data);
/*! \brief Reads the bit group 'rd_prchg_hold_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_rd_prchg_hold_cnt(void);
/*! \brief Writes the bit group 'rd_sense_hold_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_rd_sense_hold_cnt(U8 data);
/*! \brief Reads the bit group 'rd_sense_hold_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_rd_sense_hold_cnt(void);
/*! \brief Writes the bit group 'Wait_rd_addr_update_cnt' of register 'EFUSE_CTRL'. */
void GH_EFUSE_set_CTRL_Wait_rd_addr_update_cnt(U8 data);
/*! \brief Reads the bit group 'Wait_rd_addr_update_cnt' of register 'EFUSE_CTRL'. */
U8 GH_EFUSE_get_CTRL_Wait_rd_addr_update_cnt(void);
#else /* GH_INLINE_LEVEL == 0 */
GH_INLINE void GH_EFUSE_set_CTRL(U32 data)
{
*(volatile U32 *)REG_EFUSE_CTRL = data;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL] <-- 0x%08x\n",
REG_EFUSE_CTRL,data,data);
#endif
}
GH_INLINE U32 GH_EFUSE_get_CTRL(void)
{
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return value;
}
GH_INLINE void GH_EFUSE_set_CTRL_wr_progen_high_cnt(U16 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.wr_progen_high_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_wr_progen_high_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U16 GH_EFUSE_get_CTRL_wr_progen_high_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_wr_progen_high_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.wr_progen_high_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_wr_progen_low_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.wr_progen_low_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_wr_progen_low_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_wr_progen_low_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_wr_progen_low_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.wr_progen_low_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_wr_addr_setup_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.wr_addr_setup_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_wr_addr_setup_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_wr_addr_setup_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_wr_addr_setup_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.wr_addr_setup_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_rd_addr_setup_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.rd_addr_setup_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_rd_addr_setup_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_rd_addr_setup_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_rd_addr_setup_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.rd_addr_setup_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_rd_prchg_setup_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.rd_prchg_setup_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_rd_prchg_setup_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_rd_prchg_setup_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_rd_prchg_setup_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.rd_prchg_setup_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_rd_prchg_hold_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.rd_prchg_hold_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_rd_prchg_hold_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_rd_prchg_hold_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_rd_prchg_hold_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.rd_prchg_hold_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_rd_sense_hold_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.rd_sense_hold_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_rd_sense_hold_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_rd_sense_hold_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_rd_sense_hold_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.rd_sense_hold_cnt;
}
GH_INLINE void GH_EFUSE_set_CTRL_Wait_rd_addr_update_cnt(U8 data)
{
GH_EFUSE_CTRL_S d;
d.all = *(volatile U32 *)REG_EFUSE_CTRL;
d.bitc.wait_rd_addr_update_cnt = data;
*(volatile U32 *)REG_EFUSE_CTRL = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_CTRL_Wait_rd_addr_update_cnt] <-- 0x%08x\n",
REG_EFUSE_CTRL,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_CTRL_Wait_rd_addr_update_cnt(void)
{
GH_EFUSE_CTRL_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_CTRL);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_CTRL_Wait_rd_addr_update_cnt] --> 0x%08x\n",
REG_EFUSE_CTRL,value);
#endif
return tmp_value.bitc.wait_rd_addr_update_cnt;
}
#endif /* GH_INLINE_LEVEL == 0 */
/*----------------------------------------------------------------------------*/
/* register EFUSE_BOOT (read/write) */
/*----------------------------------------------------------------------------*/
#if GH_INLINE_LEVEL == 0
/*! \brief Writes the register 'EFUSE_BOOT'. */
void GH_EFUSE_set_BOOT(U32 data);
/*! \brief Reads the register 'EFUSE_BOOT'. */
U32 GH_EFUSE_get_BOOT(void);
/*! \brief Writes the bit group 'EN' of register 'EFUSE_BOOT'. */
void GH_EFUSE_set_BOOT_EN(U8 data);
/*! \brief Reads the bit group 'EN' of register 'EFUSE_BOOT'. */
U8 GH_EFUSE_get_BOOT_EN(void);
/*! \brief Writes the bit group 'RD_OK' of register 'EFUSE_BOOT'. */
void GH_EFUSE_set_BOOT_RD_OK(U8 data);
/*! \brief Reads the bit group 'RD_OK' of register 'EFUSE_BOOT'. */
U8 GH_EFUSE_get_BOOT_RD_OK(void);
#else /* GH_INLINE_LEVEL == 0 */
GH_INLINE void GH_EFUSE_set_BOOT(U32 data)
{
*(volatile U32 *)REG_EFUSE_BOOT = data;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_BOOT] <-- 0x%08x\n",
REG_EFUSE_BOOT,data,data);
#endif
}
GH_INLINE U32 GH_EFUSE_get_BOOT(void)
{
U32 value = (*(volatile U32 *)REG_EFUSE_BOOT);
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_BOOT] --> 0x%08x\n",
REG_EFUSE_BOOT,value);
#endif
return value;
}
GH_INLINE void GH_EFUSE_set_BOOT_EN(U8 data)
{
GH_EFUSE_BOOT_S d;
d.all = *(volatile U32 *)REG_EFUSE_BOOT;
d.bitc.en = data;
*(volatile U32 *)REG_EFUSE_BOOT = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_BOOT_EN] <-- 0x%08x\n",
REG_EFUSE_BOOT,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_BOOT_EN(void)
{
GH_EFUSE_BOOT_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_BOOT);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_BOOT_EN] --> 0x%08x\n",
REG_EFUSE_BOOT,value);
#endif
return tmp_value.bitc.en;
}
GH_INLINE void GH_EFUSE_set_BOOT_RD_OK(U8 data)
{
GH_EFUSE_BOOT_S d;
d.all = *(volatile U32 *)REG_EFUSE_BOOT;
d.bitc.rd_ok = data;
*(volatile U32 *)REG_EFUSE_BOOT = d.all;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "WRREG(0x%08x,0x%08x); \\\\ [GH_EFUSE_set_BOOT_RD_OK] <-- 0x%08x\n",
REG_EFUSE_BOOT,d.all,d.all);
#endif
}
GH_INLINE U8 GH_EFUSE_get_BOOT_RD_OK(void)
{
GH_EFUSE_BOOT_S tmp_value;
U32 value = (*(volatile U32 *)REG_EFUSE_BOOT);
tmp_value.all = value;
#if GH_EFUSE_ENABLE_DEBUG_PRINT
GH_EFUSE_DEBUG_PRINT_FUNCTION( "value = RDREG(0x%08x); \\\\ [GH_EFUSE_get_BOOT_RD_OK] --> 0x%08x\n",
REG_EFUSE_BOOT,value);
#endif
return tmp_value.bitc.rd_ok;
}
#endif /* GH_INLINE_LEVEL == 0 */
/*----------------------------------------------------------------------------*/
/* init function */
/*----------------------------------------------------------------------------*/
/*! \brief Initialises the registers and mirror variables. */
void GH_EFUSE_init(void);
#ifdef __cplusplus
}
#endif
#endif /* _GH_EFUSE_H */
/*----------------------------------------------------------------------------*/
/* end of file */
/*----------------------------------------------------------------------------*/