2021-08-21 20:10:13 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018-2020 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 <exosphere.hpp>
|
2021-08-22 00:49:36 +02:00
|
|
|
#include "fusee_secure_initialize.hpp"
|
2021-08-22 11:32:05 +02:00
|
|
|
#include "fusee_sdram.hpp"
|
2021-08-23 16:11:28 +02:00
|
|
|
#include "fusee_sd_card.hpp"
|
2021-08-21 20:10:13 +02:00
|
|
|
|
|
|
|
namespace ams::nxboot {
|
|
|
|
|
|
|
|
void Main() {
|
2021-08-22 00:49:36 +02:00
|
|
|
/* Perform secure hardware initialization. */
|
2021-08-22 01:32:05 +02:00
|
|
|
SecureInitialize(true);
|
2021-08-22 00:49:36 +02:00
|
|
|
|
2021-08-22 11:32:05 +02:00
|
|
|
/* Initialize Sdram. */
|
|
|
|
InitializeSdram();
|
|
|
|
|
2021-08-23 18:13:26 +02:00
|
|
|
/* Initialize cache. */
|
|
|
|
hw::InitializeDataCache();
|
|
|
|
|
2021-08-23 16:11:28 +02:00
|
|
|
/* Initialize SD card. */
|
|
|
|
Result result = InitializeSdCard();
|
|
|
|
|
|
|
|
/* DEBUG: Check SD card connection. */
|
|
|
|
{
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x40038000) = 0xAAAAAAAA;
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x40038004) = result.GetValue();
|
|
|
|
if (R_SUCCEEDED(result)) {
|
|
|
|
sdmmc::SpeedMode sm;
|
|
|
|
sdmmc::BusWidth bw;
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x40038008) = CheckSdCardConnection(std::addressof(sm), std::addressof(bw)).GetValue();
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x4003800C) = static_cast<u32>(sm);
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x40038010) = static_cast<u32>(bw);
|
|
|
|
}
|
|
|
|
*reinterpret_cast<volatile u32 *>(0x7000E400) = 0x10;
|
|
|
|
}
|
|
|
|
|
2021-08-21 20:10:13 +02:00
|
|
|
/* TODO */
|
|
|
|
AMS_INFINITE_LOOP();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|