mirror of
https://github.com/Thealexbarney/LibHac.git
synced 2024-11-14 10:49:41 +01:00
Write extra data when creating directory save data
This commit is contained in:
parent
7294206116
commit
ccb8c078aa
3 changed files with 65 additions and 14 deletions
18
src/LibHac/Fs/Shim/PosixTime.cs
Normal file
18
src/LibHac/Fs/Shim/PosixTime.cs
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
using LibHac.FsSrv.Sf;
|
||||||
|
|
||||||
|
namespace LibHac.Fs.Shim
|
||||||
|
{
|
||||||
|
public static class PosixTimeShim
|
||||||
|
{
|
||||||
|
public static Result SetCurrentPosixTime(this FileSystemClient fs, Time.PosixTime currentPosixTime,
|
||||||
|
int timeDifferenceSeconds)
|
||||||
|
{
|
||||||
|
using ReferenceCountedDisposable<IFileSystemProxy> fsProxy = fs.Impl.GetFileSystemProxyServiceObject();
|
||||||
|
|
||||||
|
Result rc = fsProxy.Target.SetCurrentPosixTimeWithTimeDifference(currentPosixTime.Value,
|
||||||
|
timeDifferenceSeconds);
|
||||||
|
fs.Impl.AbortIfNeeded(rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -984,7 +984,7 @@ namespace LibHac.FsSrv
|
||||||
Result rc = RemoveSaveIndexerEntry();
|
Result rc = RemoveSaveIndexerEntry();
|
||||||
if (rc.IsFailure()) return rc;
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
return Result.Success;
|
return ResultFs.TargetNotFound.LogConverted(saveFsResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ResultFs.TargetNotFound.Includes(saveFsResult))
|
if (ResultFs.TargetNotFound.Includes(saveFsResult))
|
||||||
|
|
|
@ -134,15 +134,9 @@ namespace LibHac.FsSrv
|
||||||
|
|
||||||
bool allowDirectorySaveData = IsAllowedDirectorySaveData2(spaceId, saveDataRootPath);
|
bool allowDirectorySaveData = IsAllowedDirectorySaveData2(spaceId, saveDataRootPath);
|
||||||
|
|
||||||
if (allowDirectorySaveData)
|
// Note: When directory save data is allowed, Nintendo creates the save directory if it doesn't exist.
|
||||||
{
|
// This bypasses normal save data// creation, leaving the save with empty extra data.
|
||||||
Span<byte> saveDirectoryPath = stackalloc byte[0x12];
|
// Instead, we return that the save doesn't exist if the directory is missing.
|
||||||
var sb = new U8StringBuilder(saveDirectoryPath);
|
|
||||||
sb.Append((byte)'/').AppendFormat(saveDataId, 'x', 16);
|
|
||||||
|
|
||||||
rc = Utility.EnsureDirectory(saveDirectoryFs.Target, new U8Span(saveDirectoryPath));
|
|
||||||
if (rc.IsFailure()) return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Note: Nintendo doesn't cache directory save data
|
// Note: Nintendo doesn't cache directory save data
|
||||||
// if (!allowDirectorySaveData)
|
// if (!allowDirectorySaveData)
|
||||||
|
@ -345,10 +339,10 @@ namespace LibHac.FsSrv
|
||||||
{
|
{
|
||||||
// Use directory save data for now
|
// Use directory save data for now
|
||||||
|
|
||||||
ReferenceCountedDisposable<IFileSystem> fileSystem = null;
|
ReferenceCountedDisposable<IFileSystem> saveDirectoryFs = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Result rc = OpenSaveDataDirectoryFileSystem(out fileSystem, creationInfo.SpaceId, saveDataRootPath,
|
Result rc = OpenSaveDataDirectoryFileSystem(out saveDirectoryFs, creationInfo.SpaceId, saveDataRootPath,
|
||||||
false);
|
false);
|
||||||
if (rc.IsFailure()) return rc;
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
|
@ -358,7 +352,46 @@ namespace LibHac.FsSrv
|
||||||
|
|
||||||
if (_config.IsPseudoSaveData())
|
if (_config.IsPseudoSaveData())
|
||||||
{
|
{
|
||||||
return Utility.EnsureDirectory(fileSystem.Target, new U8Span(saveDataPathBuffer));
|
rc = Utility.EnsureDirectory(saveDirectoryFs.Target, new U8Span(saveDataPathBuffer));
|
||||||
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
|
ReferenceCountedDisposable<IFileSystem> saveFs = null;
|
||||||
|
ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
bool isJournalingSupported = SaveDataProperties.IsJournalingSupported(attribute.Type);
|
||||||
|
|
||||||
|
rc = _config.SaveFsCreator.Create(out saveFs, out extraDataAccessor, _saveDataFsCacheManager,
|
||||||
|
ref saveDirectoryFs, creationInfo.SpaceId, saveDataId, allowDirectorySaveData: true,
|
||||||
|
useDeviceUniqueMac: false, isJournalingSupported, isMultiCommitSupported: false,
|
||||||
|
openReadOnly: false, openShared: false, _timeStampGetter);
|
||||||
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
|
var extraData = new SaveDataExtraData();
|
||||||
|
extraData.Attribute = attribute;
|
||||||
|
extraData.OwnerId = creationInfo.OwnerId;
|
||||||
|
|
||||||
|
rc = GetSaveDataCommitTimeStamp(out extraData.TimeStamp);
|
||||||
|
if (rc.IsFailure())
|
||||||
|
extraData.TimeStamp = 0;
|
||||||
|
|
||||||
|
extraData.CommitId = 0;
|
||||||
|
_config.GenerateRandomData(SpanHelpers.AsByteSpan(ref extraData.CommitId)).IgnoreResult();
|
||||||
|
|
||||||
|
extraData.Flags = creationInfo.Flags;
|
||||||
|
extraData.DataSize = creationInfo.Size;
|
||||||
|
extraData.JournalSize = creationInfo.JournalSize;
|
||||||
|
|
||||||
|
rc = extraDataAccessor.Target.WriteExtraData(in extraData);
|
||||||
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
|
return extraDataAccessor.Target.CommitExtraData(true);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
saveFs?.Dispose();
|
||||||
|
extraDataAccessor?.Dispose();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -367,7 +400,7 @@ namespace LibHac.FsSrv
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
fileSystem?.Dispose();
|
saveDirectoryFs?.Dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue