Line 14: |
Line 14: |
| | | |
| == OpenCodeFileSystem == | | == OpenCodeFileSystem == |
− | Takes an [[NCM_services#ProgramId|ProgramId]] and a [[#ContentPath]]. Returns an [[#IFileSystem]]. | + | Takes a type-0x19 input buffer containing a [[#FspPath]] and an input [[NCM_services#ProgramId|ProgramId]]. Returns an [[#IFileSystem]]. |
| | | |
| [10.0.0+] This now takes an additional type-0x1A output buffer. | | [10.0.0+] This now takes an additional type-0x1A output buffer. |
| + | |
| + | [16.0.0+] This now takes an additional input [[#ContentAttributes]]. |
| + | |
| + | [17.0.0+] This now takes a type-0x6 output buffer instead of a type-0x1A output buffer. |
| | | |
| == IsArchivedProgram == | | == IsArchivedProgram == |
− | Takes an u64 ProcessId. Returns a bool (1 if the process id's [[#ContentPath]] ends in ".nca"). | + | Takes an input u64 ProcessId. Returns a bool (1 if the process id's [[#FspPath]] ends in ".nca"). |
| | | |
| == SetCurrentProcess == | | == SetCurrentProcess == |
− | Takes a ProcessId descriptor. | + | Takes an input u64 ProcessId. No output. |
| | | |
| = fsp-pr = | | = fsp-pr = |
Line 70: |
Line 74: |
| | 7 || [2.0.0+] [[#OpenFileSystemWithPatch]] | | | 7 || [2.0.0+] [[#OpenFileSystemWithPatch]] |
| |- | | |- |
− | | 8 || [2.0.0+] [[#OpenFileSystemWithId]] | + | | 8 || [16.0.0+] [[#OpenFileSystemWithIdObsolete]] ([2.0.0-15.0.1] OpenFileSystemWithId) |
| |- | | |- |
| | 9 || [3.0.0+] OpenDataFileSystemByProgramId | | | 9 || [3.0.0+] OpenDataFileSystemByProgramId |
| + | |- |
| + | | 10 || [16.0.0+] [[#OpenFileSystemWithId]] |
| |- | | |- |
| | 11 || [[#OpenBisFileSystem]] | | | 11 || [[#OpenBisFileSystem]] |
Line 115: |
Line 121: |
| |- | | |- |
| | 36 || [9.0.0+] OpenHostFileSystemWithOption | | | 36 || [9.0.0+] OpenHostFileSystemWithOption |
| + | |- |
| + | | 37 || [14.0.0+] CreateSaveDataFileSystemWithCreationInfo2 |
| |- | | |- |
| | 51 || [[#OpenSaveDataFileSystem]] | | | 51 || [[#OpenSaveDataFileSystem]] |
Line 163: |
Line 171: |
| |- | | |- |
| | 86 || [10.0.0+] [[#OpenSaveDataMover]] | | | 86 || [10.0.0+] [[#OpenSaveDataMover]] |
| + | |- |
| + | | 87 || [11.0.0+] [[#OpenSaveDataTransferManagerForRepair]] |
| |- | | |- |
| | 100 || OpenImageDirectoryFileSystem | | | 100 || OpenImageDirectoryFileSystem |
| + | |- |
| + | | 101 || [11.0.0+] OpenBaseFileSystem |
| + | |- |
| + | | 102 || [12.0.0+] FormatBaseFileSystem |
| |- | | |- |
| | 110 || [[#OpenContentStorageFileSystem]] | | | 110 || [[#OpenContentStorageFileSystem]] |
Line 183: |
Line 197: |
| |- | | |- |
| | 205 || [7.0.0+] [[#OpenDataStorageWithProgramIndex]] | | | 205 || [7.0.0+] [[#OpenDataStorageWithProgramIndex]] |
| + | |- |
| + | | 206 || [13.0.0+] OpenDataStorageByPath |
| + | |- |
| + | | 207 || [15.0.0+] OpenDataFileSystemByDataId |
| |- | | |- |
| | 400 || [[#OpenDeviceOperator]] | | | 400 || [[#OpenDeviceOperator]] |
Line 214: |
Line 232: |
| | 608 || [2.0.0+] UnregisterAllExternalKey | | | 608 || [2.0.0+] UnregisterAllExternalKey |
| |- | | |- |
− | | 609 || [2.0.0+] GetRightsIdByPath | + | | 609 || [2.0.0-15.0.1] GetRightsIdByPath |
| |- | | |- |
| | 610 || [3.0.0+] GetRightsIdAndKeyGenerationByPath | | | 610 || [3.0.0+] GetRightsIdAndKeyGenerationByPath |
Line 231: |
Line 249: |
| |- | | |- |
| | 617 || [7.0.0+] UnregisterExternalKey | | | 617 || [7.0.0+] UnregisterExternalKey |
| + | |- |
| + | | 618 || [17.0.0+] GetProgramId |
| |- | | |- |
| | 620 || [2.0.0+] [[#SetSdCardEncryptionSeed]] | | | 620 || [2.0.0+] [[#SetSdCardEncryptionSeed]] |
Line 282: |
Line 302: |
| | 1013 || [9.0.0+] UnsetSaveDataRootPath | | | 1013 || [9.0.0+] UnsetSaveDataRootPath |
| |- | | |- |
− | | 1014 || [10.0.0+] OutputMultiProgramTagAccessLog | + | | 1014 || [10.0.0-10.2.0] OutputMultiProgramTagAccessLog |
| + | |- |
| + | | 1016 || [11.0.0+] FlushAccessLogOnSdCard |
| + | |- |
| + | | 1017 || [11.0.0+] OutputApplicationInfoAccessLog |
| + | |- |
| + | | 1018 || [13.0.0+] SetDebugOption |
| + | |- |
| + | | 1019 || [13.0.0+] UnsetDebugOption |
| + | |- |
| + | | 1020 || [18.0.0+] OpenMemoryStressor |
| |- | | |- |
− | | 1100 || [4.0.0+] OverrideSaveDataTransferTokenSignVerificationKey | + | | 1100 || [4.0.0-17.0.1] OverrideSaveDataTransferTokenSignVerificationKey |
| + | |- |
| + | | 1101 || [18.0.0+] OverrideSaveDataTransferKeyForTest |
| |- | | |- |
| | 1110 || [6.0.0+] CorruptSaveDataFileSystemByOffset | | | 1110 || [6.0.0+] CorruptSaveDataFileSystemByOffset |
Line 291: |
Line 323: |
| |- | | |- |
| | 1300 || [10.0.0+] [[#OpenBisWiper]] | | | 1300 || [10.0.0+] [[#OpenBisWiper]] |
| + | |- |
| + | | 1400 || [15.0.0+] NotifyErrorContextServiceReady |
| |} | | |} |
| | | |
Line 326: |
Line 360: |
| |- | | |- |
| | 0x8 || CanMountImageAndVideoStorage ||0x8000000000001000 || RW || [[#OpenImageDirectoryFileSystem]] | | | 0x8 || CanMountImageAndVideoStorage ||0x8000000000001000 || RW || [[#OpenImageDirectoryFileSystem]] |
− | |-
| |
− | | ([1.0.0-5.1.0] 0x9) || || 0x8000000000000084 || ||
| |
− | |-
| |
− | | ([6.0.0-9.2.0] 0x9) || CanMountCloudBackupWorkStorage || 0x8000000200000000 || RW || OpenCloudBackupWorkStorageFileSystem
| |
| |- | | |- |
| | 0x9 || CanMountCustomStorage0 || 0x8000000000000000 || RW || OpenCustomStorageFileSystem | | | 0x9 || CanMountCustomStorage0 || 0x8000000000000000 || RW || OpenCustomStorageFileSystem |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0xA) || || 0x8000000000000080 || || | + | | 0xA || CanMountBisCalibrationFile || 0x8000000000000084 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0xA) || || 0x8000000000000084 || || | + | | 0xB || CanMountBisSafeMode || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | ([7.0.0-7.0.1] 0xA) || || 0x4000000000000000 || || | + | | 0xC || CanMountBisUser || 0x8000000000008080 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | ([8.0.0-9.2.0] 0xA) || || 0x8000000000000000 || || | + | | 0xD || CanMountBisSystem || 0x8000000000008080 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | 0xA || CanMountBisCalibrationFile || 0x8000000000000084 || RW || [[#OpenBisFileSystem]] | + | | 0xE || CanMountBisSystemProperEncryption || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0xB) || || 0x8000000000008080 || || | + | | 0xF || CanMountBisSystemProperPartition || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0xB) || || 0x8000000000000080 || || | + | | 0x10 || CanMountSdCard || 0xC000000000200000 || RW || [[#OpenSdCardFileSystem]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0xB) || || 0x8000000000000084 || || | + | | 0x11 || CanMountGameCard || 0x8000000000000010 || R- || [[#OpenGameCardFileSystem]] |
| |- | | |- |
− | | 0xB || CanMountBisSafeMode || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] | + | | 0x12 || CanMountDeviceSaveData || 0x8000000000040020 || RW || [[#OpenSaveDataFileSystem]] |
| |- | | |- |
− | | ([1.0.0-6.2.0] 0xC) || || 0x8000000000008080 || || | + | | 0x13 || CanMountSystemSaveData || 0x8000000000000028 || RW || [[#OpenSaveDataFileSystemBySystemSaveDataId]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0xC) || || 0x8000000000000080 || || | + | | 0x14 || CanMountOthersSaveData || 0x8000000000000020 || RW || [[#OpenSaveDataFileSystem]] |
| |- | | |- |
− | | 0xC || CanMountBisUser || 0x8000000000008080 || RW || [[#OpenBisFileSystem]] | + | | 0x15 || CanMountOthersSystemSaveData || 0x8000000000000020 || RW || [[#OpenSaveDataFileSystemBySystemSaveDataId]] |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0xD) || || 0x8000000000000080 || || | + | | 0x16 || CanOpenBisPartitionBootPartition1Root || 0x8000000000010082 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0xD) || || 0x8000000000008080 || || | + | | 0x17 || CanOpenBisPartitionBootPartition2Root || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | 0xD || CanMountBisSystem || 0x8000000000008080 || RW || [[#OpenBisFileSystem]] | + | | 0x18 || CanOpenBisPartitionUserDataRoot || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0xE) || || 0xC000000000200000 || || | + | | 0x19 || CanOpenBisPartitionBootConfigAndPackage2Part1 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([3.0.0-6.2.0] 0xE) || || 0x8000000000000080 || || | + | | 0x1A || CanOpenBisPartitionBootConfigAndPackage2Part2 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0xE) || || 0x8000000000008080 || || | + | | 0x1B || CanOpenBisPartitionBootConfigAndPackage2Part3 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | 0xE || CanMountBisSystemProperEncryption || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] | + | | 0x1C || CanOpenBisPartitionBootConfigAndPackage2Part4 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0xF) || || 0x8000000000000010 || || | + | | 0x1D || CanOpenBisPartitionBootConfigAndPackage2Part5 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0xF) || || 0xC000000000200000 || || | + | | 0x1E || CanOpenBisPartitionBootConfigAndPackage2Part6 || 0x8000000000010080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0xF) || || 0x8000000000000080 || || | + | | 0x1F || CanOpenBisPartitionCalibrationBinary || 0x8000000000000084 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | 0xF || CanMountBisSystemProperPartition || 0x8000000000000080 || RW || [[#OpenBisFileSystem]] | + | | 0x20 || CanOpenBisPartitionCalibrationFile || 0x8000000000000084 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x10) || || 0x8000000000040020 || || | + | | 0x21 || CanOpenBisPartitionSafeMode || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x10) || || 0x8000000000000010 || || | + | | 0x22 || CanOpenBisPartitionUser || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x10) || || 0xC000000000200000 || || | + | | 0x23 || CanOpenBisPartitionSystem || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x10) || || 0x8000000000000080 || || | + | | 0x24 || CanOpenBisPartitionSystemProperEncryption || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | 0x10 || CanMountSdCard || 0xC000000000200000 || RW || [[#OpenSdCardFileSystem]] | + | | 0x25 || CanOpenBisPartitionSystemProperPartition || 0x8000000000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x11) || || 0x8000000000000028 || || | + | | 0x26 || CanOpenBisPartitionDeviceTreeBlob || 0x8000002000000080 || RW || [[#OpenBisStorage]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x11) || || 0x8000000000040020 || || | + | | [3.0.0+] 0x27 || CanOpenSdCardStorage || 0xC000000000200000 || RW || |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x11) || || 0x8000000000000010 || || | + | | [3.0.0+] 0x28 || CanOpenGameCardStorage || 0x8000000000000100 || RW || [[#OpenGameCardStorage]], [[#EraseGameCard]] (bit1), [[#WriteToGameCard]] (bit1), [[#GetGameCardErrorInfo]] (bit1), [[#EraseAndWriteParamDirectly]] (bit1), [[#ReadParamDirectly]] (bit1), [[#ForceEraseGameCard]] (bit1) |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x11) || || 0xC000000000200000 || || | + | | [4.0.0+] 0x29 || CanMountSystemDataPrivate || 0x8000000000100008 || R- || [[#OpenFileSystem]], [[#OpenDataStorageByDataId]] |
| |- | | |- |
− | | 0x11 || CanMountGameCard || 0x8000000000000010 || R- || [[#OpenGameCardFileSystem]] | + | | [5.0.0+] 0x2A || CanMountHost || 0xC000000000400000 || RW || [[#OpenHostFileSystem]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x12) || || 0x8000000000000020 || || | + | | [6.0.0+] 0x2B || CanMountRegisteredUpdatePartition || 0x8000000000010000 || R- || [[#OpenRegisteredUpdatePartition]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x12) || || 0x8000000000000028 || || | + | | [7.0.0+] 0x2C || CanOpenSaveDataInternalStorage || 0x8000000000000000 || RW || [[#OpenSaveDataInternalStorageFileSystem]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x12) || || 0x8000000000040020 || || | + | | [7.0.0+] 0x2D || CanMountTemporaryDirectory || 0xC000000000000000 || RW || |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x12) || || 0x8000000000000010 || || | + | | [11.0.0+] 0x2E || CanMountAllBaseFilesystem || 0x8000000000000000 || RW || OpenBaseFileSystem |
| |- | | |- |
− | | 0x12 || CanMountDeviceSaveData || 0x8000000000040020 || RW || [[#OpenSaveDataFileSystem]] | + | | [15.0.0+] 0x2F || CanNotMount || 0x0000000000000000 || -- || OpenCustomStorageFileSystem |
| + | |} |
| + | |
| + | === Call === |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x13) || || 0x8000000000000020 || || | + | ! OperationType || Name || Mask || Used by |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x13) || || 0x8000000000000028 || || | + | | 0x0 || CanInvalidateBisCache || 0x8000000000000080 || [[#InvalidateBisCache]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x13) || || 0x8000000000040020 || || | + | | 0x1 || CanEraseMmc || 0x8000000000000080 || EraseMmc |
| |- | | |- |
− | | 0x13 || CanMountSystemSaveData || 0x8000000000000028 || RW || [[#OpenSaveDataFileSystemBySystemSaveDataId]] | + | | 0x2 || CanGetGameCardDeviceCertificate || 0x8000000000000010 || GetGameCardDeviceCertificate |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x14) || || 0x8000000000010082 || || | + | | 0x3 || CanGetGameCardIdSet || 0x8000000000000010 || GetGameCardIdSet |
| |- | | |- |
− | | ([3.0.0-6.2.0] 0x14) || || 0x8000000000000020 || || | + | | 0x4 || CanFinalizeGameCardDriver || 0x8000000000000200 || FinalizeGameCardDriver |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x14) || || 0x8000000000000028 || || | + | | 0x5 || CanGetGameCardAsicInfo || 0x8000000000000200 || GetGameCardAsicInfo |
| |- | | |- |
− | | 0x14 || CanMountOthersSaveData || 0x8000000000000020 || RW || [[#OpenSaveDataFileSystem]] | + | | 0x6 || CanGetGameCardAsicCertificate || 0x8000000000000200 || GetGameCardAsicCertificate |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x15) || || 0x8000000000010080 || || | + | | 0x7 || CanCreateSaveData || 0x8000000000002020 || [[#CreateSaveDataFileSystem]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x15) || || 0x8000000000010082 || || | + | | 0x8 || CanDeleteSaveData || 0x8000000000000060 || [[#DeleteSaveDataFileSystem]], RegisterSaveDataFileSystemAtomicDeletion |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0x15) || || 0x8000000000000020 || || | + | | 0x9 || CanCreateSystemSaveData || 0x8000000000000028 || CreateSaveDataFileSystemBySystemSaveDataId |
| |- | | |- |
− | | 0x15 || CanMountOthersSystemSaveData || 0x8000000000000020 || RW || [[#OpenSaveDataFileSystemBySystemSaveDataId]] | + | | 0xA || CanCreateOthersSystemSaveData || 0x8000000000000020 || CreateSaveDataFileSystemBySystemSaveDataId |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x16) || || 0x8000000000010080 || || | + | | 0xB || CanDeleteSystemSaveData || 0x8000000000004028 || [[#DeleteSaveDataFileSystem]], RegisterSaveDataFileSystemAtomicDeletion |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x16) || || 0x8000000000010082 || || | + | | 0xC || CanOpenSaveDataInfoReader || 0x8000000000000060 || [[#OpenSaveDataInfoReaderBySaveDataSpaceId]], [[#OpenSaveDataInfoReader]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x16) || || 0x8000000000000020 || || | + | | 0xD || CanOpenSaveDataInfoReaderForSystem || 0x8000000000004020 || [[#OpenSaveDataInfoReaderBySaveDataSpaceId]], [[#OpenSaveDataInfoReader]] |
| |- | | |- |
− | | 0x16 || CanOpenBisPartitionBootPartition1Root || 0x8000000000010082 || RW || [[#OpenBisStorage]] | + | | 0xE || CanOpenSaveDataInfoReaderForInternal || 0x8000000000000040 || [[#OpenSaveDataInfoReaderWithFilter]] |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x17) || || 0x8000000000010080 || || | + | | 0xF || CanOpenSaveDataMetaFile || 0x8000000000020000 || OpenSaveDataMetaFile |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x17) || || 0x8000000000000080 || || | + | | 0x10 || CanSetCurrentPosixTime || 0x8000000000000400 || SetCurrentPosixTime, SetCurrentPosixTimeWithTimeDifference |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x17) || || 0x8000000000010080 || || | + | | 0x11 || CanReadSaveDataFileSystemExtraData || 0x8000000000004060 || [[#ReadSaveDataFileSystemExtraData]] |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x17) || || 0x8000000000010082 || || | + | | 0x12 || CanSetGlobalAccessLogMode || 0x8000000000080000 || [[#SetGlobalAccessLogMode]] |
| |- | | |- |
− | | 0x17 || CanOpenBisPartitionBootPartition2Root || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | 0x13 || CanSetSpeedEmulationMode || 0x8000000000080000 || SetSpeedEmulationMode |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x18) || || 0x8000000000010080 || || | + | | 0x14 || CanDebug || 0xC000000000000000 || |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x18) || || 0x8000000000000080 || || | + | | 0x15 || CanFillBis || 0xC000000000800000 || CreatePaddingFile, DeleteAllPaddingFiles |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x18) || || 0x8000000000010080 || || | + | | [2.0.0+] 0x16 || CanCorruptSaveData || 0xC000000001000000 || CorruptSaveDataFileSystem, CorruptSaveDataFileSystemBySaveDataSpaceId |
| |- | | |- |
− | | 0x18 || CanOpenBisPartitionUserDataRoot || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [2.0.0+] 0x17 || CanCorruptSystemSaveData || 0x8000000001000060 || CorruptSaveDataFileSystem, CorruptSaveDataFileSystemBySaveDataSpaceId |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x19) || || 0x8000000000010080 || || | + | | [2.0.0+] 0x18 || CanVerifySaveData || 0x8000000000000060 || [[#VerifySaveDataFileSystem]], VerifySaveDataFileSystemBySaveDataSpaceId |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x19) || || 0x8000000000000080 || || | + | | [2.0.0+] 0x19 || CanDebugSaveData || 0xC000000002000000 || [[#CreateSaveDataFileSystem]], [[#OpenSaveDataFileSystem]], [[#SetSaveDataRootPath]] |
| |- | | |- |
− | | 0x19 || CanOpenBisPartitionBootConfigAndPackage2Part1 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [2.0.0+] 0x1A || CanFormatSdCard || 0x8000000004000000 || FormatSdCardFileSystem |
| |- | | |- |
− | | ([1.0.0-9.2.0] 0x1A) || || 0x8000000000010080 || || | + | | [3.0.0+] 0x1B || CanGetRightsId || 0x8000000008000000 || GetRightsId, GetRightsIdAndKeyGenerationByPath, GetRightsIdByPath |
| |- | | |- |
− | | 0x1A || CanOpenBisPartitionBootConfigAndPackage2Part2 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [3.0.0+] 0x1C || CanRegisterExternalKey || 0x8000000010000000 || RegisterExternalKey, UnregisterAllExternalKey |
| |- | | |- |
− | | ([1.0.0-9.2.0] 0x1B) || || 0x8000000000010080 || || | + | | [4.0.0+] 0x1D || CanSetEncryptionSeed || 0x8000000000000800 || [[#SetSdCardEncryptionSeed]] |
| |- | | |- |
− | | 0x1B || CanOpenBisPartitionBootConfigAndPackage2Part3 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [4.0.0+] 0x1E || CanWriteSaveDataFileSystemExtraDataTimeStamp || 0x8000000000000020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask |
| |- | | |- |
− | | ([1.0.0-9.2.0] 0x1C) || || 0x8000000000010080 || || | + | | [4.0.0+] 0x1F || CanWriteSaveDataFileSystemExtraDataFlags || 0x8000000000004020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask |
| |- | | |- |
− | | 0x1C || CanOpenBisPartitionBootConfigAndPackage2Part4 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [4.0.0+] 0x20 || CanWriteSaveDataFileSystemExtraDataCommitId || 0x8000000000000020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x1D) || || 0x8000000000000084 || || | + | | [5.0.0+] 0x21 || CanWriteSaveDataFileSystemExtraDataAll || 0x8000000000000000 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask |
| |- | | |- |
− | | ([3.0.0-9.2.0] 0x1D) || || 0x8000000000010080 || || | + | | [5.0.0+] 0x22 || CanExtendSaveData || 0x8000000000002020 || ExtendSaveDataFileSystem |
| |- | | |- |
− | | 0x1D || CanOpenBisPartitionBootConfigAndPackage2Part5 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [5.0.0+] 0x23 || CanExtendSystemSaveData || 0x8000000000000028 || ExtendSaveDataFileSystem |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x1E) || || 0x8000000000000084 || || | + | | [5.0.0+] 0x24 || CanExtendOthersSystemSaveData || 0x8000000000000020 || ExtendSaveDataFileSystem |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0x1E) || || 0x8000000000010080 || || | + | | [5.0.0+] 0x25 || CanRegisterUpdatePartition || 0x8000000020000000 || RegisterUpdatePartition |
| |- | | |- |
− | | 0x1E || CanOpenBisPartitionBootConfigAndPackage2Part6 || 0x8000000000010080 || RW || [[#OpenBisStorage]] | + | | [5.0.0+] 0x26 || CanOpenSaveDataTransferManager || 0x8000000040000000 || [[#OpenSaveDataTransferManager]] |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x1F) || || 0x8000000000000080 || || | + | | [5.0.0+] 0x27 || CanOpenSaveDataTransferManagerVersion2 || 0x8000000200000000 || [[#OpenSaveDataTransferManagerVersion2]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x1F) || || 0x8000000000000084 || || | + | | [5.0.0+] 0x28 || CanOpenSaveDataTransferManagerForSaveDataRepair || 0x8000000200000000 || OpenSaveDataTransferManagerForSaveDataRepair |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x1F) || || 0x8000000000010080 || || | + | | [5.0.0+] 0x29 || CanOpenSaveDataTransferManagerForSaveDataRepairTool || 0x8000000000000000 || OpenSaveDataTransferManagerForSaveDataRepair |
| |- | | |- |
− | | 0x1F || CanOpenBisPartitionCalibrationBinary || 0x8000000000000084 || RW || [[#OpenBisStorage]] | + | | [5.0.0+] 0x2A || CanOpenOpenSaveDataTransferProhibiter || 0x8000000200002000 || [[#OpenSaveDataTransferProhibiter]] |
| |- | | |- |
− | | ([1.0.0-5.1.0] 0x20) || || 0x8000000000000080 || || | + | | [5.0.0+] 0x2B || CanOpenSaveDataMover || 0x8000001000000000 || [[#OpenSaveDataMover]] |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0x20) || || 0x8000000000000084 || || | + | | [5.0.0+] 0x2C || CanOpenBisWiper || 0x8000000000000800 || [[#OpenBisWiper]] |
| |- | | |- |
− | | 0x20 || CanOpenBisPartitionCalibrationFile || 0x8000000000000084 || RW || [[#OpenBisStorage]] | + | | [5.0.0+] 0x2D || CanListAccessibleSaveDataOwnerId || 0x8000000240002000 || [[#ListAccessibleSaveDataOwnerId]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x21) || || 0x8000000000000080 || || | + | | [5.0.0+] 0x2E || CanControlMmcPatrol || 0x8000000000000000 || SuspendMmcPatrol, ResumeMmcPatrol |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x21) || || 0x8000000000000084 || || | + | | [5.0.0+] 0x2F || CanOverrideSaveDataTransferTokenSignVerificationKey || 0x8000000000000000 || OverrideSaveDataTransferTokenSignVerificationKey |
| |- | | |- |
− | | 0x21 || CanOpenBisPartitionSafeMode || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [5.1.0+] 0x30 || CanOpenSdCardDetectionEventNotifier || 0x8000000080200000 || [[#OpenSdCardDetectionEventNotifier]] |
| |- | | |- |
− | | ([1.0.0-9.2.0] 0x22) || || 0x8000000000000080 || || | + | | [6.0.0+] 0x31 || CanOpenGameCardDetectionEventNotifier || 0x8000000080000110 || [[#OpenGameCardDetectionEventNotifier]] |
| |- | | |- |
− | | 0x22 || CanOpenBisPartitionUser || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [6.0.0+] 0x32 || CanOpenSystemDataUpdateEventNotifier || 0x8000000000100008 || OpenSystemDataUpdateEventNotifier |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x23) || || 0xC000000000200000 || || | + | | [6.0.0+] 0x33 || CanNotifySystemDataUpdateEvent || 0x8000000000010000 || NotifySystemDataUpdateEvent |
| |- | | |- |
− | | ([3.0.0-9.2.0] 0x23) || || 0x8000000000000080 || || | + | | [6.0.0+] 0x34 || CanOpenAccessFailureDetectionEventNotifier || 0x8000000100000000 || [[#OpenAccessFailureDetectionEventNotifier]] |
| |- | | |- |
− | | 0x23 || CanOpenBisPartitionSystem || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [6.0.0+] 0x35 || CanGetAccessFailureDetectionEvent || 0x8000000100000000 || GetAccessFailureDetectionEvent |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x24) || || 0x8000000000000100 || || | + | | [6.0.0+] 0x36 || CanIsAccessFailureDetected || 0x8000000100000000 || IsAccessFailureDetected |
| |- | | |- |
− | | ([3.0.0-9.2.0] 0x24) || || 0x8000000000000080 || || | + | | [6.0.0+] 0x37 || CanResolveAccessFailure || 0x8000000100000000 || ResolveAccessFailure |
| |- | | |- |
− | | 0x24 || CanOpenBisPartitionSystemProperEncryption || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [6.0.0+] 0x38 || CanAbandonAccessFailure || 0x8000000100000000 || AbandonAccessFailure |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x25) || || 0x8000000000100008 || || | + | | [8.0.0+] 0x39 || CanQuerySaveDataInternalStorageTotalSize || 0x8000000040000000 || QuerySaveDataInternalStorageTotalSize |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x25) || || 0xC000000000200000 || || | + | | [9.0.0+] 0x3A || CanGetSaveDataCommitId || 0x8000000200000020 || [[#GetSaveDataCommitId]] |
| |- | | |- |
− | | ([6.0.0-9.2.0] 0x25) || || 0x8000000000000080 || || | + | | [9.0.0+] 0x3B || CanSetSdCardAccessibility || 0x8000000000200000 || SetSdCardAccessibility |
| |- | | |- |
− | | 0x25 || CanOpenBisPartitionSystemProperPartition || 0x8000000000000080 || RW || [[#OpenBisStorage]] | + | | [9.0.0+] 0x3C || CanSimulateDevice || 0x4000000000000000 || SimulateDeviceDetectionEvent, SetSimulationEvent, ClearSimulationEvent |
| |- | | |- |
− | | ([1.0.0-2.3.0] 0x26) || || 0xC000000000400000 || || | + | | [9.0.0+] 0x3D || CanCreateSaveDataWithHashSalt || 0x8000000000000000 || [[#CreateSaveDataFileSystem]], [[#CreateSaveDataFileSystemWithHashSalt]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x26) || || 0x8000000000000100 || || | + | | [9.0.0+] 0x3E || CanRegisterProgramIndexMapInfo || 0x8000000400000000 || RegisterProgramIndexMapInfo |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x26) || || 0xC000000000200000 || || | + | | [9.0.0+] 0x3F || CanChallengeCardExistence || 0x8000000000000010 || ChallengeCardExistence |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x26) || || 0x8000000000000080 || || | + | | [9.0.0+] 0x40 || CanCreateOwnSaveData || 0x8000000800000000 || [[#CreateSaveDataFileSystem]], CreateSaveDataFileSystemWithHashSalt |
| |- | | |- |
− | | 0x26 || CanOpenSdCardStorage || 0xC000000000200000 || RW || | + | | [9.0.0+] 0x41 || CanDeleteOwnSaveData || 0x8000000800000000 || [[#DeleteSaveDataFileSystem]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x27) || || 0x8000000000100008 || || | + | | [10.0.0+] 0x42 || CanReadOwnSaveDataFileSystemExtraData || 0x8000000800000000 || [[#ReadSaveDataFileSystemExtraData]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x27) || || 0x8000000000000100 || || | + | | [10.0.0+] 0x43 || CanExtendOwnSaveData || 0x8000000800000000 || ExtendSaveDataFileSystem |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x27) || || 0xC000000000200000 || || | + | | [10.2.0+] 0x44 || CanOpenOwnSaveDataTransferProhibiter || 0x8000000800000000 || [[#OpenSaveDataTransferProhibiter]] |
| |- | | |- |
− | | [3.0.0+] 0x27 || CanOpenGameCardStorage || 0x8000000000000100 || RW || [[#OpenGameCardStorage]], [[#EraseGameCard]] (bit1), [[#WriteToGameCard]] (bit1), [[#GetGameCardErrorInfo]] (bit1), [[#EraseAndWriteParamDirectly]] (bit1), [[#ReadParamDirectly]] (bit1), [[#ForceEraseGameCard]] (bit1) | + | | [11.0.0+] 0x45 || CanFindOwnSaveDataWithFilter || 0x8000000800000000 || [[#FindSaveDataWithFilter]] |
| |- | | |- |
− | | ([3.0.0-5.1.0] 0x28) || || 0xC000000000400000 || || | + | | [13.0.0+] 0x46 || CanOpenSaveDataTransferManagerForRepair || 0x8000000000000020 || [[#OpenSaveDataTransferManagerForRepair]] |
| |- | | |- |
− | | ([6.0.0-6.2.0] 0x28) || || 0x8000000000100008 || || | + | | [13.0.0+] 0x47 || CanSetDebugConfiguration || 0x8000000000000000 || SetDebugOption, UnsetDebugOption |
| |- | | |- |
− | | ([7.0.0-9.2.0] 0x28) || || 0x8000000000000100 || || | + | | [15.0.0+] 0x48 || CanOpenDataStorageByPath || 0x8000000000000000 || OpenDataStorageByPath |
| |- | | |- |
− | | [3.0.0+] 0x28 || CanMountSystemDataPrivate || 0x8000000000100008 || R- || [[#OpenFileSystem]], [[#OpenDataStorageByDataId]] | + | | [17.0.0+] 0x49 || CanNotifyErrorContextServiceReady || 0x8000004000000000 || NotifyErrorContextServiceReady |
| |- | | |- |
− | | ([4.0.0-5.1.0] 0x29) || || 0x8000000000010000 || || | + | | [17.0.0+] 0x4A || CanGetProgramId || 0x8000000008000000 || GetProgramId |
− | |-
| + | |} |
− | | ([6.0.0-6.2.0] 0x29) || || 0xC000000000400000 || ||
| + | |
− | |-
| + | == OpenFileSystem == |
− | | ([7.0.0-9.2.0] 0x29) || || 0x8000000000100008 || ||
| + | Takes a type-0x19 input buffer containing a [[#FspPath]] and an input [[#FileSystemProxyType]]. Returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | [4.0.0+] 0x29 || CanMountHost || 0xC000000000400000 || RW || [[#OpenHostFileSystem]]
| + | [2.0.0+] This function was removed. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x2A) || || 0x8000000000000000 || ||
| + | == SetCurrentProcess == |
− | |-
| + | Takes an input u64 ProcessId. No output. |
− | | ([6.0.0-6.2.0] 0x2A) || || 0x8000000000010000 || ||
| + | |
− | |-
| + | == OpenFileSystemWithPatch == |
− | | ([7.0.0-9.2.0] 0x2A) || || 0xC000000000400000 || || | + | Takes an input [[#FileSystemProxyType]] and an input [[NCM_services#ProgramId|ProgramId]]. Returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | [5.0.0+] 0x2A || CanMountRegisteredUpdatePartition || 0x8000000000010000 || R- || [[#OpenRegisteredUpdatePartition]]
| + | Web-applet loads the [[#FileSystemProxyType]] (which must be '''Manual''') from u32_table[inparam]. |
− | |-
| + | |
− | | ([6.0.0-6.2.0] 0x2B) || || 0x8000000000000000 || ||
| + | Note: web-applet strings refer to both this cmd and [[#OpenFileSystemWithId]] as "MountContent", but official nn_sf_sync symbols use "OpenXX" names. |
− | |-
| + | |
− | | ([7.0.0-9.2.0] 0x2B) || || 0x8000000000010000 || ||
| + | == OpenFileSystemWithIdObsolete == |
− | |-
| + | Takes a type-0x19 input buffer containing a [[#FspPath]], an input [[#FileSystemProxyType]] and an input [[NCM_services#ProgramId|ProgramId]]. Returns an [[#IFileSystem]]. |
− | | [6.0.0+] 0x2B || CanOpenSaveDataInternalStorage || 0x8000000000000000 || RW || [[#OpenSaveDataInternalStorageFileSystem]]
| |
− | |- | |
− | | ([7.0.0-9.2.0] 0x2C) || || 0x8000000000000000 || ||
| |
− | |-
| |
− | | [7.0.0+] 0x2C || CanNotMount || 0x0000000000000000 || -- || OpenCustomStorageFileSystem
| |
− | |-
| |
− | | ([7.0.0-9.2.0] 0x2D) || || 0x0000000000000000 || ||
| |
− | |}
| |
| | | |
− | === Call ===
| + | The [[#IFileSystem]] must be '''Meta''' if the NCA type is 0. |
− | {| class="wikitable" border="1"
| + | |
− | |-
| + | The input buffer is the output string path from [[NS_Services#GetApplicationContentPath|GetApplicationContentPath]]. |
− | ! OperationType || Name || Mask || Used by
| + | |
− | |-
| + | May return errors when attempting to access NCA-paths for an update-title with a gamecard, when the gamecard isn't inserted. May return error 0x7D402 in some cases with update-titles. Non-val2 in32 values with NCA-type1 are unusable, even for normal titles. |
− | | 0x0 || CanInvalidateBisCache || 0x8000000000000080 || [[#InvalidateBisCache]]
| + | |
− | |-
| + | The official "MountApplicationPackage" func uses this with in64=0 and [[#FileSystemProxyType]] '''Package'''. |
− | | 0x1 || CanEraseMmc || 0x8000000000000080 || EraseMmc
| + | |
− | |-
| + | After the [[#FileSystemProxyType]] specific permissions are checked, it then gets the func retval for permissions-type 0x25 and func0. |
− | | 0x2 || CanGetGameCardDeviceCertificate || 0x8000000000000010 || GetGameCardDeviceCertificate
| + | |
− | |-
| + | When [[#FileSystemProxyType]] is '''Meta''', it uses in64=0xffffffffffffffff internally, otherwise it checks if in64 is set to 0xffffffffffffffff then throws an error if so. When the in64 used internally is not 0xffffffffffffffff, it's compared with the NCA [[NCM_services#ProgramId|ProgramId]], then an error is thrown on mismatch. |
− | | 0x3 || CanGetGameCardIdSet || 0x8000000000000010 || GetGameCardIdSet | + | |
− | |-
| + | == OpenFileSystemWithId == |
− | | 0x4 || CanFinalizeGameCardDriver || 0x8000000000000200 || FinalizeGameCardDriver
| + | Takes a type-0x19 input buffer containing a [[#FspPath]], an input [[#ContentAttributes]], an input [[#FileSystemProxyType]] and an input [[NCM_services#ProgramId|ProgramId]]. Returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | 0x5 || CanGetGameCardAsicInfo || 0x8000000000000200 || GetGameCardAsicInfo
| + | == OpenBisFileSystem == |
− | |-
| + | Takes a type-0x19 input buffer containing a [[#FspPath]] and an input [[#BisPartitionId]]. Returns an [[#IFileSystem]]. |
− | | 0x6 || CanCreateSaveData || 0x8000000000002020 || [[#CreateSaveDataFileSystem]]
| + | |
− | |-
| + | Official user-process code sets instr[0] = 0 normally. |
− | | 0x7 || CanDeleteSaveData || 0x8000000000000060 || [[#DeleteSaveDataFileSystem]], RegisterSaveDataFileSystemAtomicDeletion
| + | |
− | |-
| + | Only partitionIDs for FAT partitions are usable with this, otherwise error 0x2EE202 is returned. Seems to be about the same as [[#OpenBisStorage]] except this mounts the partition filesystem instead of allowing direct access to the partition sectors. |
− | | 0x8 || CanCreateSystemSaveData || 0x8000000000000028 || CreateSaveDataFileSystemBySystemSaveDataId
| + | |
− | |-
| + | == OpenBisStorage == |
− | | 0x9 || CanCreateOthersSystemSaveData || 0x8000000000000020 || CreateSaveDataFileSystemBySystemSaveDataId
| + | Takes a u32 partition ID, returns 0x2EE202 for partitions which do not exist, 0x320002 for partitions which cannot be opened and a valid [[#IStorage]] handle otherwise. |
− | |-
| + | |
− | | 0xA || CanDeleteSystemSaveData || 0x8000000000004028 || [[#DeleteSaveDataFileSystem]], RegisterSaveDataFileSystemAtomicDeletion
| + | == InvalidateBisCache == |
− | |-
| + | Seems to invalidate the Bis cache for MBR/GPT after overwriting that data via the OpenBisStorage IStorage. Used by [[SystemInitializer]]. |
− | | 0xB || CanOpenSaveDataInfoReader || 0x8000000000000060 || [[#OpenSaveDataInfoReaderBySaveDataSpaceId]], [[#OpenSaveDataInfoReader]]
| + | |
− | |-
| + | == DeleteSaveDataFileSystem == |
− | | 0xC || CanOpenSaveDataInfoReaderForSystem || 0x8000000000004020 || [[#OpenSaveDataInfoReaderBySaveDataSpaceId]], [[#OpenSaveDataInfoReader]]
| + | Takes an input u64. |
− | |-
| + | |
− | | ([1.0.0-5.1.0] 0xD) || || 0x8000000000020000 ||
| + | == CreateSaveDataFileSystem == |
− | |-
| + | Takes a 0x40-byte [[#SaveDataAttribute]], a 0x40-byte [[#SaveDataCreationInfo]], and a 0x10-byte input struct which governs creation of a saveMeta file. |
− | | 0xD || CanOpenSaveDataInfoReaderForInternal || 0x8000000000000040 || [[#OpenSaveDataInfoReaderWithFilter]]
| + | |
− | |-
| + | Only the first 0x5-bytes in the 0x10-byte struct are initialized: all-zero when automatically creating savedata during savecommon mount by official user-processes. In the dedicated save-creation code in official user-processes: +0 u32 = 0x40060 meta file size, +4 u8 = 1 meta index which dictates meta file name. |
− | | ([1.0.0-5.1.0] 0xE) || || 0x8000000000000400 ||
| + | |
− | |-
| + | Creates non-system savedata. |
− | | 0xE || CanOpenSaveDataMetaFile || 0x8000000000020000 || OpenSaveDataMetaFile
| + | |
− | |-
| + | == CreateSaveDataFileSystemBySystemSaveDataId == |
− | | ([1.0.0-5.1.0] 0xF) || || 0x8000000000004060 ||
| + | Takes a 0x40-byte [[#SaveDataAttribute]] and a 0x40-byte [[#SaveDataCreationInfo]]. |
− | |- | + | |
− | | 0xF || CanSetCurrentPosixTime || 0x8000000000000400 || SetCurrentPosixTime, SetCurrentPosixTimeWithTimeDifference
| + | Creates savedata in the SYSTEM [[Flash_Filesystem|NAND]] partition. |
− | |-
| + | |
− | | ([1.0.0-5.1.0] 0x10) || || 0x8000000000080000 ||
| + | == OpenGameCardStorage == |
− | |-
| + | Takes two input u32s (gamecard handle, partition ID), and returns an [[#IStorage]] for the [[Gamecard_Format|partition]]. |
− | | 0x10 || CanReadSaveDataFileSystemExtraData || 0x8000000000004060 || [[#ReadSaveDataFileSystemExtraData]]
| + | |
− | |-
| + | == OpenGameCardFileSystem == |
− | | 0x11 || CanSetGlobalAccessLogMode || 0x8000000000080000 || [[#SetGlobalAccessLogMode]]
| + | Takes two input u32s, with the second u32 located at +4 in rawdata after the first u32. Returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | ([1.0.0-5.1.0] 0x12) || CanDebug || 0xC000000000000000 ||
| + | Mounts a [[Gamecard_Partition|gamecard partition]]. |
− | |-
| + | |
− | | 0x12 || CanSetSpeedEmulationMode || 0x8000000000080000 || SetSpeedEmulationMode
| + | == CreateSaveDataFileSystemWithHashSalt == |
− | |-
| + | Takes a total of 0xB0-bytes of input, no output. |
− | | ([1.0.0-5.1.0] 0x13) || || 0xC000000000800000 ||
| + | |
− | |-
| + | == OpenSaveDataFileSystem == |
− | | 0x13 || CanDebug || 0xC000000000000000 ||
| + | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]]. Official user-process code is only known to use value 1 for the u8. |
− | |-
| + | |
− | | ([1.0.0-5.1.0] 0x14) || || 0xC000000001000000 ||
| + | Returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | 0x14 || CanFillBis || 0xC000000000800000 || CreatePaddingFile, DeleteAllPaddingFiles
| + | Permissions aren't checked until the specified save is successfully found. |
− | |-
| + | |
− | | ([1.0.0-4.1.0] 0x15) || || 0xC000000002000000 || | + | Only one process (specifically only one [[#IFileSystem]] session) can mount a given savedata at any given time (this includes SystemSaveData). |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x15) || || 0x8000000001000060 ||
| + | == OpenSaveDataFileSystemBySystemSaveDataId == |
− | |-
| + | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]]. Web-applet only uses value0 for the input u8. |
− | | 0x15 || CanCorruptSaveData || 0xC000000001000000 || CorruptSaveDataFileSystem, CorruptSaveDataFileSystemBySaveDataSpaceId
| + | |
− | |-
| + | Returns an [[#IFileSystem]]. |
− | | ([2.0.0-4.1.0] 0x16) || || 0x8000000004000000 ||
| + | |
− | |-
| + | Mounts savedata in the SYSTEM [[Flash_Filesystem|NAND]] partition. |
− | | ([5.0.0-5.1.0] 0x16) || || 0x8000000000000060 ||
| + | |
− | |-
| + | == OpenReadOnlySaveDataFileSystem == |
− | | [2.0.0+] 0x16 || CanCorruptSystemSaveData || 0x8000000001000060 || CorruptSaveDataFileSystem, CorruptSaveDataFileSystemBySaveDataSpaceId
| + | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]], and returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | ([2.0.0-4.1.0] 0x17) || || 0x8000000008000000 ||
| + | Mounts SaveData as ReadOnly. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x17) || || 0xC000000002000000 ||
| + | == ReadSaveDataFileSystemExtraDataBySaveDataSpaceId == |
− | |-
| + | Takes an input u8 [[#SaveDataSpaceId]], an input u64 saveID, and a type-0x6 output buffer containing the [[#SaveDataFileSystemExtraData]]. |
− | | [2.0.0+] 0x17 || CanVerifySaveData || 0x8000000000000060 || [[#VerifySaveDataFileSystem]], VerifySaveDataFileSystemBySaveDataSpaceId
| + | |
− | |-
| + | == ReadSaveDataFileSystemExtraData == |
− | | ([2.0.0-4.1.0] 0x18) || || 0x8000000010000000 ||
| + | Takes an input u64 saveID and a type-0x6 output buffer containing the [[#SaveDataFileSystemExtraData]]. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x18) || || 0x8000000004000000 ||
| + | == OpenSaveDataInfoReader == |
− | |-
| + | No input, returns an output [[#ISaveDataInfoReader]]. |
− | | [2.0.0+] 0x18 || CanDebugSaveData || 0xC000000002000000 || [[#CreateSaveDataFileSystem]], [[#OpenSaveDataFileSystem]], [[#SetSaveDataRootPath]]
| + | |
− | |-
| + | == OpenSaveDataInfoReaderBySaveDataSpaceId == |
− | | ([2.0.0-4.1.0] 0x19) || || 0x8000000000000800 ||
| + | Takes an input u8 [[#SaveDataSpaceId]], returns an output [[#ISaveDataInfoReader]]. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x19) || || 0x8000000008000000 || | + | == FindSaveDataWithFilter == |
− | |-
| + | Takes a total of 0x50-bytes of input, returns 8-bytes of output and a type-0x6 output buffer. |
− | | [2.0.0+] 0x19 || CanFormatSdCard || 0x8000000004000000 || FormatSdCardFileSystem
| + | |
− | |-
| + | == OpenSaveDataInfoReaderWithFilter == |
− | | ([2.0.0-4.1.0] 0x1A) || || 0x8000000000004020 ||
| + | Takes a total of 0x50-bytes of input, returns an [[#ISaveDataInfoReader]]. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x1A) || || 0x8000000010000000 ||
| + | == OpenSaveDataTransferManager == |
− | |-
| + | No input, returns an [[#ISaveDataTransferManager]]. |
− | | [2.0.0+] 0x1A || CanGetRightsId || 0x8000000008000000 || GetRightsId, GetRightsIdAndKeyGenerationByPath, GetRightsIdByPath
| + | |
− | |-
| + | == OpenSaveDataTransferManagerVersion2 == |
− | | ([3.0.0-4.1.0] 0x1B) || || 0x8000000000002020 ||
| + | No input, returns an [[#ISaveDataTransferManagerWithDivision]]. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x1B) || || 0x8000000000000800 || | + | == OpenSaveDataTransferProhibiter == |
− | |-
| + | Takes an input u64, returns an [[#ISaveDataTransferProhibiter]]. |
− | | [3.0.0+] 0x1B || CanRegisterExternalKey || 0x8000000010000000 || RegisterExternalKey, UnregisterAllExternalKey
| + | |
− | |-
| + | == ListAccessibleSaveDataOwnerId == |
− | | ([3.0.0-4.1.0] 0x1C) || || 0x8000000000000028 ||
| + | Takes a total of 0x10-bytes of input, returns 4-bytes of output and a type-0x6 output buffer. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x1C) || || 0x8000000000004020 ||
| + | == OpenSaveDataTransferManagerForSaveDataRepair == |
− | |-
| + | No input, returns an output [[#ISaveDataTransferManagerForSaveDataRepair]]. |
− | | [3.0.0+] 0x1C || CanSetEncryptionSeed || 0x8000000000000800 || [[#SetSdCardEncryptionSeed]]
| + | |
− | |-
| + | == OpenSaveDataMover == |
− | | ([4.0.0-4.1.0] 0x1D) || || 0x8000000020000000 ||
| + | Takes 2 input [[#SaveDataSpaceId]], an input u64 size and a TransferMemory handle. Returns an output [[#ISaveDataMover]]. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x1D) || || 0x8000000000000000 ||
| + | == OpenSaveDataTransferManagerForRepair == |
− | |-
| + | No input, returns an output [[#ISaveDataTransferManagerForRepair]]. |
− | | [4.0.0+] 0x1D || CanWriteSaveDataFileSystemExtraDataTimeStamp || 0x8000000000000020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask
| + | |
− | |-
| + | == OpenContentStorageFileSystem == |
− | | ([4.0.0-4.1.0] 0x1E) || || 0x8000000040000000 ||
| + | Takes a [[#ContentStorageId]]. Invalid values return 0x2EE202. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x1E) || || 0x8000000000002020 ||
| + | Returns an [[#IFileSystem]] with NCA files. The read data from these files is identical to the data read by [[NCM_services#ReadContentIdFile]]. |
− | |-
| + | |
− | | [4.0.0+] 0x1E || CanWriteSaveDataFileSystemExtraDataFlags || 0x8000000000004020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask
| + | == OpenCloudBackupWorkStorageFileSystem == |
− | |-
| + | Takes 4-bytes of input, returns an [[#IFileSystem]]. |
− | | ([4.0.0-4.1.0] 0x1F) || || 0x8000000000000000 ||
| + | |
− | |-
| + | == OpenCustomStorageFileSystem == |
− | | ([5.0.0-5.1.0] 0x1F) || || 0x8000000000000028 ||
| + | Takes a [[#CustomStorageId]]. Invalid values return 0x2EE202. |
− | |-
| + | |
− | | [4.0.0+] 0x1F || CanWriteSaveDataFileSystemExtraDataCommitId || 0x8000000000000020 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask
| + | Returns an [[#IFileSystem]] from either User:/CustomStorage0 or Sdcard:/Nintendo/CustomStorage0. If on the SD card, an AesXtsFileSystem is created using a key source specifically for custom storage. |
− | |-
| + | |
− | | ([4.0.0-4.1.0] 0x20) || || 0x8000000000000000 ||
| + | == OpenDataStorageByDataId == |
− | |-
| + | Takes a [[NCM_services#StorageId|StorageID]] and a [[NCM_services#DataId|DataId]]. |
− | | ([5.0.0-5.1.0] 0x20) || || 0x8000000020000000 ||
| + | |
− | |-
| + | Returns a [[IPC_Marshalling#Domain_message|domain object ID]] implementing the [[#IStorage]] interface for data archives. |
− | | [4.0.0+] 0x20 || CanWriteSaveDataFileSystemExtraDataAll || 0x8000000000000000 || WriteSaveDataFileSystemExtraData, WriteSaveDataFileSystemExtraDataWithMask
| + | |
− | |-
| + | == OpenDataFileSystemWithProgramIndex == |
− | | ([5.0.0-5.1.0] 0x21) || || 0x8000000040000000 ||
| + | Takes an input u8, returns an [[#IFileSystem]]. |
− | |-
| + | |
− | | [5.0.0+] 0x21 || CanExtendSaveData || 0x8000000000002020 || ExtendSaveDataFileSystem
| + | == OpenDataStorageWithProgramIndex == |
− | |-
| + | Takes an input u8, returns an [[#IStorage]]. |
− | | ([5.0.0-5.1.0] 0x22) || || 0x0000000080000002 ||
| + | |
− | |-
| + | == OpenDeviceOperator == |
− | | [5.0.0+] 0x22 || CanExtendSystemSaveData || 0x8000000000000028 || ExtendSaveDataFileSystem
| + | This command returns a session to a port implementing the [[#IDeviceOperator]] interface. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x23) || || 0x8000000000000000 ||
| + | == OpenSdCardDetectionEventNotifier == |
− | |-
| + | This command returns a session to a port implementing the [[#IEventNotifier]] interface. |
− | | ([6.0.0-9.2.0] 0x23) || || 0x8000000020000000 ||
| + | |
− | |-
| + | == OpenGameCardDetectionEventNotifier == |
− | | [5.0.0+] 0x23 || CanExtendOthersSystemSaveData || 0x8000000000000020 || ExtendSaveDataFileSystem
| + | This command returns a session to a port implementing the [[#IEventNotifier]] interface. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x24) || || 0x8000000000000000 ||
| + | == SimulateDeviceDetectionEvent == |
− | |-
| + | Takes a total of 0xC-bytes of input, no output. |
− | | ([6.0.0-9.2.0] 0x24) || || 0x8000000040000000 ||
| + | |
− | |-
| + | == VerifySaveDataFileSystem == |
− | | [5.0.0+] 0x24 || CanRegisterUpdatePartition || 0x8000000020000000 || RegisterUpdatePartition
| + | Takes an unknown input u64 and a type-0x6 output buffer. |
− | |-
| + | |
− | | ([5.0.0-5.1.0] 0x25) || || 0x8000000080200000 ||
| + | The input u64 high-byte must be non-zero, otherwise an [[Error_codes|error]] is returned(0xE02). |
− | |-
| + | |
− | | ([6.0.0-9.2.0] 0x25) || || 0x8000000200000000 ||
| + | == GetSaveDataCommitId == |
− | |-
| + | Takes an input u8 and u64, returns an output u64. |
− | | [5.0.0+] 0x25 || CanOpenSaveDataTransferManager || 0x8000000040000000 || [[#OpenSaveDataTransferManager]]
| + | |
− | |-
| + | == SetSdCardEncryptionSeed == |
− | | ([5.0.0-5.1.0] 0x26) || || 0x8000000080000110 ||
| + | Takes in the 0x10 byte SD card encryption seed, and loads it into FS-module state. |
− | |-
| + | |
− | | ([6.0.0-8.1.0] 0x26) || || 0x8000000200002000 ||
| + | [[NS_Services|NS]]-module reads the 0x10 bytes from SdCard:/Nintendo/Contents/private, and compares them to the first 0x10 bytes of the ns_appman:/private (in [[Flash_Filesystem#System_Savegames|system savedata]] 0x8000000000000043). If they match, NS calls this command using bytes 0x10-0x20 from ns_appman:/private. The rest of this file (0x1F0 bytes total) is all-zero except for the byte at offset 0x20. This byte is set to 1 by NS if the SD card has been mounted successfully and is subsequently passed to SetSdCardAccessibility. |
− | |-
| + | |
− | | ([9.0.0-9.2.0] 0x26) || || 0x8000000200000000 ||
| + | == OpenAccessFailureDetectionEventNotifier == |
− | |-
| + | Takes 8-bytes of input and returns an [[#IEventNotifier]]. |
− | | [5.0.0+] 0x26 || CanOpenSaveDataTransferManagerVersion2 || 0x8000000200000000 || [[#OpenSaveDataTransferManagerVersion2]]
| + | |
− | |-
| + | [8.0.0+] Now takes an additional 8-bytes of input. |
− | | ([5.0.0-5.1.0] 0x27) || || 0x8000000000100008 ||
| + | |
− | |-
| + | == SetSaveDataSize == |
− | | ([6.0.0-7.0.1] 0x27) || || 0x8000000200002000 ||
| + | Takes two input u64s "size" and "journal_size", and writes them to fsp-srv object member variables. |
− | |-
| |
− | | ([8.0.0-8.1.0] 0x27) || || 0x8000000240002000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x27) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x27 || CanOpenSaveDataTransferManagerForSaveDataRepair || 0x8000000200000000 || OpenSaveDataTransferManagerForSaveDataRepair
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x28) || || 0x8000000080010000 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x28) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x28) || || 0x8000000200002000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x28 || CanOpenSaveDataTransferManagerForSaveDataRepairTool || 0x8000000000000000 || OpenSaveDataTransferManagerForSaveDataRepair
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x29) || || 0x0000000080000001 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x29) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x29) || || 0x8000000240002000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x29 || CanOpenOpenSaveDataTransferProhibiter || 0x8000000200002000 || [[#OpenSaveDataTransferProhibiter]]
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2A) || || 0x0000000080000001 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2A) || || 0x8000000080200000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2A) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2A || CanOpenSaveDataMover || 0x8000001000000000 || [[#OpenSaveDataMover]]
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2B) || || 0x0000000080000001 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2B) || || 0x8000000080000110 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2B) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2B || CanOpenBisWiper || 0x8000000000000800 || [[#OpenBisWiper]]
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2C) || || 0x0000000080000001 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2C) || || 0x8000000000100008 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2C) || || 0x8000000080200000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2C || CanListAccessibleSaveDataOwnerId || 0x8000000240002000 || [[#ListAccessibleSaveDataOwnerId]]
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2D) || || 0x0000000080000001 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2D) || || 0x8000000000010000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2D) || || 0x8000000080000110 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2D || CanControlMmcPatrol || 0x8000000000000000 || SuspendMmcPatrol, ResumeMmcPatrol
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2E) || || 0x8000000040000000 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2E) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2E) || || 0x8000000000100008 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2E || CanOverrideSaveDataTransferTokenSignVerificationKey || 0x8000000000000000 || OverrideSaveDataTransferTokenSignVerificationKey
| |
− | |-
| |
− | | ([5.0.0-5.1.0] 0x2F) || || 0x8000000080200000 ||
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x2F) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x2F) || || 0x8000000000010000 ||
| |
− | |-
| |
− | | [5.0.0+] 0x2F || CanOpenSdCardDetectionEventNotifier || 0x8000000080200000 || [[#OpenSdCardDetectionEventNotifier]]
| |
− | |-
| |
− | | ([5.1.0-6.0.0] 0x30) || || 0x8000000080080000 ||
| |
− | |-
| |
− | | ([6.0.1-9.2.0] 0x30) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | [5.1.0+] 0x30 || CanOpenGameCardDetectionEventNotifier || 0x8000000080000110 || [[#OpenGameCardDetectionEventNotifier]]
| |
− | |-
| |
− | | ([6.0.0-9.2.0] 0x31) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x31 || CanOpenSystemDataUpdateEventNotifier || 0x8000000000100008 || OpenSystemDataUpdateEventNotifier
| |
− | |-
| |
− | | ([6.0.0-9.2.0] 0x32) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x32 || CanNotifySystemDataUpdateEvent || 0x8000000000010000 || NotifySystemDataUpdateEvent
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x33) || || 0x8000000040000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x33) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x33 || CanOpenAccessFailureDetectionEventNotifier || 0x8000000100000000 || [[#OpenAccessFailureDetectionEventNotifier]]
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x34) || || 0x8000000200000020 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x34) || || 0x8000000100000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x34 || CanGetAccessFailureDetectionEvent || 0x8000000100000000 || GetAccessFailureDetectionEvent
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x35) || || 0x8000000000200000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x35) || || 0x8000000040000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x35 || CanIsAccessFailureDetected || 0x8000000100000000 || IsAccessFailureDetected
| |
− | |-
| |
− | | ([6.0.0-8.1.0] 0x36) || || 0x4000000000000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x36) || || 0x8000000200000020 ||
| |
− | |-
| |
− | | [6.0.0+] 0x36 || CanResolveAccessFailure || 0x8000000100000000 || ResolveAccessFailure
| |
− | |-
| |
− | | ([6.0.0-6.2.0] 0x37) || || 0x8000000000080000 ||
| |
− | |-
| |
− | | ([7.0.0-8.1.0] 0x37) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x37) || || 0x8000000000200000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x37 || CanAbandonAccessFailure || 0x8000000100000000 || AbandonAccessFailure
| |
− | |-
| |
− | | ([6.0.0-6.2.0] 0x38) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | ([7.0.0-8.1.0] 0x38) || || 0x8000000400000000 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x38) || || 0x4000000000000000 ||
| |
− | |-
| |
− | | [6.0.0+] 0x38 || CanQuerySaveDataInternalStorageTotalSize || 0x8000000040000000 || QuerySaveDataInternalStorageTotalSize
| |
− | |-
| |
− | | ([8.0.0-8.1.0] 0x39) || || 0x8000000000000010 ||
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x39) || || 0x8000000000000000 ||
| |
− | |-
| |
− | | [8.0.0+] 0x39 || CanGetSaveDataCommitId || 0x8000000200000020 || [[#GetSaveDataCommitId]]
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3A) || || 0x8000000400000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3A || CanSetSdCardAccessibility || 0x8000000000200000 || SetSdCardAccessibility
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3B) || || 0x8000000000000010 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3B || CanSimulateDevice || 0x4000000000000000 || SimulateDeviceDetectionEvent, SetSimulationEvent, ClearSimulationEvent
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3C) || || 0x8000000800000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3C || CanCreateSaveDataWithHashSalt || 0x8000000000000000 || [[#CreateSaveDataFileSystem]], [[#CreateSaveDataFileSystemWithHashSalt]]
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3D) || || 0x8000000800000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3D || CanRegisterProgramIndexMapInfo || 0x8000000400000000 || RegisterProgramIndexMapInfo
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3E) || || 0x8000000800000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3E || CanChallengeCardExistence || 0x8000000000000010 || ChallengeCardExistence
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x3F) || || 0x8000000800000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x3F || CanCreateOwnSaveData || 0x8000000800000000 || [[#CreateSaveDataFileSystem]], CreateSaveDataFileSystemWithHashSalt
| |
− | |-
| |
− | | ([9.0.0-9.2.0] 0x40) || || 0x8000000800000000 ||
| |
− | |-
| |
− | | [9.0.0+] 0x40 || CanReadOwnSaveDataFileSystemExtraData || 0x8000000800000000 || [[#ReadSaveDataFileSystemExtraData]]
| |
− | |-
| |
− | | [10.0.0+] 0x41 || CanExtendOwnSaveData || 0x8000000800000000 || ExtendSaveDataFileSystem
| |
− | |-
| |
− | | [10.0.0+] 0x42 || CanOpenOwnSaveDataTransferProhibiter || 0x8000000800000000 || [[#OpenSaveDataTransferProhibiter]]
| |
− | |-
| |
− | | [10.0.0+] 0x43 || CanFindOwnSaveDataWithFilter || 0x8000000800000000 || [[#FindSaveDataWithFilter]]
| |
− | |}
| |
| | | |
− | == OpenFileSystem ==
| + | These variables are normally initialized with 32 MiB (0x2000000) and 16 MiB (0x1000000), respectively. |
− | Takes a type-0x19 input [[#ContentPath]] and a [[#FileSystemProxyType]] as parameters. Returns an [[#IFileSystem]].
| |
| | | |
− | [2.0.0+] This function was removed.
| + | These variables don't seem to be actually used anywhere else (?) |
| | | |
− | == SetCurrentProcess == | + | == SetSaveDataRootPath == |
− | Takes a pid-descriptor. | + | Takes an input path, and does snprintf(<fsp-srv object>->m_save_data_root_path, FS_MAX_PATH-1, "/%s", input_path); |
| | | |
− | == OpenFileSystemWithPatch ==
| + | This path is normally all-zero. When this path is non-zero, the internal OpenSaveDataFileSystem function will create a DirectorySaveDataFileSystem if the target save is a user-save + a directory exists, instead of the normal savedata filesystem object. |
− | Takes an input [[#FileSystemProxyType]] and an u64 title-id. Returns an [[#IFileSystem]].
| |
| | | |
− | Web-applet loads the [[#FileSystemProxyType]] (which must be '''Manual''') from u32_table[inparam].
| + | == SetGlobalAccessLogMode == |
| + | Takes an input u32. |
| | | |
− | Note: web-applet strings refer to both this cmd and [[#OpenFileSystemWithId]] as "MountContent", but official nn_sf_sync symbols use "OpenXX" names.
| + | == SetGlobalAccessLogMode == |
| + | Takes an input u32. |
| | | |
− | == OpenFileSystemWithId == | + | == GetGlobalAccessLogMode == |
− | Takes a type-0x19 input buffer, an [[#FileSystemProxyType]] and an u64 title-id. Returns an [[#IFileSystem]].
| + | Returns an output u32. |
| | | |
− | The [[#IFileSystem]] must be '''Meta''' if the NCA type is 0.
| + | GlobalAccessLogMode is normally 0. |
| | | |
− | The input buffer is the output string path from [[NS_Services#GetApplicationContentPath|GetApplicationContentPath]].
| + | == OutputAccessLogToSdCard == |
| + | Takes a type-0x5 input buffer. |
| | | |
− | May return errors when attempting to access NCA-paths for an update-title with a gamecard, when the gamecard isn't inserted. May return error 0x7D402 in some cases with update-titles. Non-val2 in32 values with NCA-type1 are unusable, even for normal titles.
| + | The input buffer is the string to output to the log. User-processes normally include a newline at the end. |
| | | |
− | The official "MountApplicationPackage" func uses this with in64=0 and [[#FileSystemProxyType]] '''Package'''.
| + | User-processes only use this when the value previously loaded from [[#GetGlobalAccessLogMode]] has bit1 set. |
| | | |
− | After the [[#FileSystemProxyType]] specific permissions are checked, it then gets the func retval for permissions-type 0x25 and func0.
| + | When bit1 in GlobalAccessLogMode is clear, FS-module will just return 0 for OutputAccessLogToSdCard. However even with that set the log doesn't show up SD, unknown why. |
| | | |
− | When [[#FileSystemProxyType]] is '''Meta''', it uses in64=0xffffffffffffffff internally, otherwise it checks if in64 is set to 0xffffffffffffffff then throws an error if so. When the in64 used internally is not 0xffffffffffffffff, it's compared with the NCA [[NCM_services#ProgramId|ProgramId]], then an error is thrown on mismatch.
| + | The input buffer is written to the "$FsAccessLog:/FsAccessLog.txt" file, where "$FsAccessLog" is the SD-card mount-name. It's written to the current end of the file(appended). |
| | | |
− | == OpenBisFileSystem == | + | == GetProgramIndexForAccessLog == |
− | Takes a type-0x19 input buffer string and a [[#BisPartitionId]]. Official user-process code sets instr[0] = 0 normally. Returns an [[#IFileSystem]].
| + | No input, returns two 32-bit values "version" and "program_index". |
| | | |
− | Only partitionIDs for FAT partitions are usable with this, otherwise error 0x2EE202 is returned. Seems to be about the same as [[#OpenBisStorage]] except this mounts the partition filesystem instead of allowing direct access to the partition sectors.
| + | == OpenMultiCommitManager == |
| + | No input, returns an output [[#IMultiCommitManager]]. |
| | | |
− | == OpenBisStorage == | + | == OpenBisWiper == |
− | Takes a u32 partition ID, returns 0x2EE202 for partitions which do not exist, 0x320002 for partitions which cannot be opened and a valid [[#IStorage]] handle otherwise. | + | Takes an input u64 size and a TransferMemory handle. Returns an output [[#IWiper]]. |
| | | |
− | == InvalidateBisCache == | + | = IStorage = |
− | Seems to invalidate the Bis cache for MBR/GPT after overwriting that data via the OpenBisStorage IStorage. Used by [[SystemInitializer]].
| + | This is "nn::fssrv::sf::IStorage". |
| | | |
− | == DeleteSaveDataFileSystem ==
| + | This is the interface for a raw device, usually a block device. |
− | Takes an input u64.
| |
| | | |
− | == CreateSaveDataFileSystem == | + | {| class="wikitable" border="1" |
− | Takes a 0x40-byte [[#SaveDataAttribute]], a 0x40-byte [[#SaveDataCreationInfo]], and a 0x10-byte input struct.
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#Read]] |
| + | |- |
| + | | 1 || [[#Write]] |
| + | |- |
| + | | 2 || [[#Flush]] |
| + | |- |
| + | | 3 || [[#SetSize]] |
| + | |- |
| + | | 4 || [[#GetSize]] |
| + | |- |
| + | | 5 || [4.0.0+] OperateRange |
| + | |} |
| | | |
− | Only the first 0x5-bytes in the 0x10-byte struct are initialized: all-zero when automatically creating savedata during savecommon mount by official user-processes. In the dedicated save-creation code in official user-processes: +0 u32 = 0x40060, +4 u8 = 1.
| + | == Read == |
| + | Takes a type-0x46 buffer, an offset and length. |
| | | |
− | Creates regular savedata.
| + | == Write == |
| + | Takes a type-0x45 buffer, an offset and length. |
| | | |
− | == CreateSaveDataFileSystemBySystemSaveDataId == | + | == Flush == |
− | Takes a 0x40-byte [[#SaveDataAttribute]] and a 0x40-byte [[#SaveDataCreationInfo]].
| + | No input. |
| | | |
− | Creates savedata in the SYSTEM [[Flash_Filesystem|NAND]] partition.
| + | == SetSize == |
| + | Takes a size. |
| | | |
− | == OpenGameCardStorage == | + | == GetSize == |
− | Takes two input u32s (gamecard handle, partition ID), and returns an [[#IStorage]] for the [[Gamecard_Format|partition]].
| + | Returns a size. |
| | | |
− | == OpenGameCardFileSystem == | + | = IFileSystem = |
− | Takes two input u32s, with the second u32 located at +4 in rawdata after the first u32. Returns an [[#IFileSystem]].
| + | This is "nn::fssrv::sf::IFileSystem". |
| | | |
− | Mounts a [[Gamecard_Partition|gamecard partition]].
| + | There are two main implementations of this interface: |
| | | |
− | == CreateSaveDataFileSystemWithHashSalt ==
| + | * '''nn::fs::fsa::IFileSystem''': The main IFileSystem implementation. Filesystem classes implement this interface, and FS code usually operates on this interface. |
− | Takes a total of 0xB0-bytes of input, no output.
| + | * '''nn::fssrv::sf::IFileSystem''': Used for sending an IFileSystem over IPC. Not used outside of IPC code. |
| | | |
− | == OpenSaveDataFileSystem ==
| + | There are two adapter classes to convert between these interfaces: |
− | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]]. Official user-process code is only known to use value 1 for the u8.
| |
| | | |
− | Returns an [[#IFileSystem]].
| + | * '''nn::fssrv::detail::FileSystemInterfaceAdapter''': Allows access to an nn::fs::fsa::IFileSystem via the nn::fssrv::sf::IFileSystem interface. |
| + | * '''nn::fs::detail::FileSystemServiceObjectAdapter''': Allows access to an nn::fssrv::sf::IFileSystem via the nn::fs::fsa::IFileSystem interface. |
| | | |
− | Permissions aren't checked until the specified save is successfully found.
| + | When the FS process returns a filesystem, it will wrap the filesystem object in a FileSystemInterfaceAdapter to return it over IPC. |
| + | Then when FS application code receives that filesystem, it will wrap the nn::fssrv::sf::IFileSystem object in a FileSystemServiceObjectAdapter before using it. |
| | | |
− | Only one process (specifically only one [[#IFileSystem]] session) can mount a given savedata at any given time (this includes SystemSaveData).
| + | {| class="wikitable" border="1" |
− | | + | |- |
− | == OpenSaveDataFileSystemBySystemSaveDataId ==
| + | ! Cmd || Name |
− | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]]. Web-applet only uses value0 for the input u8.
| + | |- |
− | | + | | 0 || CreateFile |
− | Returns an [[#IFileSystem]].
| + | |- |
− | | + | | 1 || DeleteFile |
− | Mounts savedata in the SYSTEM [[Flash_Filesystem|NAND]] partition.
| + | |- |
− | | + | | 2 || CreateDirectory |
− | == OpenReadOnlySaveDataFileSystem ==
| + | |- |
− | Takes an input u8 [[#SaveDataSpaceId]] and a 0x40-byte [[#SaveDataAttribute]], and returns an [[#IFileSystem]].
| + | | 3 || DeleteDirectory |
− | | + | |- |
− | Mounts SaveData as ReadOnly.
| + | | 4 || DeleteDirectoryRecursively |
− | | + | |- |
− | == ReadSaveDataFileSystemExtraDataBySaveDataSpaceId ==
| + | | 5 || RenameFile |
− | Takes an input u8 [[#SaveDataSpaceId]], an input u64 saveID, and a type-0x6 output buffer containing the [[#SaveDataFileSystemExtraData]].
| + | |- |
− | | + | | 6 || RenameDirectory |
− | == ReadSaveDataFileSystemExtraData ==
| + | |- |
− | Takes an input u64 saveID and a type-0x6 output buffer containing the [[#SaveDataFileSystemExtraData]].
| + | | 7 || [[#GetEntryType]] |
| + | |- |
| + | | 8 || [[#OpenFile]] |
| + | |- |
| + | | 9 || [[#OpenDirectory]] |
| + | |- |
| + | | 10 || [[#Commit]] |
| + | |- |
| + | | 11 || [[#GetFreeSpaceSize]] |
| + | |- |
| + | | 12 || [[#GetTotalSpaceSize]] |
| + | |- |
| + | | 13 || [3.0.0+] [[#CleanDirectoryRecursively]] |
| + | |- |
| + | | 14 || [3.0.0+] [[#GetFileTimeStampRaw]] |
| + | |- |
| + | | 15 || [4.0.0+] QueryEntry |
| + | |- |
| + | | 16 || [15.0.0+] GetFileSystemAttribute |
| + | |} |
| | | |
− | == OpenSaveDataInfoReader == | + | == GetEntryType == |
− | No input, returns an output [[#ISaveDataInfoReader]].
| + | Takes a type-0x9 input buffer for the path and returns [[#DirectoryEntryType]] as an output u32. |
| | | |
− | == OpenSaveDataInfoReaderBySaveDataSpaceId == | + | == OpenFile == |
− | Takes an input u8 [[#SaveDataSpaceId]], returns an output [[#ISaveDataInfoReader]]. | + | Takes a type-0x19 input buffer for the path, and an u32 '''mode'''. '''mode''' controls how the file is opened, based on which bits are set: |
| | | |
− | == FindSaveDataWithFilter ==
| + | * When bit 0 is set, the file is Readable: you can use the Read operation. |
− | Takes a total of 0x50-bytes of input, returns 8-bytes of output and a type-0x6 output buffer.
| + | * When bit 1 is set, the file is Writable: you can use the Write operation. |
| + | * When bit 2 is set, the file is Appendable: unless this bit is set, you will not be able to write beyond the end of a file (such writes will result in an error 0x307202) |
| | | |
− | == OpenSaveDataInfoReaderWithFilter == | + | == OpenDirectory == |
− | Takes a total of 0x50-bytes of input, returns an [[#ISaveDataInfoReader]]. | + | Takes a type-0x9 input buffer for the path and an u64 '''filter_flags'''. '''filter_flags''' controls what type of entries are read by the [[#IDirectory]]: bitmask 0x1 = directories, bitmask 0x2 = files. |
| | | |
− | == OpenSaveDataTransferManager == | + | == Commit == |
− | No input, returns an [[#ISaveDataTransferManager]].
| + | Like [https://3dbrew.org/wiki/FS:ControlArchive 3DS], this has to be used after writing to savedata for the changes to take affect. |
| | | |
− | == OpenSaveDataTransferManagerVersion2 == | + | == GetFreeSpaceSize == |
− | No input, returns an [[#ISaveDataTransferManagerWithDivision]].
| + | Takes a type-0x9 input buffer for the path and returns an output byte-size u64 for the total free space with this FS. |
| | | |
− | == OpenSaveDataTransferProhibiter == | + | == GetTotalSpaceSize == |
− | Takes an input u64, returns an [[#ISaveDataTransferProhibiter]]. | + | Takes a type-0x9 input buffer for the path and returns an output byte-size u64 for the total space available with this FS(free+used). |
| | | |
− | == ListAccessibleSaveDataOwnerId == | + | == CleanDirectoryRecursively == |
− | Takes a total of 0x10-bytes of input, returns 4-bytes of output and a type-0x6 output buffer. | + | Takes a type-0x9 input buffer for the path and clears the contents of the directory specified in the path. |
| | | |
− | == OpenSaveDataTransferManagerForSaveDataRepair == | + | == GetFileTimeStampRaw == |
− | No input, returns an output [[#ISaveDataTransferManagerForSaveDataRepair]].
| + | Takes a type-0x19 input buffer for the path and returns a 0x20-byte struct. This contains 3 u64s and an u8. |
| | | |
− | == OpenSaveDataMover == | + | = IDirectory = |
− | Takes 2 input [[#SaveDataSpaceId]], an input u64 size and a TransferMemory handle. Returns an output [[#ISaveDataMover]].
| + | This is "nn::fssrv::sf::IDirectory". |
| | | |
− | == OpenContentStorageFileSystem == | + | {| class="wikitable" border="1" |
− | Takes a [[#ContentStorageId]]. Invalid values return 0x2EE202.
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#Read]] |
| + | |- |
| + | | 1 || [[#GetEntryCount]] |
| + | |} |
| | | |
− | Returns an [[#IFileSystem]] with NCA files. The read data from these files is identical to the data read by [[NCM_services#ReadContentIdFile]]. | + | == Read == |
| + | Takes a type-0x6 output buffer. Returns an output u64(?) for the total number of read entries, this is 0 when no more entries are available. |
| | | |
− | == OpenCloudBackupWorkStorageFileSystem ==
| + | The output buffer contains the read array of [[#DirectoryEntry]]. This doesn't include entries for "." and "..". |
− | Takes 4-bytes of input, returns an [[#IFileSystem]].
| |
| | | |
− | == OpenCustomStorageFileSystem == | + | == GetEntryCount == |
− | Takes a [[#CustomStorageId]]. Invalid values return 0x2EE202.
| + | Returns an u64 for the total number of readable entries. |
| | | |
− | Returns an [[#IFileSystem]] from either User:/CustomStorage0 or Sdcard:/Nintendo/CustomStorage0. If on the SD card, an AesXtsFileSystem is created using a key source specifically for custom storage.
| + | = DirectoryEntry = |
| + | This is "nn::fs::DirectoryEntry". |
| | | |
− | == OpenDataStorageByDataId == | + | {| class="wikitable" border="1" |
− | Takes a [[NCM_services#StorageId|StorageID]] and a [[NCM_services#DataId|DataId]].
| + | |- |
− | | + | ! Offset || Size || Description |
− | Returns a [[IPC_Marshalling#Domain_message|domain object ID]] implementing the [[#IStorage]] interface for data archives.
| + | |- |
− | | + | | 0x0 || 0x301 || Path |
− | == OpenDataFileSystemWithProgramIndex ==
| + | |- |
− | Takes an input u8, returns an [[#IFileSystem]].
| + | | 0x301 || 0x1 || File attributes (bit 0 = is directory; bit 1 = archive bit) |
| + | |- |
| + | | 0x302 || 0x2 || Padding? |
| + | |- |
| + | | 0x304 || 0x1 || [[#DirectoryEntryType]] |
| + | |- |
| + | | 0x305 || 0x3 || Padding? |
| + | |- |
| + | | 0x308 || 0x8 || Filesize, 0 for directories. |
| + | |} |
| | | |
− | == OpenDataStorageWithProgramIndex == | + | = DirectoryEntryType = |
− | Takes an input u8, returns an [[#IStorage]].
| + | This is "nn::fs::DirectoryEntryType". |
| | | |
− | == OpenDeviceOperator ==
| + | An s8 value indicating a directory entry type. The current values are: |
− | This command returns a session to a port implementing the [[#IDeviceOperator]] interface.
| |
| | | |
− | == OpenSdCardDetectionEventNotifier == | + | {| class="wikitable" border="1" |
− | This command returns a session to a port implementing the [[#IEventNotifier]] interface.
| + | |- |
| + | ! Value || Description |
| + | |- |
| + | | 0 || Directory |
| + | |- |
| + | | 1 || File |
| + | |} |
| | | |
− | == OpenGameCardDetectionEventNotifier == | + | = IFile = |
− | This command returns a session to a port implementing the [[#IEventNotifier]] interface. | + | This is "nn::fssrv::sf::IFile". |
| | | |
− | == SimulateDeviceDetectionEvent == | + | {| class="wikitable" border="1" |
− | Takes a total of 0xC-bytes of input, no output.
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || Read |
| + | |- |
| + | | 1 || Write |
| + | |- |
| + | | 2 || Flush |
| + | |- |
| + | | 3 || SetSize |
| + | |- |
| + | | 4 || GetSize |
| + | |- |
| + | | 5 || [4.0.0+] OperateRange |
| + | |- |
| + | | 6 || [12.0.0+] OperateRangeWithBuffer |
| + | |} |
| | | |
− | == VerifySaveDataFileSystem == | + | = ISaveDataInfoReader = |
− | Takes an unknown input u64 and a type-0x6 output buffer.
| + | This is "nn::fssrv::sf::ISaveDataInfoReader". |
| | | |
− | The input u64 high-byte must be non-zero, otherwise an [[Error_codes|error]] is returned(0xE02).
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#ReadSaveDataInfo]] |
| + | |} |
| | | |
− | == GetSaveDataCommitId == | + | == ReadSaveDataInfo == |
− | Takes an input u8 and u64, returns an output u64. | + | Takes a type-0x6 output buffer. Returns an output u64 for total output entries. This buffer contains an array of [[#SaveDataInfo]]. |
| | | |
− | == SetSdCardEncryptionSeed ==
| + | This is used to get [[#SaveDataInfo]] for all savedata on the system (or all savedata for the current [[#SaveDataSpaceId]]). When used multiple times, it will resume reading where it left off, until no more entries are available (in that case the out u64 is value 0). |
− | Takes in the 0x10 byte SD card encryption seed, and loads it into FS-module state.
| |
| | | |
− | [[NS_Services|NS]]-module reads the 0x10 bytes from SdCard:/Nintendo/Contents/private, and compares them to the first 0x10 bytes of the ns_appman:/private (in [[Flash_Filesystem#System_Savegames|system savedata]] 0x8000000000000043). If they match, NS calls this command using bytes 0x10-0x20 from ns_appman:/private. The rest of this file (0x1F0 bytes total) is (usually/always?) all-zero (however in some cases the byte at offset 0x20 is value 0x1).
| + | = IDeviceOperator = |
| + | This is "nn::fssrv::sf::IDeviceOperator". |
| | | |
− | == OpenAccessFailureDetectionEventNotifier == | + | {| class="wikitable" border="1" |
− | Takes 8-bytes of input and returns an [[#IEventNotifier]].
| + | |- |
− | | + | ! Cmd || Name |
− | [8.0.0+] Now takes an additional 8-bytes of input. | + | |- |
− | | + | | 0 || [[#IsSdCardInserted]] |
− | == SetSaveDataSize ==
| + | |- |
− | Takes two input u64s "size" and "journal_size", and writes them to fsp-srv object member variables.
| + | | 1 || [[#GetSdCardSpeedMode]] |
− | | + | |- |
− | These variables are normally initialized with 32 MiB (0x2000000) and 16 MiB (0x1000000), respectively.
| + | | 2 || [2.0.0+] [[#GetSdCardCid]] |
− | | + | |- |
− | These variables don't seem to be actually used anywhere else (?)
| + | | 3 || [2.0.0+] [[#GetSdCardUserAreaSize]] |
− | | + | |- |
− | == SetSaveDataRootPath ==
| + | | 4 || [2.0.0+] [[#GetSdCardProtectedAreaSize]] |
− | Takes an input path, and does snprintf(<fsp-srv object>->m_save_data_root_path, FS_MAX_PATH-1, "/%s", input_path);
| + | |- |
− | | + | | 5 || [2.0.0+] [[#GetAndClearSdCardErrorInfo]] |
− | This path is normally all-zero. When this path is non-zero, the internal OpenSaveDataFileSystem function will create a DirectorySaveDataFileSystem if the target save is a user-save + a directory exists, instead of the normal savedata filesystem object.
| + | |- |
− | | + | | 6 || [17.0.0+] GetSdCardHostControllerStatus |
− | == SetGlobalAccessLogMode ==
| + | |- |
− | Takes an input u32.
| + | | 100 || [[#GetMmcCid]] |
− | | + | |- |
− | == SetGlobalAccessLogMode ==
| + | | 101 || [[#GetMmcSpeedMode]] |
− | Takes an input u32.
| + | |- |
− | | + | | 110 || [[#EraseMmc]] |
− | == GetGlobalAccessLogMode ==
| + | |- |
− | Returns an output u32.
| + | | 111 || [[#GetMmcPartitionSize]] |
− | | + | |- |
− | GlobalAccessLogMode is normally 0.
| + | | 112 || [2.0.0+] [[#GetMmcPatrolCount]] |
− | | + | |- |
− | == OutputAccessLogToSdCard ==
| + | | 113 || [2.0.0+] [[#GetAndClearMmcErrorInfo]] |
− | Takes a type-0x5 input buffer.
| + | |- |
− | | + | | 114 || [2.0.0+] [[#GetMmcExtendedCsd]] |
− | The input buffer is the string to output to the log. User-processes normally include a newline at the end.
| + | |- |
− | | + | | 115 || [4.0.0+] [[#SuspendMmcPatrol]] |
− | User-processes only use this when the value previously loaded from [[#GetGlobalAccessLogMode]] has bit1 set.
| + | |- |
− | | + | | 116 || [4.0.0+] [[#ResumeMmcPatrol]] |
− | When bit1 in GlobalAccessLogMode is clear, FS-module will just return 0 for OutputAccessLogToSdCard. However even with that set the log doesn't show up SD, unknown why.
| + | |- |
− | | + | | 117 || [17.0.0+] EraseMmcWithRange |
− | The input buffer is written to the "$FsAccessLog:/FsAccessLog.txt" file, where "$FsAccessLog" is the SD-card mount-name. It's written to the current end of the file(appended).
| + | |- |
− | | + | | 200 || [[#IsGameCardInserted]] |
− | == GetProgramIndexForAccessLog ==
| + | |- |
− | No input, returns two 32-bit values "version" and "program_index".
| + | | 201 || [[#EraseGameCard]] |
− | | + | |- |
− | == OpenMultiCommitManager ==
| + | | 202 || [[#GetGameCardHandle]] |
− | No input, returns an output [[#IMultiCommitManager]].
| + | |- |
− | | + | | 203 || [[#GetGameCardUpdatePartitionInfo]] |
− | == OpenBisWiper ==
| |
− | Takes an input u64 size and a TransferMemory handle. Returns an output [[#IWiper]].
| |
− | | |
− | = IStorage =
| |
− | This is "nn::fssrv::sf::IStorage".
| |
− | | |
− | This is the interface for a raw device, usually a block device.
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name
| + | | 204 || [[#FinalizeGameCardDriver]] |
| |- | | |- |
− | | 0 || [[#Read]] | + | | 205 || [[#GetGameCardAttribute]] |
| |- | | |- |
− | | 1 || [[#Write]] | + | | 206 || [[#GetGameCardDeviceCertificate]] |
| + | |- |
| + | | 207 || [[#GetGameCardAsicInfo]] |
| + | |- |
| + | | 208 || [[#GetGameCardIdSet]] |
| + | |- |
| + | | 209 || [[#WriteToGameCardDirectly]] |
| + | |- |
| + | | 210 || [[#SetVerifyWriteEnalbleFlag]] |
| + | |- |
| + | | 211 || [[#GetGameCardImageHash]] |
| + | |- |
| + | | 212 || [2.0.0+] [[#GetGameCardDeviceIdForProdCard]] |
| + | |- |
| + | | 213 || [2.0.0+] [[#EraseAndWriteParamDirectly]] |
| + | |- |
| + | | 214 || [2.0.0+] [[#ReadParamDirectly]] |
| + | |- |
| + | | 215 || [2.0.0+] [[#ForceEraseGameCard]] |
| + | |- |
| + | | 216 || [2.0.0+] [[#GetGameCardErrorInfo]] |
| + | |- |
| + | | 217 || [2.1.0+] [[#GetGameCardErrorReportInfo]] |
| + | |- |
| + | | 218 || [3.0.0+] [[#GetGameCardDeviceId]] |
| + | |- |
| + | | 219 || [8.0.0+] [[#ChallengeCardExistence]] |
| + | |- |
| + | | 220 || [9.0.0+] [[#GetGameCardCompatibilityType]] |
| + | |- |
| + | | 221 || [17.0.0+] [[#GetGameCardAsicCertificate]] |
| + | |- |
| + | | 222 || [18.0.0+] [[#GetGameCardCardHeader]] |
| + | |- |
| + | | 300 || [[#SetSpeedEmulationMode]] |
| + | |- |
| + | | 301 || [[#GetSpeedEmulationMode]] |
| + | |- |
| + | | 302 || [18.0.0+] SetApplicationStorageSpeed |
| + | |- |
| + | | 400 || [5.0.0+] [[#SuspendSdmmcControl]] |
| |- | | |- |
− | | 2 || [[#Flush]] | + | | 401 || [5.0.0+] [[#ResumeSdmmcControl]] |
| |- | | |- |
− | | 3 || [[#SetSize]] | + | | 402 || [6.0.0+] [[#GetSdmmcConnectionStatus]] |
| |- | | |- |
− | | 4 || [[#GetSize]] | + | | 500 || [6.0.0+] [[#SetDeviceSimulationEvent]] |
| |- | | |- |
− | | 5 || [4.0.0+] OperateRange | + | | 501 || [6.0.0+] [[#ClearDeviceSimulationEvent]] |
| |} | | |} |
| | | |
− | == Read == | + | == IsSdCardInserted == |
− | Takes a type-0x46 buffer, an offset and length. | + | No input. Returns an output bool. |
| + | |
| + | == GetSdCardSpeedMode == |
| + | No input. Returns an output [[#SdCardSpeedMode]]. |
| + | |
| + | == GetSdCardCid == |
| + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
| + | |
| + | == GetSdCardUserAreaSize == |
| + | No input. Returns an output s64 '''SdCardUserAreaSize'''. |
| + | |
| + | == GetSdCardProtectedAreaSize == |
| + | No input. Returns an output s64 '''SdCardProtectedAreaSize'''. |
| | | |
− | == Write == | + | == GetAndClearSdCardErrorInfo == |
− | Takes a type-0x45 buffer, an offset and length. | + | Takes a type-0x6 output buffer '''LogBuffer''' and an input s64 '''LogBufferSize'''. Returns an output [[#StorageErrorInfo]] and an output s64 '''LogSize'''. |
| | | |
− | == Flush == | + | == GetMmcCid == |
− | No input. | + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
| | | |
− | == SetSize == | + | == GetMmcSpeedMode == |
− | Takes a size.
| + | No input. Returns an output [[#MmcSpeedMode]]. |
| | | |
− | == GetSize == | + | == EraseMmc == |
− | Returns a size.
| + | Takes an input [[#MmcPartition]]. No output. |
| | | |
− | = IFileSystem = | + | == GetMmcPartitionSize == |
− | This is "nn::fssrv::sf::IFileSystem".
| + | Takes an input [[#MmcPartition]]. Returns an output s64 '''MmcPartitionSize'''. |
| | | |
− | There are two main implementations of this interface:
| + | == GetMmcPatrolCount == |
| + | No input. Returns an output u32 '''MmcPatrolCount'''. |
| | | |
− | * '''nn::fs::fsa::IFileSystem''': The main IFileSystem implementation. Filesystem classes implement this interface, and FS code usually operates on this interface.
| + | == GetAndClearMmcErrorInfo == |
− | * '''nn::fssrv::sf::IFileSystem''': Used for sending an IFileSystem over IPC. Not used outside of IPC code.
| + | Takes a type-0x6 output buffer '''LogBuffer''' and an input s64 '''LogBufferSize'''. Returns an output [[#StorageErrorInfo]] and an output s64 '''LogSize'''. |
| | | |
− | There are two adapter classes to convert between these interfaces:
| + | == GetMmcExtendedCsd == |
| + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
| | | |
− | * '''nn::fssrv::detail::FileSystemInterfaceAdapter''': Allows access to an nn::fs::fsa::IFileSystem via the nn::fssrv::sf::IFileSystem interface.
| + | == SuspendMmcPatrol == |
− | * '''nn::fs::detail::FileSystemServiceObjectAdapter''': Allows access to an nn::fssrv::sf::IFileSystem via the nn::fs::fsa::IFileSystem interface.
| + | No input/output. |
| | | |
− | When the FS process returns a filesystem, it will wrap the filesystem object in a FileSystemInterfaceAdapter to return it over IPC.
| + | == ResumeMmcPatrol == |
− | Then when FS application code receives that filesystem, it will wrap the nn::fssrv::sf::IFileSystem object in a FileSystemServiceObjectAdapter before using it.
| + | No input/output. |
| | | |
− | {| class="wikitable" border="1"
| + | == IsGameCardInserted == |
− | |-
| + | No input. Returns an output bool. |
− | ! Cmd || Name
| |
− | |-
| |
− | | 0 || CreateFile
| |
− | |-
| |
− | | 1 || DeleteFile
| |
− | |-
| |
− | | 2 || CreateDirectory
| |
− | |-
| |
− | | 3 || DeleteDirectory
| |
− | |-
| |
− | | 4 || DeleteDirectoryRecursively
| |
− | |-
| |
− | | 5 || RenameFile
| |
− | |-
| |
− | | 6 || RenameDirectory
| |
− | |-
| |
− | | 7 || [[#GetEntryType]]
| |
− | |-
| |
− | | 8 || [[#OpenFile]]
| |
− | |-
| |
− | | 9 || [[#OpenDirectory]]
| |
− | |-
| |
− | | 10 || [[#Commit]]
| |
− | |-
| |
− | | 11 || [[#GetFreeSpaceSize]]
| |
− | |-
| |
− | | 12 || [[#GetTotalSpaceSize]]
| |
− | |-
| |
− | | 13 || [3.0.0+] [[#CleanDirectoryRecursively]]
| |
− | |-
| |
− | | 14 || [3.0.0+] [[#GetFileTimeStampRaw]]
| |
− | |-
| |
− | | 15 || [4.0.0+] QueryEntry
| |
− | |}
| |
| | | |
− | == GetEntryType == | + | == EraseGameCard == |
− | Takes a type-0x9 input buffer for the path and returns [[#DirectoryEntryType]] as an output u32. | + | Takes an input [[#GameCardSize]] and an input u64 '''NormalAreaSize'''. No output. |
| + | |
| + | == GetGameCardHandle == |
| + | No input. Returns an output [[#GameCardHandle]]. |
| + | |
| + | == GetGameCardUpdatePartitionInfo == |
| + | Takes an input [[#GameCardHandle]]. Returns an output [[#GameCardUpdatePartitionInfo]]. |
| + | |
| + | == FinalizeGameCardDriver == |
| + | No input/output. |
| | | |
− | == OpenFile == | + | == GetGameCardAttribute == |
− | Takes a type-0x19 input buffer for the path, and an u32 '''mode'''. '''mode''' controls how the file is opened, based on which bits are set: | + | Takes an input [[#GameCardHandle]]. Returns an output [[#GameCardAttribute]]. |
| | | |
− | * When bit 0 is set, the file is Readable: you can use the Read operation.
| + | == GetGameCardDeviceCertificate == |
− | * When bit 1 is set, the file is Writable: you can use the Write operation.
| + | Takes a type-0x6 output buffer, an input s64 '''BufferSize''' and an input [[#GameCardHandle]]. No output. |
− | * When bit 2 is set, the file is Appendable: unless this bit is set, you will not be able to write beyond the end of a file (such writes will result in an error 0x307202)
| |
| | | |
− | == OpenDirectory == | + | == GetGameCardAsicInfo == |
− | Takes a type-0x9 input buffer for the path and an u64 '''filter_flags'''. '''filter_flags''' controls what type of entries are read by the [[#IDirectory]]: bitmask 0x1 = directories, bitmask 0x2 = files. | + | Takes a type-0x5 input buffer '''FwBuffer''', a type-0x6 output buffer containing [[#RmaInformation]] and two input s64s '''FwBufferSize''' and '''RmaInformationSize'''. No output. |
| | | |
− | == Commit == | + | == GetGameCardIdSet == |
− | Like [https://3dbrew.org/wiki/FS:ControlArchive 3DS], this has to be used after writing to savedata for the changes to take affect.
| + | Takes a type-0x6 output buffer containing a [[#GameCardIdSet]] and an input s64 '''BufferSize'''. No output. |
| | | |
− | == GetFreeSpaceSize == | + | == WriteToGameCardDirectly == |
− | Takes a type-0x9 input buffer for the path and returns an output byte-size u64 for the total free space with this FS. | + | Takes a type-0x6 output buffer and two input s64s '''Offset''' and '''BufferSize'''. No output. |
| | | |
− | == GetTotalSpaceSize == | + | == SetVerifyWriteEnalbleFlag == |
− | Takes a type-0x9 input buffer for the path and returns an output byte-size u64 for the total space available with this FS(free+used). | + | Takes an input bool. No output. |
| | | |
− | == CleanDirectoryRecursively == | + | == GetGameCardImageHash == |
− | Takes a type-0x9 input buffer for the path and clears the contents of the directory specified in the path. | + | Takes a type-0x6 output buffer, an input s64 '''BufferSize''' and an input [[#GameCardHandle]]. No output. |
| | | |
− | == GetFileTimeStampRaw == | + | == GetGameCardDeviceIdForProdCard == |
− | Takes a type-0x19 input buffer for the path and returns a 0x20-byte struct. This contains 3 u64s and an u8. | + | Takes a type-0x5 input buffer '''CardHeaderForDev''', a type-0x6 output buffer and two input s64s '''CardHeaderForDevSize''' and '''BufferSize'''. No output. |
| | | |
− | = IDirectory = | + | == EraseAndWriteParamDirectly == |
− | This is "nn::fssrv::sf::IDirectory".
| + | Takes a type-0x5 input buffer and an input s64 '''BufferSize'''. No output. |
| | | |
− | {| class="wikitable" border="1"
| + | == ReadParamDirectly == |
− | |-
| + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
− | ! Cmd || Name
| |
− | |-
| |
− | | 0 || [[#Read]]
| |
− | |-
| |
− | | 1 || [[#GetEntryCount]]
| |
− | |}
| |
| | | |
− | == Read == | + | == ForceEraseGameCard == |
− | Takes a type-0x6 output buffer. Returns an output u64(?) for the total number of read entries, this is 0 when no more entries are available.
| + | No input/output. |
| | | |
− | The output buffer contains the read array of [[#DirectoryEntry]]. This doesn't include entries for "." and "..".
| + | == GetGameCardErrorInfo == |
| + | No input. Returns an output [[#GameCardErrorInfo]]. |
| | | |
− | == GetEntryCount == | + | == GetGameCardErrorReportInfo == |
− | Returns an u64 for the total number of readable entries. | + | No input. Returns an output [[#GameCardErrorReportInfo]]. |
| | | |
− | = DirectoryEntry = | + | == GetGameCardDeviceId == |
− | This is "nn::fs::DirectoryEntry".
| + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
| | | |
− | {| class="wikitable" border="1"
| + | == ChallengeCardExistence == |
− | |-
| + | Takes a type-0x6 output buffer, two type-0x5 input buffers and an input [[#GameCardHandle]]. No output. |
− | ! Offset || Size || Description
| |
− | |-
| |
− | | 0x0 || 0x301 || Path
| |
− | |-
| |
− | | 0x301 || 0x1 || File attributes (bit 0 = is directory; bit 1 = archive bit)
| |
− | |-
| |
− | | 0x302 || 0x2 || Padding?
| |
− | |-
| |
− | | 0x304 || 0x1 || [[#DirectoryEntryType]]
| |
− | |-
| |
− | | 0x305 || 0x3 || Padding?
| |
− | |-
| |
− | | 0x308 || 0x8 || Filesize, 0 for directories.
| |
− | |}
| |
| | | |
− | = DirectoryEntryType = | + | [9.0.0+] The [[Account_services|account]] system module uses this as part of a new challenge-response mechanism for [[Network#aauth|application authentication]]. |
− | This is "nn::fs::DirectoryEntryType".
| + | |
| + | == GetGameCardCompatibilityType == |
| + | Takes an input [[#GameCardHandle]]. Returns an output [[#GameCardCompatibilityType]]. |
| + | |
| + | == GetGameCardAsicCertificate == |
| + | Takes a type-0x6 output buffer and an input s64 '''BufferSize'''. No output. |
| + | |
| + | == GetGameCardCardHeader == |
| + | Takes a type-0x6 output buffer, an input s64 '''BufferSize''' and an input [[#GameCardHandle]]. No output. |
| + | |
| + | == SetSpeedEmulationMode == |
| + | Takes an input [[#SpeedEmulationMode]]. No output. |
| + | |
| + | == GetSpeedEmulationMode == |
| + | No input. Returns an output [[#SpeedEmulationMode]]. |
| + | |
| + | == SuspendSdmmcControl == |
| + | No input/output. |
| + | |
| + | == ResumeSdmmcControl == |
| + | No input/output. |
| + | |
| + | == GetSdmmcConnectionStatus == |
| + | Takes a total of 4-bytes of input. Returns a total of 8-bytes of output. |
| | | |
− | An s8 value indicating a directory entry type. The current values are:
| + | == SetDeviceSimulationEvent == |
| + | Takes a total of 0x14-bytes of input. No output. |
| | | |
− | {| class="wikitable" border="1"
| + | == ClearDeviceSimulationEvent == |
− | |-
| + | Takes a total of 4-bytes of input. No output. |
− | ! Value || Description
| |
− | |-
| |
− | | 0 || Directory
| |
− | |-
| |
− | | 1 || File
| |
− | |}
| |
| | | |
− | = IFile = | + | = IEventNotifier = |
− | This is "nn::fssrv::sf::IFile". | + | This is "nn::fssrv::sf::IEventNotifier". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,324: |
Line 1,284: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || Read | + | | 0 || [[#GetEventHandle]] |
| + | |} |
| + | |
| + | == GetEventHandle == |
| + | No input, returns an output Event handle. With official sw the EventClearMode is user-specified. |
| + | |
| + | = ISaveDataTransferManager = |
| + | This is "nn::fssrv::sf::ISaveDataTransferManager". |
| + | |
| + | This was added with [[4.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 1 || Write | + | ! Cmd || Name |
| |- | | |- |
− | | 2 || Flush | + | | 0 || [[#GetChallenge]] |
| |- | | |- |
− | | 3 || SetSize | + | | 16 || [[#SetToken]] |
| |- | | |- |
− | | 4 || GetSize | + | | 32 || [[#OpenSaveDataExporter]] |
| |- | | |- |
− | | 5 || [4.0.0+] OperateRange | + | | 64 || [[#OpenSaveDataImporter]] |
| |} | | |} |
| | | |
− | = ISaveDataInfoReader = | + | == GetChallenge == |
− | This is "nn::fssrv::sf::ISaveDataInfoReader".
| + | No input/output, takes a type-0x6 output buffer. |
| | | |
− | {| class="wikitable" border="1"
| + | == SetToken == |
− | |-
| + | No input/output, takes a type-0x5 input buffer. |
− | ! Cmd || Name
| + | |
− | |-
| + | == OpenSaveDataExporter == |
− | | 0 || [[#ReadSaveDataInfo]]
| + | Takes an input u8 [[#SaveDataSpaceId]] and u64, returns an [[#ISaveDataExporter]]. |
− | |}
| |
| | | |
− | == ReadSaveDataInfo == | + | == OpenSaveDataImporter == |
− | Takes a type-0x6 output buffer. Returns an output u64 for total output entries. This buffer contains an array of [[#SaveDataInfo]]. | + | Takes an input u8 [[#SaveDataSpaceId]] and a 0x10-byte userID, and a type-0x5 input buffer. Returns an output u64 and an [[#ISaveDataImporter]]. |
| | | |
− | This is used to get [[#SaveDataInfo]] for all savedata on the system (or all savedata for the current [[#SaveDataSpaceId]]). When used multiple times, it will resume reading where it left off, until no more entries are available (in that case the out u64 is value 0). | + | = ISaveDataTransferManagerForSaveDataRepair = |
| + | This is "nn::fssrv::sf::ISaveDataTransferManagerForSaveDataRepair". |
| | | |
− | = IDeviceOperator =
| + | This was added with [[9.0.0]]. |
− | This is "nn::fssrv::sf::IDeviceOperator". | |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,359: |
Line 1,329: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || IsSdCardInserted | + | | 0 || [[#GetChallenge]] |
| |- | | |- |
− | | 1 || GetSdCardSpeedMode | + | | 16 || [[#SetKeyPackage]] |
| |- | | |- |
− | | 2 || [2.0.0+] GetSdCardCid | + | | 80 || [[#OpenSaveDataExporterAndGetEncryptedKey]] |
| |- | | |- |
− | | 3 || [2.0.0+] GetSdCardUserAreaSize | + | | 81 || [[#PrepareOpenSaveDataImporter]] |
| |- | | |- |
− | | 4 || [2.0.0+] GetSdCardProtectedAreaSize | + | | 90 || [[#OpenSaveDataImporter]] |
| |- | | |- |
− | | 5 || [2.0.0+] GetAndClearSdCardErrorInfo | + | | 91 || [[#OpenSaveDataImporter2]] |
| |- | | |- |
− | | 100 || GetMmcCid | + | | 100 || [[#OpenSaveDataExporterWithKey]] |
| |- | | |- |
− | | 101 || GetMmcSpeedMode | + | | 110 || [[#OpenSaveDataImporterWithKey]] |
− | |- | + | |} |
− | | 110 || EraseMmc
| + | |
− | |-
| + | == SetKeyPackage == |
− | | 111 || GetMmcPartitionSize
| + | No input/output, takes a type-0x5 input buffer. |
− | |-
| + | |
− | | 112 || [2.0.0+] GetMmcPatrolCount
| + | == OpenSaveDataExporterAndGetEncryptedKey == |
− | |-
| + | Takes a total of 0x10-bytes of input and a type-0x1A output buffer to receive a RsaEncryptedKey. Returns an [[#ISaveDataDivisionExporter]]. |
− | | 113 || [2.0.0+] GetAndClearMmcErrorInfo
| + | |
| + | == PrepareOpenSaveDataImporter == |
| + | Takes a type-0x1A output buffer to receive a RsaEncryptedKey. |
| + | |
| + | == OpenSaveDataImporter == |
| + | Takes a total of 0x18-bytes of input and two type-0x5 input buffers, returns an [[#ISaveDataDivisionImporter]]. |
| + | |
| + | == OpenSaveDataImporter2 == |
| + | Takes a total of 0x18-bytes of input and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| + | |
| + | == OpenSaveDataExporterWithKey == |
| + | Takes a total of 0x20-bytes of input, returns an [[#ISaveDataDivisionExporter]]. |
| + | |
| + | == OpenSaveDataImporterWithKey == |
| + | Takes a total of 0x28-bytes of input and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| + | |
| + | [17.0.0+] Now only takes 0x18-bytes of input and an additional type-0x5 input buffer. |
| + | |
| + | = ISaveDataMover = |
| + | This is "nn::fssrv::sf::ISaveDataMover". |
| + | |
| + | This was added with [[10.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 114 || [2.0.0+] GetMmcExtendedCsd | + | ! Cmd || Name |
| |- | | |- |
− | | 115 || [4.0.0+] SuspendMmcPatrol | + | | 8 || [[#Register]] |
| |- | | |- |
− | | 116 || [4.0.0+] ResumeMmcPatrol | + | | 16 || [[#Process]] |
| |- | | |- |
− | | 200 || [[#IsGameCardInserted]] | + | | 18 || [[#Cancel]] |
| + | |} |
| + | |
| + | == Register == |
| + | Takes an input u64, no output. |
| + | |
| + | == Process == |
| + | Takes an input u64, returns an output u64. |
| + | |
| + | == Cancel == |
| + | No input/output. |
| + | |
| + | = ISaveDataTransferManagerForRepair = |
| + | This is "nn::fssrv::sf::ISaveDataTransferManagerForRepair". |
| + | |
| + | This was added with [[11.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 201 || EraseGameCard | + | ! Cmd || Name |
| |- | | |- |
− | | 202 || [[#GetGameCardHandle]] | + | | 80 || [[#OpenSaveDataExporter]] |
| |- | | |- |
− | | 203 || [[#GetGameCardUpdatePartitionInfo]] | + | | 90 || [[#OpenSaveDataImporter]] |
| + | |} |
| + | |
| + | == OpenSaveDataExporter == |
| + | Takes a total of 0x10-bytes of input, returns an [[#ISaveDataDivisionExporter]]. |
| + | |
| + | == OpenSaveDataImporter == |
| + | Takes 1-byte of input, a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| + | |
| + | = ISaveDataExporter = |
| + | This is "nn::fssrv::sf::ISaveDataExporter". |
| + | |
| + | This was added with [[4.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 204 || FinalizeGameCardDriver | + | ! Cmd || Name |
| |- | | |- |
− | | 205 || GetGameCardAttribute | + | | 0 || [[#GetSaveDataInfo]] |
| |- | | |- |
− | | 206 || [[#GetGameCardDeviceCertificate]] | + | | 1 || [[#GetRestSize]] |
| |- | | |- |
− | | 207 || GetGameCardAsicInfo | + | | 16 || [[#Pull]] |
| |- | | |- |
− | | 208 || GetGameCardIdSet | + | | 17 || [[#PullInitialData]] |
| + | |} |
| + | |
| + | == GetSaveDataInfo == |
| + | No input/output, takes a type-0x1A [[#SaveDataInfo]] output buffer. |
| + | |
| + | The actual name for this is the SaveDataExporter constructor. This is used automatically after [[#OpenSaveDataExporter]] by official sw. |
| + | |
| + | == GetRestSize == |
| + | No input, returns an output u64. |
| + | |
| + | == Pull == |
| + | Takes a type-0x6 output buffer, returns an output u64. |
| + | |
| + | == PullInitialData == |
| + | No input/output, takes a type-0x6 output buffer. |
| + | |
| + | = ISaveDataImporter = |
| + | This is "nn::fssrv::sf::ISaveDataImporter". |
| + | |
| + | This was added with [[4.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 209 || WriteToGameCardDirectly | + | ! Cmd || Name |
| |- | | |- |
− | | 210 || SetVerifyWriteEnalbleFlag | + | | 0 || [[#GetSaveDataInfo]] |
| |- | | |- |
− | | 211 || GetGameCardImageHash | + | | 1 || [[#GetRestSize]] |
| |- | | |- |
− | | 212 || [2.0.0+] GetGameCardDeviceIdForProdCard | + | | 16 || [[#Push]] |
| |- | | |- |
− | | 213 || [2.0.0+] EraseAndWriteParamDirectly | + | | 17 || [[#Finalize]] |
| + | |} |
| + | |
| + | == GetSaveDataInfo == |
| + | No input/output, takes a type-0x1A [[#GetSaveDataInfo]] output buffer. |
| + | |
| + | The actual name for this is the SaveDataImporter constructor. This is used automatically after [[#OpenSaveDataImporter]] by official sw. |
| + | |
| + | == GetRestSize == |
| + | No input, returns an output u64. |
| + | |
| + | == Push == |
| + | No input/output, takes a type-0x5 input buffer. |
| + | |
| + | == Finalize == |
| + | No input/output. |
| + | |
| + | = ISaveDataTransferManagerWithDivision = |
| + | This is "nn::fssrv::sf::ISaveDataTransferManagerWithDivision". |
| + | |
| + | This was added with [[5.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 214 || [2.0.0+] ReadParamDirectly | + | ! Cmd || Name |
| |- | | |- |
− | | 215 || [2.0.0+] ForceEraseGameCard | + | | 0 || [[#GetChallenge]] |
| |- | | |- |
− | | 216 || [2.0.0+] GetGameCardErrorInfo | + | | 8 || [18.0.0+] SetMode |
| |- | | |- |
− | | 217 || [2.1.0+] GetGameCardErrorReportInfo | + | | 9 || [18.0.0+] SetAttribute |
| |- | | |- |
− | | 218 || [3.0.0+] GetGameCardDeviceId | + | | 16 || [[#SetKeySeedPackage]] |
| |- | | |- |
− | | 219 || [8.0.0+] [[#ChallengeCardExistence]] | + | | 32 || [[#OpenSaveDataExporter]] |
| |- | | |- |
− | | 220 || [9.0.0+] [[#GetGameCardCompatibilityType]] | + | | 33 || [[#OpenSaveDataExporterForDiffExport]] |
| |- | | |- |
− | | 300 || SetSpeedEmulationMode | + | | 34 || [6.0.0+] [[#OpenSaveDataExporterByContext]] |
| |- | | |- |
− | | 301 || GetSpeedEmulationMode | + | | 63 || [17.0.0+] OpenSaveDataImporter |
| |- | | |- |
− | | 400 || [5.0.0+] SuspendSdmmcControl | + | | 64 || [6.0.0-17.0.1] [[#OpenSaveDataImporterDeprecated]] ([5.0.0-5.1.0] OpenSaveDataImporter) |
| |- | | |- |
− | | 401 || [5.0.0+] ResumeSdmmcControl | + | | 65 || [5.0.0-17.0.1] [[#OpenSaveDataImporterForDiffImport]] |
| |- | | |- |
− | | 402 || [6.0.0+] [[#GetSdmmcConnectionStatus]] | + | | 66 || [6.0.0-17.0.1] [[#OpenSaveDataImporterForDuplicateDiffImport]] |
| + | |- |
| + | | 67 || [6.0.0-16.1.0] [[#OpenSaveDataImporter]] |
| + | |- |
| + | | 68 || [6.0.0+] [[#OpenSaveDataImporterByContext]] |
| + | |- |
| + | | 69 || [6.0.0+] [[#CancelSuspendingImport]] |
| |- | | |- |
− | | 500 || [6.0.0+] [[#SetDeviceSimulationEvent]] | + | | 70 || [10.0.0+] CancelSuspendingImportByAttribute |
| |- | | |- |
− | | 501 || [6.0.0+] [[#ClearDeviceSimulationEvent]] | + | | 80 || [11.0.0+] SwapSecondary |
| |} | | |} |
| | | |
− | == IsGameCardInserted == | + | == GetChallenge == |
− | No input, returns a bool. | + | No input/output, takes a type-0x6 output buffer containing the '''Challenge'''. |
| | | |
− | == GetGameCardHandle == | + | == SetKeySeedPackage == |
− | No input, returns an u32 '''GameCardHandle'''. | + | No input/output, takes a type-0x5 input buffer containing the '''KeySeedPackage'''. |
| | | |
− | == GetGameCardUpdatePartitionInfo == | + | == OpenSaveDataExporter == |
− | Returns a [[NCM_services#ProgramId|ProgramId]] and the title-version for it. | + | Takes an input u8 [[#SaveDataSpaceId]] and u64. Returns an [[#ISaveDataDivisionExporter]]. |
| | | |
− | * Output u32 with ARMS-gamecard: title-version v131162. This is the title-version for [[2.1.0]], which is the sysupdate included with this gamecard. Launch-day gamecards return title-version v450.
| + | == OpenSaveDataExporterForDiffExport == |
− | * Output u64 with ARMS-gamecard: [[NCM_services#ProgramId|ProgramId]] 0100000000000816.
| + | Takes an input u8 [[#SaveDataSpaceId]], an u64, and a type-0x5 input buffer [[#InitialDataVersion2]]. Returns an [[#ISaveDataDivisionExporter]]. |
| | | |
− | [[NS_Services|NS]] appears to only use this with [[NCM_services|NCM]] for checking whether a sysupdate is required. | + | == OpenSaveDataExporterByContext == |
| + | No input/output, takes a type-0x5 input buffer, returns an [[#ISaveDataDivisionExporter]]. |
| | | |
− | == GetGameCardDeviceCertificate == | + | == OpenSaveDataImporterDeprecated == |
− | Takes a type-0x6 output buffer, an u32 '''GameCardHandle''' and an u64 '''DeviceCertificateBufferSize'''. No output. | + | Takes an input u8 [[#SaveDataSpaceId]], a 0x10-byte userID, and a type-0x5 input buffer [[#InitialDataVersion2]]. Returns an [[#ISaveDataDivisionImporter]]. |
| | | |
− | == ChallengeCardExistence == | + | == OpenSaveDataImporterForDiffImport == |
− | Takes a type-0x6 output buffer, two type-0x5 input buffers and an u32 '''GameCardHandle'''. No output. | + | Takes an input u8 [[#SaveDataSpaceId]], an u64, and a type-0x5 input buffer [[#InitialDataVersion2]], returns an [[#ISaveDataDivisionImporter]]. |
| | | |
− | [9.0.0+] The [[Account_services|account]] system module uses this as part of a new challenge-response mechanism for [[Network#aauth|application authentication]].
| + | == OpenSaveDataImporterForDuplicateDiffImport == |
| + | Takes an input u8 and an u64, and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| | | |
− | == GetGameCardCompatibilityType == | + | == OpenSaveDataImporter == |
− | Takes an u32 '''GameCardHandle''', returns an u8 '''CompatibilityType''' (0x00 = Global, 0x01 = China) from [[Gamecard_Format#Gamecard_Info|Gamecard Info]]. | + | Takes an input u8, an u8(bool), a 0x10-byte struct, and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| | | |
− | == GetSdmmcConnectionStatus == | + | == OpenSaveDataImporterByContext == |
− | Takes a total of 4-bytes of input, returns a total of 8-bytes of output.
| + | No input/output, takes a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. |
| | | |
− | == SetDeviceSimulationEvent == | + | == CancelSuspendingImport == |
− | Takes a total of 0x14-bytes of input, no output. | + | Takes an input u64 and a 0x10-byte struct, no output. |
| | | |
− | == ClearDeviceSimulationEvent == | + | = ISaveDataDivisionExporter = |
− | Takes a total of 4-bytes of input, no output.
| + | This is "nn::fssrv::sf::ISaveDataDivisionExporter". |
| | | |
− | = IEventNotifier =
| + | This was added with [[5.0.0]]. |
− | This is "nn::fssrv::sf::IEventNotifier". | |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,487: |
Line 1,562: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || [[#GetEventHandle]] | + | | 0 || [[#SetDivisionCount]] |
− | |}
| |
− | | |
− | == GetEventHandle ==
| |
− | No input, returns an output Event handle. With official sw the EventClearMode is user-specified.
| |
− | | |
− | = ISaveDataTransferManager =
| |
− | This is "nn::fssrv::sf::ISaveDataTransferManager".
| |
− | | |
− | This was added with [[4.0.0]].
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name
| + | | 1 || [6.0.0+] [[#ReadSaveDataExtraData]] |
| |- | | |- |
− | | 0 || [[#GetChallenge]] | + | | 16 || [[#OpenSaveDataDiffChunkIterator]] |
| |- | | |- |
− | | 16 || [[#SetToken]] | + | | 48 || [[#OpenSaveDataChunkExporter]] |
| |- | | |- |
− | | 32 || [[#OpenSaveDataExporter]] | + | | 64 || [6.0.0-8.1.0] [[#FinalizeFullExport]] |
| |- | | |- |
− | | 64 || [[#OpenSaveDataImporter]] | + | | 65 || [6.0.0-8.1.0] [[#FinalizeDiffExport]] |
− | |}
| |
− | | |
− | == GetChallenge ==
| |
− | No input/output, takes a type-0x6 output buffer.
| |
− | | |
− | == SetToken ==
| |
− | No input/output, takes a type-0x5 input buffer.
| |
− | | |
− | == OpenSaveDataExporter ==
| |
− | Takes an input u8 [[#SaveDataSpaceId]] and u64, returns an [[#ISaveDataExporter]].
| |
− | | |
− | == OpenSaveDataImporter ==
| |
− | Takes an input u8 [[#SaveDataSpaceId]] and a 0x10-byte userID, and a type-0x5 input buffer. Returns an output u64 and an [[#ISaveDataImporter]].
| |
− | | |
− | = ISaveDataTransferManagerForSaveDataRepair =
| |
− | This is "nn::fssrv::sf::ISaveDataTransferManagerForSaveDataRepair".
| |
− | | |
− | This was added with [[9.0.0]].
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name
| + | | 66 || [6.0.0+] [[#CancelExport]] |
| |- | | |- |
− | | 0 || [[#GetChallenge]] | + | | 67 || [6.0.0+] [[#SuspendExport]] |
| |- | | |- |
− | | 16 || [[#SetKeyPackage]] | + | | 70 || [6.0.0-17.0.1] [[#GetKeySeed]] |
| |- | | |- |
− | | 80 || [[#OpenSaveDataExporterAndGetEncryptedKey]] | + | | 71 || [6.0.0+] [[#GetInitialDataMac]] |
| + | |- |
| + | | 72 || [6.0.0+] [[#FinalizeExport]] |
| |- | | |- |
− | | 81 || [[#PrepareOpenSaveDataImporter]] | + | | 73 || [9.0.0+] [[#GetInitialDataMacKeyGeneration]] |
| |- | | |- |
− | | 90 || [[#OpenSaveDataImporter]] | + | | 74 || [18.0.0+] [[#GetKeySeed]] |
| |- | | |- |
− | | 91 || [[#OpenSaveDataImporter2]] | + | | 80 || [6.0.0+] [[#GetImportInitialDataAad]] |
| |- | | |- |
− | | 100 || [[#OpenSaveDataExporterWithKey]] | + | | 81 || [6.0.0+] [[#SetExportInitialDataAad]] |
| |- | | |- |
− | | 110 || [[#OpenSaveDataImporterWithKey]] | + | | 96 || [6.0.0+] [[#GetReportInfo]] |
| |} | | |} |
| | | |
− | == SetKeyPackage == | + | == SetDivisionCount == |
− | No input/output, takes a type-0x5 input buffer.
| + | Takes an input u32, no output. |
| | | |
− | == OpenSaveDataExporterAndGetEncryptedKey == | + | == OpenSaveDataChunkExporter == |
− | Takes a total of 0x10-bytes of input and a type-0x1A output buffer to receive a RsaEncryptedKey. Returns an [[#ISaveDataDivisionExporter]]. | + | Takes an input u32, returns an [[#ISaveDataChunkExporter]]. |
| | | |
− | == PrepareOpenSaveDataImporter == | + | == FinalizeFullExport == |
− | Takes a type-0x1A output buffer to receive a RsaEncryptedKey.
| + | No input, returns two 0x10-byte output structs. |
| | | |
− | == OpenSaveDataImporter == | + | == FinalizeDiffExport == |
− | Takes a total of 0x18-bytes of input and two type-0x5 input buffers, returns an [[#ISaveDataDivisionImporter]].
| + | No input, returns an output 0x10-byte struct. |
| | | |
− | == OpenSaveDataImporter2 == | + | == CancelExport == |
− | Takes a total of 0x18-bytes of input and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]].
| + | No input/output. |
| + | |
| + | == SuspendExport == |
| + | No input/output, takes a type-0x6 output buffer. |
| + | |
| + | == GetKeySeed == |
| + | No input, returns an output 0x10-byte struct. |
| + | |
| + | == GetInitialDataMac == |
| + | No input, returns an output 0x10-byte struct. |
| | | |
− | == OpenSaveDataExporterWithKey == | + | == FinalizeExport == |
− | Takes a total of 0x20-bytes of input, returns an [[#ISaveDataDivisionExporter]].
| + | No input/output. |
| | | |
− | == OpenSaveDataImporterWithKey == | + | == SetExportInitialDataAad == |
− | Takes a total of 0x28-bytes of input and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]]. | + | Takes an input 0x20-byte struct, no output. |
| | | |
− | = ISaveDataMover = | + | = ISaveDataDivisionImporter = |
− | This is "nn::fssrv::sf::ISaveDataMover". | + | This is "nn::fssrv::sf::ISaveDataDivisionImporter". |
| | | |
− | This was added with [[10.0.0]]. | + | This was added with [[5.0.0]]. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,579: |
Line 1,634: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 8 || [[#Register]] | + | | 0 || [6.0.0+] [[#ReadSaveDataExtraData]] |
| + | |- |
| + | | 16 || [[#OpenSaveDataDiffChunkIterator]] |
| |- | | |- |
− | | 16 || [[#Process]] | + | | 32 || [[#InitializeImport]] |
| |- | | |- |
− | | 18 || [[#Cancel]] | + | | 33 || [[#FinalizeImport]] |
− | |} | + | |- |
− | | + | | 34 || [6.0.0+] [[#CancelImport]] |
− | == Register ==
| + | |- |
− | Takes an input u64, no output.
| + | | 35 || [6.0.0+] [[#GetImportContext]] |
− | | |
− | == Process ==
| |
− | Takes an input u64, returns an output u64.
| |
− | | |
− | == Cancel ==
| |
− | No input/output.
| |
− | | |
− | = ISaveDataExporter =
| |
− | This is "nn::fssrv::sf::ISaveDataExporter".
| |
− | | |
− | This was added with [[4.0.0]].
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name
| + | | 36 || [6.0.0+] [[#SuspendImport]] |
| |- | | |- |
− | | 0 || [[#GetSaveDataInfo]] | + | | 37 || [11.0.0+] FinalizeImportWithoutSwap |
| |- | | |- |
− | | 1 || [[#GetRestSize]] | + | | 48 || [[#OpenSaveDataChunkImporter]] |
| |- | | |- |
− | | 16 || [[#Pull]] | + | | 64 || [6.0.0+] [[#GetImportInitialDataAad]] |
| |- | | |- |
− | | 17 || [[#PullInitialData]] | + | | 80 || [6.0.0+] [[#GetReportInfo]] |
| |} | | |} |
| | | |
− | == GetSaveDataInfo == | + | == ReadSaveDataExtraData == |
− | No input/output, takes a type-0x1A [[#SaveDataInfo]] output buffer. | + | No input/output, takes a type-0x6 output buffer. |
| | | |
− | The actual name for this is the SaveDataExporter constructor. This is used automatically after [[#OpenSaveDataExporter]] by official sw.
| + | == OpenSaveDataDiffChunkIterator == |
| + | No input, returns an [[#ISaveDataChunkIterator]]. |
| | | |
− | == GetRestSize == | + | == InitializeImport == |
| No input, returns an output u64. | | No input, returns an output u64. |
| | | |
− | == Pull == | + | == FinalizeImport == |
− | Takes a type-0x6 output buffer, returns an output u64.
| + | No input/output. |
| + | |
| + | == CancelImport == |
| + | No input/output. |
| | | |
− | == PullInitialData == | + | == GetImportContext == |
| No input/output, takes a type-0x6 output buffer. | | No input/output, takes a type-0x6 output buffer. |
| | | |
− | = ISaveDataImporter = | + | == SuspendImport == |
− | This is "nn::fssrv::sf::ISaveDataImporter".
| + | No input/output. |
| + | |
| + | == OpenSaveDataChunkImporter == |
| + | Takes an input u32, returns an [[#ISaveDataChunkImporter]]. |
| | | |
− | This was added with [[4.0.0]].
| + | == GetImportInitialDataAad == |
| + | No input, returns an output 0x20-byte struct. |
| | | |
− | {| class="wikitable" border="1"
| + | == GetReportInfo == |
− | |-
| + | No input, returns an output 0x20-byte struct. |
− | ! Cmd || Name
| |
− | |-
| |
− | | 0 || [[#GetSaveDataInfo]]
| |
− | |-
| |
− | | 1 || [[#GetRestSize]]
| |
− | |-
| |
− | | 16 || [[#Push]]
| |
− | |-
| |
− | | 17 || [[#Finalize]]
| |
− | |}
| |
| | | |
− | == GetSaveDataInfo == | + | = ISaveDataChunkIterator = |
− | No input/output, takes a type-0x1A [[#GetSaveDataInfo]] output buffer.
| + | This is "nn::fssrv::sf::ISaveDataChunkIterator". |
− | | |
− | The actual name for this is the SaveDataImporter constructor. This is used automatically after [[#OpenSaveDataImporter]] by official sw.
| |
− | | |
− | == GetRestSize ==
| |
− | No input, returns an output u64.
| |
− | | |
− | == Push ==
| |
− | No input/output, takes a type-0x5 input buffer.
| |
− | | |
− | == Finalize ==
| |
− | No input/output.
| |
− | | |
− | = ISaveDataTransferManagerWithDivision =
| |
− | This is "nn::fssrv::sf::ISaveDataTransferManagerWithDivision". | |
| | | |
| This was added with [[5.0.0]]. | | This was added with [[5.0.0]]. |
Line 1,668: |
Line 1,696: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || [[#GetChallenge]] | + | | 0 || [[#Next]] |
| |- | | |- |
− | | 16 || [[#SetKeySeedPackage]] | + | | 1 || [[#IsEnd]] |
| |- | | |- |
− | | 32 || [[#OpenSaveDataExporter]] | + | | 16 || [[#GetId]] |
− | |-
| |
− | | 33 || [[#OpenSaveDataExporterForDiffExport]]
| |
− | |-
| |
− | | 34 || [6.0.0+] [[#OpenSaveDataExporterByContext]]
| |
− | |-
| |
− | |rowspan="2"| 64 || [5.0.0-5.1.0] OpenSaveDataImporter
| |
− | |-
| |
− | | [6.0.0+] [[#OpenSaveDataImporterDeprecated]]
| |
− | |-
| |
− | | 65 || [[#OpenSaveDataImporterForDiffImport]]
| |
− | |-
| |
− | | 66 || [6.0.0+] [[#OpenSaveDataImporterForDuplicateDiffImport]]
| |
− | |-
| |
− | | 67 || [6.0.0+] [[#OpenSaveDataImporter]]
| |
− | |-
| |
− | | 68 || [6.0.0+] [[#OpenSaveDataImporterByContext]]
| |
− | |-
| |
− | | 69 || [6.0.0+] [[#CancelSuspendingImport]]
| |
− | |-
| |
− | | 70 || [10.0.0+] DecryptAndVerifyInitialData
| |
| |} | | |} |
| | | |
− | == GetChallenge == | + | == Next == |
− | No input/output, takes a type-0x6 output buffer containing the '''Challenge'''. | + | No input/output. |
| | | |
− | == SetKeySeedPackage == | + | == IsEnd == |
− | No input/output, takes a type-0x5 input buffer containing the '''KeySeedPackage'''. | + | No input, returns an output u8. |
| | | |
− | == OpenSaveDataExporter == | + | == GetId == |
− | Takes an input u8 [[#SaveDataSpaceId]] and u64. Returns an [[#ISaveDataDivisionExporter]].
| + | No input, returns an output u32. |
| | | |
− | == OpenSaveDataExporterForDiffExport == | + | = ISaveDataChunkExporter = |
− | Takes an input u8 [[#SaveDataSpaceId]], an u64, and a type-0x5 input buffer [[#InitialDataVersion2]]. Returns an [[#ISaveDataDivisionExporter]].
| + | This is "nn::fssrv::sf::ISaveDataChunkExporter". |
− | | |
− | == OpenSaveDataExporterByContext ==
| |
− | No input/output, takes a type-0x5 input buffer, returns an [[#ISaveDataDivisionExporter]].
| |
− | | |
− | == OpenSaveDataImporterDeprecated ==
| |
− | Takes an input u8 [[#SaveDataSpaceId]], a 0x10-byte userID, and a type-0x5 input buffer [[#InitialDataVersion2]]. Returns an [[#ISaveDataDivisionImporter]].
| |
− | | |
− | == OpenSaveDataImporterForDiffImport ==
| |
− | Takes an input u8 [[#SaveDataSpaceId]], an u64, and a type-0x5 input buffer [[#InitialDataVersion2]], returns an [[#ISaveDataDivisionImporter]].
| |
− | | |
− | == OpenSaveDataImporterForDuplicateDiffImport ==
| |
− | Takes an input u8 and an u64, and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]].
| |
− | | |
− | == OpenSaveDataImporter ==
| |
− | Takes an input u8, an u8(bool), a 0x10-byte struct, and a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]].
| |
− | | |
− | == OpenSaveDataImporterByContext ==
| |
− | No input/output, takes a type-0x5 input buffer, returns an [[#ISaveDataDivisionImporter]].
| |
− | | |
− | == CancelSuspendingImport ==
| |
− | Takes an input u64 and a 0x10-byte struct, no output.
| |
− | | |
− | = ISaveDataDivisionExporter =
| |
− | This is "nn::fssrv::sf::ISaveDataDivisionExporter". | |
| | | |
| This was added with [[5.0.0]]. | | This was added with [[5.0.0]]. |
Line 1,737: |
Line 1,721: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || [[#SetDivisionCount]] | + | | 0 || [[#Pull]] |
| |- | | |- |
− | | 1 || [6.0.0+] [[#GetSaveDataInfo]] | + | | 16 || [6.0.0+] [[#GetRestRawDataSize]] |
− | |- | + | |} |
− | | 16 || [[#OpenSaveDataDiffChunkIterator]]
| + | |
| + | == Pull == |
| + | Takes an input u64 and a type-0x6 output buffer, returns an output u64. |
| + | |
| + | == GetRestRawDataSize == |
| + | No input, returns an output u64. |
| + | |
| + | = ISaveDataChunkImporter = |
| + | This is "nn::fssrv::sf::ISaveDataChunkImporter". |
| + | |
| + | This was added with [[5.0.0]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 48 || [[#OpenSaveDataChunkExporter]] | + | ! Cmd || Name |
| |- | | |- |
− | | 64 || [6.0.0-8.1.0] [[#FinalizeFullExport]] | + | | 0 || [[#Push]] |
| + | |} |
| + | |
| + | == Push == |
| + | Takes an input u64 and a type-0x5 input buffer, no output. |
| + | |
| + | = ISaveDataTransferProhibiter = |
| + | This is "nn::fssrv::sf::ISaveDataTransferProhibiter". |
| + | |
| + | This was added with [6.0.0+]. |
| + | |
| + | This doesn't seem to handle any commands (?). |
| + | |
| + | = IMultiCommitManager = |
| + | This is "nn::fssrv::sf::IMultiCommitManager". |
| + | |
| + | This was added with [6.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 65 || [6.0.0-8.1.0] [[#FinalizeDiffExport]] | + | ! Cmd || Name |
| |- | | |- |
− | | 66 || [6.0.0+] [[#CancelExport]] | + | | 1 || [[#Add]] |
| |- | | |- |
− | | 67 || [6.0.0+] [[#SuspendExport]] | + | | 2 || [[#Commit]] |
− | |-
| |
− | | 70 || [6.0.0+] [[#GetKeySeed]]
| |
− | |-
| |
− | | 71 || [6.0.0+] [[#GetInitialDataMac]]
| |
− | |-
| |
− | | 72 || [6.0.0+] [[#FinalizeExport]]
| |
− | |-
| |
− | | 73 || [9.0.0+] [[#GetInitialDataMacKeyGeneration]]
| |
− | |-
| |
− | | 80 || [6.0.0+] [[#GetImportInitialDataAad]]
| |
− | |-
| |
− | | 81 || [6.0.0+] [[#SetExportInitialDataAad]]
| |
− | |-
| |
− | | 96 || [6.0.0+] [[#GetReportInfo]]
| |
| |} | | |} |
| | | |
− | == SetDivisionCount == | + | == Add == |
− | Takes an input u32, no output. | + | Takes an input [[#IFilesystem]], no output. |
| | | |
− | == OpenSaveDataChunkExporter == | + | == Commit == |
− | Takes an input u32, returns an [[#ISaveDataChunkExporter]].
| + | No input/output. |
| | | |
− | == FinalizeFullExport == | + | = IWiper = |
− | No input, returns two 0x10-byte output structs.
| + | This is "nn::fssrv::sf::IWiper". |
| | | |
− | == FinalizeDiffExport ==
| + | This was added with [[10.0.0]]. |
− | No input, returns an output 0x10-byte struct.
| |
− | | |
− | == CancelExport ==
| |
− | No input/output.
| |
− | | |
− | == SuspendExport ==
| |
− | No input/output, takes a type-0x6 output buffer.
| |
− | | |
− | == GetKeySeed ==
| |
− | No input, returns an output 0x10-byte struct.
| |
− | | |
− | == GetInitialDataMac ==
| |
− | No input, returns an output 0x10-byte struct.
| |
− | | |
− | == FinalizeExport ==
| |
− | No input/output.
| |
− | | |
− | == SetExportInitialDataAad ==
| |
− | Takes an input 0x20-byte struct, no output.
| |
− | | |
− | = ISaveDataDivisionImporter =
| |
− | This is "nn::fssrv::sf::ISaveDataDivisionImporter".
| |
− | | |
− | This was added with [[5.0.0]]. | |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,807: |
Line 1,783: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || [6.0.0+] [[#GetSaveDataInfo]] | + | | 0 || [[#Startup|Startup]] |
| |- | | |- |
− | | 16 || [[#OpenSaveDataDiffChunkIterator]] | + | | 16 || [[#Process_2|Process]] |
− | |- | + | |} |
− | | 32 || [[#InitializeImport]]
| + | |
| + | == Startup == |
| + | No input. Returns an u64. |
| + | |
| + | == Process == |
| + | No input. Returns an u64. |
| + | |
| + | = IStorageDeviceManager = |
| + | This is "nn::fssrv::storage::sf::IStorageDeviceManager". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| |- | | |- |
− | | 33 || [[#FinalizeImport]] | + | | N/A || IsInserted |
| |- | | |- |
− | | 34 || [6.0.0+] [[#CancelImport]] | + | | N/A || IsHandleValid |
| |- | | |- |
− | | 35 || [6.0.0+] [[#GetImportContext]] | + | | N/A || OpenDetectionEvent |
| |- | | |- |
− | | 36 || [6.0.0+] [[#SuspendImport]] | + | | N/A || OpenOperator |
| |- | | |- |
− | | 48 || [[#OpenSaveDataChunkImporter]] | + | | N/A || OpenDevice |
| |- | | |- |
− | | 64 || [6.0.0+] [[#GetImportInitialDataAad]] | + | | N/A || OpenStorage |
| |- | | |- |
− | | 80 || [6.0.0+] [[#GetReportInfo]] | + | | N/A || Invalidate |
| |} | | |} |
| | | |
− | == GetSaveDataInfo == | + | = IStorageDeviceOperator = |
− | No input/output, takes a type-0x6 output buffer.
| + | This is "nn::fssrv::storage::sf::IStorageDeviceOperator". |
| | | |
− | == OpenSaveDataDiffChunkIterator == | + | {| class="wikitable" border="1" |
− | No input, returns an [[#ISaveDataChunkIterator]].
| + | |- |
− | | + | ! Cmd || Name |
− | == InitializeImport ==
| + | |- |
− | No input, returns an output u64.
| + | | N/A || Operate |
− | | + | |- |
− | == FinalizeImport ==
| + | | N/A || OperateIn |
− | No input/output.
| + | |- |
− | | + | | N/A || OperateOut |
− | == CancelImport ==
| + | |- |
− | No input/output.
| + | | N/A || OperateOut2 |
− | | + | |- |
− | == GetImportContext ==
| + | | N/A || OperateInOut |
− | No input/output, takes a type-0x6 output buffer.
| + | |- |
| + | | N/A || OperateIn2Out |
| + | |} |
| | | |
− | == SuspendImport == | + | = IStorageDevice = |
− | No input/output.
| + | This is "nn::fssrv::storage::sf::IStorageDevice". |
− | | |
− | == OpenSaveDataChunkImporter ==
| |
− | Takes an input u32, returns an [[#ISaveDataChunkImporter]].
| |
− | | |
− | == GetImportInitialDataAad ==
| |
− | No input, returns an output 0x20-byte struct.
| |
− | | |
− | == GetReportInfo ==
| |
− | No input, returns an output 0x20-byte struct.
| |
− | | |
− | = ISaveDataChunkIterator =
| |
− | This is "nn::fssrv::sf::ISaveDataChunkIterator". | |
− | | |
− | This was added with [[5.0.0]].
| |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,867: |
Line 1,843: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || [[#Next]] | + | | N/A || GetHandle |
| |- | | |- |
− | | 1 || [[#IsEnd]] | + | | N/A || IsHandleValid |
| |- | | |- |
− | | 16 || [[#GetId]] | + | | N/A || OpenOperator |
| + | |- |
| + | | N/A || Read |
| + | |- |
| + | | N/A || Write |
| + | |- |
| + | | N/A || Flush |
| + | |- |
| + | | N/A || SetSize |
| + | |- |
| + | | N/A || GetSize |
| + | |- |
| + | | N/A || OperateRange |
| |} | | |} |
| | | |
− | == Next == | + | = FileSystemProxyType = |
− | No input/output.
| + | This is "nn::fs::FileSystemProxyType". |
− | | |
− | == IsEnd ==
| |
− | No input, returns an output u8.
| |
− | | |
− | == GetId ==
| |
− | No input, returns an output u32.
| |
− | | |
− | = ISaveDataChunkExporter =
| |
− | This is "nn::fssrv::sf::ISaveDataChunkExporter". | |
− | | |
− | This was added with [[5.0.0]].
| |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name | + | ! Value || Name |
| + | |- |
| + | | 0 || Code |
| |- | | |- |
− | | 0 || [[#Pull]] | + | | 1 || Rom |
| |- | | |- |
− | | 16 || [6.0.0+] [[#GetRestRawDataSize]] | + | | 2 || Logo |
− | |} | + | |- |
| + | | 3 || Control |
| + | |- |
| + | | 4 || Manual |
| + | |- |
| + | | 5 || Meta |
| + | |- |
| + | | 6 || Data |
| + | |- |
| + | | 7 || Package |
| + | |- |
| + | | 8 || [4.0.0+] RegisteredUpdate |
| + | |} |
| | | |
− | == Pull == | + | = ContentType = |
− | Takes an input u64 and a type-0x6 output buffer, returns an output u64.
| + | This is "nn::fs::ContentType". |
− | | |
− | == GetRestRawDataSize ==
| |
− | No input, returns an output u64.
| |
− | | |
− | = ISaveDataChunkImporter =
| |
− | This is "nn::fssrv::sf::ISaveDataChunkImporter". | |
− | | |
− | This was added with [[5.0.0]].
| |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name | + | ! Value || Name |
| |- | | |- |
− | | 0 || [[#Push]] | + | | 0 || Meta |
− | |} | + | |- |
− | | + | | 1 || Control |
− | == Push ==
| |
− | Takes an input u64 and a type-0x5 input buffer, no output.
| |
− | | |
− | = ISaveDataTransferProhibiter =
| |
− | This was added with [[6.0.0]].
| |
− | | |
− | This doesn't seem to handle any commands (?).
| |
− | | |
− | = IMultiCommitManager =
| |
− | This was added with [[6.0.0]].
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name
| + | | 2 || Manual |
| |- | | |- |
− | | 1 || [[#Add]] | + | | 3 || Logo |
| |- | | |- |
− | | 2 || [[#Commit]] | + | | 4 || Data |
| |} | | |} |
| | | |
− | == Add == | + | = ContentAttributes = |
− | Takes an input [[#IFilesystem]], no output.
| + | This is "nn::fs::ContentAttributes". |
− | | |
− | == Commit ==
| |
− | No input/output.
| |
− | | |
− | = IWiper =
| |
− | This is "nn::fs::IWiper". | |
− | | |
− | This was added with [[10.0.0]].
| |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name | + | ! Value || Name |
| |- | | |- |
− | | 0 || [[#Startup|Startup]] | + | | 0 || None |
| |- | | |- |
− | | 16 || [[#Process_2|Process]] | + | | 15 || All |
| |} | | |} |
| | | |
− | == Startup == | + | = ContentStorageId = |
− | No input. Returns an u64.
| + | This is "nn::fs::ContentStorageId". |
− | | |
− | == Process ==
| |
− | No input. Returns an u64.
| |
− | | |
− | = FileSystemProxyType =
| |
− | This is "nn::fs::FileSystemProxyType". | |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,968: |
Line 1,925: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Code | + | | 0 || System |
| |- | | |- |
− | | 1 || Rom | + | | 1 || User |
| |- | | |- |
− | | 2 || Logo | + | | 2 || SdCard |
| |- | | |- |
− | | 3 || Control | + | | 3 || [16.0.0+] System0 |
| + | |} |
| + | |
| + | = SaveDataSpaceId = |
| + | This is "nn::fs::SaveDataSpaceId". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 4 || Manual | + | ! Value || Name |
| |- | | |- |
− | | 5 || Meta | + | | 0 || System |
| |- | | |- |
− | | 6 || Data | + | | 1 || User |
| |- | | |- |
− | | 7 || Package | + | | 2 || SdSystem |
| + | |- |
| + | | 3 || [3.0.0+] Temporary |
| + | |- |
| + | | 4 || [4.0.0+] SdUser |
| + | |- |
| + | | 100 || [3.0.0+] ProperSystem |
| |- | | |- |
− | | 8 || [4.0.0+] RegisteredUpdate | + | | 101 || [3.0.0+] SafeMode |
| |} | | |} |
| | | |
− | = ContentType = | + | Determines the storage where the savedata is stored. |
− | This is "nn::fs::ContentType". | + | |
| + | = SaveDataType = |
| + | This is "nn::fs::SaveDataType". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 1,994: |
Line 1,965: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Meta | + | | 0 || System |
| + | |- |
| + | | 1 || Account |
| + | |- |
| + | | 2 || Bcat |
| |- | | |- |
− | | 1 || Control | + | | 3 || Device |
| |- | | |- |
− | | 2 || Manual | + | | 4 || [3.0.0+] Temporary |
| |- | | |- |
− | | 3 || Logo | + | | 5 || [3.0.0+] Cache |
| |- | | |- |
− | | 4 || Data | + | | 6 || [4.0.0+] SystemBcat |
| |} | | |} |
| | | |
− | = ContentStorageId = | + | = SaveDataRank = |
− | This is "nn::fs::ContentStorageId". | + | This is "nn::fs::SaveDataRank". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,012: |
Line 1,987: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || System | + | | 0 || Primary |
| |- | | |- |
− | | 1 || User | + | | 1 || Secondary |
− | |-
| |
− | | 2 || SdCard
| |
| |} | | |} |
| | | |
− | = SaveDataSpaceId = | + | = SaveDataEnumerateOption = |
− | This is "nn::fs::SaveDataSpaceId". | + | This is "nn::fs::SaveDataEnumerateOption". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,026: |
Line 1,999: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || System | + | | 1 || AllRank |
| + | |} |
| + | |
| + | = SaveDataFlags = |
| + | This is "nn::fs::SaveDataFlags". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 1 || User | + | ! Value || Name |
| |- | | |- |
− | | 2 || SdSystem | + | | 1 || KeepAfterResettingSystemSaveData |
| |- | | |- |
− | | 3 || [3.0.0+] Temporary | + | | 2 || KeepAfterRefurbishment |
| |- | | |- |
− | | 4 || [4.0.0+] SdUser | + | | 4 || KeepAfterResettingSystemSaveDataWithoutUserSaveData |
| |- | | |- |
− | | 100 || [3.0.0+] ProperSystem | + | | 8 || NeedsSecureDelete |
− | |-
| + | |} |
− | | 101 || [3.0.0+] SafeMode
| |
− | |} | |
| | | |
− | Determines the storage where the savedata is stored.
| + | = SaveDataMetaType = |
− | | + | This is "nn::fs::SaveDataMetaType". |
− | = SaveDataType = | |
− | This is "nn::fs::SaveDataType". | |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,050: |
Line 2,025: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || System | + | | 0 || None |
| |- | | |- |
− | | 1 || Account | + | | 1 || Thumbnail |
| |- | | |- |
− | | 2 || Bcat | + | | 2 || ExtensionContext |
− | |-
| |
− | | 3 || Device
| |
− | |-
| |
− | | 4 || [3.0.0+] Temporary
| |
− | |-
| |
− | | 5 || [3.0.0+] Cache
| |
− | |-
| |
− | | 6 || [4.0.0+] SystemBcat
| |
| |} | | |} |
| | | |
− | = SaveDataRank = | + | = ImageDirectoryId = |
− | This is "nn::fs::SaveDataRank". | + | This is "nn::fs::ImageDirectoryId". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,072: |
Line 2,039: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Primary | + | | 0 || Nand |
| |- | | |- |
− | | 1 || Secondary | + | | 1 || SdCard |
| |} | | |} |
| | | |
− | = SaveDataEnumerateOption = | + | = CloudBackupWorkStorageId = |
− | This is "nn::fs::SaveDataEnumerateOption". | + | This is "nn::fs::CloudBackupWorkStorageId". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,084: |
Line 2,051: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 1 || AllRank | + | | 0 || Nand |
| + | |- |
| + | | 1 || SdCard |
| |} | | |} |
| | | |
− | = SaveDataFlags = | + | = CustomStorageId = |
− | This is "nn::fs::SaveDataFlags". | + | This is "nn::fs::CustomStorageId". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,094: |
Line 2,063: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 1 || KeepAfterResettingSystemSaveData | + | | 0 || System |
| |- | | |- |
− | | 2 || KeepAfterRefurbishment | + | | 1 || SdCard |
− | |-
| |
− | | 4 || KeepAfterResettingSystemSaveDataWithoutUserSaveData
| |
− | |-
| |
− | | 8 || NeedsSecureDelete
| |
| |} | | |} |
| | | |
− | = SaveDataMetaType = | + | = Priority = |
− | This is "nn::fs::SaveDataMetaType". | + | This is "nn::fs::Priority". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,110: |
Line 2,075: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || None | + | | 0 || Realtime |
| |- | | |- |
− | | 1 || Thumbnail | + | | 1 || Normal |
| |- | | |- |
− | | 2 || ExtensionContext | + | | 2 || Low |
| |} | | |} |
| | | |
− | = ImageDirectoryId = | + | = PriorityRaw = |
− | This is "nn::fs::ImageDirectoryId". | + | This is "nn::fs::PriorityRaw". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,124: |
Line 2,089: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Nand | + | | 0 || Realtime |
| + | |- |
| + | | 1 || Normal |
| + | |- |
| + | | 2 || Low |
| |- | | |- |
− | | 1 || SdCard | + | | 3 || Background |
| |} | | |} |
| | | |
− | = CloudBackupWorkStorageId = | + | = AbortSpecifier = |
− | This is "nn::fs::CloudBackupWorkStorageId". | + | This is "nn::fs::AbortSpecifier". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,136: |
Line 2,105: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Nand | + | | 0 || Default |
| + | |- |
| + | | 1 || Abort |
| |- | | |- |
− | | 1 || SdCard | + | | 2 || ReturnResult |
| |} | | |} |
| | | |
− | = CustomStorageId = | + | = OperationId = |
− | This is "nn::fs::CustomStorageId". | + | This is "nn::fs::OperationId". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
− | |- | + | |- |
− | ! Value || Name | + | ! Value || Name |
− | |- | + | |- |
− | | 0 || System | + | | 0 || Clear |
− | |- | + | |- |
− | | 1 || SdCard | + | | 1 || ClearSignature |
| + | |- |
| + | | 2 || InvalidateCache |
| + | |- |
| + | | 3 || QueryRange |
| + | |} |
| + | |
| + | = MountHostOption = |
| + | This is "nn::fs::MountHostOption". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 1 || PseudoCaseSensitive |
| + | |} |
| + | |
| + | = BisPartitionId = |
| + | This is "nn::fs::BisPartitionId". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || BootPartition1Root |
| + | |- |
| + | | 10 || BootPartition2Root |
| + | |- |
| + | | 20 || UserDataRoot |
| + | |- |
| + | | 21 || BootConfigAndPackage2Part1 |
| + | |- |
| + | | 22 || BootConfigAndPackage2Part2 |
| + | |- |
| + | | 23 || BootConfigAndPackage2Part3 |
| + | |- |
| + | | 24 || BootConfigAndPackage2Part4 |
| + | |- |
| + | | 25 || BootConfigAndPackage2Part5 |
| + | |- |
| + | | 26 || BootConfigAndPackage2Part6 |
| + | |- |
| + | | 27 || CalibrationBinary |
| + | |- |
| + | | 28 || CalibrationFile |
| + | |- |
| + | | 29 || SafeMode |
| + | |- |
| + | | 30 || User |
| + | |- |
| + | | 31 || System |
| + | |- |
| + | | 32 || SystemProperEncryption |
| + | |- |
| + | | 33 || SystemProperPartition |
| + | |- |
| + | | 34 || SignedSystemPartitionOnSafeMode |
| + | |- |
| + | | 35 || [16.0.0+] DeviceTreeBlob |
| + | |- |
| + | | 36 || [16.0.0+] System0 |
| + | |} |
| + | |
| + | = SdCardSpeedMode = |
| + | This is "nn::fs::SdCardSpeedMode". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Identification |
| + | |- |
| + | | 1 || DefaultSpeed |
| + | |- |
| + | | 2 || HighSpeed |
| + | |- |
| + | | 3 || Sdr12 |
| + | |- |
| + | | 4 || Sdr25 |
| + | |- |
| + | | 5 || Sdr50 |
| + | |- |
| + | | 6 || Sdr104 |
| + | |- |
| + | | 7 || Ddr50 |
| + | |- |
| + | | 8 || Unknown |
| + | |} |
| + | |
| + | = MmcSpeedMode = |
| + | This is "nn::fs::MmcSpeedMode". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Identification |
| + | |- |
| + | | 1 || LegacySpeed |
| + | |- |
| + | | 2 || HighSpeed |
| + | |- |
| + | | 3 || Hs200 |
| + | |- |
| + | | 4 || Hs400 |
| + | |- |
| + | | 5 || Unknown |
| + | |} |
| + | |
| + | = MmcPartition = |
| + | This is "nn::fs::MmcPartition". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || UserData |
| + | |- |
| + | | 1 || BootPartition1 |
| + | |- |
| + | | 2 || BootPartition2 |
| + | |} |
| + | |
| + | = MemoryReportInfo = |
| + | This is "nn::fs::MemoryReportInfo". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset |
| + | ! Size |
| + | ! Description |
| + | |- |
| + | | 0x0 |
| + | | 0x8 |
| + | | PooledBufferFreeSizePeak |
| + | |- |
| + | | 0x8 |
| + | | 0x8 |
| + | | PooledBufferRetriedCount |
| + | |- |
| + | | 0x10 |
| + | | 0x8 |
| + | | PooledBufferReduceAllocationCount |
| + | |- |
| + | | 0x18 |
| + | | 0x8 |
| + | | BufferManagerFreeSizePeak |
| + | |- |
| + | | 0x20 |
| + | | 0x8 |
| + | | BufferManagerRetriedCount |
| + | |- |
| + | | 0x28 |
| + | | 0x8 |
| + | | ExpHeapFreeSizePeak |
| + | |- |
| + | | 0x30 |
| + | | 0x8 |
| + | | BufferPoolFreeSizePeak |
| + | |- |
| + | | 0x38 |
| + | | 0x8 |
| + | | PatrolReadAllocateBufferSuccessCount |
| + | |- |
| + | | 0x40 |
| + | | 0x8 |
| + | | PatrolReadAllocateBufferFailureCount |
| + | |- |
| + | | 0x48 |
| + | | 0x8 |
| + | | BufferManagerTotalAllocatableSizePeak |
| + | |- |
| + | | 0x50 |
| + | | 0x8 |
| + | | BufferPoolAllocateSizeMax |
| + | |- |
| + | | 0x58 |
| + | | 0x8 |
| + | | PooledBufferFailedIdealAllocationCountOnAsyncAccess |
| + | |- |
| + | | 0x60 |
| + | | 0x20 |
| + | | Reserved |
| + | |} |
| + | |
| + | = StorageErrorInfo = |
| + | This is "nn::fs::StorageErrorInfo". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset |
| + | ! Size |
| + | ! Description |
| + | |- |
| + | | 0x0 |
| + | | 0x4 |
| + | | NumActivationFailures |
| + | |- |
| + | | 0x4 |
| + | | 0x4 |
| + | | NumActivationErrorCorrections |
| + | |- |
| + | | 0x8 |
| + | | 0x4 |
| + | | NumReadWriteFailures |
| + | |- |
| + | | 0xC |
| + | | 0x4 |
| + | | NumReadWriteErrorCorrections |
| + | |} |
| + | |
| + | = GameCardErrorInfo = |
| + | This is "nn::fs::GameCardErrorInfo". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset |
| + | ! Size |
| + | ! Description |
| + | |- |
| + | | 0x0 |
| + | | 0x2 |
| + | | GameCardCrcErrorCount |
| + | |- |
| + | | 0x2 |
| + | | 0x2 |
| + | | Reserved |
| + | |- |
| + | | 0x4 |
| + | | 0x2 |
| + | | AsicCrcErrorCount |
| + | |- |
| + | | 0x6 |
| + | | 0x2 |
| + | | Reserved |
| + | |- |
| + | | 0x8 |
| + | | 0x2 |
| + | | RefreshCount |
| + | |- |
| + | | 0xA |
| + | | 0x2 |
| + | | Reserved |
| + | |- |
| + | | 0xC |
| + | | 0x2 |
| + | | ReadRetryCount |
| + | |- |
| + | | 0xE |
| + | | 0x2 |
| + | | TimeoutRetryErrorCount |
| + | |} |
| + | |
| + | = GameCardErrorReportInfo = |
| + | This is "nn::fs::GameCardErrorReportInfo". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset |
| + | ! Size |
| + | ! Description |
| + | |- |
| + | | 0x0 |
| + | | 0x10 |
| + | | [[#GameCardErrorInfo|ErrorInfo]] |
| + | |- |
| + | | 0x10 |
| + | | 0x2 |
| + | | AsicReinitializeFailureDetail |
| + | |- |
| + | | 0x12 |
| + | | 0x2 |
| + | | InsertionCount |
| + | |- |
| + | | 0x14 |
| + | | 0x2 |
| + | | RemovalCount |
| + | |- |
| + | | 0x16 |
| + | | 0x2 |
| + | | AsicReinitializeCount |
| + | |- |
| + | | 0x18 |
| + | | 0x4 |
| + | | AsicInitializeCount |
| + | |- |
| + | | 0x1C |
| + | | 0x2 |
| + | | AsicReinitializeFailureCount |
| + | |- |
| + | | 0x1E |
| + | | 0x2 |
| + | | AwakenFailureCount |
| + | |- |
| + | | 0x20 |
| + | | 0x2 |
| + | | Reserved |
| + | |- |
| + | | 0x22 |
| + | | 0x2 |
| + | | RefreshCount |
| + | |- |
| + | | 0x24 |
| + | | 0x4 |
| + | | LastReadErrorPageAddress |
| + | |- |
| + | | 0x28 |
| + | | 0x4 |
| + | | LastReadErrorPageCount |
| + | |- |
| + | | 0x2C |
| + | | 0x4 |
| + | | AwakenCount |
| + | |- |
| + | | 0x30 |
| + | | 0x4 |
| + | | ReadCountFromInsert |
| + | |- |
| + | | 0x34 |
| + | | 0x4 |
| + | | ReadCountFromAwaken |
| + | |- |
| + | | 0x38 |
| + | | 0x8 |
| + | | Reserved |
| + | |} |
| + | |
| + | = GameCardHandle = |
| + | This is "nn::fs::GameCardHandle". This is an u32. |
| + | |
| + | = GameCardPartition = |
| + | This is "nn::fs::GameCardPartition". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Update |
| + | |- |
| + | | 1 || Normal |
| + | |- |
| + | | 2 || Secure |
| + | |- |
| + | | 3 || [4.0.0+] Logo |
| + | |} |
| + | |
| + | = GameCardPartitionRaw = |
| + | This is "nn::fs::GameCardPartitionRaw". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || NormalReadOnly |
| + | |- |
| + | | 1 || SecureReadOnly |
| + | |- |
| + | | 2 || RootWriteOnly |
| + | |} |
| + | |
| + | = GameCardAttribute = |
| + | This is "nn::fs::GameCardAttribute". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 1 || AutoBootFlag |
| + | |- |
| + | | 2 || HistoryEraseFlag |
| + | |- |
| + | | 4 || [4.0.0+] RepairToolFlag |
| + | |- |
| + | | 8 || [9.0.0+] DifferentRegionCupToTerraDeviceFlag |
| + | |- |
| + | | 16 || [9.0.0+] DifferentRegionCupToGlobalDeviceFlag |
| + | |} |
| + | |
| + | = GameCardAttribute2 = |
| + | This is "nn::fs::GameCardAttribute2". |
| + | |
| + | = GameCardSize = |
| + | This is "nn::fs::GameCardSize". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 1 || Size1GB |
| + | |- |
| + | | 2 || Size2GB |
| + | |- |
| + | | 4 || Size4GB |
| + | |- |
| + | | 8 || Size8GB |
| + | |- |
| + | | 16 || Size16GB |
| + | |- |
| + | | 32 || Size32GB |
| + | |} |
| + | |
| + | = GameCardClockRate = |
| + | This is "nn::fs::GameCardClockRate". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 25 || ClockRate25MHz |
| + | |- |
| + | | 50 || ClockRate50MHz |
| |} | | |} |
| | | |
− | = Priority = | + | = GameCardCompatibilityType = |
− | This is "nn::fs::Priority". | + | This is "nn::fs::GameCardCompatibilityType". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,160: |
Line 2,541: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Realtime | + | | 0 || Global |
− | |-
| |
− | | 1 || Normal
| |
| |- | | |- |
− | | 2 || Low | + | | 1 || China |
| |} | | |} |
| | | |
− | = PriorityRaw = | + | = GameCardUpdatePartitionInfo = |
− | This is "nn::fs::PriorityRaw". | + | This is "nn::fs::GameCardUpdatePartitionInfo". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
| + | ! Size |
| + | ! Description |
| |- | | |- |
− | | 0 || Realtime | + | | 0x0 |
| + | | 0x4 |
| + | | Version |
| |- | | |- |
− | | 1 || Normal | + | | 0x4 |
− | |- | + | | 0x4 |
− | | 2 || Low | + | | Reserved |
| |- | | |- |
− | | 3 || Background | + | | 0x8 |
| + | | 0x8 |
| + | | Id |
| |} | | |} |
| | | |
− | = AbortSpecifier = | + | = GameCardIdSet = |
− | This is "nn::fs::AbortSpecifier". | + | This is "nn::gc::GameCardIdSet". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
| + | ! Size |
| + | ! Description |
| |- | | |- |
− | | 0 || Default | + | | 0x0 |
| + | | 0x4 |
| + | | [[#CardId1|Id1]] |
| |- | | |- |
− | | 1 || Abort | + | | 0x4 |
| + | | 0x4 |
| + | | [[#CardId2|Id2]] |
| |- | | |- |
− | | 2 || ReturnResult | + | | 0x8 |
| + | | 0x4 |
| + | | [[#CardId3|Id3]] |
| |} | | |} |
| | | |
− | = OperationId = | + | = CardId1 = |
− | This is "nn::fs::OperationId". | + | This is "nn::gc::detail::CardId1". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
− | |-
| + | ! Size |
− | | 0 || Clear
| + | ! Description |
− | |-
| |
− | | 1 || ClearSignature
| |
| |- | | |- |
− | | 2 || InvalidateCache | + | | 0x0 |
| + | | 0x1 |
| + | | [[#MakerCodeForCardId1|MakerCode]] |
| |- | | |- |
− | | 3 || QueryRange | + | | 0x1 |
− | |} | + | | 0x1 |
− | | + | | [[#MemoryCapacity|MemoryCapacity]] |
− | = MountHostOption =
| |
− | This is "nn::fs::MountHostOption".
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Value || Name
| + | | 0x2 |
| + | | 0x1 |
| + | | Reserved |
| |- | | |- |
− | | 1 || PseudoCaseSensitive | + | | 0x3 |
| + | | 0x1 |
| + | | MemoryType |
| |} | | |} |
| | | |
− | = BisPartitionId = | + | = CardId2 = |
− | This is "nn::fs::BisPartitionId". | + | This is "nn::gc::detail::CardId2". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
− | |-
| + | ! Size |
− | | 0 || BootPartition1Root
| + | ! Description |
− | |-
| |
− | | 10 || BootPartition2Root
| |
− | |-
| |
− | | 20 || UserDataRoot
| |
− | |-
| |
− | | 21 || BootConfigAndPackage2Part1
| |
− | |-
| |
− | | 22 || BootConfigAndPackage2Part2
| |
− | |-
| |
− | | 23 || BootConfigAndPackage2Part3
| |
− | |-
| |
− | | 24 || BootConfigAndPackage2Part4
| |
− | |-
| |
− | | 25 || BootConfigAndPackage2Part5
| |
− | |-
| |
− | | 26 || BootConfigAndPackage2Part6
| |
− | |-
| |
− | | 27 || CalibrationBinary
| |
− | |-
| |
− | | 28 || CalibrationFile
| |
− | |-
| |
− | | 29 || SafeMode
| |
− | |-
| |
− | | 30 || User
| |
− | |-
| |
− | | 31 || System
| |
| |- | | |- |
− | | 32 || SystemProperEncryption | + | | 0x0 |
| + | | 0x1 |
| + | | CardSecurityNumber |
| |- | | |- |
− | | 33 || SystemProperPartition | + | | 0x1 |
| + | | 0x1 |
| + | | CardType |
| |- | | |- |
− | | 34 || SignedSystemPartitionOnSafeMode | + | | 0x2 |
| + | | 0x2 |
| + | | Reserved |
| |} | | |} |
| | | |
− | = MmcSpeedMode = | + | = CardId3 = |
− | This is "nn::fs::MmcSpeedMode". | + | This is "nn::gc::detail::CardId3". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
− | |-
| + | ! Size |
− | | 0 || Identification
| + | ! Description |
− | |-
| |
− | | 1 || LegacySpeed
| |
− | |-
| |
− | | 2 || HighSpeed
| |
| |- | | |- |
− | | 3 || Hs200 | + | | 0x0 |
− | |-
| + | | 0x4 |
− | | 4 || Hs400
| + | | Reserved |
− | |- | |
− | | 5 || Unknown | |
| |} | | |} |
| | | |
− | = MmcPartition = | + | = MakerCodeForCardId1 = |
− | This is "nn::fs::MmcPartition". | + | This is "nn::gc::detail::MakerCodeForCardId1". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,292: |
Line 2,659: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || UserData | + | | 0x36 || Unknown |
| |- | | |- |
− | | 1 || BootPartition1 | + | | 0xC2 || MegaChips |
| |- | | |- |
− | | 2 || BootPartition2 | + | | 0xAE || Lapis |
| |} | | |} |
| | | |
− | = GameCardPartition = | + | = MemoryCapacity = |
− | This is "nn::fs::GameCardPartition". | + | This is "nn::gc::detail::MemoryCapacity". |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 2,306: |
Line 2,673: |
| ! Value || Name | | ! Value || Name |
| |- | | |- |
− | | 0 || Update | + | | 0xFA || 1GB |
| |- | | |- |
− | | 1 || Normal | + | | 0xF8 || 2GB |
| |- | | |- |
− | | 2 || Secure | + | | 0xF0 || 4GB |
| |- | | |- |
− | | 3 || [4.0.0+] Logo | + | | 0xE0 || 8GB |
− | |}
| |
− | | |
− | = GameCardPartitionRaw =
| |
− | This is "nn::fs::GameCardPartitionRaw".
| |
− | | |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Value || Name
| + | | 0xE1 || 16GB |
| |- | | |- |
− | | 0 || NormalReadOnly | + | | 0xE2 || 32GB |
− | |-
| |
− | | 1 || SecureReadOnly
| |
− | |-
| |
− | | 2 || RootWriteOnly
| |
| |} | | |} |
| | | |
− | = GameCardAttribute = | + | = RmaInformation = |
− | This is "nn::fs::GameCardAttribute". | + | This is "nn::gc::RmaInformation". This is a 0x200-byte struct. |
− | | |
− | {| class="wikitable" border="1"
| |
− | |-
| |
− | ! Value || Name
| |
− | |-
| |
− | | 1 || AutoBootFlag
| |
− | |-
| |
− | | 2 || HistoryEraseFlag
| |
− | |-
| |
− | | 4 || [4.0.0+] RepairToolFlag
| |
− | |-
| |
− | | 8 || [9.0.0+] DifferentRegionCupToTerraDeviceFlag
| |
− | |-
| |
− | | 16 || [9.0.0+] DifferentRegionCupToGlobalDeviceFlag
| |
− | |}
| |
| | | |
− | = GameCardSize = | + | = GameCardCardHeader = |
− | This is "nn::fs::GameCardSize". | + | This is a 0x600-byte struct. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Value || Name | + | ! Offset |
− | |-
| + | ! Size |
− | | 1 || Size1GB
| + | ! Description |
− | |-
| |
− | | 2 || Size2GB
| |
| |- | | |- |
− | | 4 || Size4GB | + | | 0x0 |
| + | | 0x100 |
| + | | [[XCI#CardHeader|Signature]] |
| |- | | |- |
− | | 8 || Size8GB | + | | 0x100 |
| + | | 0x100 |
| + | | [[Lotus3#GetCardHeader|Header]] |
| |- | | |- |
− | | 16 || Size16GB | + | | 0x200 |
− | |-
| + | | 0x400 |
− | | 32 || Size32GB
| + | | [[XCI#NewCardHeaderCertArea|NewCardHeaderCertArea]] |
− | |}
| |
− | | |
− | = GameCardClockRate =
| |
− | This is "nn::fs::GameCardClockRate".
| |
− | | |
− | {| class="wikitable" border="1"
| |
− | |-
| |
− | ! Value || Name
| |
− | |-
| |
− | | 25 || ClockRate25MHz | |
− | |- | |
− | | 50 || ClockRate50MHz
| |
| |} | | |} |
| | | |
Line 2,451: |
Line 2,783: |
| |} | | |} |
| | | |
− | = ContentPath = | + | = FspPath = |
− | These are the 0x300 paths to NCA files for the various filesystems FS can access, beginning with @. They're passed via X descriptors, and returned via various [[Location Resolver services|ncm/lr]] commands.
| + | This is "nn::fssrv::sf::FspPath". This is a 0x301-byte string. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |