52 #ifndef __GR55xx_LL_EFUSE_H__
53 #define __GR55xx_LL_EFUSE_H__
78 #define LL_EFUSE_WRITE_KEYRAM EFUSE_OPER_WRITE_KEYRAM
79 #define LL_EFUSE_READ_TRIM EFUSE_OPER_READ_TRIM
80 #define LL_EFUSE_CRC_CHECK EFUSE_OPER_CRC_CHECK
81 #define LL_EFUSE_INIT_CHECK EFUSE_OPER_INIT_CHECK
82 #define LL_EFUSE_TEST_READ EFUSE_OPER_RD_TEST_MODE
89 #define LL_EFUSE_WRITE_KEYRAM_BUSY EFUSE_STATUS_WRITE_KEYRAM_BUSY
90 #define LL_EFUSE_READ_TRIM_DONE EFUSE_STATUS_READ_TRIM_DONE
91 #define LL_EFUSE_CRC_CHECK_DONE EFUSE_STATUS_CRC_CHECK_DONE
92 #define LL_EFUSE_CRC_CHECK_SUCCESS EFUSE_STATUS_TRIM_CRC_SUCCESS
93 #define LL_EFUSE_INIT_CHECK_DONE EFUSE_STATUS_INIT_DONE
94 #define LL_EFUSE_INIT_CHECK_SUCCESS EFUSE_STATUS_INIT_SUCCESS
95 #define LL_EFUSE_WRITE_DONE EFUSE_STATUS_WRITE_DONE
96 #define LL_EFUSE_TEST_DONE EFUSE_STATUS_TEST_MODE_DONE
103 #define LL_EFUSE_PWR_CTL_EN_DONE MCU_SUB_EFUSE_PWR_CTL0_EN_DONE
104 #define LL_EFUSE_PWR_CTL_DIS_DONE MCU_SUB_EFUSE_PWR_CTL0_DIS_DONE
125 #define LL_EFUSE_WriteReg(__instance__, __REG__, __VALUE__) WRITE_REG(__instance__->__REG__, (__VALUE__))
133 #define LL_EFUSE_ReadReg(__instance__, __REG__) READ_REG(__instance__->__REG__)
167 MODIFY_REG(EFUSEx->TPGM, EFUSE_TPGM_TIME, time << EFUSE_TPGM_TIME_Pos);
186 return (uint32_t)(READ_BITS(EFUSEx->TPGM, EFUSE_TPGM_TIME) >> EFUSE_TPGM_TIME_Pos);
205 SET_BITS(EFUSEx->TPGM, EFUSE_TPGM_MAIN_OR_BACKUP);
224 CLEAR_BITS(EFUSEx->TPGM, EFUSE_TPGM_MAIN_OR_BACKUP);
243 return (READ_BITS(EFUSEx->TPGM, EFUSE_TPGM_MAIN_OR_BACKUP) == (EFUSE_TPGM_MAIN_OR_BACKUP));
263 MODIFY_REG(EFUSEx->TPGM, EFUSE_TPGM_CRC_CHECK_LEN, length << EFUSE_TPGM_CRC_CHECK_LEN_Pos);
282 return (uint32_t)(READ_BITS(EFUSEx->TPGM, EFUSE_TPGM_CRC_CHECK_LEN) >> EFUSE_TPGM_CRC_CHECK_LEN_Pos);
302 MODIFY_REG(EFUSEx->TPGM, EFUSE_TPGM_WRITE_INTERVAL, interval << EFUSE_TPGM_WRITE_INTERVAL_Pos);
321 return (uint32_t)(READ_BITS(EFUSEx->TPGM, EFUSE_TPGM_WRITE_INTERVAL) >> EFUSE_TPGM_WRITE_INTERVAL_Pos);
340 SET_BITS(EFUSEx->PGENB, EFUSE_PGENB_SIG);
359 CLEAR_BITS(EFUSEx->PGENB, EFUSE_PGENB_SIG);
378 return (READ_BITS(EFUSEx->PGENB, EFUSE_PGENB_SIG) == (EFUSE_PGENB_SIG));
398 return (uint32_t)(READ_BITS(EFUSEx->TEST_MODE, EFUSE_TEST_MODE));
427 WRITE_REG(EFUSEx->OPERATION, mode);
462 return (READ_BITS(EFUSEx->STAT, flag) == (flag));
482 WRITE_REG(EFUSEx->KEY_MASK, mask);
501 return (uint32_t)(READ_REG(EFUSEx->KEY_MASK));
522 WRITE_REG(EFUSEx->CRC_ADDR, address);
541 return (uint32_t)(READ_REG(EFUSEx->CRC_ADDR));
560 return (uint32_t)(READ_REG(EFUSEx->CRC_OUTPUT));
581 WRITE_REG(EFUSEx->TRIM_ADDR, address);
600 return (uint32_t)(READ_REG(EFUSEx->TRIM_ADDR));
620 WRITE_REG(EFUSEx->TRIM_LEN, length & EFUSE_TRIM_LENGTH);
639 return (uint32_t)(READ_REG(EFUSEx->TRIM_LEN) & EFUSE_TRIM_LENGTH);
659 return (uint32_t)(READ_REG(EFUSEx->TRIM[indx]));
677 SET_BITS(AON->RF_REG_2, AON_RF_REG_2_EFUSE_VDD_EN);
695 CLEAR_BITS(AON->RF_REG_2, AON_RF_REG_2_EFUSE_VDD_EN);
711 WRITE_REG(MCU_SUB->EFUSE_PWR_DELTA[0], vddq_0 + (vddq_1 << 16));
712 WRITE_REG(MCU_SUB->EFUSE_PWR_DELTA[1], vddq_2);
727 WRITE_REG(MCU_SUB->EFUSE_PWR_CTRL[0], MCU_SUB_EFUSE_PWR_CTL0_BGN | MCU_SUB_EFUSE_PWR_CTL0_EN);
742 WRITE_REG(MCU_SUB->EFUSE_PWR_CTRL[0], MCU_SUB_EFUSE_PWR_CTL0_STP | MCU_SUB_EFUSE_PWR_CTL0_EN);
758 WRITE_REG(MCU_SUB->EFUSE_PWR_CTRL[0], 0);
781 return (READ_BITS(MCU_SUB->EFUSE_PWR_CTRL[1], flag) == (flag));