mirror of
				https://github.com/Atmosphere-NX/Atmosphere-libs.git
				synced 2025-10-25 09:55:49 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			111 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 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/>.
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| #include <stratosphere/spl/spl_types.hpp>
 | |
| 
 | |
| namespace ams::spl {
 | |
| 
 | |
|     void Initialize();
 | |
|     void InitializeForCrypto();
 | |
|     void InitializeForSsl();
 | |
|     void InitializeForEs();
 | |
|     void InitializeForFs();
 | |
|     void InitializeForManu();
 | |
| 
 | |
|     void Finalize();
 | |
| 
 | |
|     Result AllocateAesKeySlot(s32 *out_slot);
 | |
|     Result DeallocateAesKeySlot(s32 slot);
 | |
| 
 | |
|     Result GenerateAesKek(AccessKey *access_key, const void *key_source, size_t key_source_size, s32 generation, u32 option);
 | |
|     Result LoadAesKey(s32 slot, const AccessKey &access_key, const void *key_source, size_t key_source_size);
 | |
|     Result GenerateAesKey(void *dst, size_t dst_size, const AccessKey &access_key, const void *key_source, size_t key_source_size);
 | |
|     Result GenerateSpecificAesKey(void *dst, size_t dst_size, const void *key_source, size_t key_source_size, s32 generation, u32 option);
 | |
|     Result ComputeCtr(void *dst, size_t dst_size, s32 slot, const void *src, size_t src_size, const void *iv, size_t iv_size);
 | |
|     Result DecryptAesKey(void *dst, size_t dst_size, const void *src, size_t src_size, s32 generation, u32 option);
 | |
| 
 | |
|     Result GetConfig(u64 *out, ConfigItem item);
 | |
|     Result SetConfig(ConfigItem item, u64 v);
 | |
|     bool IsDevelopment();
 | |
|     MemoryArrangement GetMemoryArrangement();
 | |
| 
 | |
|     inline bool GetConfigBool(ConfigItem item) {
 | |
|         u64 v;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetConfig(std::addressof(v), item));
 | |
|         return v != 0;
 | |
|     }
 | |
| 
 | |
|     inline HardwareType GetHardwareType() {
 | |
|         u64 v;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetConfig(std::addressof(v), ::ams::spl::ConfigItem::HardwareType));
 | |
|         return static_cast<HardwareType>(v);
 | |
|     }
 | |
| 
 | |
|     inline HardwareState GetHardwareState() {
 | |
|         u64 v;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetConfig(std::addressof(v), ::ams::spl::ConfigItem::HardwareState));
 | |
|         return static_cast<HardwareState>(v);
 | |
|     }
 | |
| 
 | |
|     inline RetailInteractiveDisplayState GetRetailInteractiveDisplayState() {
 | |
|         u64 v;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetConfig(std::addressof(v), ::ams::spl::ConfigItem::RetailInteractiveDisplayState));
 | |
|         return static_cast<RetailInteractiveDisplayState>(v);
 | |
|     }
 | |
| 
 | |
|     inline u64 GetDeviceIdLow() {
 | |
|         u64 v;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetConfig(std::addressof(v), ::ams::spl::ConfigItem::DeviceId));
 | |
|         return v;
 | |
|     }
 | |
| 
 | |
|     inline bool IsRecoveryBoot() {
 | |
|         return ::ams::spl::GetConfigBool(::ams::spl::ConfigItem::IsRecoveryBoot);
 | |
|     }
 | |
| 
 | |
|     inline bool IsDevelopmentFunctionEnabled() {
 | |
|         return ::ams::spl::GetConfigBool(::ams::spl::ConfigItem::IsDevelopmentFunctionEnabled);
 | |
|     }
 | |
| 
 | |
|     inline bool IsDisabledProgramVerification() {
 | |
|         return ::ams::spl::GetConfigBool(::ams::spl::ConfigItem::DisableProgramVerification);
 | |
|     }
 | |
| 
 | |
|     inline bool IsUsb30ForceEnabled() {
 | |
|         return ::ams::spl::GetConfigBool(::ams::spl::ConfigItem::ExosphereForceEnableUsb30);
 | |
|     }
 | |
| 
 | |
|     Result SetBootReason(BootReasonValue boot_reason);
 | |
|     Result GetBootReason(BootReasonValue *out);
 | |
| 
 | |
|     inline BootReasonValue GetBootReason() {
 | |
|         BootReasonValue br;
 | |
|         R_ABORT_UNLESS(::ams::spl::GetBootReason(std::addressof(br)));
 | |
|         return br;
 | |
|     }
 | |
| 
 | |
|     SocType GetSocType();
 | |
| 
 | |
|     Result GetPackage2Hash(void *dst, size_t dst_size);
 | |
|     Result GenerateRandomBytes(void *out, size_t buffer_size);
 | |
| 
 | |
|     Result LoadPreparedAesKey(s32 slot, const AccessKey &access_key);
 | |
| 
 | |
|     Result PrepareCommonEsTitleKey(AccessKey *out, const void *key_source, const size_t key_source_size, int generation);
 | |
| 
 | |
| }
 |