Filesystem services: Difference between revisions

From 3dbrew
Jump to navigation Jump to search
Yuriks (talk | contribs)
m Add links to RenameFile and RenameDirectory
m this doesnt match observations nor the header in the page for the command
 
(185 intermediate revisions by 24 users not shown)
Line 1: Line 1:
[[Category:Services]]
= Services =
 
{{Anchor|FS}}{{Anchor|FSUSER}}{{Anchor|fs:USER}}
= Filesystem service "fs:USER" =
== Filesystem service "fs:USER" ==
You can at most have 32 FS archive handles.
You can at most have 32 FS archive handles.


Line 13: Line 13:
| 0x000100C6
| 0x000100C6
|?
|?
| Dummy1
| [[FS:Dummy1|Dummy1]]
| None
| None
|-
|-
| 0x040100C4
| 0x040100C4
|?
|?
| Control
| [[FS:Control|Control]]
| None
| None
|-
|-
Line 53: Line 53:
| 0x08070142
| 0x08070142
|?
|?
| DeleteDirectoryRecursively
| [[FS:DeleteDirectoryRecursively|DeleteDirectoryRecursively]]
| None
| None
|-
|-
| 0x08080202
| 0x08080202
|?
|?
| CreateFile
| [[FS:CreateFile|CreateFile]]
| None
| None
|-
|-
Line 83: Line 83:
| 0x080D0144
| 0x080D0144
|?
|?
| ControlArchive
| [[FS:ControlArchive|ControlArchive]]
| None
| None
|-
|-
Line 93: Line 93:
| 0x080F0180
| 0x080F0180
|?
|?
| FormatThisUserSaveData
| [[FS:Obsoleted_2_0_FormatThisUserSaveData|Obsoleted_2_0_FormatThisUserSaveData]]
| None
| None
|-
|-
| 0x08100200
| 0x08100200
|?
|?
| CreateSystemSaveData
| [[FS:Obsoleted_3_0_CreateSystemSaveData|Obsoleted_3_0_CreateSystemSaveData]]
| 0x4, for when the input saveID doesn't match the exheader saveID
| 0x4, for when the input saveID doesn't match the exheader saveID
|-
|-
| 0x08110040
| 0x08110040
|?
|?
| DeleteSystemSaveData
| [[FS:Obsoleted_3_0_DeleteSystemSaveData|Obsoleted_3_0_DeleteSystemSaveData]]
| 0x1004, for when the input saveID doesn't match the exheader saveID
| 0x1004, for when the input saveID doesn't match the exheader saveID
|-
|-
| 0x08120080
| 0x08120080
|?
|?
| GetFreeBytes
| [[FS:GetFreeBytes|GetFreeBytes]]
| None
| None
|-
|-
| 0x08130000
| 0x08130000
|?
|?
| GetCardType
| [[FS:GetCardType|GetCardType]]
| 0x1017
| 0x1017
|-
|-
Line 124: Line 124:
|?
|?
| [[FS:GetNandArchiveResource|GetNandArchiveResource]]
| [[FS:GetNandArchiveResource|GetNandArchiveResource]]
| None
| 0x1007
|-
|-
| 0x08160000
| 0x08160000
|?
|?
| GetSdmcFatfsError
| [[FS:GetSdmcFatfsError|GetSdmcFatfsError]]
| 0x2
| 0x2
|-
|-
Line 143: Line 143:
| 0x08190042
| 0x08190042
|?
|?
| GetSdmcCid
| [[FS:GetSdmcCid|GetSdmcCid]]
| 0x2
| 0x2
|-
|-
| 0x081A0042
| 0x081A0042
|?
|?
| GetNandCid
| [[FS:GetNandCid|GetNandCid]]
| 0x2
| 0x2
|-
|-
| 0x081B0000
| 0x081B0000
|?
|?
| GetSdmcSpeedInfo
| [[FS:GetSdmcSpeedInfo|GetSdmcSpeedInfo]]
| 0x2
| 0x2
|-
|-
| 0x081C0000
| 0x081C0000
|?
|?
| GetNandSpeedInfo
| [[FS:GetNandSpeedInfo|GetNandSpeedInfo]]
| 0x2
| 0x2
|-
|-
| 0x081D0042
| 0x081D0042
|?
|?
| GetSdmcLog
| [[FS:GetSdmcLog|GetSdmcLog]]
| 0x2
| 0x2
|-
|-
| 0x081E0042
| 0x081E0042
|?
|?
| GetNandLog
| [[FS:GetNandLog|GetNandLog]]
| 0x2
| 0x2
|-
|-
| 0x081F0000
| 0x081F0000
|?
|?
| ClearSdmcLog
| [[FS:ClearSdmcLog|ClearSdmcLog]]
| 0x2
| 0x2
|-
|-
| 0x08200000
| 0x08200000
|?
|?
| ClearNandLog
| [[FS:ClearNandLog|ClearNandLog]]
| 0x2
| 0x2
|-
|-
| 0x08210000
| 0x08210000
|?
|?
| CardSlotIsInserted
| [[FS:CardSlotIsInserted|CardSlotIsInserted]]
| 0x1017
| 0x1017
|-
|-
| 0x08220000
| 0x08220000
|?
|?
| CardSlotPowerOn
| [[FS:CardSlotPowerOn|CardSlotPowerOn]]
| 0x2
| 0x2
|-
|-
| 0x08230000
| 0x08230000
|?
|?
| CardSlotPowerOff
| [[FS:CardSlotPowerOff|CardSlotPowerOff]]
| 0x2
| 0x2
|-
|-
| 0x08240000
| 0x08240000
|?
|?
| CardSlotGetCardIFPowerStatus
| [[FS:CardSlotGetCardIFPowerStatus|CardSlotGetCardIFPowerStatus]]
| 0x2
| 0x2
|-
|-
| 0x08250040
| 0x08250040
|?
|?
| CardNorDirectCommand
| [[FS:CardNorDirectCommand|CardNorDirectCommand]]
| 0x2
| 0x2
|-
|-
| 0x08260080
| 0x08260080
|?
|?
| CardNorDirectCommandWithAddress
| [[FS:CardNorDirectCommandWithAddress|CardNorDirectCommandWithAddress]]
| 0x2
| 0x2
|-
|-
| 0x08270082
| 0x08270082
|?
|?
| CardNorDirectRead
| [[FS:CardNorDirectRead|CardNorDirectRead]]
| 0x2
| 0x2
|-
|-
| 0x082800C2
| 0x082800C2
|?
|?
| CardNorDirectReadWithAddress
| [[FS:CardNorDirectReadWithAddress|CardNorDirectReadWithAddress]]
| 0x2
| 0x2
|-
|-
| 0x08290082
| 0x08290082
|?
|?
| CardNorDirectWrite
| [[FS:CardNorDirectWrite|CardNorDirectWrite]]
| 0x2
| 0x2
|-
|-
| 0x082A00C2
| 0x082A00C2
|?
|?
| CardNorDirectWriteWithAddress
| [[FS:CardNorDirectWriteWithAddress|CardNorDirectWriteWithAddress]]
| 0x2
| 0x2
|-
|-
| 0x082B00C2
| 0x082B00C2
|?
|?
| CardNorDirectRead_4xIO
| [[FS:CardNorDirectRead_4xIO|CardNorDirectRead_4xIO]]
| 0x2
| 0x2
|-
|-
| 0x082C0082
| 0x082C0082
|?
|?
| CardNorDirectCpuWriteWithoutVerify
| [[FS:CardNorDirectCpuWriteWithoutVerify|CardNorDirectCpuWriteWithoutVerify]]
| 0x2
| 0x2
|-
|-
| 0x082D0040
| 0x082D0040
|?
|?
| CardNorDirectSectorEraseWithoutVerify
| [[FS:CardNorDirectSectorEraseWithoutVerify|CardNorDirectSectorEraseWithoutVerify]]
| 0x2
| 0x2
|-
|-
Line 258: Line 258:
| 0x08300182
| 0x08300182
|?
|?
| CreateExtSaveData
| [[FS:Obsoleted_3_0_CreateExtSaveData|Obsoleted_3_0_CreateExtSaveData]]
| 0xC, for when the input extdataID doesn't match the exheader extdataID
| 0xC, for when the input extdataID doesn't match the exheader extdataID
|-
|-
| 0x08310180
| 0x08310180
|?
|?
| CreateSharedExtSaveData
| [[FS:Obsoleted_3_0_CreateSharedExtSaveData|Obsoleted_3_0_CreateSharedExtSaveData]]
| 0x1005
| 0x1005
|-
|-
| 0x08320102
| 0x08320102
|?
|?
| [[FS:ReadExtSaveDataIcon|ReadExtSaveDataIcon]]
| [[FS:Obsoleted_3_0_ReadExtSaveDataIcon|Obsoleted_3_0_ReadExtSaveDataIcon]]
| 0x100D, for when the input extdataID doesn't match the exheader extdataID
| 0x100D, for when the input extdataID doesn't match the exheader extdataID
|-
|-
| 0x08330082
| 0x08330082
|?
|?
| EnumerateExtSaveData
| [[FS:Obsoleted_3_0_EnumerateExtSaveData|Obsoleted_3_0_EnumerateExtSaveData]]
| 0x1005
| 0x1005
|-
|-
| 0x08340082
| 0x08340082
|?
|?
| EnumerateSharedExtSaveData
| [[FS:Obsoleted_3_0_EnumerateSharedExtSaveData|Obsoleted_3_0_EnumerateSharedExtSaveData]]
| 0x1005
| 0x1005
|-
|-
| 0x08350080
| 0x08350080
|?
|?
| DeleteExtSaveData
| [[FS:Obsoleted_3_0_DeleteExtSaveData|Obsoleted_3_0_DeleteExtSaveData]]
| 0x100D, for when the input extdataID doesn't match the exheader extdataID
| 0x100D, for when the input extdataID doesn't match the exheader extdataID
|-
|-
| 0x08360080
| 0x08360080
|?
|?
| DeleteSharedExtSaveData
| [[FS:Obsoleted_3_0_DeleteSharedExtSaveData|Obsoleted_3_0_DeleteSharedExtSaveData]]
| 0x1005
| 0x1005
|-
|-
| 0x08370040
| 0x08370040
|?
|?
| SetCardSpiBaudRate
| [[FS:SetCardSpiBaudRate|SetCardSpiBaudRate]]
| 0x2
| 0x2
|-
|-
| 0x08380040
| 0x08380040
|?
|?
| SetCardSpiBusMode
| [[FS:SetCardSpiBusMode|SetCardSpiBusMode]]
| 0x2
| 0x2
|-
|-
| 0x08390000
| 0x08390000
|?
|?
| SendInitializeInfoTo9
| [[FS:SendInitializeInfoTo9|SendInitializeInfoTo9]]
| None
| None
|-
|-
| 0x083A0100
| 0x083A0100
|?
|?
| GetSpecialContentIndex
| [[FS:GetSpecialContentIndex|GetSpecialContentIndex]]
| 0x1005
| 0x1005
|-
|-
| 0x083B00C2
| 0x083B00C2
|?
|?
| GetLegacyRomHeader
| [[FS:GetLegacyRomHeader|GetLegacyRomHeader]]
| 0x1015
| 0x1015
|-
|-
| 0x083C00C2
| 0x083C00C2
|?
|?
| GetLegacyBannerData
| [[FS:GetLegacyBannerData|GetLegacyBannerData]]
| 0x1015
| 0x1015
|-
|-
| 0x083D0100
| 0x083D0100
|?
|?
| CheckAuthorityToAccessExtSaveData
| [[FS:CheckAuthorityToAccessExtSaveData|CheckAuthorityToAccessExtSaveData]]
| 0x44
| 0x44
|-
|-
| 0x083E00C2
| 0x083E00C2
|?
|?
| QueryTotalQuotaSize
| [[FS:QueryTotalQuotaSize|QueryTotalQuotaSize]]
| None
| None
|-
|-
| 0x083F00C0
| 0x083F00C0
|?
|?
| GetExtDataBlockSize
| [[FS:Obsoleted_3_0_GetExtDataBlockSize|Obsoleted_3_0_GetExtDataBlockSize]]
| None
| None
|-
|-
| 0x08400040
| 0x08400040
|?
|?
| AbnegateAccessRight
| [[FS:AbnegateAccessRight|AbnegateAccessRight]]
|?
|?
|-
|-
| 0x08410000
| 0x08410000
|?
|?
| DeleteSdmcRoot
| [[FS:DeleteSdmcRoot|DeleteSdmcRoot]]
| 0x1005
| 0x1005
|-
|-
| 0x08420040
| 0x08420040
|?
|?
| DeleteAllExtSaveDataOnNand
| [[FS:DeleteAllExtSaveDataOnNand|DeleteAllExtSaveDataOnNand]]
| 0x1005
| 0x1005
|-
|-
Line 358: Line 358:
| 0x08440000
| 0x08440000
|?
|?
| CreateSeed
| [[FS:CreateSeed|CreateSeed]]
| 0x2
| 0x2
|-
|-
| 0x084500C2
| 0x084500C2
|?
|?
| GetFormatInfo
| [[FS:GetFormatInfo|GetFormatInfo]]
|?
|?
|-
|-
| 0x08460102
| 0x08460102
|?
|?
| GetLegacyRomHeader2
| [[FS:GetLegacyRomHeader2|GetLegacyRomHeader2]]
| 0x1015
| 0x1015
|-
|-
| 0x08470180
| 0x08470180
|?
|?
| FormatCtrCardUserSaveData
| [[FS:Obsoleted_2_0_FormatCtrCardUserSaveData|Obsoleted_2_0_FormatCtrCardUserSaveData]]
| 0x6
| 0x6
|-
|-
| 0x08480042
| 0x08480042
|?
|?
| GetSdmcCtrRootPath
| [[FS:GetSdmcCtrRootPath|GetSdmcCtrRootPath]]
| 0x100D
| 0x100D
|-
|-
| 0x08490040
| 0x08490040
|?
|?
| GetArchiveResource
| [[FS:GetArchiveResource|GetArchiveResource]]
|?
|?
|-
|-
| 0x084A0002
| 0x084A0002
|?
|?
| ExportIntegrityVerificationSeed
| [[FS:ExportIntegrityVerificationSeed|ExportIntegrityVerificationSeed]]
| 0x4000
| 0x4000
|-
|-
| 0x084B0002
| 0x084B0002
|?
|?
| ImportIntegrityVerificationSeed
| [[FS:ImportIntegrityVerificationSeed|ImportIntegrityVerificationSeed]]
| 0x4000
| 0x4000
|-
|-
| 0x084C0242
| 0x084C0242
|?
|?
| FormatSaveData
| [[FS:FormatSaveData|FormatSaveData]]
| 0x6, in some cases this write isn't needed however
| 0x6, in some cases this write isn't needed however
|-
|-
| 0x084D0102
| 0x084D0102
|?
|?
| GetLegacySubBannerData
| [[FS:GetLegacySubBannerData|GetLegacySubBannerData]]
| 0x1015
| 0x1015
|-
|-
Line 413: Line 413:
| 0x084F0102
| 0x084F0102
|?
|?
| ReadSpecialFile
| [[FS:ReadSpecialFile|ReadSpecialFile]]
| None
| None
|-
|-
| 0x08500040
| 0x08500040
|?
|?
| GetSpecialFileSize
| [[FS:GetSpecialFileSize|GetSpecialFileSize]]
| None
| None
|-
|-
| 0x08510242
| 0x08510242
| [[3.0.0-5]]
| [[3.0.0-5]]
| CreateExtSaveData
| [[FS:CreateExtSaveData|CreateExtSaveData]]
| Shared extdata: 0x101005. Regular extdata in certain cases: 0xC
| Shared extdata: 0x101005. Regular extdata in certain cases: 0xC
|-
|-
| 0x08520100
| 0x08520100
| [[3.0.0-5]]
| [[3.0.0-5]]
| DeleteExtSaveData (u32 flags, u64 extdataID)
| [[FS:DeleteExtSaveData|DeleteExtSaveData]]
| Shared extdata: 0x101005. Regular extdata in certain cases: 0x10100D
| Shared extdata: 0x101005. Regular extdata in certain cases: 0x10100D
|-
|-
| 0x08530142
| 0x08530142
| [[3.0.0-5]]
| [[3.0.0-5]]
| ReadExtSaveDataIcon
| [[FS:ReadExtSaveDataIcon|ReadExtSaveDataIcon]]
| 0x10100D (this doesn't apply in certain cases, however)
| 0x10100D (this doesn't apply in certain cases, however)
|-
|-
| 0x085400C0
| 0x08540010
| [[3.0.0-5]]
| [[3.0.0-5]]
| GetExtDataBlockSize?
| [[FS:GetExtDataBlockSize|GetExtDataBlockSize]]
| 0x10100D (this doesn't apply in certain cases, however)
| 0x10100D (this doesn't apply in certain cases, however)
|-
|-
| 0x08550102
| 0x08550102
| [[3.0.0-5]]
| [[3.0.0-5]]
| EnumerateExtSaveData
| [[FS:EnumerateExtSaveData|EnumerateExtSaveData]]
| 0x101005
| 0x101005
|-
|-
| 0x08560200
| 0x08560240
| [[3.0.0-5]]
| [[3.0.0-5]]
| FsCreateSystemSaveData?
| [[FS:CreateSystemSaveData|CreateSystemSaveData]]
| 0x4 (this doesn't apply in certain cases, however)
| 0x4 (this doesn't apply in certain cases, however)
|-
|-
| 0x08570080
| 0x08570080
| [[3.0.0-5]]
| [[3.0.0-5]]
| DeleteSystemSaveData
| [[FS:DeleteSystemSaveData|DeleteSystemSaveData]]
| 0x1004 (this doesn't apply in certain cases, however)
| 0x1004 (this doesn't apply in certain cases, however)
|-
|-
| 0x08580000
| 0x08580000
| [[3.0.0-5]]
| [[3.0.0-5]]
| [[FS:GetMovableSedHashedKeyYRandomData|GetMovableSedHashedKeyYRandomData]]
| [[FS:StartDeviceMoveAsSource|StartDeviceMoveAsSource]]
| 0x2004
| 0x2004
|-
|-
| 0x08590200
| 0x08590200
| [[3.0.0-5]]
| [[3.0.0-5]]
| SetMovableSedHashedKeyYRandomData?
| [[FS:StartDeviceMoveAsDestination|StartDeviceMoveAsDestination]]
| 0x2004
| 0x2004
|-
|-
| 0x085A00C0
| 0x085A00C0
| [[3.0.0-5]]
| [[3.0.0-5]]
| SetArchivePriority(u64 ID,u32 priority)
| [[FS:SetArchivePriority|SetArchivePriority]]
| None
| None
|-
|-
| 0x085B0080
| 0x085B0080
| [[3.0.0-5]]
| [[3.0.0-5]]
| GetArchivePriority(u64 ID,u32 *priority)
| [[FS:GetArchivePriority|GetArchivePriority]]
| None
| None
|-
|-
| 0x085C00C0
| 0x085C00C0
| [[3.0.0-5]]
| [[3.0.0-5]]
| SetCtrCardLatencyParameter
| [[FS:SetCtrCardLatencyParameter|SetCtrCardLatencyParameter]]
| 0xE
| 0xE
|-
|-
| 0x085D0180
| 0x085D01C0
| [[3.0.0-5]]
| [[3.0.0-5]]
|?
| [[FS:SetFsCompatibilityInfo|SetFsCompatibilityInfo]]
| 0x100001
| 0x100001
|-
|-
| 0x085E0040
| 0x085E0040
| [[3.0.0-5]]
| [[3.0.0-5]]
| ResetCardCompatibilityParameter
| [[FS:ResetCardCompatibilityParameter|ResetCardCompatibilityParameter]]
| 0xE
| 0xE
|-
|-
| 0x085F0040
| 0x085F0040
| [[3.0.0-5]]
| [[3.0.0-5]]
| SwitchCleanupInvalidSaveData
| [[FS:SwitchCleanupInvalidSaveData|SwitchCleanupInvalidSaveData]]
| 0x12004
| 0x12004
|-
|-
| 0x08600042
| 0x08600042
| [[3.0.0-5]]
| [[3.0.0-5]]
| EnumerateSystemSaveData
| [[FS:EnumerateSystemSaveData|EnumerateSystemSaveData]]
| 0x2004
| 0x2004
|-
|-
| 0x08610042
| 0x08610042
| [[3.0.0-5]]
| [[3.0.0-5]]
| InitializeWithSdkVersion
| [[FS:InitializeWithSdkVersion|InitializeWithSdkVersion]]
| None
| None
|-
|-
| 0x08620040
| 0x08620040
| [[3.0.0-5]]
| [[3.0.0-5]]
| SetPriority
| [[FS:SetPriority|SetPriority]]
| None
| None
|-
|-
| 0x08630000
| 0x08630000
| [[3.0.0-5]]
| [[3.0.0-5]]
| GetPriority
| [[FS:GetPriority|GetPriority]]
| None
| None
|-
|-
| 0x08640000
| 0x08640000
| [[3.0.0-5]]
| [[3.0.0-5]]
| Obsoleted_4_0_GetNandInfo Stubbed, this returns an error
| [[FS:Obsoleted_4_0_GetNandInfo|Obsoleted_4_0_GetNandInfo]]
| None
| Stubbed, this returns an error
|-
|-
| 0x08650140
| 0x08650140
| [[4.0.0-7]]
| [[4.0.0-7]]
| SetSaveDataSecureValue, this is used with [[Anti Savegame Restore]].
| [[FS:SetSaveDataSecureValue|SetSaveDataSecureValue]]
| 0x121004 (in certain cases this doesn't apply, however)
| 0x121004 (in certain cases this doesn't apply, however)
|-
|-
| 0x086600C0
| 0x086600C0
| [[4.0.0-7]]
| [[4.0.0-7]]
| GetSaveDataSecureValue, this is used with [[Anti Savegame Restore]].
| [[FS:GetSaveDataSecureValue|GetSaveDataSecureValue]]
| 0x121004 (in certain cases this doesn't apply, however)
| 0x121004 (in certain cases this doesn't apply, however)
|-
|-
| 0x086700C4
| 0x086700C4
| [[4.0.0-7]]
| [[4.0.0-7]]
| ControlSecureSave
| [[FS:ControlSecureSave|ControlSecureSave]]
| 0x121004
| 0x121004
|-
|-
| 0x08680000
| 0x08680000
| [[4.0.0-7]]
| [[4.0.0-7]]
| GetMediaType, This loads the u8 mediatype for the current application from already initialized state, this u8 was originally loaded from the same data used by [[FS:GetProgramLaunchInfo|GetProgramLaunchInfo]]. This then writes the u8 to response-word[2]. This is used with [[Anti Savegame Restore]]
| [[FS:GetMediaType|GetMediaType]]
| None
| None
|-
|-
| 0x08690000
| 0x08690000
| [[4.0.0-7]]
| [[4.0.0-7]]
| Obsoleted_4_0_GetNandEraseCount Stubbed, this returns an error.
| [[FS:Obsoleted_4_0_GetNandEraseCount|Obsoleted_4_0_GetNandEraseCount]]
| None
| Stubbed, this returns an error.
|-
|-
| 0x086A0082
| 0x086A0082
| [[4.0.0-7]]
| [[4.0.0-7]]
| ReadNandReport This is a wrapper for [[Filesystem_services_PXI|FSPXI]] command 0x00550082.
| [[FS:ReadNandReport|ReadNandReport]]
| None
| None
|-
|-
| 0x086B00C2
| 0x086B00C2
|?
|?
|?
| [[FS:SetOtherSaveDataSecureValue|SetOtherSaveDataSecureValue]]
| 00121004
| 0x121004
|-
|-
| 0x086C00C2
| 0x086C00C2
|?
|?
|?
| [[FS:GetOtherSaveDataSecureValue|GetOtherSaveDataSecureValue]]
| 00121004
| 0x121004
|-
|-
| 0x086D0040
| 0x086D0080
|?
|?
|?
| [[FS:BeginSaveDataMove|BeginSaveDataMove]]
| 00020004
| 0x20004
|-
|-
| 0x086E00C0
| 0x086E00C0
|?
|?
|?
| [[FS:SetThisSaveDataSecureValue|SetThisSaveDataSecureValue]]
|None?
|None
|-
|-
| 0x086F0040
| 0x086F0040
|?
|?
|?
| [[FS:GetThisSaveDataSecureValue|GetThisSaveDataSecureValue]]
| 0xE
| None
|-
|-
| 0x087000C2
| 0x087000C2
|?
|?
|?
| [[FS:CheckArchive|CheckArchive]]
|None?
|None
|-
|-
| 0x08710100
| 0x08710140
|?
| ?
|?
| [[FS:TransferSaveDataCMAC|TransferSaveDataCMAC]]
| 0xC
| 0x20004
|-
|-
| 0x087201C0
| 0x08720200
|?
|?
|?
| [[FS:RegisterTitleContentOverlay|RegisterTitleContentOverlay]]
| 00080004
| 0x80004
|-
|-
| 0x087300C0
| 0x08730100
|?
|?
|?
| [[FS:UnregisterTitleContentOverlay|UnregisterTitleContentOverlay]]
| 00080004
| 0x80004
|-
|-
| 0x08740000
| 0x08740000
|?
|?
|?
| [[FS:UnregisterAllTitleContentOverlays|UnregisterAllTitleContentOverlays]]
| 00080004
| 0x80004
|-
|-
| 0x08750140
| 0x08750140
|?
|?
|?
| [[FS:SetSaveArchiveSecureValue|SetSaveArchiveSecureValue]]
|None?
|None
|-
|-
| 0x087600C0
| 0x087600C0
|?
|?
| [[FS:GetSaveArchiveSecureValue|GetSaveArchiveSecureValue]]
|None
|-
| 0x08770140
|?
|?
|None?
| [[FS:RegisterSpecialTitleContent|RegisterSpecialTitleContent]]
| 0x80004
|-
|-
| 0x08770100
| 0x08780100
|?
|?
|?
|?
| [[FS:UnregisterSpecialTitleContent|UnregisterSpecialTitleContent]]
| 0x80004
|-
| 0x087900C2
| ?
| Same as [[FS:GetLegacyBannerData|GetLegacyBannerData]], except for the last parameter this internally passes u8 value 0x1 instead of 0x0, for the FSPXI command.
| 0x101015
|-
| 0x087A0180
| [[9.6.0-24|9.6.0-X]]
| [[FS:AddSeed|AddSeed]]
| 0x200000
|-
| 0x087B0080
| [[9.6.0-24|9.6.0-X]]
| [[FS:GetSeed|GetSeed]]
| 0x200000
|-
| 0x087C0080
| [[9.6.0-24|9.6.0-X]]
| [[FS:DeleteSeed|DeleteSeed]]
| 0x200000
|-
| 0x087D0000
| [[9.6.0-24|9.6.0-X]]
| [[FS:GetNumSeeds|GetNumSeeds]]
| 0x200000
|-
| 0x087E0042
| [[9.6.0-24|9.6.0-X]]
| [[FS:ListSeeds|ListSeeds]]
| 0x200000
|-
| 0x087F0100
| [[9.6.0-24|9.6.0-X]]
| [[FS:TitleContentHasSeed|TitleContentHasSeed]]
| 0x200000
|-
| 0x08800880
| [[9.6.0-24|9.6.0-X]]
| [[FS:AddTitleTag|AddTitleTag]]
| 0x200000
|-
| 0x08810080
| [[9.6.0-24|9.6.0-X]]
| [[FS:GetTitleTag|GetTitleTag]]
| 0x200000
|-
| 0x08820080
| [[9.6.0-24|9.6.0-X]]
| [[FS:DeleteTitleTag|DeleteTitleTag]]
| 0x200000
|-
| 0x08830000
| [[9.6.0-24|9.6.0-X]]
| [[FS:GetNumTitleTags|GetNumTitleTags]]
| 0x200000
|-
| 0x08840042
| [[9.6.0-24|9.6.0-X]]
| [[FS:ListTitleTags|ListTitleTags]]
| 0x200000
|-
| 0x088500C0
| [[9.6.0-24|9.6.0-X]]
| [[FS:CheckTitleSeed|CheckTitleSeed]]
| 0x200000
|-
|-
| 0x087800C0
| 0x088600C0
|?
| [[11.1.0-34|11.1.0-X]]
|?
| [[FS:CheckUpdatedDat|CheckUpdatedDat]]
|?
| 0x80000
|}
|}


Line 628: Line 698:
Each session for fs:USER has separate permissions, initially these are set to all zero's for new fs:USER sessions. The permissions/etc for fs:USER sessions are initialized via [[FS:Initialize]](loaded from the user process exheader).
Each session for fs:USER has separate permissions, initially these are set to all zero's for new fs:USER sessions. The permissions/etc for fs:USER sessions are initialized via [[FS:Initialize]](loaded from the user process exheader).


=File service=
{{Anchor|FSLDR}}{{Anchor|fs:LDR}}
 
== Filesystem service "fs:LDR" ==
This service is identical to fs:USER, except [[FS:OpenArchive]] archive 0x2345678E can only be accessed with fs:LDR.
 
{{Anchor|FSReg}}{{Anchor|FSREG}}{{Anchor|fs:REG}}
== ProgramRegistry service "fs:REG" ==
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
Line 635: Line 711:
|-
|-
| 0x000100C6
| 0x000100C6
| Dummy1
| [[FSReg:Dummy1|Dummy1]]
|-
| 0x040103C0
| [[FSReg:Register|Register]]
|-
| 0x04020040
| [[FSReg:Unregister|Unregister]]
|-
| 0x040300C0
| [[FSReg:GetProgramInfo|GetProgramInfo]]
|-
| 0x04040100
| [[FSReg:LoadProgram|LoadProgram]]
|-
| 0x04050080
| [[FSReg:UnloadProgram|UnloadProgram]]
|-
| 0x04060080
| [[FSReg:CheckHostLoadId|CheckHostLoadId]]
|}
 
Only two sessions can be opened for this service at a time, hence no other processes can use this due to [[Process_Manager_Services|pm-module]] and [[Loader_Services|loader]] using this.
 
=File and directory access=
==Files==
File session handles obtained via [[FS:OpenFile]] and [[FS:OpenFileDirectly]] can be used to access files through a service-like interface, despite not being an actual service registered using [[SRV:RegisterService]]. To use this service-like interface, simply call the SendSyncRequest SVC with a file session handle, using the IPC buffer in thread-local storage for parameters and responses, just like you would with a proper service.
 
{| class="wikitable" border="1"
|-
!  Command Header
!  Description
|-
| 0x000100C6
| [[FSFile:Dummy1|Dummy1]]
|-
|-
| 0x040100C4
| 0x040100C4
| Control
| [[FSFile:Control|Control]]
|-
|-
| 0x08010100
| 0x08010100
| OpenSubFile
| [[FSFile:OpenSubFile|OpenSubFile]]
|-
|-
| 0x080200C2
| 0x080200C2
Line 656: Line 765:
|-
|-
| 0x08060000
| 0x08060000
| GetAttributes
| [[FSFile:GetAttributes|GetAttributes]]
|-
|-
| 0x08070040
| 0x08070040
| SetAttributes
| [[FSFile:SetAttributes|SetAttributes]]
|-
|-
| 0x08080000
| 0x08080000
Line 665: Line 774:
|-
|-
| 0x08090000
| 0x08090000
| Flush
| [[FSFile:Flush|Flush]]
|-
|-
| 0x080A0040
| 0x080A0040
| SetPriority
| [[FSFile:SetPriority|SetPriority]]
|-
|-
| 0x080B0000
| 0x080B0000
| GetPriority
| [[FSFile:GetPriority|GetPriority]]
|-
|-
| 0x080C0000
| 0x080C0000
| OpenLinkFile
| [[FSFile:OpenLinkFile|OpenLinkFile]]
|-
| 0x0C010100
| [[FSFile:GetAvailable|GetAvailable]]
|}
|}


=Directory service=
==Directories==
Directory session handles obtained via [[FS:OpenDirectory]] are usable via a service-like interface, following the exact same procedure described above for file sessions.
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
!  Command Header
!  Command Header
!  Available since system version
!  Description
!  Description
|-
|-
| 0x000100C6
| 0x000100C6
| Dummy1
| [[1.0.0-0]]
| [[FSDir:Dummy1|Dummy1]]
|-
|-
| 0x040100C4
| 0x040100C4
| Control
| [[1.0.0-0]]
| [[FSDir:Control|Control]]
|-
|-
| 0x08010042
| 0x08010042
| [[1.0.0-0]]
| [[FSDir:Read|Read]]
| [[FSDir:Read|Read]]
|-
|-
| 0x08020000
| 0x08020000
| [[1.0.0-0]]
| [[FSDir:Close|Close]]
| [[FSDir:Close|Close]]
|-
| 0x08030040
| ?
| [[FSDir:SetPriority|SetPriority]]
|-
| 0x08040000
| ?
| [[FSDir:GetPriority|GetPriority]]
|}
= Archives =
{| class="wikitable" border="1"
|-
!  ArchiveId
!  Description
!  Accessible via [[Filesystem_services|FS]]
!  Accessible via [[Filesystem_services_PXI|FSPXI]]
!  Only accessible by Process9 internally
!  Requires binary [[FS:OpenFile|Lowpath]]
!  Required exheader FS access info bitmask
|-
| 0x00000003
| SelfNCCH (including [[#RomFS|RomFS]])
| Yes
| No
| No
| No
| None
|-
| 0x00000004
| SaveData (the saveID/mediatype for this is loaded from data originally from the user process' exheader)
| Yes
| No
| No
| No
| None
|-
| 0x00000006
| ExtSaveData
| Yes
| No
| No
| Yes
| 0x100D, when the input extdataID isn't listed in the exheader.
|-
| 0x00000007
| Shared ExtSaveData
| Yes
| No
| No
| Yes
| None
|-
| 0x00000008
| SystemSaveData
| Yes
| No
| No
| Yes
| 0x4, when the input saveID doesn't match the exheader system-saveID.
|-
| 0x00000009
| SDMC
| Yes
| Yes
| No
| No
| 0x8E
|-
| 0x0000000A
| SDMC Write-Only
| Yes
| No
| No
| No
| 0x808E
|-
| 0x12345678
| ExtSaveData for BOSS
| Yes
| No
| No
| Yes
| 0x44
|-
| 0x12345679
| CARD SPI FS
| Yes
| Yes
| No
| No
| 0x16
|-
| 0x1234567B
| ExtSaveData, and ExtSaveData for BOSS
| No
| Yes
| No
| Yes
|
|-
| 0x1234567C
| SystemSaveData
| No
| Yes
| No
| Yes
|
|-
| 0x1234567D
| NAND RW
| Yes
| Yes
| No
| No
| 0x800
|-
| 0x1234567E
| NAND RO
| Yes
| Yes
| No
| No
| 0x200
|-
| 0x1234567F
| NAND RO Write FS
| No
| Yes
| No
| No
| ?
|-
| 0x12345680
| Extdata transfer. Used for transferring [[Extdata#NAND_Shared_Extdata|NAND Shared Extdata]] during [[System_Transfer#System_Save_Data_/_Shared_Extdata_Transfer|system tranfers]].
| Yes
| Yes
| No
| Yes
| ?
|-
| 0x12345681
| System Savedata transfer. Used for transferring [[System_SaveData|System Save Data]] during [[System_Transfer#System_Save_Data_/_Shared_Extdata_Transfer|system tranfers]].
| Yes
| Yes
| No
| Yes
| ?
|-
| 0x12345682
| Unknown. There's code for this in spider v9.9, but that code isn't actually used.
| Yes
| No
| No
| Yes
| ?
|-
| 0x2345678A
| Title access. With FS, this allows accessing NCCH/NCSD contents (ExeFS, RomFS, checking if a content uses a seed, checking the validity of the installed seed). FSPXI, additionally, allows opening raw NCCH/NCSD NCCH contents and DSiWare contents for reading, along with encrypted save data.
| Yes
| Yes
| No
| Yes
| 0x1005
|-
| 0x2345678B
| Used internally by Process9 as the lowest level title access archive. Allows for opening various sections of a title (TMD, CMD, raw contents, DLC contents, raw save data (including public/private/banner saves for DSiWare), title and/or content import context files and /data directories for save data.
| No
| No
| Yes
| Yes
|
|-
| 0x2345678C
| Used internally to access [[Title_Database|Title Database (/dbs)]] files. For SD, <code>title.db</code> and <code>import.db</code>. For NAND, <code>title.db</code>, <code>import.db</code>, <code>tmp_t.db</code>, <code>tmp_i.db</code>, and <code>jumpid.db</code>.
| No
| No
| Yes
| Yes
|
|-
| 0x2345678D
| Used internally to access non-title /dbs files on the NAND: <code>certs.db</code> and <code>ticket.db</code>.
| No
| No
| Yes
| No
|
|-
| 0x2345678E
| FSPXI: Program Access (limited subset of merged main title + update/patch title access). For fs:LDR(used by the "loader" FIRM ARM11-process), only <code>exefs:/.code</code>. Not accessible with fs:USER.
| Yes
| Yes
| No
| Yes
| None, see description.
|-
| 0x567890AB
| NAND CTR FS
| No
| Yes
| No
| No
| ?
|-
| 0x567890AC
| TWL PHOTO
| Yes
| Yes
| No
| No
| ?
|-
| 0x567890AD
| TWLS (DSi Sound stores recordings here). This is mapped to the FAT12 image stored in the file at [[Twln/shared2/0000]].
| No
| Yes
| No
| No
| ?
|-
| 0x567890AE
| NAND TWL FS
| Yes
| Yes
| No
| No
| 0x100
|-
| 0x567890AF
| NAND W FS
| Yes
| Yes
| No
| No
| 0x100
|-
| 0x567890B0
| Internally creates the same "ID Storage" wrapper over the NAND that is used for SystemSaveData and Shared ExtData, but all operations are stubbed and return 0xE0C046F8.
| No
| Yes
| No
| No
|
|-
| 0x567890B1
| Gamecard SaveData (for check). This is a wrapper for UserSaveDataForCheck: the OpenArchive code for that is called with archive-lowpath TID=0/mediatype=2(gamecard).
| Yes
| No
| No
| No
| 0x6
|-
| 0x567890B2
| UserSaveData (for check). This is the same as the regular SaveData archive, except with this the savedata ID and mediatype is loaded from the input archive lowpath.
| Yes
| No
| No
| Yes
| 0x6
|-
| 0x567890B3
| [[3DS_Virtual_Console#NAND_Savegame|AGB Save Data]]
| No
| No
| Yes
| No
| -
|-
| 0x567890B4
| Similar to 0x567890B2 but can only access Accessible Save specified in [[NCCH/Extended_Header#Storage_Info|exheader]]?
| Yes
| No
| No
| Yes
| ?
|}
|}


= Filesystem service "fs:LDR" =
Archives listed as not requiring a binary lowpath, use lowpath type [[FS:OpenFile|empty]].
This service is identical to fs:USER, except [[FS:OpenArchive]] archive 0x2345678E can only be accessed with fs:LDR


= ProgramRegistry service "fs:REG" =
The above permission bitmasks are from v2.x, see the above Services section for how these are handled.
 
Archives CTR NAND, NAND RO Write FS, TWL NAND, NAND W FS, and CARD SPI FS require the corresponding process exheader access control mount flag to be set, in the exheader for any of the currently running ARM11 processes, for [[Filesystem_services_PXI|FSPXI]]. The access rights checked by [[Filesystem services|FS]] module for archive mounting with fs:USER, are stored in the process' exheader accessinfo.
 
The CARDSPI archive allows access to the gamecard CARD1 raw savedata flash(aka "cardspi:/" in [[FIRM|Process9]]), the file lowpath must be WCHAR "/". The "NAND W FS" archive allows access to the raw NAND image(aka "wnand:/" in Process9), the file lowpath must be WCHAR "/".
 
= Filenames and Paths =
{{Anchor|PathType}}
==PathType==
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
Command Header
Value
!  Description
|-
| -1
| Returned internally by Process9, when errors occur it seems(in particular when no nul-terminator was found in the input path). The data ptr is set to NULL.
|-
| 0x0
| INVALID - Specifies an invalid path
|-
| 0x1
| EMPTY - Specifies an empty path
|-
| 0x2
| BINARY - Non-text based path. Meaning is per-archive
|-
| 0x3
| ASCII - Text-based path with 7-bit ASCII characters padded to 8-bits each (signed char)
|-
| 0x4
| UTF16 - Text-based path with UTF-16 characters
|}
 
In IPC requests, sizes of ASCII and UTF16 paths must include space for the null-terminator.
 
== Binary LowPath ==
The format of the data that a binary LowPath points to is custom per archive.
 
=== SystemSaveData / Extdata / Shared Extdata Archive Path Data Format ===
 
==== DataAccessPath ====
 
{| class="wikitable" border="1"
|-
!  Offset !! Size !! Description
|-
| 0x0 || 0x1 || u8 [[Mediatypes|Mediatype]]
|-
| 0x1 || 0x1 || only for NAND data (System Savedata / Shared Extdata), otherwise left 0:
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || Accesses from/to <code>nand:/data/<ID0 of current system></code>
|-
| 1 || Accesses from/to <code>nand:/fixdata</code>
|-
| 2 || Accesses from/to <code>nand:/data/<ID0 from [[Filesystem_services#DeviceMoveContext|Device Move Context]]></code>
|}
|-
| 0x2 || 0x2 || padding
|}
 
==== SystemSaveData ====
 
===== FS =====
 
====== Archive Path ======
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| [[Filesystem_services#DataAccessPath|DataAccessPath]]
|-
| 1
| save ID low (save ID high is 0)
|}
 
====== File Path ======
The file path is a cleartext ASCII or UTF16 file path (<code><file path></code>).
 
The file path would access the file at <code><base path>/sysdata/<save ID low>/<save ID high>/<file path></code>.
Note that <code>/<file path></code> refers to the virtual file system inside the </code><save ID high></code> file.
 
===== FSPXI / FS System Savedata Transfer / FSPXI System Savedata Transfer =====
 
====== Archive Path ======
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| [[Filesystem_services#DataAccessPath|DataAccessPath]]
|}
 
====== File Path ======
{| class="wikitable" border="1"
|-
! Index word !! Description
|-
| 0 || save ID low
|-
| 1 || save ID high
|}
 
The file path would access the file at <code><base path>/sysdata/<save ID low>/<save ID high></code>.
 
==== Extdata / Shared Extdata ====
 
===== FS / FS Extdata Transfer / FSPXI Extdata Transfer =====
 
====== Archive Path ======
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| [[Filesystem_services#DataAccessPath|DataAccessPath]]
|-
| 1
| ext save ID low
|-
| 2
| ext save ID high
|}
 
This refers to the extdata filesystem structure's base directory at <code><base path>/extdata/<ext save ID low>/<ext save ID high></code>.
 
====== File Path ======
The file path is a cleartext ASCII or UTF16 file path (<code><file path></code>).
 
For FS Extdata, this would acccess <code><base path>/extdata/<save ID low>/<save ID high>/<directory ID>/<file ID>/<file path></code>, and <code>/<file path></code> refers to the virtual file system inside the </code><file ID></code> file.
 
For FS / FSPXI Extdata Transfer, this accesses <code><base path>/extdata/<save ID low>/<save ID high>/<file path></code>.
 
=== UserSaveDataForCheck Archive Path Data Format ===
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| [[Mediatypes|Mediatype]] (must be non-zero)
|-
| 1
| Lower word saveid
|-
| 2
| Upper word saveid
|}
 
The file/directory lowpath for this FS archive is a text path in the [[Savegames|savegame]] filesystem.
 
=== 0x567890B4 Archive Path Data Format ===
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| [[Mediatypes|Mediatype]]
|-
| 1
| <code><nowiki>Lower_word_saveid >> 8</nowiki></code> ?
|-
| 2
| Unknown. Game calculate this using formula <code><nowiki>0xFFFFFF00 | unknown_b</nowiki></code>
|}
 
=== Title Access Archive Path Data Format ===
==== Title Access Type ====
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || High-level NCCH content access
|-
| 1 || Save data access (high-level, decrypted)
|-
| 2 || Raw content (low-level NCCH/SRL) access
|-
| 3 || Banner save data access (for DSiWare titles)
|-
| 4 || FS only: Save data transfer (internally uses generated data from [[FS:BeginSaveDataMove]] as the IV for "Save data access (low-level, encrypted)")
|-
| 5 || Save data access (low-level, encrypted)
|}
 
==== NCCH Access Type ====
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || RomFS
|-
| 1 || <code>exefs:/.code</code>
|-
| 2 || System Menu Data (<code>exefs:/icon</code>, <code>exefs:/banner</code>, <code>exefs:/logo</code>)
|-
| 3 || NCCH Header(s)
|-
| 4 || "is seeded" check
|-
| 5 || Seed verify/validate
|}
 
==== NCCH Header Access Type ====
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || [[NCCH/Extended_Header|Extheader]] (0x0-0x400)
|-
| 1 || [[NCCH/Extended_Header|Extheader]] AccessDesc (0x400-0x800)
|-
| 2 || Raw [[NCCH#NCCH_Header|NCCH Header]]
|}
 
==== Archive Path ====
 
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x8 || Program ID (Title ID)
|-
| 0x9 || 0x1 || [[Mediatypes|Media Type]]
|-
| 0xA || 0x7 || padding
|}
 
==== File Path ====
 
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || [[Filesystem_services#Title_Access_Type|Title Access Type]]
|-
| 0x4 || 0x10 || Dynamic data depending on [[Filesystem_services#Title_Access_Type|Title Access Type]]:
 
{| class="wikitable" border="1"
|-
! High Level NCCH Access !! Save Data Access (high level) !! Raw Content !! FS only: Save Data Transfer
|-
|
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || Content index from TMD for NAND/SD titles
NCSD partition index for gamecards
|-
| 0x4 || 0x4 || [[Filesystem_services#NCCH_Access_Type|NCCH Access Type]]
|-
| 0x8 || 0x8 || Dynamic data depending on [[Filesystem_services#NCCH_Access_Type|NCCH Access Type]]:
For ExeFS, (System Menu Data / <code>exefs:/.code</code>),
 
{| class="wikitable" border="1"
| 8-byte ExeFS file name
|}
 
For Header Access,
 
{| class="wikitable" border="1"
| [[Filesystem_services#NCCH_Header_Access_Type|u64, NCCH Header Access Type]]
|}
 
For RomFS,
 
{| class="wikitable" border="1"
| [[NCCH#Content_Types|u64, Allowed content types flag]]
(<code>(1 << allowed_type_a) |
 
(1 << allowed_type_b)...</code>)
|}
 
|}
|
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x10 || 16-byte IV for save data crypto
|}
|
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || Content index from TMD for NAND/SD titles
NCSD partition index for gamecards
|-
| 0x4 || 0xC || padding
|}
|
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || Save data transfer key from [[FS:BeginSaveDataMove]]
|-
| 0x4 || 0xC || padding
|}
|}
|-
| 0x14 || 0x10 || 16-byte seed for titles that require one, or for validating a seed against the check value in the [[NCCH#NCCH_Header|NCCH Header]]'s check value.
If the title does not use a seed, this should not be included and size 0x14 should be used instead of 0x24.
|}
 
For encrypted save data access and banner save data access, the entire 0x10 portion of the dynamic data is left blank.
 
The "is seeded check" NCCH access type opens a virtual 1-byte file that reads either 0 or 1; this value is generated on-the-fly and will be 1 if ncchflags[7] has bit5 set (content uses seed), and 0 otherwise.
 
For NCCH sections that require a seed (e.g. <code>.code</code>, RomFS, etc.), the additional seed portion of the low path must be populated with the correct seed.
 
The "Seed Verify/Validate" NCCH access type also requires the seed portion of the lowpath. The target NCCH content is opened (with the opened file interface being stubbed, meaning no real reads/writes can be performed on it), and the given seed is used to calculate the seed check hash, and part of it is compared to the check value in the NCCH header. If it matches, opening the "file" succeeds, otherwise 0xD900458C is returned. If attempt is made to use the seed validation type on a content that does not use a seed, error 0xC92044E6 is returned.
 
==== FS Limitations ====
 
For FS, this archive functions the same, except for the following limitations:
 
- Only the title access types "High Level NCCH Access" and "High Level Save Data Access", and "Save Data Transfer" are allowed.
 
- For high level NCCH access, the types "RomFS", "System Menu Data", "Seeded check", and "Seed Check/Verify" are allowed.
 
- For "Seed Check/Verify", rather than providing the title seed in the file path (as is the case for FSPXI), the seed is retrieved from the seed database (meaning the file lowpath size is always 0x14 for FS).
 
=== Program Access / SelfNCCH access ===
 
Provides access to a "merged" archive of a base title and, optionally, a separate update (patch) title.
 
If no patch title exists, the base title is considered to be the patch title, i.e. turning all "patch" accesses into accesses to the base title.
 
==== Program Access Type ====
{| class="wikitable" border="1"
|-
! Value !! Description !! Accesses
|-
| 0 || RomFS ("unspecified" [[NCCH#Content_Type|content type]], the default) || Base title
|-
| 1 || <code>exefs:/.code</code> || Patch title
|-
| 2 || System Menu Data (<code>exefs:/icon</code>, <code>exefs:/banner</code>, <code>exefs:/logo</code>) || Base title
|-
| 3 || Save Data (high level, decrypted) || -
|-
| 4 || RomFS (all [[NCCH#Content_Type|content types]]) || Base title
|-
| 5 || RomFS ("unspecified" [[NCCH#Content_Type|content type]], the default) || Patch title
|}
 
==== Archive Path ====
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x8 || u64, Program Handle from [[PXIPM:RegisterProgram]]
|}
 
==== File Path ====
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || [[Filesystem_services#Program_Access_Type|Program Access Type]]
|-
| 0x4 || 0x8 || Dynamic data depending on [[Filesystem_services#Program_Access_Type|Program Access Type]]:
{| class="wikitable" border="1"
|-
! ExeFS files (System Menu Data, etc.) !! RomFS of base title (all [[NCCH#Content_Type|content types]])
|-
|
{| class="wikitable" border="1"
| 8-character ExeFS filename
|}
|
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || u32, content index of target content
|-
| 0x4 || 0x4 || padding
|}
|}
|}
 
==== FS Limitations ====
 
- FSPXI allows all access types.
 
- When used through fs:LDR by loader, FS only provides access to <code>exefs:/.code</code>.
 
- For SelfNCCH access, the only allowed access types are "RomFS ("unspecified" [[NCCH#Content_Type|content type]], the default)" of the Base or Patch title, and "System Menu Data". Attempting to access "Save Data" results in error 0xE0E046BE, "RomFS (all [[NCCH#Content_Type|content types]])" in 0xF9604784, and "<code>exefs:/.code</code>" in 0xD9004676.
 
=== [[RomFS]] ===
 
Archives 0x3 and 0x2345678E both allow for accessing the [[RomFS#Level_3_Format|level-3 IVFC images]] for RomFS access. The main CXI RomFS is accessible via an all-zero 0xc-byte binary file-lowpath. The update RomFS can be accessed with the first u32 in the binary file-lowpath being set to 0x5. The user must handle parsing the filesystem used in the exposed image itself.
 
With FSPXI the returned data for RomFS is the entire RomFS section from the NCCH, starting at the IVFC header.
 
The 0x3 archive is an interface for the 0x2345678E archive with the current process programID+mediatype. The file lowpath is 3-words. These words are written to 0x2345678E-archive file_lowpath+0, with the rest of that lowpath set to all-zero(lowpath is different from archive 0x2345678A). File lowpath:
{| class="wikitable" border="1"
|-
!  Index word
!  Description
|-
| 0
| See above. The only values which FS-module doesn't allow to be used here are:
* 0x1: Error 0xE0E046BE.
* 0x3: Error 0xE0E046BE.
* 0x4: FS-module executes svcBreak when using this.
|-
| 1-2
| See above. Not validated by FS-module.
|}
 
=Anti Savegame Restore=
Anti Savegame Restore, internally referred to as ''Save Data Rollback Prevention'', is a feature originally implemented in the FS module with [[4.0.0-7]], which prevents the user from restoring previous versions of a savegame image. This feature is not used (in practice) for gamecard games. When an old version of the save is detected, the application will display an error regarding old savegame version, then delete and recreate the save data (similar to when it is corrupted).
 
==Implementation==
When creating the savedata, the application generates a secure value (a 64 bit unsigned integer), then stores it in either the [[DISA_and_DIFF#DISA_header|DISA save image header]] or the [[Filesystem_services#Anti_Savegame_Restore_Save_Data|Anti Savegame Restore Save Data]]. The application then uses the anti-savegame-restore commands ([[FS:SetSaveDataSecureValue]], [[FS:GetSaveDataSecureValue]], [[FS:SetOtherSaveDataSecureValue]], [[FS:GetOtherSaveDataSecureValue]], [[FS:SetThisSaveDataSecureValue]], [[FS:GetThisSaveDataSecureValue]], [[FS:SetSaveArchiveSecureValue]] and [[FS:GetSaveArchiveSecureValue]]) to verify the value known to the game for comparison with the value returned by FS, and to update the value in the corresponding storage location.
 
Each time the application writes to the savegame, the value should be updated by both the application and through FS. Usually, applications update this value by incrementing it. However, generating a new random-number or other methods of updating it can be used as well.
 
==Anti Savegame Restore Save Data==
The save data used for this feature is stored in [[System_SaveData|System Save Data]] ID 0x00010011 and contains only one file, named <code>DB</code>:
 
===Main Structure===
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1000 || Header
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1 || u8, version (usually 0)
|-
| 0x1 || 0x3 || padding
|-
| 0x4 || 0x4 || u32, number of secure value entries
|-
| 0x8 || 0xFF8 || completely unused, padding
|}
|-
| 0x1000 || 0x1C000 (8 * 14336) || [[Filesystem_services#SecureValueKey|Secure value keys]]
|-
| 0x1D000 || 0x1C000 (8 * 14336) || u64s, Secure values
|}
 
===SecureValueKey===
Depending on which command is used, secure value keys can be interpreted as:
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x8 || u64, Title ID
|}
or:
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || u32, [[Filesystem_services#SecureValueSlot|Secure Value Slot]]
|-
| 0x4 || 0x4 || u32, Unique ID
|}
 
==Applications using this feature==
* Animal Crossing: New Leaf
* Pokemon X & Y
* Pokemon Omega Ruby & Alpha Sapphire
* Pokemon Omega Ruby & Alpha Sapphire Demo
* Pokemon Shuffle
* Super Smash Bros
* Pokemon Red,Blue and Yellow (GB(C) VC)
* Rusty's Real Deal Baseball
* Megami Meguri
 
=SEEDDB and TITLETAG=
With [[9.6.0-24|9.6.0-X]] new [[System_SaveData]] with save ID 0x0001000F was added. This save data contains both the NCCH seed database (SEEDDB) and the title tag database (TITLETAG).
 
These databases are managed by the commands [[FS:AddSeed]], [[FS:GetSeed]], [[FS:DeleteSeed]], [[FS:GetNumSeeds]] and [[FS:ListSeeds]] for SEEDDB, and [[FS:AddTitleTag]], [[FS:GetTitleTag]], [[FS:DeleteTitleTag]], [[FS:GetNumTitleTags]], and [[FS:ListTitleTags]] for TITLETAG respectively.
 
Both the [[Home_Menu|HOME Menu]] and the [[NIM_Services|NIM]] module have access to these commands.
 
==SEEDDB==
 
Stored in the system savedata archive 0x0001000F as a file named <code>SEEDDB</code>, it contains the title-unique seed-data used for the new [[NCCH]] keyY generation added with FIRM [[9.6.0-24|9.6.0-X]].
 
The file follows a simple key-value format allowing the storage of seed data for up to 2000 unique title IDs.
 
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1000 || Header
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1 || u8, version (usually 0)
|-
| 0x1 || 0x3 || padding
|-
| 0x4 || 0x4 || u32, number of seed entries
|-
| 0x8 || 0xFF8 || completely unused, padding
|}
|-
| 0x1000 || 0x3E80 (8 * 2000) || u64s, Title IDs
|-
| 0x4E80 || 0x7D00 (16 * 2000) || Seed data, 16 bytes per seed
|}
 
==TITLETAG Database==
 
Stored in the system savedata archive 0x0001000F as a file named <code>TITLETAG</code>, it contains information used by the [[Home_Menu|HOME Menu]] to handle cases when a to-be-released title has been purchased already, that is, to properly install the seed required for [[NCCH]] keyY generation added with FIRM [[9.6.0-24|9.6.0-X]].
 
When a to-be-released title is purchased, the [[NIM_Services|NIM]] module installs a [[Filesystem_services#TitleTag|title tag]] with enough information about the title for the [[Home_Menu|HOME Menu]] to be able to initiate a seed import once the title has been released (and thus, the title's NCCH content lock seed). Until the title's seed is released, and while the title tag remains in the database, the HOME Menu will prevent the user from launching the software as it would not run without the seed. Once released, information from the title tag is used to download the seed, and, if successful, the title tag is removed from the database, making the software playable.
 
The file follows a simple key-value format allowing the storage of title tag data for up to 2000 unique title IDs.
 
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1000 || Header
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x1 || u8, version (usually 0)
|-
| 0x1 || 0x3 || padding
|-
| 0x4 || 0x4 || u32, number of entries
|-
| 0x8 || 0xFF8 || completely unused, padding
|}
|-
| 0x1000 || 0x3E80 (8 * 2000) || u64s, Title IDs
|-
| 0x4E80 || 0x3E800 (0x80 * 2000) || [[Filesystem_services#TitleTag|Title Tag]] data, 0x80 bytes per entry
|}
 
= Common Types =
== MediaType ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0
| NAND
|-
| 1
| SD
|-
| 2
| Game Card
|}
 
== SystemMediaType ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0
| CTR NAND
|-
| 1
| TWL NAND
|-
| 2
| SD
|-
| 3
| TWL Photo
|}
 
== OpenFlags ==
{| class="wikitable" border="1"
|-
!  Bit
!  Description
|-
| 0
| Read
|-
| 1
| Write
|-
| 2
| Create
|}
 
== Attributes ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x1
| Is Directory
|-
| 0x1
| 0x1
| Is Hidden
|-
| 0x2
| 0x1
| Is Archive
|-
| 0x3
| 0x1
| Is Read-Only
|}
 
== WriteOption ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x1
| Flush
|-
| 0x1
| 0x1
| Update Time Stamp
|-
| 0x2
| 0x1
| Reserved
|-
| 0x3
| 0x1
| Reserved
|}
 
== DirectoryEntry ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x20C
| UTF-16 Entry Name
|-
| 0x20C
| 0xA
| 8.3 short filename name
|-
| 0x216
| 0x4
| 8.3 short filename extension
|-
| 0x21A
| 0x1
| Always 1
|-
| 0x21B
| 0x1
| Reserved
|-
| 0x21C
| 0x4
| [[Filesystem_services#Attributes|Attributes]]
|-
| 0x220
| 0x8
| Entry Size
|}
 
== ArchiveResource ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x4
| Sector byte-size
|-
| 0x4
| 0x4
| Cluster byte-size
|-
| 0x8
| 0x4
| Partition capacity in clusters
|-
| 0xC
| 0x4
| Available free space in clusters
|}
 
== ProgramInfo ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x8
| Program ID
|-
| 0x8
| 0x1
| [[Filesystem_services#MediaType|Media Type]]
|-
| 0x9
| 0x7
| Padding
|}
 
== ProductInfo ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x10
| Product Code
|-
| 0x10
| 0x2
| Company Code
|-
| 0x12
| 0x2
| Remaster Version
|}
 
== IntegrityVerificationSeed ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
|  0x0
|  0x10
|  AES-CBC MAC over a SHA256 hash, which hashes the first 0x110-bytes of the cleartext SEED.
|-
|  0x10
|  0x120
|  The [[nand/private/movable.sed]], encrypted with AES-CBC using the above MAC for the counter.
|}
 
== ExtSaveDataInfo ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x4
| [[Filesystem_services#DataAccessPath|DataAccessPath]]
|-
| 0x4
| 0x8
| Save ID
|-
| 0xC
| 0x4
| Reserved
|}
 
== SystemSaveDataInfo ==
{| class="wikitable" border="1"
|-
!  Offset
!  Size
!  Description
|-
| 0x0
| 0x4
| [[Filesystem_services#DataAccessPath|DataAccessPath]]
|-
| 0x4
| 0x4
| Save ID
|}
 
== SecureValueSlot ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0x1000
| SD Application
|}
 
== SecureValueEntry ==
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || u32, [[Filesystem_services#SecureValueSlot|Secure Value Slot]]
|-
| 0x4 || 0x1 || When used as an input entry:
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || This entry should be removed.
|-
| 1 || This entry should be updated with the given value.
|}
When returned from a command:
{| class="wikitable" border="1"
|-
! Value !! Description
|-
| 0 || No entry with the given slot and title ID was found, or: this entry is unused.
|-
| 1 || The entry with the given slot and title ID was found, or: this entry is used.
|}
|-
| 0x5 || 0x3 || padding
|-
| 0x8 || 0x8 || u64, Secure Value
|}
 
== TitleTag ==
{| class="wikitable" border="1"
|-
! Offset !! Size !! Description
|-
| 0x0 || 0x4 || Magic, <code>PREP</code> (PREPurchase install)
|-
| 0x4 || 0x4 || s32, Release date year
|-
| 0x8 || 0x1 || u8, Release date month
|-
| 0x9 || 0x1 || u8, Release date day
|-
| 0xA || 0x2 || u16, Country code
|-
| 0xC || 0x4 || u32, Seed status (0: not downloaded yet, 1: last download attempt failed, 2: seed installed successfully)
|-
| 0x10 || 0x4 || Result code from last seed installation attempt
|-
| 0x14 || 0x4 || Support error code from last seed installation attempt
|-
| 0x18 || 0x68 || reserved padding (unused)
|}
 
== CardSpiBaudRate ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0x0
| 512KHz
|-
| 0x1
| 1MHz
|-
| 0x2
| 2MHz
|-
| 0x3
| 4MHz
|-
| 0x4
| 8MHz
|-
| 0x5
| 16MHz
|}
 
== CardSpiBusMode ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0x0
| 1-bit
|-
| 0x1
| 4-bit
|}
 
== SpecialContentType ==
{| class="wikitable" border="1"
|-
!  Value
!  Description
!  Description
!  Found in
|-
|-
| 0x000100C6
| 0x1
| Dummy1
| CTR (Old3DS) Update Partition
| Gamecards
|-
| 0x2
| Manual
| Gamecards, Digital titles
|-
|-
| 0x040103C0
| 0x3
| Register
| DLP Child
| Gamecards, Digital titles
|-
|-
| 0x04020040
| 0x4
| Unregister
| KTR (New3DS) Update Partition
| Gamecards
|-
|-
| 0x040300C0
|}
| GetProgramInfo
 
== DeviceMoveContext ==
{| class="wikitable" border="1"
|-
|-
| 0x04040100
!  Offset
| LoadProgram
!  Size
!  Description
|-
|-
| 0x04050080
| 0x0
| UnloadProgram
| 0x10
|  IVs (ID0 of source console)
|-
|-
| 0x04060080
| 0x10
| CheckHostLoadId
| 0x10
|  Encrypt Parameter (used to calculate the IV for encryption)
|}
|}


=Errors=
=Errors=
See [[Filesystem_services_PXI]].
See [[Filesystem_services_PXI]].
[[Category:Services]]

Latest revision as of 03:01, 28 August 2025

Services

Filesystem service "fs:USER"

You can at most have 32 FS archive handles.

Command Header Available since system version Description Required exheader access info bitmask
0x000100C6 ? Dummy1 None
0x040100C4 ? Control None
0x08010002 ? Initialize None
0x080201C2 ? OpenFile None
0x08030204 ? OpenFileDirectly None
0x08040142 ? DeleteFile None
0x08050244 ? RenameFile None
0x08060142 ? DeleteDirectory None
0x08070142 ? DeleteDirectoryRecursively None
0x08080202 ? CreateFile None
0x08090182 ? CreateDirectory None
0x080A0244 ? RenameDirectory None
0x080B0102 ? OpenDirectory None
0x080C00C2 ? OpenArchive Each archive ID code has separate access info bitmasks, if it has any
0x080D0144 ? ControlArchive None
0x080E0080 ? CloseArchive None
0x080F0180 ? Obsoleted_2_0_FormatThisUserSaveData None
0x08100200 ? Obsoleted_3_0_CreateSystemSaveData 0x4, for when the input saveID doesn't match the exheader saveID
0x08110040 ? Obsoleted_3_0_DeleteSystemSaveData 0x1004, for when the input saveID doesn't match the exheader saveID
0x08120080 ? GetFreeBytes None
0x08130000 ? GetCardType 0x1017
0x08140000 ? GetSdmcArchiveResource None
0x08150000 ? GetNandArchiveResource 0x1007
0x08160000 ? GetSdmcFatfsError 0x2
0x08170000 ? IsSdmcDetected None
0x08180000 ? IsSdmcWritable None
0x08190042 ? GetSdmcCid 0x2
0x081A0042 ? GetNandCid 0x2
0x081B0000 ? GetSdmcSpeedInfo 0x2
0x081C0000 ? GetNandSpeedInfo 0x2
0x081D0042 ? GetSdmcLog 0x2
0x081E0042 ? GetNandLog 0x2
0x081F0000 ? ClearSdmcLog 0x2
0x08200000 ? ClearNandLog 0x2
0x08210000 ? CardSlotIsInserted 0x1017
0x08220000 ? CardSlotPowerOn 0x2
0x08230000 ? CardSlotPowerOff 0x2
0x08240000 ? CardSlotGetCardIFPowerStatus 0x2
0x08250040 ? CardNorDirectCommand 0x2
0x08260080 ? CardNorDirectCommandWithAddress 0x2
0x08270082 ? CardNorDirectRead 0x2
0x082800C2 ? CardNorDirectReadWithAddress 0x2
0x08290082 ? CardNorDirectWrite 0x2
0x082A00C2 ? CardNorDirectWriteWithAddress 0x2
0x082B00C2 ? CardNorDirectRead_4xIO 0x2
0x082C0082 ? CardNorDirectCpuWriteWithoutVerify 0x2
0x082D0040 ? CardNorDirectSectorEraseWithoutVerify 0x2
0x082E0040 ? GetProductInfo 0x1005
0x082F0040 ? GetProgramLaunchInfo 0x1005
0x08300182 ? Obsoleted_3_0_CreateExtSaveData 0xC, for when the input extdataID doesn't match the exheader extdataID
0x08310180 ? Obsoleted_3_0_CreateSharedExtSaveData 0x1005
0x08320102 ? Obsoleted_3_0_ReadExtSaveDataIcon 0x100D, for when the input extdataID doesn't match the exheader extdataID
0x08330082 ? Obsoleted_3_0_EnumerateExtSaveData 0x1005
0x08340082 ? Obsoleted_3_0_EnumerateSharedExtSaveData 0x1005
0x08350080 ? Obsoleted_3_0_DeleteExtSaveData 0x100D, for when the input extdataID doesn't match the exheader extdataID
0x08360080 ? Obsoleted_3_0_DeleteSharedExtSaveData 0x1005
0x08370040 ? SetCardSpiBaudRate 0x2
0x08380040 ? SetCardSpiBusMode 0x2
0x08390000 ? SendInitializeInfoTo9 None
0x083A0100 ? GetSpecialContentIndex 0x1005
0x083B00C2 ? GetLegacyRomHeader 0x1015
0x083C00C2 ? GetLegacyBannerData 0x1015
0x083D0100 ? CheckAuthorityToAccessExtSaveData 0x44
0x083E00C2 ? QueryTotalQuotaSize None
0x083F00C0 ? Obsoleted_3_0_GetExtDataBlockSize None
0x08400040 ? AbnegateAccessRight ?
0x08410000 ? DeleteSdmcRoot 0x1005
0x08420040 ? DeleteAllExtSaveDataOnNand 0x1005
0x08430000 ? InitializeCtrFileSystem None
0x08440000 ? CreateSeed 0x2
0x084500C2 ? GetFormatInfo ?
0x08460102 ? GetLegacyRomHeader2 0x1015
0x08470180 ? Obsoleted_2_0_FormatCtrCardUserSaveData 0x6
0x08480042 ? GetSdmcCtrRootPath 0x100D
0x08490040 ? GetArchiveResource ?
0x084A0002 ? ExportIntegrityVerificationSeed 0x4000
0x084B0002 ? ImportIntegrityVerificationSeed 0x4000
0x084C0242 ? FormatSaveData 0x6, in some cases this write isn't needed however
0x084D0102 ? GetLegacySubBannerData 0x1015
0x084E0342 ? UpdateSha256Context 0x5
0x084F0102 ? ReadSpecialFile None
0x08500040 ? GetSpecialFileSize None
0x08510242 3.0.0-5 CreateExtSaveData Shared extdata: 0x101005. Regular extdata in certain cases: 0xC
0x08520100 3.0.0-5 DeleteExtSaveData Shared extdata: 0x101005. Regular extdata in certain cases: 0x10100D
0x08530142 3.0.0-5 ReadExtSaveDataIcon 0x10100D (this doesn't apply in certain cases, however)
0x08540010 3.0.0-5 GetExtDataBlockSize 0x10100D (this doesn't apply in certain cases, however)
0x08550102 3.0.0-5 EnumerateExtSaveData 0x101005
0x08560240 3.0.0-5 CreateSystemSaveData 0x4 (this doesn't apply in certain cases, however)
0x08570080 3.0.0-5 DeleteSystemSaveData 0x1004 (this doesn't apply in certain cases, however)
0x08580000 3.0.0-5 StartDeviceMoveAsSource 0x2004
0x08590200 3.0.0-5 StartDeviceMoveAsDestination 0x2004
0x085A00C0 3.0.0-5 SetArchivePriority None
0x085B0080 3.0.0-5 GetArchivePriority None
0x085C00C0 3.0.0-5 SetCtrCardLatencyParameter 0xE
0x085D01C0 3.0.0-5 SetFsCompatibilityInfo 0x100001
0x085E0040 3.0.0-5 ResetCardCompatibilityParameter 0xE
0x085F0040 3.0.0-5 SwitchCleanupInvalidSaveData 0x12004
0x08600042 3.0.0-5 EnumerateSystemSaveData 0x2004
0x08610042 3.0.0-5 InitializeWithSdkVersion None
0x08620040 3.0.0-5 SetPriority None
0x08630000 3.0.0-5 GetPriority None
0x08640000 3.0.0-5 Obsoleted_4_0_GetNandInfo Stubbed, this returns an error
0x08650140 4.0.0-7 SetSaveDataSecureValue 0x121004 (in certain cases this doesn't apply, however)
0x086600C0 4.0.0-7 GetSaveDataSecureValue 0x121004 (in certain cases this doesn't apply, however)
0x086700C4 4.0.0-7 ControlSecureSave 0x121004
0x08680000 4.0.0-7 GetMediaType None
0x08690000 4.0.0-7 Obsoleted_4_0_GetNandEraseCount Stubbed, this returns an error.
0x086A0082 4.0.0-7 ReadNandReport None
0x086B00C2 ? SetOtherSaveDataSecureValue 0x121004
0x086C00C2 ? GetOtherSaveDataSecureValue 0x121004
0x086D0080 ? BeginSaveDataMove 0x20004
0x086E00C0 ? SetThisSaveDataSecureValue None
0x086F0040 ? GetThisSaveDataSecureValue None
0x087000C2 ? CheckArchive None
0x08710140 ? TransferSaveDataCMAC 0x20004
0x08720200 ? RegisterTitleContentOverlay 0x80004
0x08730100 ? UnregisterTitleContentOverlay 0x80004
0x08740000 ? UnregisterAllTitleContentOverlays 0x80004
0x08750140 ? SetSaveArchiveSecureValue None
0x087600C0 ? GetSaveArchiveSecureValue None
0x08770140 ? RegisterSpecialTitleContent 0x80004
0x08780100 ? UnregisterSpecialTitleContent 0x80004
0x087900C2 ? Same as GetLegacyBannerData, except for the last parameter this internally passes u8 value 0x1 instead of 0x0, for the FSPXI command. 0x101015
0x087A0180 9.6.0-X AddSeed 0x200000
0x087B0080 9.6.0-X GetSeed 0x200000
0x087C0080 9.6.0-X DeleteSeed 0x200000
0x087D0000 9.6.0-X GetNumSeeds 0x200000
0x087E0042 9.6.0-X ListSeeds 0x200000
0x087F0100 9.6.0-X TitleContentHasSeed 0x200000
0x08800880 9.6.0-X AddTitleTag 0x200000
0x08810080 9.6.0-X GetTitleTag 0x200000
0x08820080 9.6.0-X DeleteTitleTag 0x200000
0x08830000 9.6.0-X GetNumTitleTags 0x200000
0x08840042 9.6.0-X ListTitleTags 0x200000
0x088500C0 9.6.0-X CheckTitleSeed 0x200000
0x088600C0 11.1.0-X CheckUpdatedDat 0x80000

Note: The question marks from Dummy1 to GetSpecialFileSize on the "available since system version" field are mainly there because I think that most of these are necessary for the main system to function, so theoretically that would mean that since the creation of the 3DS these were available, or since launch if that makes more sense. But because of the peculiar nature of some of the functions, they will remain question marks until they can be confirmed 100%.

When access rights are required for a command, at least one of the bits in the process access info specified in the above table for the command must be set. Error 0xD9004676 is returned when a process attempts to use a command which it doesn't have access rights for the command. The exheader access info field is all zero's for most applications. Note that the permissions listed in the above table is for system-version v2.x, therefore permission bit(s) added with newer FIRM may be missing from this.

Each session for fs:USER has separate permissions, initially these are set to all zero's for new fs:USER sessions. The permissions/etc for fs:USER sessions are initialized via FS:Initialize(loaded from the user process exheader).

Filesystem service "fs:LDR"

This service is identical to fs:USER, except FS:OpenArchive archive 0x2345678E can only be accessed with fs:LDR.

ProgramRegistry service "fs:REG"

Command Header Description
0x000100C6 Dummy1
0x040103C0 Register
0x04020040 Unregister
0x040300C0 GetProgramInfo
0x04040100 LoadProgram
0x04050080 UnloadProgram
0x04060080 CheckHostLoadId

Only two sessions can be opened for this service at a time, hence no other processes can use this due to pm-module and loader using this.

File and directory access

Files

File session handles obtained via FS:OpenFile and FS:OpenFileDirectly can be used to access files through a service-like interface, despite not being an actual service registered using SRV:RegisterService. To use this service-like interface, simply call the SendSyncRequest SVC with a file session handle, using the IPC buffer in thread-local storage for parameters and responses, just like you would with a proper service.

Command Header Description
0x000100C6 Dummy1
0x040100C4 Control
0x08010100 OpenSubFile
0x080200C2 Read
0x08030102 Write
0x08040000 GetSize
0x08050080 SetSize
0x08060000 GetAttributes
0x08070040 SetAttributes
0x08080000 Close
0x08090000 Flush
0x080A0040 SetPriority
0x080B0000 GetPriority
0x080C0000 OpenLinkFile
0x0C010100 GetAvailable

Directories

Directory session handles obtained via FS:OpenDirectory are usable via a service-like interface, following the exact same procedure described above for file sessions.

Command Header Available since system version Description
0x000100C6 1.0.0-0 Dummy1
0x040100C4 1.0.0-0 Control
0x08010042 1.0.0-0 Read
0x08020000 1.0.0-0 Close
0x08030040 ? SetPriority
0x08040000 ? GetPriority

Archives

ArchiveId Description Accessible via FS Accessible via FSPXI Only accessible by Process9 internally Requires binary Lowpath Required exheader FS access info bitmask
0x00000003 SelfNCCH (including RomFS) Yes No No No None
0x00000004 SaveData (the saveID/mediatype for this is loaded from data originally from the user process' exheader) Yes No No No None
0x00000006 ExtSaveData Yes No No Yes 0x100D, when the input extdataID isn't listed in the exheader.
0x00000007 Shared ExtSaveData Yes No No Yes None
0x00000008 SystemSaveData Yes No No Yes 0x4, when the input saveID doesn't match the exheader system-saveID.
0x00000009 SDMC Yes Yes No No 0x8E
0x0000000A SDMC Write-Only Yes No No No 0x808E
0x12345678 ExtSaveData for BOSS Yes No No Yes 0x44
0x12345679 CARD SPI FS Yes Yes No No 0x16
0x1234567B ExtSaveData, and ExtSaveData for BOSS No Yes No Yes
0x1234567C SystemSaveData No Yes No Yes
0x1234567D NAND RW Yes Yes No No 0x800
0x1234567E NAND RO Yes Yes No No 0x200
0x1234567F NAND RO Write FS No Yes No No ?
0x12345680 Extdata transfer. Used for transferring NAND Shared Extdata during system tranfers. Yes Yes No Yes ?
0x12345681 System Savedata transfer. Used for transferring System Save Data during system tranfers. Yes Yes No Yes ?
0x12345682 Unknown. There's code for this in spider v9.9, but that code isn't actually used. Yes No No Yes ?
0x2345678A Title access. With FS, this allows accessing NCCH/NCSD contents (ExeFS, RomFS, checking if a content uses a seed, checking the validity of the installed seed). FSPXI, additionally, allows opening raw NCCH/NCSD NCCH contents and DSiWare contents for reading, along with encrypted save data. Yes Yes No Yes 0x1005
0x2345678B Used internally by Process9 as the lowest level title access archive. Allows for opening various sections of a title (TMD, CMD, raw contents, DLC contents, raw save data (including public/private/banner saves for DSiWare), title and/or content import context files and /data directories for save data. No No Yes Yes
0x2345678C Used internally to access Title Database (/dbs) files. For SD, title.db and import.db. For NAND, title.db, import.db, tmp_t.db, tmp_i.db, and jumpid.db. No No Yes Yes
0x2345678D Used internally to access non-title /dbs files on the NAND: certs.db and ticket.db. No No Yes No
0x2345678E FSPXI: Program Access (limited subset of merged main title + update/patch title access). For fs:LDR(used by the "loader" FIRM ARM11-process), only exefs:/.code. Not accessible with fs:USER. Yes Yes No Yes None, see description.
0x567890AB NAND CTR FS No Yes No No ?
0x567890AC TWL PHOTO Yes Yes No No ?
0x567890AD TWLS (DSi Sound stores recordings here). This is mapped to the FAT12 image stored in the file at Twln/shared2/0000. No Yes No No ?
0x567890AE NAND TWL FS Yes Yes No No 0x100
0x567890AF NAND W FS Yes Yes No No 0x100
0x567890B0 Internally creates the same "ID Storage" wrapper over the NAND that is used for SystemSaveData and Shared ExtData, but all operations are stubbed and return 0xE0C046F8. No Yes No No
0x567890B1 Gamecard SaveData (for check). This is a wrapper for UserSaveDataForCheck: the OpenArchive code for that is called with archive-lowpath TID=0/mediatype=2(gamecard). Yes No No No 0x6
0x567890B2 UserSaveData (for check). This is the same as the regular SaveData archive, except with this the savedata ID and mediatype is loaded from the input archive lowpath. Yes No No Yes 0x6
0x567890B3 AGB Save Data No No Yes No -
0x567890B4 Similar to 0x567890B2 but can only access Accessible Save specified in exheader? Yes No No Yes ?

Archives listed as not requiring a binary lowpath, use lowpath type empty.

The above permission bitmasks are from v2.x, see the above Services section for how these are handled.

Archives CTR NAND, NAND RO Write FS, TWL NAND, NAND W FS, and CARD SPI FS require the corresponding process exheader access control mount flag to be set, in the exheader for any of the currently running ARM11 processes, for FSPXI. The access rights checked by FS module for archive mounting with fs:USER, are stored in the process' exheader accessinfo.

The CARDSPI archive allows access to the gamecard CARD1 raw savedata flash(aka "cardspi:/" in Process9), the file lowpath must be WCHAR "/". The "NAND W FS" archive allows access to the raw NAND image(aka "wnand:/" in Process9), the file lowpath must be WCHAR "/".

Filenames and Paths

PathType

Value Description
-1 Returned internally by Process9, when errors occur it seems(in particular when no nul-terminator was found in the input path). The data ptr is set to NULL.
0x0 INVALID - Specifies an invalid path
0x1 EMPTY - Specifies an empty path
0x2 BINARY - Non-text based path. Meaning is per-archive
0x3 ASCII - Text-based path with 7-bit ASCII characters padded to 8-bits each (signed char)
0x4 UTF16 - Text-based path with UTF-16 characters

In IPC requests, sizes of ASCII and UTF16 paths must include space for the null-terminator.

Binary LowPath

The format of the data that a binary LowPath points to is custom per archive.

SystemSaveData / Extdata / Shared Extdata Archive Path Data Format

DataAccessPath

Offset Size Description
0x0 0x1 u8 Mediatype
0x1 0x1 only for NAND data (System Savedata / Shared Extdata), otherwise left 0:
Value Description
0 Accesses from/to nand:/data/<ID0 of current system>
1 Accesses from/to nand:/fixdata
2 Accesses from/to nand:/data/<ID0 from Device Move Context>
0x2 0x2 padding

SystemSaveData

FS
Archive Path
Index word Description
0 DataAccessPath
1 save ID low (save ID high is 0)
File Path

The file path is a cleartext ASCII or UTF16 file path (<file path>).

The file path would access the file at <base path>/sysdata/<save ID low>/<save ID high>/<file path>. Note that /<file path> refers to the virtual file system inside the <save ID high> file.

FSPXI / FS System Savedata Transfer / FSPXI System Savedata Transfer
Archive Path
Index word Description
0 DataAccessPath
File Path
Index word Description
0 save ID low
1 save ID high

The file path would access the file at <base path>/sysdata/<save ID low>/<save ID high>.

Extdata / Shared Extdata

FS / FS Extdata Transfer / FSPXI Extdata Transfer
Archive Path
Index word Description
0 DataAccessPath
1 ext save ID low
2 ext save ID high

This refers to the extdata filesystem structure's base directory at <base path>/extdata/<ext save ID low>/<ext save ID high>.

File Path

The file path is a cleartext ASCII or UTF16 file path (<file path>).

For FS Extdata, this would acccess <base path>/extdata/<save ID low>/<save ID high>/<directory ID>/<file ID>/<file path>, and /<file path> refers to the virtual file system inside the <file ID> file.

For FS / FSPXI Extdata Transfer, this accesses <base path>/extdata/<save ID low>/<save ID high>/<file path>.

UserSaveDataForCheck Archive Path Data Format

Index word Description
0 Mediatype (must be non-zero)
1 Lower word saveid
2 Upper word saveid

The file/directory lowpath for this FS archive is a text path in the savegame filesystem.

0x567890B4 Archive Path Data Format

Index word Description
0 Mediatype
1 Lower_word_saveid >> 8 ?
2 Unknown. Game calculate this using formula 0xFFFFFF00 | unknown_b

Title Access Archive Path Data Format

Title Access Type

Value Description
0 High-level NCCH content access
1 Save data access (high-level, decrypted)
2 Raw content (low-level NCCH/SRL) access
3 Banner save data access (for DSiWare titles)
4 FS only: Save data transfer (internally uses generated data from FS:BeginSaveDataMove as the IV for "Save data access (low-level, encrypted)")
5 Save data access (low-level, encrypted)

NCCH Access Type

Value Description
0 RomFS
1 exefs:/.code
2 System Menu Data (exefs:/icon, exefs:/banner, exefs:/logo)
3 NCCH Header(s)
4 "is seeded" check
5 Seed verify/validate

NCCH Header Access Type

Value Description
0 Extheader (0x0-0x400)
1 Extheader AccessDesc (0x400-0x800)
2 Raw NCCH Header

Archive Path

Offset Size Description
0x0 0x8 Program ID (Title ID)
0x9 0x1 Media Type
0xA 0x7 padding

File Path

Offset Size Description
0x0 0x4 Title Access Type
0x4 0x10 Dynamic data depending on Title Access Type:
High Level NCCH Access Save Data Access (high level) Raw Content FS only: Save Data Transfer
Offset Size Description
0x0 0x4 Content index from TMD for NAND/SD titles

NCSD partition index for gamecards

0x4 0x4 NCCH Access Type
0x8 0x8 Dynamic data depending on NCCH Access Type:

For ExeFS, (System Menu Data / exefs:/.code),

8-byte ExeFS file name

For Header Access,

u64, NCCH Header Access Type

For RomFS,

u64, Allowed content types flag

((1 << allowed_type_a) |

(1 << allowed_type_b)...)

Offset Size Description
0x0 0x10 16-byte IV for save data crypto
Offset Size Description
0x0 0x4 Content index from TMD for NAND/SD titles

NCSD partition index for gamecards

0x4 0xC padding
Offset Size Description
0x0 0x4 Save data transfer key from FS:BeginSaveDataMove
0x4 0xC padding
0x14 0x10 16-byte seed for titles that require one, or for validating a seed against the check value in the NCCH Header's check value.

If the title does not use a seed, this should not be included and size 0x14 should be used instead of 0x24.

For encrypted save data access and banner save data access, the entire 0x10 portion of the dynamic data is left blank.

The "is seeded check" NCCH access type opens a virtual 1-byte file that reads either 0 or 1; this value is generated on-the-fly and will be 1 if ncchflags[7] has bit5 set (content uses seed), and 0 otherwise.

For NCCH sections that require a seed (e.g. .code, RomFS, etc.), the additional seed portion of the low path must be populated with the correct seed.

The "Seed Verify/Validate" NCCH access type also requires the seed portion of the lowpath. The target NCCH content is opened (with the opened file interface being stubbed, meaning no real reads/writes can be performed on it), and the given seed is used to calculate the seed check hash, and part of it is compared to the check value in the NCCH header. If it matches, opening the "file" succeeds, otherwise 0xD900458C is returned. If attempt is made to use the seed validation type on a content that does not use a seed, error 0xC92044E6 is returned.

FS Limitations

For FS, this archive functions the same, except for the following limitations:

- Only the title access types "High Level NCCH Access" and "High Level Save Data Access", and "Save Data Transfer" are allowed.

- For high level NCCH access, the types "RomFS", "System Menu Data", "Seeded check", and "Seed Check/Verify" are allowed.

- For "Seed Check/Verify", rather than providing the title seed in the file path (as is the case for FSPXI), the seed is retrieved from the seed database (meaning the file lowpath size is always 0x14 for FS).

Program Access / SelfNCCH access

Provides access to a "merged" archive of a base title and, optionally, a separate update (patch) title.

If no patch title exists, the base title is considered to be the patch title, i.e. turning all "patch" accesses into accesses to the base title.

Program Access Type

Value Description Accesses
0 RomFS ("unspecified" content type, the default) Base title
1 exefs:/.code Patch title
2 System Menu Data (exefs:/icon, exefs:/banner, exefs:/logo) Base title
3 Save Data (high level, decrypted) -
4 RomFS (all content types) Base title
5 RomFS ("unspecified" content type, the default) Patch title

Archive Path

Offset Size Description
0x0 0x8 u64, Program Handle from PXIPM:RegisterProgram

File Path

Offset Size Description
0x0 0x4 Program Access Type
0x4 0x8 Dynamic data depending on Program Access Type:
ExeFS files (System Menu Data, etc.) RomFS of base title (all content types)
8-character ExeFS filename
Offset Size Description
0x0 0x4 u32, content index of target content
0x4 0x4 padding

FS Limitations

- FSPXI allows all access types.

- When used through fs:LDR by loader, FS only provides access to exefs:/.code.

- For SelfNCCH access, the only allowed access types are "RomFS ("unspecified" content type, the default)" of the Base or Patch title, and "System Menu Data". Attempting to access "Save Data" results in error 0xE0E046BE, "RomFS (all content types)" in 0xF9604784, and "exefs:/.code" in 0xD9004676.

RomFS

Archives 0x3 and 0x2345678E both allow for accessing the level-3 IVFC images for RomFS access. The main CXI RomFS is accessible via an all-zero 0xc-byte binary file-lowpath. The update RomFS can be accessed with the first u32 in the binary file-lowpath being set to 0x5. The user must handle parsing the filesystem used in the exposed image itself.

With FSPXI the returned data for RomFS is the entire RomFS section from the NCCH, starting at the IVFC header.

The 0x3 archive is an interface for the 0x2345678E archive with the current process programID+mediatype. The file lowpath is 3-words. These words are written to 0x2345678E-archive file_lowpath+0, with the rest of that lowpath set to all-zero(lowpath is different from archive 0x2345678A). File lowpath:

Index word Description
0 See above. The only values which FS-module doesn't allow to be used here are:
  • 0x1: Error 0xE0E046BE.
  • 0x3: Error 0xE0E046BE.
  • 0x4: FS-module executes svcBreak when using this.
1-2 See above. Not validated by FS-module.

Anti Savegame Restore

Anti Savegame Restore, internally referred to as Save Data Rollback Prevention, is a feature originally implemented in the FS module with 4.0.0-7, which prevents the user from restoring previous versions of a savegame image. This feature is not used (in practice) for gamecard games. When an old version of the save is detected, the application will display an error regarding old savegame version, then delete and recreate the save data (similar to when it is corrupted).

Implementation

When creating the savedata, the application generates a secure value (a 64 bit unsigned integer), then stores it in either the DISA save image header or the Anti Savegame Restore Save Data. The application then uses the anti-savegame-restore commands (FS:SetSaveDataSecureValue, FS:GetSaveDataSecureValue, FS:SetOtherSaveDataSecureValue, FS:GetOtherSaveDataSecureValue, FS:SetThisSaveDataSecureValue, FS:GetThisSaveDataSecureValue, FS:SetSaveArchiveSecureValue and FS:GetSaveArchiveSecureValue) to verify the value known to the game for comparison with the value returned by FS, and to update the value in the corresponding storage location.

Each time the application writes to the savegame, the value should be updated by both the application and through FS. Usually, applications update this value by incrementing it. However, generating a new random-number or other methods of updating it can be used as well.

Anti Savegame Restore Save Data

The save data used for this feature is stored in System Save Data ID 0x00010011 and contains only one file, named DB:

Main Structure

Offset Size Description
0x0 0x1000 Header
Offset Size Description
0x0 0x1 u8, version (usually 0)
0x1 0x3 padding
0x4 0x4 u32, number of secure value entries
0x8 0xFF8 completely unused, padding
0x1000 0x1C000 (8 * 14336) Secure value keys
0x1D000 0x1C000 (8 * 14336) u64s, Secure values

SecureValueKey

Depending on which command is used, secure value keys can be interpreted as:

Offset Size Description
0x0 0x8 u64, Title ID

or:

Offset Size Description
0x0 0x4 u32, Secure Value Slot
0x4 0x4 u32, Unique ID

Applications using this feature

  • Animal Crossing: New Leaf
  • Pokemon X & Y
  • Pokemon Omega Ruby & Alpha Sapphire
  • Pokemon Omega Ruby & Alpha Sapphire Demo
  • Pokemon Shuffle
  • Super Smash Bros
  • Pokemon Red,Blue and Yellow (GB(C) VC)
  • Rusty's Real Deal Baseball
  • Megami Meguri

SEEDDB and TITLETAG

With 9.6.0-X new System_SaveData with save ID 0x0001000F was added. This save data contains both the NCCH seed database (SEEDDB) and the title tag database (TITLETAG).

These databases are managed by the commands FS:AddSeed, FS:GetSeed, FS:DeleteSeed, FS:GetNumSeeds and FS:ListSeeds for SEEDDB, and FS:AddTitleTag, FS:GetTitleTag, FS:DeleteTitleTag, FS:GetNumTitleTags, and FS:ListTitleTags for TITLETAG respectively.

Both the HOME Menu and the NIM module have access to these commands.

SEEDDB

Stored in the system savedata archive 0x0001000F as a file named SEEDDB, it contains the title-unique seed-data used for the new NCCH keyY generation added with FIRM 9.6.0-X.

The file follows a simple key-value format allowing the storage of seed data for up to 2000 unique title IDs.

Offset Size Description
0x0 0x1000 Header
Offset Size Description
0x0 0x1 u8, version (usually 0)
0x1 0x3 padding
0x4 0x4 u32, number of seed entries
0x8 0xFF8 completely unused, padding
0x1000 0x3E80 (8 * 2000) u64s, Title IDs
0x4E80 0x7D00 (16 * 2000) Seed data, 16 bytes per seed

TITLETAG Database

Stored in the system savedata archive 0x0001000F as a file named TITLETAG, it contains information used by the HOME Menu to handle cases when a to-be-released title has been purchased already, that is, to properly install the seed required for NCCH keyY generation added with FIRM 9.6.0-X.

When a to-be-released title is purchased, the NIM module installs a title tag with enough information about the title for the HOME Menu to be able to initiate a seed import once the title has been released (and thus, the title's NCCH content lock seed). Until the title's seed is released, and while the title tag remains in the database, the HOME Menu will prevent the user from launching the software as it would not run without the seed. Once released, information from the title tag is used to download the seed, and, if successful, the title tag is removed from the database, making the software playable.

The file follows a simple key-value format allowing the storage of title tag data for up to 2000 unique title IDs.

Offset Size Description
0x0 0x1000 Header
Offset Size Description
0x0 0x1 u8, version (usually 0)
0x1 0x3 padding
0x4 0x4 u32, number of entries
0x8 0xFF8 completely unused, padding
0x1000 0x3E80 (8 * 2000) u64s, Title IDs
0x4E80 0x3E800 (0x80 * 2000) Title Tag data, 0x80 bytes per entry

Common Types

MediaType

Value Description
0 NAND
1 SD
2 Game Card

SystemMediaType

Value Description
0 CTR NAND
1 TWL NAND
2 SD
3 TWL Photo

OpenFlags

Bit Description
0 Read
1 Write
2 Create

Attributes

Offset Size Description
0x0 0x1 Is Directory
0x1 0x1 Is Hidden
0x2 0x1 Is Archive
0x3 0x1 Is Read-Only

WriteOption

Offset Size Description
0x0 0x1 Flush
0x1 0x1 Update Time Stamp
0x2 0x1 Reserved
0x3 0x1 Reserved

DirectoryEntry

Offset Size Description
0x0 0x20C UTF-16 Entry Name
0x20C 0xA 8.3 short filename name
0x216 0x4 8.3 short filename extension
0x21A 0x1 Always 1
0x21B 0x1 Reserved
0x21C 0x4 Attributes
0x220 0x8 Entry Size

ArchiveResource

Offset Size Description
0x0 0x4 Sector byte-size
0x4 0x4 Cluster byte-size
0x8 0x4 Partition capacity in clusters
0xC 0x4 Available free space in clusters

ProgramInfo

Offset Size Description
0x0 0x8 Program ID
0x8 0x1 Media Type
0x9 0x7 Padding

ProductInfo

Offset Size Description
0x0 0x10 Product Code
0x10 0x2 Company Code
0x12 0x2 Remaster Version

IntegrityVerificationSeed

Offset Size Description
0x0 0x10 AES-CBC MAC over a SHA256 hash, which hashes the first 0x110-bytes of the cleartext SEED.
0x10 0x120 The nand/private/movable.sed, encrypted with AES-CBC using the above MAC for the counter.

ExtSaveDataInfo

Offset Size Description
0x0 0x4 DataAccessPath
0x4 0x8 Save ID
0xC 0x4 Reserved

SystemSaveDataInfo

Offset Size Description
0x0 0x4 DataAccessPath
0x4 0x4 Save ID

SecureValueSlot

Value Description
0x1000 SD Application

SecureValueEntry

Offset Size Description
0x0 0x4 u32, Secure Value Slot
0x4 0x1 When used as an input entry:
Value Description
0 This entry should be removed.
1 This entry should be updated with the given value.

When returned from a command:

Value Description
0 No entry with the given slot and title ID was found, or: this entry is unused.
1 The entry with the given slot and title ID was found, or: this entry is used.
0x5 0x3 padding
0x8 0x8 u64, Secure Value

TitleTag

Offset Size Description
0x0 0x4 Magic, PREP (PREPurchase install)
0x4 0x4 s32, Release date year
0x8 0x1 u8, Release date month
0x9 0x1 u8, Release date day
0xA 0x2 u16, Country code
0xC 0x4 u32, Seed status (0: not downloaded yet, 1: last download attempt failed, 2: seed installed successfully)
0x10 0x4 Result code from last seed installation attempt
0x14 0x4 Support error code from last seed installation attempt
0x18 0x68 reserved padding (unused)

CardSpiBaudRate

Value Description
0x0 512KHz
0x1 1MHz
0x2 2MHz
0x3 4MHz
0x4 8MHz
0x5 16MHz

CardSpiBusMode

Value Description
0x0 1-bit
0x1 4-bit

SpecialContentType

Value Description Found in
0x1 CTR (Old3DS) Update Partition Gamecards
0x2 Manual Gamecards, Digital titles
0x3 DLP Child Gamecards, Digital titles
0x4 KTR (New3DS) Update Partition Gamecards

DeviceMoveContext

Offset Size Description
0x0 0x10 IVs (ID0 of source console)
0x10 0x10 Encrypt Parameter (used to calculate the IV for encryption)

Errors

See Filesystem_services_PXI.