mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 06:32:27 -07:00 
			
		
		
		
	Add support for cache storage (#936)
* Update LibHac * Run EnsureApplicationCacheStorage when launching a game * Add new FS commands
This commit is contained in:
		| @@ -519,7 +519,7 @@ namespace Ryujinx.HLE.HOS | ||||
|         { | ||||
|             Result result = codeFs.OpenFile(out IFile npdmFile, "/main.npdm", OpenMode.Read); | ||||
|  | ||||
|             if (result == ResultFs.PathNotFound) | ||||
|             if (ResultFs.PathNotFound.Includes(result)) | ||||
|             { | ||||
|                 Logger.PrintWarning(LogClass.Loader, "NPDM file not found, using default values!"); | ||||
|  | ||||
| @@ -691,7 +691,16 @@ namespace Ryujinx.HLE.HOS | ||||
|                     "No control file was found for this game. Using a dummy one instead. This may cause inaccuracies in some games."); | ||||
|             } | ||||
|  | ||||
|             Result rc = EnsureApplicationSaveData(Device.FileSystem.FsClient, out _, titleId, ref control, ref user); | ||||
|             FileSystemClient fs = Device.FileSystem.FsClient; | ||||
|  | ||||
|             Result rc = fs.EnsureApplicationCacheStorage(out _, titleId, ref ControlData.Value); | ||||
|  | ||||
|             if (rc.IsFailure()) | ||||
|             { | ||||
|                 Logger.PrintError(LogClass.Application, $"Error calling EnsureApplicationCacheStorage. Result code {rc.ToStringWithName()}"); | ||||
|             } | ||||
|  | ||||
|             rc = EnsureApplicationSaveData(fs, out _, titleId, ref ControlData.Value, ref user); | ||||
|  | ||||
|             if (rc.IsFailure()) | ||||
|             { | ||||
|   | ||||
| @@ -12,6 +12,17 @@ namespace Ryujinx.HLE.HOS.Services.Fs | ||||
|             _baseOperator = baseOperator; | ||||
|         } | ||||
|  | ||||
|         [Command(0)] | ||||
|         // IsSdCardInserted() -> b8 is_inserted | ||||
|         public ResultCode IsSdCardInserted(ServiceCtx context) | ||||
|         { | ||||
|             Result result = _baseOperator.IsSdCardInserted(out bool isInserted); | ||||
|  | ||||
|             context.ResponseData.Write(isInserted); | ||||
|  | ||||
|             return (ResultCode)result.Value; | ||||
|         } | ||||
|  | ||||
|         [Command(200)] | ||||
|         // IsGameCardInserted() -> b8 is_inserted | ||||
|         public ResultCode IsGameCardInserted(ServiceCtx context) | ||||
|   | ||||
| @@ -448,6 +448,37 @@ namespace Ryujinx.HLE.HOS.Services.Fs | ||||
|             return (ResultCode)result.Value; | ||||
|         } | ||||
|  | ||||
|         [Command(630)] | ||||
|         // SetSdCardAccessibility(u8) | ||||
|         public ResultCode SetSdCardAccessibility(ServiceCtx context) | ||||
|         { | ||||
|             bool isAccessible = context.RequestData.ReadBoolean(); | ||||
|  | ||||
|             return (ResultCode)_baseFileSystemProxy.SetSdCardAccessibility(isAccessible).Value; | ||||
|         } | ||||
|  | ||||
|         [Command(631)] | ||||
|         // IsSdCardAccessible() -> u8 | ||||
|         public ResultCode IsSdCardAccessible(ServiceCtx context) | ||||
|         { | ||||
|             Result result = _baseFileSystemProxy.IsSdCardAccessible(out bool isAccessible); | ||||
|  | ||||
|             context.ResponseData.Write(isAccessible); | ||||
|  | ||||
|             return (ResultCode)result.Value; | ||||
|         } | ||||
|  | ||||
|         [Command(1004)] | ||||
|         // SetGlobalAccessLogMode(u32 mode) | ||||
|         public ResultCode SetGlobalAccessLogMode(ServiceCtx context) | ||||
|         { | ||||
|             int mode = context.RequestData.ReadInt32(); | ||||
|  | ||||
|             context.Device.System.GlobalAccessLogMode = mode; | ||||
|  | ||||
|             return ResultCode.Success; | ||||
|         } | ||||
|  | ||||
|         [Command(1005)] | ||||
|         // GetGlobalAccessLogMode() -> u32 logMode | ||||
|         public ResultCode GetGlobalAccessLogMode(ServiceCtx context) | ||||
|   | ||||
| @@ -132,7 +132,7 @@ namespace Ryujinx.HLE.HOS.Services.Mii | ||||
|  | ||||
|                 if (result.IsFailure()) | ||||
|                 { | ||||
|                     if (ResultFs.TargetNotFound == result) | ||||
|                     if (ResultFs.TargetNotFound.Includes(result)) | ||||
|                     { | ||||
|                         // TODO: We're currently always specifying the owner ID because FS doesn't have a way of | ||||
|                         // knowing which process called it | ||||
| @@ -212,7 +212,7 @@ namespace Ryujinx.HLE.HOS.Services.Mii | ||||
|  | ||||
|                 return (ResultCode)result.Value; | ||||
|             } | ||||
|             else if (result == ResultFs.PathNotFound) | ||||
|             else if (ResultFs.PathNotFound.Includes(result)) | ||||
|             { | ||||
|                 return (ResultCode)ForceSaveDatabase().Value; | ||||
|             } | ||||
| @@ -224,7 +224,7 @@ namespace Ryujinx.HLE.HOS.Services.Mii | ||||
|         { | ||||
|             Result result = _filesystemClient.CreateFile(DatabasePath, Unsafe.SizeOf<NintendoFigurineDatabase>()); | ||||
|  | ||||
|             if (result.IsSuccess() || result == ResultFs.PathAlreadyExists) | ||||
|             if (result.IsSuccess() || ResultFs.PathAlreadyExists.Includes(result)) | ||||
|             { | ||||
|                 result = _filesystemClient.OpenFile(out FileHandle handle, DatabasePath, OpenMode.Write); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user