forked from CTCaer/hekate
nyx: retry to dump imu cal and skip it failed
On devices with mangled cal0 imu calibration can now be skipped (still mandatory on Lite).
This commit is contained in:
parent
9567ba19c8
commit
06b7a38d47
@ -842,6 +842,7 @@ static lv_res_t _joycon_info_dump_action(lv_obj_t * btn)
|
|||||||
{
|
{
|
||||||
FIL fp;
|
FIL fp;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
int cal_error = 0;
|
||||||
bool is_l_hos = false;
|
bool is_l_hos = false;
|
||||||
bool is_r_hos = false;
|
bool is_r_hos = false;
|
||||||
bool nx_hoag = fuse_read_hw_type() == FUSE_NX_HW_TYPE_HOAG;
|
bool nx_hoag = fuse_read_hw_type() == FUSE_NX_HW_TYPE_HOAG;
|
||||||
@ -853,8 +854,17 @@ static lv_res_t _joycon_info_dump_action(lv_obj_t * btn)
|
|||||||
if (!nx_hoag && !jc_pad)
|
if (!nx_hoag && !jc_pad)
|
||||||
error = 255;
|
error = 255;
|
||||||
|
|
||||||
if (!error)
|
// Try 2 times to get factory calibration data.
|
||||||
error = hos_dump_cal0();
|
for (u32 i = 0; i < 2; i++)
|
||||||
|
{
|
||||||
|
if (!error)
|
||||||
|
cal_error = hos_dump_cal0();
|
||||||
|
if (!cal_error)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cal_error && nx_hoag)
|
||||||
|
error = cal_error;
|
||||||
|
|
||||||
if (error)
|
if (error)
|
||||||
goto disabled_or_cal0_issue;
|
goto disabled_or_cal0_issue;
|
||||||
@ -919,35 +929,38 @@ save_data:
|
|||||||
f_mkdir("switchroot");
|
f_mkdir("switchroot");
|
||||||
|
|
||||||
// Save IMU Calibration data.
|
// Save IMU Calibration data.
|
||||||
s_printf(data,
|
if (!error && !cal_error)
|
||||||
"imu_type=%d\n\n"
|
|
||||||
"acc_cal_off_x=0x%X\n"
|
|
||||||
"acc_cal_off_y=0x%X\n"
|
|
||||||
"acc_cal_off_z=0x%X\n"
|
|
||||||
"acc_cal_scl_x=0x%X\n"
|
|
||||||
"acc_cal_scl_y=0x%X\n"
|
|
||||||
"acc_cal_scl_z=0x%X\n\n"
|
|
||||||
|
|
||||||
"gyr_cal_off_x=0x%X\n"
|
|
||||||
"gyr_cal_off_y=0x%X\n"
|
|
||||||
"gyr_cal_off_z=0x%X\n"
|
|
||||||
"gyr_cal_scl_x=0x%X\n"
|
|
||||||
"gyr_cal_scl_y=0x%X\n"
|
|
||||||
"gyr_cal_scl_z=0x%X\n\n"
|
|
||||||
|
|
||||||
"device_bt_mac=%02X:%02X:%02X:%02X:%02X:%02X\n",
|
|
||||||
cal0->console_6axis_sensor_type,
|
|
||||||
cal0->acc_offset[0], cal0->acc_offset[1], cal0->acc_offset[2],
|
|
||||||
cal0->acc_scale[0], cal0->acc_scale[1], cal0->acc_scale[2],
|
|
||||||
cal0->gyro_offset[0], cal0->gyro_offset[1], cal0->gyro_offset[2],
|
|
||||||
cal0->gyro_scale[0], cal0->gyro_scale[1], cal0->gyro_scale[2],
|
|
||||||
cal0->bd_mac[0], cal0->bd_mac[1], cal0->bd_mac[2], cal0->bd_mac[3], cal0->bd_mac[4], cal0->bd_mac[5]);
|
|
||||||
if (!error)
|
|
||||||
error = f_open(&fp, "switchroot/switch.cal", FA_WRITE | FA_CREATE_ALWAYS) ? 4 : 0;
|
|
||||||
if (!error)
|
|
||||||
{
|
{
|
||||||
f_puts(data, &fp);
|
s_printf(data,
|
||||||
f_close(&fp);
|
"imu_type=%d\n\n"
|
||||||
|
"acc_cal_off_x=0x%X\n"
|
||||||
|
"acc_cal_off_y=0x%X\n"
|
||||||
|
"acc_cal_off_z=0x%X\n"
|
||||||
|
"acc_cal_scl_x=0x%X\n"
|
||||||
|
"acc_cal_scl_y=0x%X\n"
|
||||||
|
"acc_cal_scl_z=0x%X\n\n"
|
||||||
|
|
||||||
|
"gyr_cal_off_x=0x%X\n"
|
||||||
|
"gyr_cal_off_y=0x%X\n"
|
||||||
|
"gyr_cal_off_z=0x%X\n"
|
||||||
|
"gyr_cal_scl_x=0x%X\n"
|
||||||
|
"gyr_cal_scl_y=0x%X\n"
|
||||||
|
"gyr_cal_scl_z=0x%X\n\n"
|
||||||
|
|
||||||
|
"device_bt_mac=%02X:%02X:%02X:%02X:%02X:%02X\n",
|
||||||
|
cal0->console_6axis_sensor_type,
|
||||||
|
cal0->acc_offset[0], cal0->acc_offset[1], cal0->acc_offset[2],
|
||||||
|
cal0->acc_scale[0], cal0->acc_scale[1], cal0->acc_scale[2],
|
||||||
|
cal0->gyro_offset[0], cal0->gyro_offset[1], cal0->gyro_offset[2],
|
||||||
|
cal0->gyro_scale[0], cal0->gyro_scale[1], cal0->gyro_scale[2],
|
||||||
|
cal0->bd_mac[0], cal0->bd_mac[1], cal0->bd_mac[2], cal0->bd_mac[3], cal0->bd_mac[4], cal0->bd_mac[5]);
|
||||||
|
if (!error)
|
||||||
|
error = f_open(&fp, "switchroot/switch.cal", FA_WRITE | FA_CREATE_ALWAYS) ? 4 : 0;
|
||||||
|
if (!error)
|
||||||
|
{
|
||||||
|
f_puts(data, &fp);
|
||||||
|
f_close(&fp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1066,6 +1079,9 @@ disabled_or_cal0_issue:;
|
|||||||
strcat(txt_buf,
|
strcat(txt_buf,
|
||||||
"\n\n#FFDD00 Make sure that both Joy-Con are connected,#\n"
|
"\n\n#FFDD00 Make sure that both Joy-Con are connected,#\n"
|
||||||
"#FFDD00 and that you paired them in HOS!#");
|
"#FFDD00 and that you paired them in HOS!#");
|
||||||
|
|
||||||
|
if (cal_error)
|
||||||
|
strcat(txt_buf, "\n\n#FF8000 Warning:# Failed to get full calibration data!");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user