Fix tW2R and tR2W patch and multiple ram freqs
This commit is contained in:
2
LICENSE
2
LICENSE
@@ -4,7 +4,7 @@
|
||||
|
||||
- Tinymembench is under MIT license, which is compatible with GPL v2.
|
||||
|
||||
- Although "sys-clk" uses permissive license, all modifications towards it in this repo ("sys-clk-OC") are licensed under GPL v2.
|
||||
- Although "sys-clk" uses permissive license, all modifications towards it in this repo ("Horizon OC") are licensed under GPL v2.
|
||||
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
@@ -40,7 +40,7 @@ volatile CustomizeTable C = {
|
||||
* Value should be divided evenly by 12'500.
|
||||
* Not enabled by default.
|
||||
*/
|
||||
.commonEmcMemVolt = 1237500,
|
||||
.commonEmcMemVolt = 1175000,
|
||||
|
||||
/* Erista CPU:
|
||||
* - Max Voltage in mV
|
||||
@@ -57,11 +57,11 @@ volatile CustomizeTable C = {
|
||||
* - NAND corruption
|
||||
*/
|
||||
|
||||
.eristaEmcClock1 = 1862400, // Lowest
|
||||
.eristaEmcClock1 = 1996800, // Lowest
|
||||
|
||||
.eristaEmcClock2 = 1996800, // Middle
|
||||
.eristaEmcClock2 = 2032640, // Middle
|
||||
|
||||
.eristaEmcClock3 = 2132640, // Highest
|
||||
.eristaEmcClock3 = 2232640, // Highest
|
||||
|
||||
|
||||
/* Mariko CPU:
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
@@ -161,8 +161,8 @@
|
||||
table->burst_mc_regs.mc_emem_arb_timing_rrd = CEIL(GET_CYCLE_CEIL(tRRD) / MC_ARB_DIV) - 1;
|
||||
table->burst_mc_regs.mc_emem_arb_timing_rap2pre = CEIL(GET_CYCLE_CEIL(tRTP) / MC_ARB_DIV);
|
||||
table->burst_mc_regs.mc_emem_arb_timing_wap2pre = CEIL(WTP / MC_ARB_DIV);
|
||||
// table->burst_mc_regs.mc_emem_arb_timing_r2r = CEIL(table->burst_regs.emc_rext / MC_ARB_DIV) - 1 + MC_ARB_SFA;
|
||||
// table->burst_mc_regs.mc_emem_arb_timing_w2w = CEIL(table->burst_regs.emc_wext / MC_ARB_DIV) - 1 + MC_ARB_SFA;
|
||||
table->burst_mc_regs.mc_emem_arb_timing_r2r = CEIL(table->burst_regs.emc_rext / MC_ARB_DIV) - 1 + MC_ARB_SFA; // ocs does not patch this
|
||||
table->burst_mc_regs.mc_emem_arb_timing_w2w = CEIL(table->burst_regs.emc_wext / MC_ARB_DIV) - 1 + MC_ARB_SFA;
|
||||
table->burst_mc_regs.mc_emem_arb_timing_r2w = CEIL(R2W / MC_ARB_DIV) - 1 + MC_ARB_SFA;
|
||||
table->burst_mc_regs.mc_emem_arb_timing_w2r = CEIL(W2R / MC_ARB_DIV) - 1 + MC_ARB_SFA;
|
||||
table->burst_mc_regs.mc_emem_arb_timing_rfcpb = CEIL(GET_CYCLE_CEIL(tRFCpb) / MC_ARB_DIV);
|
||||
@@ -257,9 +257,9 @@
|
||||
R_UNLESS(table_list[i]->rev == MTC_TABLE_REV, ldr::ResultInvalidMtcTable());
|
||||
}
|
||||
|
||||
if (C.eristaEmcClock1 <= EmcClkOSLimit ||
|
||||
C.eristaEmcClock2 <= EmcClkOSLimit ||
|
||||
C.eristaEmcClock3 <= EmcClkOSLimit)
|
||||
if (C.eristaEmcClock1 >= EmcClkOSLimit ||
|
||||
C.eristaEmcClock2 >= EmcClkOSLimit ||
|
||||
C.eristaEmcClock3 >= EmcClkOSLimit)
|
||||
R_SKIP();
|
||||
|
||||
// Make room for three new mtc tables, discarding useless 40.8, 68.0, and 102 MHz tables
|
||||
@@ -278,11 +278,11 @@
|
||||
u32 *patch_ptr2 = ptr - sizeof(EristaMtcTable) / sizeof(u32);
|
||||
u32 *patch_ptr3 = ptr - 2 * (sizeof(EristaMtcTable) / sizeof(u32));
|
||||
|
||||
if (C.eristaEmcClock3 > EmcClkOSLimit)
|
||||
if (C.eristaEmcClock3 < EmcClkOSLimit)
|
||||
PATCH_OFFSET(patch_ptr1, C.eristaEmcClock3);
|
||||
if (C.eristaEmcClock2 > EmcClkOSLimit)
|
||||
if (C.eristaEmcClock2 < EmcClkOSLimit)
|
||||
PATCH_OFFSET(patch_ptr2, C.eristaEmcClock2);
|
||||
if (C.eristaEmcClock3 > EmcClkOSLimit)
|
||||
if (C.eristaEmcClock3 < EmcClkOSLimit)
|
||||
PATCH_OFFSET(patch_ptr3, C.eristaEmcClock1);
|
||||
|
||||
// Handle customize table replacement
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* Copyright (c) 2023 hanai3Bi
|
||||
*
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) Switch-OC-Suite
|
||||
* Copyright (c) Horizon OC Contributors
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
|
||||
@@ -33,7 +33,7 @@ AboutTab::AboutTab()
|
||||
// Subtitle
|
||||
brls::Label *subTitle = new brls::Label(
|
||||
brls::LabelStyle::REGULAR,
|
||||
"Nintendo Switch overclocking / underclocking system module and frontend app by the RetroNX Team",
|
||||
"Nittendo Switch Overclocking tool by Souldbminer based on sys-clk by RetroNX",
|
||||
true
|
||||
);
|
||||
subTitle->setHorizontalAlign(NVG_ALIGN_CENTER);
|
||||
@@ -42,9 +42,9 @@ AboutTab::AboutTab()
|
||||
// Copyright
|
||||
brls::Label *copyright = new brls::Label(
|
||||
brls::LabelStyle::DESCRIPTION,
|
||||
"System module licensed under the Beerware license\n" \
|
||||
"System module licensed under the GPLv2\n" \
|
||||
"Frontend app licensed under GPL-3.0\n" \
|
||||
"\u00A9 2019 - 2020 natinusala, p-sam, m4xw",
|
||||
"\u00A9 2019 - 2020 natinusala, p-sam, m4xw, \u00A9 2025 Souldbminer",
|
||||
true
|
||||
);
|
||||
copyright->setHorizontalAlign(NVG_ALIGN_CENTER);
|
||||
@@ -54,9 +54,9 @@ AboutTab::AboutTab()
|
||||
this->addView(new brls::Header("Links and Resources"));
|
||||
brls::Label *links = new brls::Label(
|
||||
brls::LabelStyle::SMALL,
|
||||
"\uE016 User guide and code source can be found on our GitHub repository\n" \
|
||||
"\uE016 The sys-clk manager is powered by Borealis, an hardware accelerated UI library\n" \
|
||||
"\uE016 Join the RetroNX Discord server for support, to request features or just hang out!",
|
||||
"\uE016 User guide and code source can be found on my GitHub repository (souldbminersmwc/horizon-oc)\n" \
|
||||
"\uE016 The Horizon OC manager is powered by Borealis, an hardware accelerated UI library\n" \
|
||||
"\uE016 Join the OC Discord server for support, to request features or just hang out!",
|
||||
true
|
||||
);
|
||||
this->addView(links);
|
||||
|
||||
@@ -54,24 +54,24 @@ int main(int argc, char* argv[])
|
||||
// Check that sys-clk is running
|
||||
if (!sysclkIpcRunning())
|
||||
{
|
||||
brls::Logger::error("sys-clk is not running");
|
||||
brls::Application::crash("sys-clk does not seem to be running, please check that it is correctly installed and enabled.");
|
||||
brls::Logger::error("Horizon OC is not running");
|
||||
brls::Application::crash("Horizon OC does not seem to be running, please check that it is correctly installed and enabled.");
|
||||
}
|
||||
// Initialize sys-clk IPC client
|
||||
else if (R_FAILED(sysclkIpcInitialize()) || R_FAILED(sysclkIpcGetAPIVersion(&apiVersion)))
|
||||
{
|
||||
brls::Logger::error("Unable to initialize sys-clk IPC client");
|
||||
brls::Application::crash("Could not connect to sys-clk, please check that it is correctly installed and enabled.");
|
||||
brls::Logger::error("Unable to initialize Horizon OC IPC client");
|
||||
brls::Application::crash("Could not connect to Horizon OC, please check that it is correctly installed and enabled.");
|
||||
}
|
||||
else if (SYSCLK_IPC_API_VERSION != apiVersion)
|
||||
{
|
||||
brls::Logger::error("sys-clk IPC API version mismatch (expected: %u; actual: %u)", SYSCLK_IPC_API_VERSION, apiVersion);
|
||||
brls::Application::crash("The manager is not compatible with the currently running sysmodule of sys-clk, please check that you have correctly installed the latest version (reboot?).");
|
||||
brls::Logger::error("Horizon OC IPC API version mismatch (expected: %u; actual: %u)", SYSCLK_IPC_API_VERSION, apiVersion);
|
||||
brls::Application::crash("The manager is not compatible with the currently running sysmodule of Horizon OC, please check that you have correctly installed the latest version (reboot?).");
|
||||
}
|
||||
else if (R_FAILED(cacheFreqList()))
|
||||
{
|
||||
brls::Logger::error("Failed to get the freq list from sys-clk");
|
||||
brls::Application::crash("Failed to get the freq list from sys-clk, please check that you have correctly installed the latest version (reboot?).");
|
||||
brls::Logger::error("Failed to get the freq list from Horizon OC");
|
||||
brls::Application::crash("Failed to get the freq list from Horizon OC, please check that you have correctly installed the latest version (reboot?).");
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -84,7 +84,7 @@ int main(int argc, char* argv[])
|
||||
}
|
||||
else
|
||||
{
|
||||
brls::Logger::error("Unable to get sys-clk version string");
|
||||
brls::Logger::error("Unable to get Horizon OC version string");
|
||||
brls::Application::setCommonFooter("[unknown]");
|
||||
}
|
||||
|
||||
|
||||
@@ -40,7 +40,7 @@ class AppOverlay : public tsl::Overlay
|
||||
if(!sysclkIpcRunning())
|
||||
{
|
||||
return initially<FatalGui>(
|
||||
"sys-clk is not running.\n\n"
|
||||
"Horizon OC is not running.\n\n"
|
||||
"\n"
|
||||
"Please make sure it is correctly\n\n"
|
||||
"installed and enabled.",
|
||||
@@ -51,7 +51,7 @@ class AppOverlay : public tsl::Overlay
|
||||
if(R_FAILED(sysclkIpcInitialize()) || R_FAILED(sysclkIpcGetAPIVersion(&apiVersion)))
|
||||
{
|
||||
return initially<FatalGui>(
|
||||
"Could not connect to sys-clk.\n\n"
|
||||
"Could not connect to Horizon OC.\n\n"
|
||||
"\n"
|
||||
"Please make sure it is correctly\n\n"
|
||||
"installed and enabled.",
|
||||
@@ -63,7 +63,7 @@ class AppOverlay : public tsl::Overlay
|
||||
{
|
||||
return initially<FatalGui>(
|
||||
"Overlay not compatible with\n\n"
|
||||
"the running sys-clk version.\n\n"
|
||||
"the running Horizon OC version.\n\n"
|
||||
"\n"
|
||||
"Please make sure everything is\n\n"
|
||||
"installed and up to date.",
|
||||
|
||||
@@ -80,6 +80,7 @@
|
||||
uint32_t unsafe_gpu;
|
||||
uint32_t danger_cpu;
|
||||
uint32_t danger_gpu;
|
||||
|
||||
if (IsMariko())
|
||||
{
|
||||
unsafe_cpu = 1964;
|
||||
@@ -92,7 +93,7 @@
|
||||
unsafe_cpu = 1786;
|
||||
unsafe_gpu = 922;
|
||||
danger_cpu = 2092;
|
||||
danger_gpu = 999;
|
||||
danger_gpu = 1076;
|
||||
}
|
||||
|
||||
if (moduleName == "cpu") {
|
||||
|
||||
@@ -80,7 +80,7 @@ void MainGui::listUI()
|
||||
|
||||
return false;
|
||||
});
|
||||
this->listElement->addItem(miscItem);
|
||||
// this->listElement->addItem(miscItem);
|
||||
}
|
||||
|
||||
void MainGui::refresh()
|
||||
|
||||
Reference in New Issue
Block a user