mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	Merge pull request #68 from archshift/readfile
Added FS functions to Archive and Archive_RomFS
This commit is contained in:
		
						commit
						0ffc966e42
					
				| @ -37,18 +37,33 @@ public: | |||||||
| 
 | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Read data from the archive |      * Read data from the archive | ||||||
|      * @param offset Offset in bytes to start reading archive from |      * @param offset Offset in bytes to start reading data from | ||||||
|      * @param length Length in bytes to read data from archive |      * @param length Length in bytes of data to read from archive | ||||||
|      * @param buffer Buffer to read data into |      * @param buffer Buffer to read data into | ||||||
|      * @return Number of bytes read |      * @return Number of bytes read | ||||||
|      */ |      */ | ||||||
|     virtual size_t Read(const u64 offset, const u32 length, u8* buffer) const = 0; |     virtual size_t Read(const u64 offset, const u32 length, u8* buffer) const = 0; | ||||||
| 
 | 
 | ||||||
|  |     /**
 | ||||||
|  |      * Write data to the archive | ||||||
|  |      * @param offset Offset in bytes to start writing data to | ||||||
|  |      * @param length Length in bytes of data to write to archive | ||||||
|  |      * @param buffer Buffer to write data from | ||||||
|  |      * @param flush  The flush parameters (0 == do not flush) | ||||||
|  |      * @return Number of bytes written | ||||||
|  |      */ | ||||||
|  |     virtual size_t Write(const u64 offset, const u32 length, const u32 flush, u8* buffer) = 0; | ||||||
|  | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Get the size of the archive in bytes |      * Get the size of the archive in bytes | ||||||
|      * @return Size of the archive in bytes |      * @return Size of the archive in bytes | ||||||
|      */ |      */ | ||||||
|     virtual size_t GetSize() const = 0; |     virtual size_t GetSize() const = 0; | ||||||
|  |      | ||||||
|  |     /**
 | ||||||
|  |      * Set the size of the archive in bytes | ||||||
|  |      */ | ||||||
|  |     virtual void SetSize(const u64 size) = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } // namespace FileSys
 | } // namespace FileSys
 | ||||||
|  | |||||||
| @ -23,8 +23,8 @@ Archive_RomFS::~Archive_RomFS() { | |||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Read data from the archive |  * Read data from the archive | ||||||
|  * @param offset Offset in bytes to start reading archive from |  * @param offset Offset in bytes to start reading data from | ||||||
|  * @param length Length in bytes to read data from archive |  * @param length Length in bytes of data to read from archive | ||||||
|  * @param buffer Buffer to read data into |  * @param buffer Buffer to read data into | ||||||
|  * @return Number of bytes read |  * @return Number of bytes read | ||||||
|  */ |  */ | ||||||
| @ -34,13 +34,32 @@ size_t Archive_RomFS::Read(const u64 offset, const u32 length, u8* buffer) const | |||||||
|     return length; |     return length; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * Write data to the archive | ||||||
|  |  * @param offset Offset in bytes to start writing data to | ||||||
|  |  * @param length Length in bytes of data to write to archive | ||||||
|  |  * @param buffer Buffer to write data from | ||||||
|  |  * @param flush  The flush parameters (0 == do not flush) | ||||||
|  |  * @return Number of bytes written | ||||||
|  |  */ | ||||||
|  | size_t Archive_RomFS::Write(const u64 offset, const u32 length, const u32 flush, u8* buffer) { | ||||||
|  |     ERROR_LOG(FILESYS, "Attempted to write to ROMFS."); | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Get the size of the archive in bytes |  * Get the size of the archive in bytes | ||||||
|  * @return Size of the archive in bytes |  * @return Size of the archive in bytes | ||||||
|  */ |  */ | ||||||
| size_t Archive_RomFS::GetSize() const { | size_t Archive_RomFS::GetSize() const { | ||||||
|     ERROR_LOG(FILESYS, "(UNIMPLEMENTED)"); |     return sizeof(u8) * raw_data.size(); | ||||||
|     return 0; | } | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Set the size of the archive in bytes | ||||||
|  |  */ | ||||||
|  | void Archive_RomFS::SetSize(const u64 size) { | ||||||
|  |     ERROR_LOG(FILESYS, "Attempted to set the size of ROMFS"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } // namespace FileSys
 | } // namespace FileSys
 | ||||||
|  | |||||||
| @ -30,19 +30,34 @@ public: | |||||||
| 
 | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Read data from the archive |      * Read data from the archive | ||||||
|      * @param offset Offset in bytes to start reading archive from |      * @param offset Offset in bytes to start reading data from | ||||||
|      * @param length Length in bytes to read data from archive |      * @param length Length in bytes of data to read from archive | ||||||
|      * @param buffer Buffer to read data into |      * @param buffer Buffer to read data into | ||||||
|      * @return Number of bytes read |      * @return Number of bytes read | ||||||
|      */ |      */ | ||||||
|     size_t Read(const u64 offset, const u32 length, u8* buffer) const override; |     size_t Read(const u64 offset, const u32 length, u8* buffer) const override; | ||||||
| 
 | 
 | ||||||
|  |     /**
 | ||||||
|  |      * Write data to the archive | ||||||
|  |      * @param offset Offset in bytes to start writing data to | ||||||
|  |      * @param length Length in bytes of data to write to archive | ||||||
|  |      * @param buffer Buffer to write data from | ||||||
|  |      * @param flush  The flush parameters (0 == do not flush) | ||||||
|  |      * @return Number of bytes written | ||||||
|  |      */ | ||||||
|  |     size_t Write(const u64 offset, const u32 length, const u32 flush, u8* buffer) override; | ||||||
|  | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Get the size of the archive in bytes |      * Get the size of the archive in bytes | ||||||
|      * @return Size of the archive in bytes |      * @return Size of the archive in bytes | ||||||
|      */ |      */ | ||||||
|     size_t GetSize() const override; |     size_t GetSize() const override; | ||||||
|      |      | ||||||
|  |     /**
 | ||||||
|  |      * Set the size of the archive in bytes | ||||||
|  |      */ | ||||||
|  |     void SetSize(const u64 size) override; | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
|     std::vector<u8> raw_data; |     std::vector<u8> raw_data; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ | |||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
|  | #include "common/math_util.h" | ||||||
| 
 | 
 | ||||||
| #include "core/file_sys/archive.h" | #include "core/file_sys/archive.h" | ||||||
| #include "core/hle/service/service.h" | #include "core/hle/service/service.h" | ||||||
| @ -48,23 +49,50 @@ public: | |||||||
|     Result SyncRequest(bool* wait) { |     Result SyncRequest(bool* wait) { | ||||||
|         u32* cmd_buff = Service::GetCommandBuffer(); |         u32* cmd_buff = Service::GetCommandBuffer(); | ||||||
|         FileCommand cmd = static_cast<FileCommand>(cmd_buff[0]); |         FileCommand cmd = static_cast<FileCommand>(cmd_buff[0]); | ||||||
|         switch (cmd) { |  | ||||||
|          |          | ||||||
|  |         switch (cmd) { | ||||||
|         // Read from archive...
 |         // Read from archive...
 | ||||||
|         case FileCommand::Read: |         case FileCommand::Read: | ||||||
|         { |         { | ||||||
|             u64 offset = cmd_buff[1] | ((u64) cmd_buff[2]) << 32; |             u64 offset  = cmd_buff[1] | ((u64)cmd_buff[2] << 32); | ||||||
|             u32 length  = cmd_buff[3]; |             u32 length  = cmd_buff[3]; | ||||||
|             u32 address = cmd_buff[5]; |             u32 address = cmd_buff[5]; | ||||||
|  | 
 | ||||||
|  |             // Number of bytes read
 | ||||||
|             cmd_buff[2] = backend->Read(offset, length, Memory::GetPointer(address)); |             cmd_buff[2] = backend->Read(offset, length, Memory::GetPointer(address)); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|  |         // Write to archive...
 | ||||||
|  |         case FileCommand::Write: | ||||||
|  |         { | ||||||
|  |             u64 offset  = cmd_buff[1] | ((u64)cmd_buff[2] << 32); | ||||||
|  |             u32 length  = cmd_buff[3]; | ||||||
|  |             u32 flush   = cmd_buff[4]; | ||||||
|  |             u32 address = cmd_buff[6]; | ||||||
| 
 | 
 | ||||||
|  |             // Number of bytes written
 | ||||||
|  |             cmd_buff[2] = backend->Write(offset, length, flush, Memory::GetPointer(address)); | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         case FileCommand::GetSize: | ||||||
|  |         { | ||||||
|  |             u64 filesize = (u64) backend->GetSize(); | ||||||
|  |             cmd_buff[2]  = (u32) filesize;         // Lower word
 | ||||||
|  |             cmd_buff[3]  = (u32) (filesize >> 32); // Upper word
 | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         case FileCommand::SetSize: | ||||||
|  |         { | ||||||
|  |             backend->SetSize(cmd_buff[1] | ((u64)cmd_buff[2] << 32)); | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|         // Unknown command...
 |         // Unknown command...
 | ||||||
|         default: |         default: | ||||||
|  |         { | ||||||
|             ERROR_LOG(KERNEL, "Unknown command=0x%08X!", cmd); |             ERROR_LOG(KERNEL, "Unknown command=0x%08X!", cmd); | ||||||
|             return -1; |             return -1; | ||||||
|         } |         } | ||||||
|  |         } | ||||||
|         cmd_buff[1] = 0; // No error
 |         cmd_buff[1] = 0; // No error
 | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| @ -140,7 +168,7 @@ Archive* CreateArchive(Handle& handle, FileSys::Archive* backend, const std::str | |||||||
|  */ |  */ | ||||||
| Handle CreateArchive(FileSys::Archive* backend, const std::string& name) { | Handle CreateArchive(FileSys::Archive* backend, const std::string& name) { | ||||||
|     Handle handle; |     Handle handle; | ||||||
|     Archive* archive = CreateArchive(handle, backend, name); |     CreateArchive(handle, backend, name); | ||||||
|     return handle; |     return handle; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 bunnei
						bunnei