[VFS] Fix StfsContainerDevice::total_allocation_units()
This commit is contained in:
parent
d1c685afb3
commit
930f348650
|
@ -107,6 +107,8 @@ StfsContainerDevice::Error StfsContainerDevice::MapFiles() {
|
||||||
return header_result;
|
return header_result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mmap_total_size_ += header_map->size();
|
||||||
|
|
||||||
// If the STFS package is a single file, the header is self contained and
|
// If the STFS package is a single file, the header is self contained and
|
||||||
// we don't need to map any extra files.
|
// we don't need to map any extra files.
|
||||||
// NOTE: data_file_count is 0 for STFS and 1 for SVOD
|
// NOTE: data_file_count is 0 for STFS and 1 for SVOD
|
||||||
|
@ -145,8 +147,10 @@ StfsContainerDevice::Error StfsContainerDevice::MapFiles() {
|
||||||
if (!data) {
|
if (!data) {
|
||||||
XELOGI("Failed to map SVOD file %ls.", path.c_str());
|
XELOGI("Failed to map SVOD file %ls.", path.c_str());
|
||||||
mmap_.clear();
|
mmap_.clear();
|
||||||
|
mmap_total_size_ = 0;
|
||||||
return Error::kErrorReadError;
|
return Error::kErrorReadError;
|
||||||
}
|
}
|
||||||
|
mmap_total_size_ += data->size();
|
||||||
mmap_.emplace(std::make_pair(i, std::move(data)));
|
mmap_.emplace(std::make_pair(i, std::move(data)));
|
||||||
}
|
}
|
||||||
XELOGI("SVOD successfully mapped %d files.", fragment_files.size());
|
XELOGI("SVOD successfully mapped %d files.", fragment_files.size());
|
||||||
|
|
|
@ -437,7 +437,7 @@ class StfsContainerDevice : public Device {
|
||||||
Entry* ResolvePath(const std::string& path) override;
|
Entry* ResolvePath(const std::string& path) override;
|
||||||
|
|
||||||
uint32_t total_allocation_units() const override {
|
uint32_t total_allocation_units() const override {
|
||||||
return uint32_t(mmap_total_size_ / sectors_per_allocation_unit() /
|
return uint32_t(data_size() / sectors_per_allocation_unit() /
|
||||||
bytes_per_sector());
|
bytes_per_sector());
|
||||||
}
|
}
|
||||||
uint32_t available_allocation_units() const override { return 0; }
|
uint32_t available_allocation_units() const override { return 0; }
|
||||||
|
@ -496,7 +496,9 @@ class StfsContainerDevice : public Device {
|
||||||
|
|
||||||
std::wstring local_path_;
|
std::wstring local_path_;
|
||||||
std::map<size_t, std::unique_ptr<MappedMemory>> mmap_;
|
std::map<size_t, std::unique_ptr<MappedMemory>> mmap_;
|
||||||
size_t mmap_total_size_;
|
size_t mmap_total_size_ = 0;
|
||||||
|
|
||||||
|
size_t data_size() const { return mmap_total_size_ - sizeof(StfsHeader); }
|
||||||
|
|
||||||
uint32_t blocks_per_hash_table_ = 1;
|
uint32_t blocks_per_hash_table_ = 1;
|
||||||
uint32_t block_step_[2] = {0xAB, 0x718F};
|
uint32_t block_step_[2] = {0xAB, 0x718F};
|
||||||
|
|
Loading…
Reference in New Issue