2019-08-06 20:26:28 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2019 Atmosphère-NX
|
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include "core_ctx.h"
|
2020-01-17 22:10:26 +00:00
|
|
|
#include "platform/stage2.h"
|
|
|
|
#include "platform/devices.h"
|
2019-08-06 20:26:28 +00:00
|
|
|
#include "sysreg.h"
|
|
|
|
#include "utils.h"
|
|
|
|
|
2020-01-17 22:10:26 +00:00
|
|
|
// BSS includes real bss and tmp bss
|
|
|
|
extern u8 __bss_start__[], __real_bss_end__[], __bss_end__[];
|
2019-08-06 20:26:28 +00:00
|
|
|
|
|
|
|
static void initSysregs(void)
|
|
|
|
{
|
|
|
|
// Set system to sane defaults, aarch64 for el1, mmu&caches initially disabled for EL1, etc.
|
2020-01-12 21:51:50 +00:00
|
|
|
SET_SYSREG(hcr_el2, 0x80000000);
|
|
|
|
SET_SYSREG(dacr32_el2, 0xFFFFFFFF); // unused
|
|
|
|
SET_SYSREG(sctlr_el1, 0x00C50838);
|
2019-08-06 20:26:28 +00:00
|
|
|
|
2020-01-12 21:51:50 +00:00
|
|
|
SET_SYSREG(mdcr_el2, 0x00000000);
|
|
|
|
SET_SYSREG(mdscr_el1, 0x00000000);
|
2020-01-08 22:18:56 +00:00
|
|
|
|
2020-01-12 21:51:50 +00:00
|
|
|
// Timer stuff
|
|
|
|
SET_SYSREG(cntvoff_el2, 0x00000000);
|
|
|
|
SET_SYSREG(cnthctl_el2, 0x00000003); // Don't trap anything for now; event streams disabled
|
|
|
|
SET_SYSREG(cntkctl_el1, 0x00000003); // Don't trap anything for now; event streams disabled
|
|
|
|
SET_SYSREG(cntp_ctl_el0, 0x00000000);
|
|
|
|
SET_SYSREG(cntv_ctl_el0, 0x00000000);
|
2020-01-15 02:42:07 +00:00
|
|
|
|
2020-01-20 02:24:02 +00:00
|
|
|
__dsb_local();
|
2020-01-15 02:42:07 +00:00
|
|
|
__isb();
|
2019-08-06 20:26:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void initSystem(u32 coreId, bool isBootCore, u64 argument)
|
|
|
|
{
|
|
|
|
coreCtxInit(coreId, isBootCore, argument);
|
|
|
|
initSysregs();
|
|
|
|
|
|
|
|
if (isBootCore) {
|
|
|
|
if (!currentCoreCtx->warmboot) {
|
2020-01-17 22:10:26 +00:00
|
|
|
memset(__bss_start__, 0, __real_bss_end__ - __bss_start__);
|
2019-08-06 20:26:28 +00:00
|
|
|
}
|
|
|
|
|
2020-01-17 22:10:26 +00:00
|
|
|
memset(__real_bss_end__, 0, __bss_end__ - __real_bss_end__);
|
2019-08-06 20:26:28 +00:00
|
|
|
}
|
|
|
|
|
2020-01-17 22:10:26 +00:00
|
|
|
stage2ConfigureAndEnable();
|
|
|
|
if (isBootCore) {
|
|
|
|
devicesMapAllExtra();
|
|
|
|
}
|
2019-08-06 20:26:28 +00:00
|
|
|
}
|