separate namespace for patch; update info on emc
This commit is contained in:
@@ -16,138 +16,224 @@ constexpr ro::ModuleId AmModuleId[] = {
|
||||
ParseModuleId("75A273B296056EAC7A453C4C5B38C257EA9F4A6E"), //13.1.0
|
||||
};
|
||||
|
||||
constexpr u32 AmCopyrightOffset[] = {
|
||||
0xCA314,
|
||||
0xCB80C,
|
||||
0xCBA8C,
|
||||
};
|
||||
namespace am {
|
||||
constexpr u32 CopyrightOffset[] = {
|
||||
0xCA314,
|
||||
0xCB80C,
|
||||
0xCBA8C,
|
||||
};
|
||||
|
||||
constexpr u8 AmCopyrightPatch[] = { 0xE0, 0x03, 0x1F, 0xAA, 0xC0, 0x03, 0x5F, 0xD6 };
|
||||
constexpr u8 CopyrightPatch[] = { 0xE0, 0x03, 0x1F, 0xAA, 0xC0, 0x03, 0x5F, 0xD6 };
|
||||
}
|
||||
|
||||
constexpr u32 EmcFreqOffsets[][30] = {
|
||||
{ 0xD7C60, 0xD7C68, 0xD7C70, 0xD7C78, 0xD7C80, 0xD7C88, 0xD7C90, 0xD7C98, 0xD7CA0, 0xD7CA8, 0xE1800, 0xEEFA0, 0xF2478, 0xFE284, 0x10A304, 0x10D7DC, 0x110A40, 0x113CA4, 0x116F08, 0x11A16C, 0x11D3D0, 0x120634, 0x123898, 0x126AFC, 0x129D60, 0x12CFC4, 0x130228, 0x13BFE0, 0x140D00, 0x140D50, },
|
||||
{ 0xE1810, 0xE6530, 0xE6580, 0xE6AB0, 0xE6AB8, 0xE6AC0, 0xE6AC8, 0xE6AD0, 0xE6AD8, 0xE6AE0, 0xE6AE8, 0xE6AF0, 0xE6AF8, 0xF0650, 0xFDDF0, 0x1012C8, 0x10D0D4, 0x119154, 0x11C62C, 0x11F890, 0x122AF4, 0x125D58, 0x128FBC, 0x12C220, 0x12F484, 0x1326E8, 0x13594C, 0x138BB0, 0x13BE14, 0x13F078, },
|
||||
{ 0xE1860, 0xE6580, 0xE65D0, 0xE6B00, 0xE6B08, 0xE6B10, 0xE6B18, 0xE6B20, 0xE6B28, 0xE6B30, 0xE6B38, 0xE6B40, 0xE6B48, 0xF06A0, 0xFDE40, 0x101318, 0x10D124, 0x1191A4, 0x11C67C, 0x11F8E0, 0x122B44, 0x125DA8, 0x12900C, 0x12C270, 0x12F4D4, 0x132738, 0x13599C, 0x138C00, 0x13BE64, 0x13F0C8, },
|
||||
};
|
||||
namespace pcv {
|
||||
typedef struct {
|
||||
u32 freq = 0;
|
||||
u32 unk1 = 0;
|
||||
s32 coeffs[6] = {0};
|
||||
u32 volt = 0;
|
||||
u32 unk3[5] = {0};
|
||||
} cpu_freq_cvb_table_t;
|
||||
|
||||
typedef struct {
|
||||
u32 hz = 0;
|
||||
u32 volt = 0;
|
||||
u32 unk[6] = {0};
|
||||
s32 coeffs[6] = {0};
|
||||
} gpu_clock_table_t;
|
||||
typedef struct {
|
||||
u32 freq = 0;
|
||||
u32 volt = 0;
|
||||
u32 unk[6] = {0};
|
||||
s32 coeffs[6] = {0};
|
||||
} gpu_cvb_pll_table_t;
|
||||
|
||||
typedef struct {
|
||||
u32 hz = 0;
|
||||
u32 unk1 = 0;
|
||||
s32 coeffs[6] = {0};
|
||||
u32 volt = 0;
|
||||
u32 unk3[5] = {0};
|
||||
} cpu_clock_table_t;
|
||||
typedef struct {
|
||||
u64 freq;
|
||||
s32 volt[4] = {0};
|
||||
} emc_dvb_dvfs_table_t;
|
||||
|
||||
/* CPU */
|
||||
constexpr u32 CpuVoltageLimitOffsets[][11] = {
|
||||
{ 0xE1A8C, 0xE1A98, 0xE1AA4, 0xE1AB0, 0xE1AF8, 0xE1B04, 0xE1B10, 0xE1B1C, 0xE1B28, 0xE1B34, 0xE1F4C },
|
||||
{ 0xF08DC, 0xF08E8, 0xF08F4, 0xF0900, 0xF0948, 0xF0954, 0xF0960, 0xF096C, 0xF0978, 0xF0984, 0xF0D9C },
|
||||
{ 0xF092C, 0xF0938, 0xF0944, 0xF0950, 0xF0998, 0xF09A4, 0xF09B0, 0xF09BC, 0xF09C8, 0xF09D4, 0xF0DEC },
|
||||
};
|
||||
constexpr u32 NewCpuVoltageLimit = 1220;
|
||||
static_assert(NewCpuVoltageLimit <= 1300); //1300mV hangs for me
|
||||
/* CPU */
|
||||
constexpr u32 CpuVoltageLimitOffsets[][11] = {
|
||||
{ 0xE1A8C, 0xE1A98, 0xE1AA4, 0xE1AB0, 0xE1AF8, 0xE1B04, 0xE1B10, 0xE1B1C, 0xE1B28, 0xE1B34, 0xE1F4C },
|
||||
{ 0xF08DC, 0xF08E8, 0xF08F4, 0xF0900, 0xF0948, 0xF0954, 0xF0960, 0xF096C, 0xF0978, 0xF0984, 0xF0D9C },
|
||||
{ 0xF092C, 0xF0938, 0xF0944, 0xF0950, 0xF0998, 0xF09A4, 0xF09B0, 0xF09BC, 0xF09C8, 0xF09D4, 0xF0DEC },
|
||||
};
|
||||
constexpr u32 NewCpuVoltageLimit = 1220;
|
||||
static_assert(NewCpuVoltageLimit <= 1300); //1300mV hangs for me
|
||||
|
||||
constexpr u32 CpuVoltageOldTableCoeff[][10] = {
|
||||
{ 0xE2140, 0xE2178, 0xE21B0, 0xE21E8, 0xE2220, 0xE2258, 0xE2290, 0xE22C8, 0xE2300, 0xE2338 },
|
||||
{ 0xF0F90, 0xF0FC8, 0xF1000, 0xF1038, 0xF1070, 0xF10A8, 0xF10E0, 0xF1118, 0xF1150, 0xF1188 },
|
||||
{ 0xF0FE0, 0xF1018, 0xF1050, 0xF1088, 0xF10C0, 0xF10F8, 0xF1130, 0xF1168, 0xF11A0, 0xF11D8 },
|
||||
};
|
||||
constexpr u32 NewCpuVoltageCoeff = NewCpuVoltageLimit * 1000;
|
||||
constexpr u32 CpuVoltageOldTableCoeff[][10] = {
|
||||
{ 0xE2140, 0xE2178, 0xE21B0, 0xE21E8, 0xE2220, 0xE2258, 0xE2290, 0xE22C8, 0xE2300, 0xE2338 },
|
||||
{ 0xF0F90, 0xF0FC8, 0xF1000, 0xF1038, 0xF1070, 0xF10A8, 0xF10E0, 0xF1118, 0xF1150, 0xF1188 },
|
||||
{ 0xF0FE0, 0xF1018, 0xF1050, 0xF1088, 0xF10C0, 0xF10F8, 0xF1130, 0xF1168, 0xF11A0, 0xF11D8 },
|
||||
};
|
||||
constexpr u32 NewCpuVoltageCoeff = NewCpuVoltageLimit * 1000;
|
||||
|
||||
constexpr u32 CpuTablesFreeSpace[] = {
|
||||
0xE2350,
|
||||
0xF11A0,
|
||||
0xF11F0,
|
||||
};
|
||||
constexpr cpu_clock_table_t NewCpuTables[] = {
|
||||
{ 2091000, 0, {1719782, -40440, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2193000, 0, {1809766, -41939, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2295000, 0, {1904458, -43439, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2397000, 0, {2004105, -44938, 27}, NewCpuVoltageCoeff, {} },
|
||||
// calculated using linear regression:
|
||||
// coeffs[0]=604531*exp(0.0000005*hz)
|
||||
// coeffs[1]=-0.0147*hz-9702.1
|
||||
};
|
||||
static_assert(sizeof(NewCpuTables) <= sizeof(cpu_clock_table_t)*14);
|
||||
constexpr u32 CpuTablesFreeSpace[] = {
|
||||
0xE2350,
|
||||
0xF11A0,
|
||||
0xF11F0,
|
||||
};
|
||||
// TODO: correctly derive c0-c2 coefficients
|
||||
constexpr cpu_freq_cvb_table_t NewCpuTables[] = {
|
||||
{ 2091000, 0, {1719782, -40440, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2193000, 0, {1809766, -41939, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2295000, 0, {1904458, -43439, 27}, NewCpuVoltageCoeff, {} },
|
||||
{ 2397000, 0, {2004105, -44938, 27}, NewCpuVoltageCoeff, {} },
|
||||
};
|
||||
static_assert(sizeof(NewCpuTables) <= sizeof(cpu_freq_cvb_table_t)*14);
|
||||
|
||||
constexpr u32 MaxCpuClockOffset[] = {
|
||||
0xE2740,
|
||||
0xF1590,
|
||||
0xF15E0,
|
||||
};
|
||||
constexpr u32 NewMaxCpuClock = 2397000;
|
||||
constexpr u32 MaxCpuClockOffset[] = {
|
||||
0xE2740,
|
||||
0xF1590,
|
||||
0xF15E0,
|
||||
};
|
||||
constexpr u32 NewMaxCpuClock = 2397000;
|
||||
|
||||
/* GPU */
|
||||
constexpr u32 GpuTablesFreeSpace[] = {
|
||||
0xE3410,
|
||||
0xF2260,
|
||||
0xF22B0,
|
||||
};
|
||||
constexpr gpu_clock_table_t NewGpuTables[] = {
|
||||
{ 1305600, 0, {}, {1380113, -13465, -874, 0, 2580, 648} },
|
||||
{ 1344000, 0, {}, {1420000, -14000, -870, 0, 2193, 824} },
|
||||
// some arbitrary coeffs I guessed and tested, YMMV
|
||||
};
|
||||
static_assert(sizeof(NewGpuTables) <= sizeof(gpu_clock_table_t)*15);
|
||||
/* GPU */
|
||||
constexpr u32 GpuTablesFreeSpace[] = {
|
||||
0xE3410,
|
||||
0xF2260,
|
||||
0xF22B0,
|
||||
};
|
||||
// TODO: correctly derive c0-c5 coefficients
|
||||
constexpr gpu_cvb_pll_table_t NewGpuTables[] = {
|
||||
{ 1305600, 0, {}, {1380113, -13465, -874, 0, 2580, 648} },
|
||||
{ 1344000, 0, {}, {1420000, -14000, -870, 0, 2193, 824} },
|
||||
};
|
||||
static_assert(sizeof(NewGpuTables) <= sizeof(gpu_cvb_pll_table_t)*15);
|
||||
|
||||
constexpr u32 Reg1MaxGpuOffset[] = {
|
||||
0x2E0AC,
|
||||
0x3F6CC,
|
||||
0x3F12C,
|
||||
};
|
||||
constexpr u8 Reg1NewMaxGpuClock[][0xC] = {
|
||||
// Original: 1267MHz
|
||||
/*
|
||||
MOV W13,#0x5600
|
||||
MOVK W13,#0x13,LSL #16
|
||||
NOP
|
||||
*/
|
||||
// Bump to 1536MHz
|
||||
/*
|
||||
MOV W13,#0x7000
|
||||
MOVK W13,#0x17,LSL #16
|
||||
NOP
|
||||
*/
|
||||
//0x0D, 0xC0, 0x8A, 0x52, 0x6D, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5
|
||||
{ 0x0D, 0x00, 0x8E, 0x52, 0xED, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
};
|
||||
constexpr u32 Reg1MaxGpuOffset[] = {
|
||||
0x2E0AC,
|
||||
0x3F6CC,
|
||||
0x3F12C,
|
||||
};
|
||||
constexpr u8 Reg1NewMaxGpuClock[][0xC] = {
|
||||
/* Original: 1267MHz
|
||||
*
|
||||
* MOV W13,#0x5600
|
||||
* MOVK W13,#0x13,LSL #16
|
||||
* NOP
|
||||
*
|
||||
* Bump to 1536MHz
|
||||
*
|
||||
* MOV W13,#0x7000
|
||||
* MOVK W13,#0x17,LSL #16
|
||||
* NOP
|
||||
*/
|
||||
{ 0x0D, 0x00, 0x8E, 0x52, 0xED, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, 0x1F, 0x20, 0x03, 0xD5 },
|
||||
};
|
||||
|
||||
constexpr u32 Reg2MaxGpuOffset[] = {
|
||||
0x2E110,
|
||||
0x3F730,
|
||||
0x3F190,
|
||||
};
|
||||
constexpr u8 Reg2NewMaxGpuClock[][0x8] = {
|
||||
// Original: 1267MHz
|
||||
/*
|
||||
MOV W13,#0x5600
|
||||
MOVK W13,#0x13,LSL #16
|
||||
*/
|
||||
// Bump to 1536MHz
|
||||
/*
|
||||
MOV W13,#0x7000
|
||||
MOVK W13,#0x17,LSL #16
|
||||
*/
|
||||
//0x0D, 0xC0, 0x8A, 0x52, 0x6D, 0x02, 0xA0, 0x72
|
||||
{ 0x0D, 0x00, 0x8E, 0x52, 0xED, 0x02, 0xA0, 0x72, },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, },
|
||||
};
|
||||
constexpr u32 Reg2MaxGpuOffset[] = {
|
||||
0x2E110,
|
||||
0x3F730,
|
||||
0x3F190,
|
||||
};
|
||||
constexpr u8 Reg2NewMaxGpuClock[][0x8] = {
|
||||
/* Original: 1267MHz
|
||||
*
|
||||
* MOV W13,#0x5600
|
||||
* MOVK W13,#0x13,LSL #16
|
||||
*
|
||||
* Bump to 1536MHz
|
||||
*
|
||||
* MOV W13,#0x7000
|
||||
* MOVK W13,#0x17,LSL #16
|
||||
*/
|
||||
{ 0x0D, 0x00, 0x8E, 0x52, 0xED, 0x02, 0xA0, 0x72, },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, },
|
||||
{ 0x0B, 0x00, 0x8E, 0x52, 0xEB, 0x02, 0xA0, 0x72, },
|
||||
};
|
||||
|
||||
constexpr u32 PtmEmcOffsetStart[] = {
|
||||
0xC5E24,
|
||||
0xA032C,
|
||||
};
|
||||
/* EMC */
|
||||
// constexpr u32 EmcDvbTableOffsets[] =
|
||||
// {
|
||||
// 0xFFFFFFFF,
|
||||
// 0xFFFFFFFF,
|
||||
// 0xF0628,
|
||||
// };
|
||||
|
||||
constexpr u32 PtmOffsetInterval = 0x20;
|
||||
// constexpr emc_dvb_dvfs_table_t EmcDvbTable[6] =
|
||||
// {
|
||||
// { 204000, { 637, 637, 637, } },
|
||||
// { 408000, { 637, 637, 637, } },
|
||||
// { 800000, { 637, 637, 637, } },
|
||||
// { 1065600, { 637, 637, 637, } },
|
||||
// { 1331200, { 650, 637, 637, } },
|
||||
// { 1600000, { 675, 650, 637, } },
|
||||
// };
|
||||
|
||||
constexpr u32 PtmCpuBoostOffset = 0x170;
|
||||
// Sourced from 13.x pcv module
|
||||
// 1st regulator table, 0x142778 - 0x143BB4, if mask = 0b0110101
|
||||
// 2nd regulator table, 0x143BB8 - 0x144FF4, if mask = 0b1010011
|
||||
|
||||
// Access pattern:
|
||||
// BL 0x6C390 // read mask from 0x195588 (.bss section) and return X0 (address of regulator table)
|
||||
// MOV W8, #0x120 // offset per entry
|
||||
// (S)MADD(L) X8, X22, X8, X0 // X8 = X22 * X8 + X0, X22 is regulator entry ID (0x11 for max77812_dram)
|
||||
// LDR W8, [X8, #0x10] // read maxim regulator identifier
|
||||
// CMP W8, #3
|
||||
// B.EQ ...
|
||||
|
||||
// 1st regulator table:
|
||||
// 0x143A98 2 #0x0
|
||||
// 0x143A9C 0 #0x4
|
||||
// 0x143AA0 "max77812_dram" #0x8
|
||||
// 0x143AA8 3 #0x10 // maxim regulator identifier ( 1 = max77620, 2 = max77621, 3 = max77812)
|
||||
// 0x143AAC 0 #0x14
|
||||
// 0x143AB0 5000 #0x18 // voltage step
|
||||
// 0x143AB4 0 #0x1C
|
||||
// 0x143AB8 250000 #0x20 // min voltage
|
||||
// 0x143ABC 1525000 #0x24 // max voltage
|
||||
// 0x143AC0 0 #0x28 // voltage multiplier ( * step )
|
||||
// 0x143AC4 600000 #0x2C // default voltage (not likely)
|
||||
|
||||
// 0x142898 1 #0x0
|
||||
// 0x14289C 0 #0x4
|
||||
// 0x1428A0 "max77620_sd1" #0x8
|
||||
// 0x1428A8 1 #0x10 // maxim regulator identifier ( 1 = max77620, 2 = max77621, 3 = max77812)
|
||||
// 0x1428AC 23 #0x14
|
||||
// 0x1428B0 12500 #0x18 // voltage step
|
||||
// 0x1428B4 600000 #0x1C
|
||||
// 0x1428B8 1125000 #0x20 // min voltage, default voltage for Erista EMC
|
||||
// 0x1428BC 1125000 #0x24 // max voltage, default voltage for Erista EMC
|
||||
// 0x1428C0 0 #0x28
|
||||
// 0x1428C4 0 #0x2C
|
||||
|
||||
// 0x143858 0 #0x0
|
||||
// 0x14385C 0 #0x4
|
||||
// 0x143860 "max77812_cpu" #0x8
|
||||
// 0x143868 3 #0x10 // maxim regulator identifier ( 1 = max77620, 2 = max77621, 3 = max77812)
|
||||
// 0x14386C 0 #0x14
|
||||
// 0x143870 5000 #0x18 // voltage step
|
||||
// 0x143874 0 #0x1C
|
||||
// 0x143878 250000 #0x20 // min voltage
|
||||
// 0x14387C 1525000 #0x24 // max voltage
|
||||
// 0x143880 0 #0x28 // voltage multiplier ( * step )
|
||||
// 0x143884 1000000 #0x2C
|
||||
|
||||
// 0x143978 2 #0x0
|
||||
// 0x14397C 0 #0x4
|
||||
// 0x143980 "max77812_gpu" #0x8
|
||||
// 0x143988 3 #0x10 // maxim regulator identifier ( 1 = max77620, 2 = max77621, 3 = max77812)
|
||||
// 0x14398C 0 #0x14
|
||||
// 0x143990 5000 #0x18 // voltage step
|
||||
// 0x143994 0 #0x1C
|
||||
// 0x143998 250000 #0x20 // min voltage
|
||||
// 0x14399C 1525000 #0x24 // max voltage
|
||||
// 0x1439A0 0 #0x28 // voltage multiplier ( * step )
|
||||
// 0x1439A4 800000 #0x2C
|
||||
|
||||
constexpr u32 EmcFreqOffsets[][30] = {
|
||||
{ 0xD7C60, 0xD7C68, 0xD7C70, 0xD7C78, 0xD7C80, 0xD7C88, 0xD7C90, 0xD7C98, 0xD7CA0, 0xD7CA8, 0xE1800, 0xEEFA0, 0xF2478, 0xFE284, 0x10A304, 0x10D7DC, 0x110A40, 0x113CA4, 0x116F08, 0x11A16C, 0x11D3D0, 0x120634, 0x123898, 0x126AFC, 0x129D60, 0x12CFC4, 0x130228, 0x13BFE0, 0x140D00, 0x140D50, },
|
||||
{ 0xE1810, 0xE6530, 0xE6580, 0xE6AB0, 0xE6AB8, 0xE6AC0, 0xE6AC8, 0xE6AD0, 0xE6AD8, 0xE6AE0, 0xE6AE8, 0xE6AF0, 0xE6AF8, 0xF0650, 0xFDDF0, 0x1012C8, 0x10D0D4, 0x119154, 0x11C62C, 0x11F890, 0x122AF4, 0x125D58, 0x128FBC, 0x12C220, 0x12F484, 0x1326E8, 0x13594C, 0x138BB0, 0x13BE14, 0x13F078, },
|
||||
{ 0xE1860, 0xE6580, 0xE65D0, 0xE6B00, 0xE6B08, 0xE6B10, 0xE6B18, 0xE6B20, 0xE6B28, 0xE6B30, 0xE6B38, 0xE6B40, 0xE6B48, 0xF06A0, 0xFDE40, 0x101318, 0x10D124, 0x1191A4, 0x11C67C, 0x11F8E0, 0x122B44, 0x125DA8, 0x12900C, 0x12C270, 0x12F4D4, 0x132738, 0x13599C, 0x138C00, 0x13BE64, 0x13F0C8, },
|
||||
};
|
||||
}
|
||||
|
||||
namespace ptm {
|
||||
constexpr u32 EmcOffsetStart[] = {
|
||||
0xC5E24,
|
||||
0xA032C,
|
||||
};
|
||||
|
||||
constexpr u32 OffsetInterval = 0x20;
|
||||
|
||||
constexpr u32 CpuBoostOffset = 0x170;
|
||||
}
|
||||
@@ -159,26 +159,30 @@ namespace ams::ldr {
|
||||
for (u32 i = 0; i < sizeof(PcvModuleId)/sizeof(ro::ModuleId); i++) {
|
||||
if (std::memcmp(std::addressof(PcvModuleId[i]), std::addressof(module_id), sizeof(module_id)) == 0) {
|
||||
/* Add new CPU and GPU clock tables for Mariko */
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + CpuTablesFreeSpace[i]), NewCpuTables, sizeof(NewCpuTables));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + GpuTablesFreeSpace[i]), NewGpuTables, sizeof(NewGpuTables));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::CpuTablesFreeSpace[i]), pcv::NewCpuTables, sizeof(pcv::NewCpuTables));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::GpuTablesFreeSpace[i]), pcv::NewGpuTables, sizeof(pcv::NewGpuTables));
|
||||
|
||||
/* Patch Mariko max CPU and GPU clockrates */
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + MaxCpuClockOffset[i]), &NewMaxCpuClock, sizeof(NewMaxCpuClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + Reg1MaxGpuOffset[i]), Reg1NewMaxGpuClock, sizeof(Reg1NewMaxGpuClock[i]));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + Reg2MaxGpuOffset[i]), Reg2NewMaxGpuClock, sizeof(Reg2NewMaxGpuClock[i]));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::MaxCpuClockOffset[i]), &pcv::NewMaxCpuClock, sizeof(pcv::NewMaxCpuClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::Reg1MaxGpuOffset[i]), pcv::Reg1NewMaxGpuClock, sizeof(pcv::Reg1NewMaxGpuClock[i]));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::Reg2MaxGpuOffset[i]), pcv::Reg2NewMaxGpuClock, sizeof(pcv::Reg2NewMaxGpuClock[i]));
|
||||
|
||||
/* Patch max cpu voltage on Mariko */
|
||||
for (u32 j = 0; j < sizeof(CpuVoltageLimitOffsets[i])/sizeof(u32); j++) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + CpuVoltageLimitOffsets[i][j]), &NewCpuVoltageLimit, sizeof(NewCpuVoltageLimit));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::CpuVoltageLimitOffsets[i][j]), &pcv::NewCpuVoltageLimit, sizeof(pcv::NewCpuVoltageLimit));
|
||||
}
|
||||
for (u32 j = 0; j < sizeof(CpuVoltageOldTableCoeff[i])/sizeof(u32); j++) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + CpuVoltageOldTableCoeff[i][j]), &NewCpuVoltageCoeff, sizeof(NewCpuVoltageCoeff));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::CpuVoltageOldTableCoeff[i][j]), &pcv::NewCpuVoltageCoeff, sizeof(pcv::NewCpuVoltageCoeff));
|
||||
}
|
||||
|
||||
/* Patch RAM Clock */
|
||||
for (u32 j = 0; j < sizeof(EmcFreqOffsets[i])/sizeof(u32); j++) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + EmcFreqOffsets[i][j]), &EmcClock, sizeof(EmcClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::EmcFreqOffsets[i][j]), &EmcClock, sizeof(EmcClock));
|
||||
}
|
||||
|
||||
/* Patch RAM DVB table */
|
||||
//if (i == 2)
|
||||
// std::memcpy(reinterpret_cast<void *>(mapped_nso + pcv::EmcDvbTableOffsets[2]), pcv::EmcDvbTable, sizeof(pcv::EmcDvbTable));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -189,12 +193,12 @@ namespace ams::ldr {
|
||||
for (u32 i = 0; i < sizeof(PtmModuleId)/sizeof(ro::ModuleId); i++) {
|
||||
if (std::memcmp(std::addressof(PtmModuleId[i]), std::addressof(module_id), sizeof(module_id)) == 0) {
|
||||
for (u32 j = 0; j < 16; j++) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + PtmEmcOffsetStart[i] + PtmOffsetInterval * j), &EmcClock, sizeof(EmcClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + PtmEmcOffsetStart[i] + PtmOffsetInterval * j + 0x4), &EmcClock, sizeof(EmcClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + ptm::EmcOffsetStart[i] + Ptm::OffsetInterval * j), &EmcClock, sizeof(EmcClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + ptm::EmcOffsetStart[i] + Ptm::OffsetInterval * j + 0x4), &EmcClock, sizeof(EmcClock));
|
||||
}
|
||||
for (u32 j = 0; j < 2; j++) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + PtmEmcOffsetStart[i] + PtmCpuBoostOffset + PtmOffsetInterval * j), &CpuBoostClock, sizeof(CpuBoostClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + PtmEmcOffsetStart[i] + PtmCpuBoostOffset + PtmOffsetInterval * j + 0x4), &CpuBoostClock, sizeof(CpuBoostClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + ptm::EmcOffsetStart[i] + Ptm::CpuBoostOffset + Ptm::OffsetInterval * j), &CpuBoostClock, sizeof(CpuBoostClock));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + ptm::EmcOffsetStart[i] + Ptm::CpuBoostOffset + Ptm::OffsetInterval * j + 0x4), &CpuBoostClock, sizeof(CpuBoostClock));
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -202,7 +206,7 @@ namespace ams::ldr {
|
||||
|
||||
for (u32 i = 0; i < sizeof(AmModuleId)/sizeof(ro::ModuleId); i++) {
|
||||
if(std::memcmp(std::addressof(AmModuleId[i]), std::addressof(module_id), sizeof(module_id)) == 0) {
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + AmCopyrightOffset[i]), AmCopyrightPatch, sizeof(AmCopyrightPatch));
|
||||
std::memcpy(reinterpret_cast<void *>(mapped_nso + am::CopyrightOffset[i]), am::CopyrightPatch, sizeof(Am::CopyrightPatch));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user