| 
									
										
										
										
											2018-01-19 21:45:07 -05:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 14:58:59 +01:00
										 |  |  | #include <cstring>
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | #include <memory>
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-06 04:06:12 -03:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | #include "core/file_sys/romfs_filesystem.h"
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | std::string RomFS_FileSystem::GetName() const { | 
					
						
							| 
									
										
										
										
											2018-01-19 21:45:07 -05:00
										 |  |  |     return "RomFS"; | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-19 00:32:00 -05:00
										 |  |  | ResultVal<std::unique_ptr<StorageBackend>> RomFS_FileSystem::OpenFile(const std::string& path, | 
					
						
							|  |  |  |                                                                       Mode mode) const { | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  |     return MakeResult<std::unique_ptr<StorageBackend>>( | 
					
						
							|  |  |  |         std::make_unique<RomFS_Storage>(romfs_file, data_offset, data_size)); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-15 13:15:18 -04:00
										 |  |  | ResultCode RomFS_FileSystem::DeleteFile(const std::string& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to delete a file from an ROMFS archive ({}).", GetName()); | 
					
						
							| 
									
										
										
										
											2017-10-31 19:26:11 -04:00
										 |  |  |     // TODO(bunnei): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 10:56:05 +03:00
										 |  |  | ResultCode RomFS_FileSystem::RenameFile(const std::string& src_path, | 
					
						
							|  |  |  |                                         const std::string& dest_path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to rename a file within an ROMFS archive ({}).", | 
					
						
							|  |  |  |                    GetName()); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:29:09 +08:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | ResultCode RomFS_FileSystem::DeleteDirectory(const Path& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to delete a directory from an ROMFS archive ({}).", | 
					
						
							|  |  |  |                    GetName()); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:29:09 +08:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | ResultCode RomFS_FileSystem::DeleteDirectoryRecursively(const Path& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to delete a directory from an ROMFS archive ({}).", | 
					
						
							|  |  |  |                    GetName()); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:29:09 +08:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2016-10-02 11:29:04 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-19 00:32:00 -05:00
										 |  |  | ResultCode RomFS_FileSystem::CreateFile(const std::string& path, u64 size) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to create a file in an ROMFS archive ({}).", GetName()); | 
					
						
							| 
									
										
										
										
											2017-10-31 19:26:11 -04:00
										 |  |  |     // TODO(bunnei): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-21 09:36:26 -05:00
										 |  |  | ResultCode RomFS_FileSystem::CreateDirectory(const std::string& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to create a directory in an ROMFS archive ({}).", | 
					
						
							|  |  |  |                    GetName()); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:29:09 +08:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | ResultCode RomFS_FileSystem::RenameDirectory(const Path& src_path, const Path& dest_path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Attempted to rename a file within an ROMFS archive ({}).", | 
					
						
							|  |  |  |                    GetName()); | 
					
						
							| 
									
										
										
										
											2016-10-14 15:29:09 +08:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-20 23:01:00 -05:00
										 |  |  | ResultVal<std::unique_ptr<DirectoryBackend>> RomFS_FileSystem::OpenDirectory( | 
					
						
							| 
									
										
										
										
											2018-03-19 23:00:37 -05:00
										 |  |  |     const std::string& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_WARNING(Service_FS, "Opening Directory in a ROMFS archive"); | 
					
						
							| 
									
										
										
										
											2018-01-19 21:45:07 -05:00
										 |  |  |     return MakeResult<std::unique_ptr<DirectoryBackend>>(std::make_unique<ROMFSDirectory>()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | u64 RomFS_FileSystem::GetFreeSpaceSize() const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_WARNING(Service_FS, "Attempted to get the free space in an ROMFS archive"); | 
					
						
							| 
									
										
										
										
											2015-10-18 15:52:37 -07:00
										 |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-19 00:32:00 -05:00
										 |  |  | ResultVal<FileSys::EntryType> RomFS_FileSystem::GetEntryType(const std::string& path) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_CRITICAL(Service_FS, "Called within an ROMFS archive (path {}).", path); | 
					
						
							| 
									
										
										
										
											2018-02-19 00:32:00 -05:00
										 |  |  |     // TODO(wwylele): Use correct error code
 | 
					
						
							|  |  |  |     return ResultCode(-1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | ResultVal<size_t> RomFS_Storage::Read(const u64 offset, const size_t length, u8* buffer) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_TRACE(Service_FS, "called offset={}, length={}", offset, length); | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  |     romfs_file->Seek(data_offset + offset, SEEK_SET); | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  |     size_t read_length = (size_t)std::min((u64)length, data_size - offset); | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-28 10:03:09 -05:00
										 |  |  |     return MakeResult<size_t>(romfs_file->ReadBytes(buffer, read_length)); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | ResultVal<size_t> RomFS_Storage::Write(const u64 offset, const size_t length, const bool flush, | 
					
						
							|  |  |  |                                        const u8* buffer) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_ERROR(Service_FS, "Attempted to write to ROMFS file"); | 
					
						
							| 
									
										
										
										
											2015-12-28 10:03:09 -05:00
										 |  |  |     // TODO(Subv): Find error code
 | 
					
						
							|  |  |  |     return MakeResult<size_t>(0); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | u64 RomFS_Storage::GetSize() const { | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  |     return data_size; | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-19 22:34:48 -05:00
										 |  |  | bool RomFS_Storage::SetSize(const u64 size) const { | 
					
						
							| 
									
										
										
										
											2018-04-25 11:37:33 -04:00
										 |  |  |     NGLOG_ERROR(Service_FS, "Attempted to set the size of an ROMFS file"); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace FileSys
 |