Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
CTCaer
GitHub Repository: CTCaer/hekate
Path: blob/master/bdk/storage/nx_emmc_bis.h
1476 views
1
/*
2
* Copyright (c) 2019 shchmue
3
* Copyright (c) 2019 CTCaer
4
*
5
* This program is free software; you can redistribute it and/or modify it
6
* under the terms and conditions of the GNU General Public License,
7
* version 2, as published by the Free Software Foundation.
8
*
9
* This program is distributed in the hope it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12
* more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with this program. If not, see <http://www.gnu.org/licenses/>.
16
*/
17
18
#ifndef NX_EMMC_BIS_H
19
#define NX_EMMC_BIS_H
20
21
#include <storage/emmc.h>
22
#include <storage/sdmmc.h>
23
24
typedef struct _nx_emmc_cal0_spk_t
25
{
26
u16 unk0;
27
u16 unk1;
28
u16 eq_bw_lop;
29
u16 eq_gn_lop;
30
u16 eq_fc_bp1;
31
u16 eq_bw_bp1;
32
u16 eq_gn_bp1;
33
u16 eq_fc_bp2;
34
u16 eq_bw_bp2;
35
u16 eq_gn_bp2;
36
u16 eq_fc_bp3;
37
u16 eq_bw_bp3;
38
u16 eq_gn_bp3;
39
u16 eq_fc_bp4;
40
u16 eq_bw_bp4;
41
u16 eq_gn_bp4;
42
u16 eq_fc_hip1;
43
u16 eq_gn_hip1;
44
u16 eq_fc_hip2;
45
u16 eq_bw_hip2;
46
u16 eq_gn_hip2;
47
u16 eq_pre_vol;
48
u16 eq_pst_vol;
49
u16 eq_ctrl2;
50
u16 eq_ctrl1;
51
u16 drc_agc_2;
52
u16 drc_agc_3;
53
u16 drc_agc_1;
54
u16 spk_vol;
55
u16 hp_vol;
56
u16 dac1_min_vol_spk;
57
u16 dac1_max_vol_spk;
58
u16 dac1_min_vol_hp;
59
u16 dac1_max_vol_hp;
60
u16 in1_in2;
61
u16 adc_vol_min;
62
u16 adc_vol_max;
63
u8 unk4[16];
64
} __attribute__((packed)) nx_emmc_cal0_spk_t;
65
66
typedef struct _nx_emmc_cal0_t
67
{
68
u32 magic; // 'CAL0'.
69
u32 version;
70
u32 body_size;
71
u16 model;
72
u16 update_cnt;
73
u8 pad_crc16_0[0x10];
74
u8 body_sha256[0x20];
75
char cfg_id1[0x1E];
76
u8 crc16_pad1[2];
77
u8 rsvd0[0x20];
78
u32 wlan_cc_num;
79
u32 wlan_cc_last;
80
char wlan_cc[128][3];
81
u8 crc16_pad2[8];
82
u8 wlan_mac[6];
83
u8 crc16_pad3[2];
84
u8 rsvd1[8];
85
u8 bd_mac[6];
86
u8 crc16_pad4[2];
87
u8 rsvd2[8];
88
u16 acc_offset[3];
89
u8 crc16_pad5[2];
90
u16 acc_scale[3];
91
u8 crc16_pad6[2];
92
u16 gyro_offset[3];
93
u8 crc16_pad7[2];
94
u16 gyro_scale[3];
95
u8 crc16_pad8[2];
96
char serial_number[0x18];
97
u8 crc16_pad9[8];
98
99
u8 ecc_p256_device_key[0x30];
100
u8 crc16_pad10[0x10];
101
u8 ecc_p256_device_cert[0x180];
102
u8 crc16_pad11[0x10];
103
u8 ecc_p233_device_key[0x30];
104
u8 crc16_pad12[0x10];
105
u8 ecc_p33_device_cert[0x180];
106
u8 crc16_pad13[0x10];
107
u8 ecc_p256_ticket_key[0x30];
108
u8 crc16_pad14[0x10];
109
u8 ecc_p256_ticket_cert[0x180];
110
u8 crc16_pad15[0x10];
111
u8 ecc_p233_ticket_key[0x30];
112
u8 crc16_pad16[0x10];
113
u8 ecc_p33_ticket_cert[0x180];
114
u8 crc16_pad17[0x10];
115
u8 ssl_key[0x110];
116
u8 crc16_pad18[0x10];
117
u32 ssl_cert_size;
118
u8 crc16_pad19[0xC];
119
u8 ssl_cert[0x800];
120
u8 ssl_sha256[0x20];
121
u8 random_number[0x1000];
122
u8 random_number_sha256[0x20];
123
u8 gc_key[0x110];
124
u8 crc16_pad20[0x10];
125
u8 gc_cert[0x400];
126
u8 gc_cert_sha256[0x20];
127
u8 rsa2048_eticket_key[0x220];
128
u8 crc16_pad21[0x10];
129
u8 rsa2048_eticket_cert[0x240];
130
u8 crc16_pad22[0x10];
131
132
char battery_lot[0x1E];
133
u8 crc16_pad23[2];
134
nx_emmc_cal0_spk_t spk_cal;
135
u8 spk_cal_rsvd[0x800 - sizeof(nx_emmc_cal0_spk_t)];
136
u8 crc16_pad24[0x10];
137
u32 region_code;
138
u8 crc16_pad25[0xC];
139
140
u8 amiibo_key[0x50];
141
u8 crc16_pad26[0x10];
142
u8 amiibo_ecqv_cert[0x14];
143
u8 crc16_pad27[0xC];
144
u8 amiibo_ecqdsa_cert[0x70];
145
u8 crc16_pad28[0x10];
146
u8 amiibo_ecqv_bls_key[0x40];
147
u8 crc16_pad29[0x10];
148
u8 amiibo_ecqv_bls_cert[0x20];
149
u8 crc16_pad30[0x10];
150
u8 amiibo_ecqv_bls_root_cert[0x90];
151
u8 crc16_pad31[0x10];
152
153
u32 product_model; // 1: Nx, 2: Copper, 4: Hoag.
154
u8 crc16_pad32[0xC];
155
u8 home_menu_scheme_main_color[6];
156
u8 crc16_pad33[0xA];
157
u32 lcd_bl_brightness_mapping[3]; // Floats. Normally 100%, 0% and 2%.
158
u8 crc16_pad34[0x4];
159
160
u8 ext_ecc_b233_device_key[0x50];
161
u8 crc16_pad35[0x10];
162
u8 ext_ecc_p256_eticket_key[0x50];
163
u8 crc16_pad36[0x10];
164
u8 ext_ecc_b233_eticket_key[0x50];
165
u8 crc16_pad37[0x10];
166
u8 ext_ecc_rsa2048_eticket_key[0x240];
167
u8 crc16_pad38[0x10];
168
u8 ext_ssl_key[0x130];
169
u8 crc16_pad39[0x10];
170
u8 ext_gc_key[0x130];
171
u8 crc16_pad40[0x10];
172
173
u32 lcd_vendor;
174
u8 crc16_pad41[0xC];
175
176
// 5.0.0 and up.
177
u8 ext_rsa2048_device_key[0x240];
178
u8 crc16_pad42[0x10];
179
u8 rsa2048_device_cert[0x240];
180
u8 crc16_pad43[0x10];
181
182
u8 usbc_pwr_src_circuit_ver;
183
u8 crc16_pad44[0xF];
184
185
// 9.0.0 and up.
186
u32 home_menu_scheme_sub_color;
187
u8 crc16_pad45[0xC];
188
u32 home_menu_scheme_bezel_color;
189
u8 crc16_pad46[0xC];
190
u32 home_menu_scheme_main_color1;
191
u8 crc16_pad47[0xC];
192
u32 home_menu_scheme_main_color2;
193
u8 crc16_pad48[0xC];
194
u32 home_menu_scheme_main_color3;
195
u8 crc16_pad49[0xC];
196
197
u8 analog_stick_type_l;
198
u8 crc16_pad50[0xF];
199
u8 analog_stick_param_l[0x12];
200
u8 crc16_pad51[0xE];
201
u8 analog_stick_cal_l[0x9];
202
u8 crc16_pad52[0x7];
203
u8 analog_stick_type_r;
204
u8 crc16_pad53[0xF];
205
u8 analog_stick_param_r[0x12];
206
u8 crc16_pad54[0xE];
207
u8 analog_stick_cal_r[0x9];
208
u8 crc16_pad55[0x7];
209
u8 console_6axis_sensor_type;
210
u8 crc16_pad56[0xF];
211
u8 console_6axis_sensor_hor_off[0x6];
212
u8 crc16_pad57[0xA];
213
214
// 6.0.0 and up.
215
u8 battery_ver;
216
u8 crc16_pad58[0xF];
217
218
// 10.0.0 and up.
219
u8 touch_ic_vendor_id;
220
u8 crc16_pad59[0xF];
221
222
// 9.0.0 and up.
223
u32 color_model;
224
u8 crc16_pad60[0xC];
225
226
// 10.0.0 and up.
227
u8 console_6axis_sensor_mount_type;
228
} __attribute__((packed)) nx_emmc_cal0_t;
229
230
int nx_emmc_bis_read(u32 sector, u32 count, void *buff);
231
int nx_emmc_bis_write(u32 sector, u32 count, void *buff);
232
void nx_emmc_bis_init(emmc_part_t *part, bool enable_cache, u32 emummc_offset);
233
void nx_emmc_bis_end();
234
235
#endif
236
237