1
0
mirror of https://github.com/CTCaer/hekate.git synced 2025-01-01 00:14:29 +00:00
hekate/bdk/soc/fuse.h

116 lines
3.1 KiB
C
Raw Normal View History

2018-05-01 05:15:48 +00:00
/*
2018-08-05 11:40:32 +00:00
* Copyright (c) 2018 naehrwert
2018-09-09 22:44:04 +00:00
* Copyright (c) 2018 shuffle2
* Copyright (c) 2018 balika011
* Copyright (c) 2019-2022 CTCaer
2018-08-05 11:40:32 +00:00
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2018-05-01 05:15:48 +00:00
#ifndef _FUSE_H_
#define _FUSE_H_
#include <utils/types.h>
2018-05-01 05:15:48 +00:00
/*! Fuse registers. */
#define FUSE_CTRL 0x0
#define FUSE_ADDR 0x4
#define FUSE_RDATA 0x8
#define FUSE_WDATA 0xC
#define FUSE_TIME_RD1 0x10
#define FUSE_TIME_RD2 0x14
#define FUSE_TIME_PGM1 0x18
#define FUSE_TIME_PGM2 0x1C
#define FUSE_PRIV2INTFC 0x20
#define FUSE_FUSEBYPASS 0x24
#define FUSE_PRIVATEKEYDISABLE 0x28
#define FUSE_DISABLEREGPROGRAM 0x2C
#define FUSE_WRITE_ACCESS_SW 0x30
#define FUSE_PWR_GOOD_SW 0x34
/*! Fuse Cached registers */
2018-11-10 12:11:42 +00:00
#define FUSE_SKU_INFO 0x110
2019-06-30 00:15:46 +00:00
#define FUSE_CPU_SPEEDO_0_CALIB 0x114
#define FUSE_CPU_IDDQ_CALIB 0x118
#define FUSE_OPT_FT_REV 0x128
#define FUSE_CPU_SPEEDO_1_CALIB 0x12C
#define FUSE_CPU_SPEEDO_2_CALIB 0x130
#define FUSE_SOC_SPEEDO_0_CALIB 0x134
#define FUSE_SOC_SPEEDO_1_CALIB 0x138
#define FUSE_SOC_SPEEDO_2_CALIB 0x13C
#define FUSE_SOC_IDDQ_CALIB 0x140
#define FUSE_OPT_CP_REV 0x190
2018-09-09 22:44:04 +00:00
#define FUSE_FIRST_BOOTROM_PATCH_SIZE 0x19c
2018-11-10 12:11:42 +00:00
#define FUSE_PRIVATE_KEY0 0x1A4
#define FUSE_PRIVATE_KEY1 0x1A8
#define FUSE_PRIVATE_KEY2 0x1AC
#define FUSE_PRIVATE_KEY3 0x1B0
2019-06-30 00:15:46 +00:00
#define FUSE_PRIVATE_KEY4 0x1B4
#define FUSE_RESERVED_SW 0x1C0
2020-04-30 11:25:58 +00:00
#define FUSE_USB_CALIB 0x1F0
2019-12-04 19:31:39 +00:00
#define FUSE_SKU_DIRECT_CONFIG 0x1F4
2019-06-30 00:15:46 +00:00
#define FUSE_OPT_VENDOR_CODE 0x200
#define FUSE_OPT_FAB_CODE 0x204
#define FUSE_OPT_LOT_CODE_0 0x208
#define FUSE_OPT_LOT_CODE_1 0x20C
#define FUSE_OPT_WAFER_ID 0x210
#define FUSE_OPT_X_COORDINATE 0x214
#define FUSE_OPT_Y_COORDINATE 0x218
#define FUSE_OPT_OPS_RESERVED 0x220
2019-06-30 00:15:46 +00:00
#define FUSE_GPU_IDDQ_CALIB 0x228
2020-04-30 11:25:58 +00:00
#define FUSE_USB_CALIB_EXT 0x350
#define FUSE_RESERVED_FIELD 0x354
2018-09-09 22:44:04 +00:00
#define FUSE_RESERVED_ODM28_T210B01 0x240
2018-09-09 22:44:04 +00:00
/*! Fuse commands. */
#define FUSE_READ 0x1
#define FUSE_WRITE 0x2
#define FUSE_SENSE 0x3
#define FUSE_CMD_MASK 0x3
2018-05-01 05:15:48 +00:00
/*! Fuse cache registers. */
#define FUSE_RESERVED_ODMX(x) (0x1C8 + 4 * (x))
#define FUSE_ARRAY_WORDS_NUM 192
#define FUSE_ARRAY_WORDS_NUM_T210B01 256
2020-06-26 15:45:21 +00:00
enum
{
FUSE_NX_HW_TYPE_ICOSA,
FUSE_NX_HW_TYPE_IOWA,
2021-08-28 13:44:16 +00:00
FUSE_NX_HW_TYPE_HOAG,
2022-10-11 03:16:38 +00:00
FUSE_NX_HW_TYPE_AULA
2020-06-26 15:45:21 +00:00
};
enum
{
FUSE_NX_HW_STATE_PROD,
FUSE_NX_HW_STATE_DEV
};
2018-05-01 05:15:48 +00:00
void fuse_disable_program();
u32 fuse_read_odm(u32 idx);
u32 fuse_read_odm_keygen_rev();
u32 fuse_read_dramid(bool raw_id);
u32 fuse_read_hw_state();
2020-06-26 15:45:21 +00:00
u32 fuse_read_hw_type();
int fuse_set_sbk();
2018-09-09 22:44:04 +00:00
void fuse_wait_idle();
int fuse_read_ipatch(void (*ipatch)(u32 offset, u32 value));
int fuse_read_evp_thunk(u32 *iram_evp_thunks, u32 *iram_evp_thunks_len);
2019-04-16 17:05:35 +00:00
void fuse_read_array(u32 *words);
bool fuse_check_patched_rcm();
2018-05-01 05:15:48 +00:00
#endif