mirror of
https://github.com/citra-emu/citra.git
synced 2024-11-26 05:50:05 +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,18 +30,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
|
||||||
*/
|
*/
|
||||||
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