mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	Added FS functions to Archive and Archive_RomFS
This commit is contained in:
		
							parent
							
								
									2386764756
								
							
						
					
					
						commit
						4c4a01bf41
					
				@ -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