Merge pull request #8850 from JosJuice/block-size-warning
Show an OSD message when running a disc image with a large block size
This commit is contained in:
commit
f9f4734237
|
@ -36,6 +36,7 @@
|
||||||
#include "Core/IOS/IOS.h"
|
#include "Core/IOS/IOS.h"
|
||||||
#include "Core/Movie.h"
|
#include "Core/Movie.h"
|
||||||
|
|
||||||
|
#include "DiscIO/Blob.h"
|
||||||
#include "DiscIO/Enums.h"
|
#include "DiscIO/Enums.h"
|
||||||
#include "DiscIO/Volume.h"
|
#include "DiscIO/Volume.h"
|
||||||
#include "DiscIO/VolumeWii.h"
|
#include "DiscIO/VolumeWii.h"
|
||||||
|
@ -426,6 +427,17 @@ void SetDisc(std::unique_ptr<DiscIO::VolumeDisc> disc,
|
||||||
bool had_disc = IsDiscInside();
|
bool had_disc = IsDiscInside();
|
||||||
bool has_disc = static_cast<bool>(disc);
|
bool has_disc = static_cast<bool>(disc);
|
||||||
|
|
||||||
|
if (has_disc)
|
||||||
|
{
|
||||||
|
const DiscIO::BlobReader& blob = disc->GetBlobReader();
|
||||||
|
if (!blob.HasFastRandomAccessInBlock() && blob.GetBlockSize() > 0x200000)
|
||||||
|
{
|
||||||
|
OSD::AddMessage("You are running a disc image with a very large block size.", 60000);
|
||||||
|
OSD::AddMessage("This will likely lead to performance problems.", 60000);
|
||||||
|
OSD::AddMessage("You can use Dolphin's convert feature to reduce the block size.", 60000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (auto_disc_change_paths)
|
if (auto_disc_change_paths)
|
||||||
{
|
{
|
||||||
ASSERT_MSG(DISCIO, (*auto_disc_change_paths).size() != 1,
|
ASSERT_MSG(DISCIO, (*auto_disc_change_paths).size() != 1,
|
||||||
|
|
|
@ -49,7 +49,8 @@ public:
|
||||||
virtual bool IsDataSizeAccurate() const = 0;
|
virtual bool IsDataSizeAccurate() const = 0;
|
||||||
|
|
||||||
// Returns 0 if the format does not use blocks
|
// Returns 0 if the format does not use blocks
|
||||||
virtual u64 GetBlockSize() const { return 0; }
|
virtual u64 GetBlockSize() const = 0;
|
||||||
|
virtual bool HasFastRandomAccessInBlock() const = 0;
|
||||||
|
|
||||||
// NOT thread-safe - can't call this from multiple threads.
|
// NOT thread-safe - can't call this from multiple threads.
|
||||||
virtual bool Read(u64 offset, u64 size, u8* out_ptr) = 0;
|
virtual bool Read(u64 offset, u64 size, u8* out_ptr) = 0;
|
||||||
|
|
|
@ -45,6 +45,7 @@ public:
|
||||||
bool IsDataSizeAccurate() const override { return false; }
|
bool IsDataSizeAccurate() const override { return false; }
|
||||||
|
|
||||||
u64 GetBlockSize() const override { return m_block_size; }
|
u64 GetBlockSize() const override { return m_block_size; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return true; }
|
||||||
|
|
||||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||||
|
|
||||||
|
|
|
@ -47,12 +47,18 @@ public:
|
||||||
static std::unique_ptr<CompressedBlobReader> Create(File::IOFile file,
|
static std::unique_ptr<CompressedBlobReader> Create(File::IOFile file,
|
||||||
const std::string& filename);
|
const std::string& filename);
|
||||||
~CompressedBlobReader();
|
~CompressedBlobReader();
|
||||||
|
|
||||||
const CompressedBlobHeader& GetHeader() const { return m_header; }
|
const CompressedBlobHeader& GetHeader() const { return m_header; }
|
||||||
|
|
||||||
BlobType GetBlobType() const override { return BlobType::GCZ; }
|
BlobType GetBlobType() const override { return BlobType::GCZ; }
|
||||||
|
|
||||||
u64 GetRawSize() const override { return m_file_size; }
|
u64 GetRawSize() const override { return m_file_size; }
|
||||||
u64 GetDataSize() const override { return m_header.data_size; }
|
u64 GetDataSize() const override { return m_header.data_size; }
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
u64 GetBlockSize() const override { return m_header.block_size; }
|
u64 GetBlockSize() const override { return m_header.block_size; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return false; }
|
||||||
|
|
||||||
u64 GetBlockCompressedSize(u64 block_num) const;
|
u64 GetBlockCompressedSize(u64 block_num) const;
|
||||||
bool GetBlock(u64 block_num, u8* out_ptr) override;
|
bool GetBlock(u64 block_num, u8* out_ptr) override;
|
||||||
|
|
||||||
|
|
|
@ -161,10 +161,14 @@ public:
|
||||||
bool ReadWiiDecrypted(u64 offset, u64 size, u8* buffer, u64 partition_data_offset) override;
|
bool ReadWiiDecrypted(u64 offset, u64 size, u8* buffer, u64 partition_data_offset) override;
|
||||||
|
|
||||||
BlobType GetBlobType() const override;
|
BlobType GetBlobType() const override;
|
||||||
|
|
||||||
u64 GetRawSize() const override;
|
u64 GetRawSize() const override;
|
||||||
u64 GetDataSize() const override;
|
u64 GetDataSize() const override;
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
|
u64 GetBlockSize() const override { return 0; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
struct PartitionWithType
|
struct PartitionWithType
|
||||||
{
|
{
|
||||||
|
|
|
@ -31,6 +31,7 @@ public:
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
u64 GetBlockSize() const override { return ECC_BLOCK_SIZE; }
|
u64 GetBlockSize() const override { return ECC_BLOCK_SIZE; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return false; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DriveReader(const std::string& drive);
|
DriveReader(const std::string& drive);
|
||||||
|
|
|
@ -20,9 +20,14 @@ public:
|
||||||
static std::unique_ptr<PlainFileReader> Create(File::IOFile file);
|
static std::unique_ptr<PlainFileReader> Create(File::IOFile file);
|
||||||
|
|
||||||
BlobType GetBlobType() const override { return BlobType::PLAIN; }
|
BlobType GetBlobType() const override { return BlobType::PLAIN; }
|
||||||
|
|
||||||
u64 GetRawSize() const override { return m_size; }
|
u64 GetRawSize() const override { return m_size; }
|
||||||
u64 GetDataSize() const override { return m_size; }
|
u64 GetDataSize() const override { return m_size; }
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
|
u64 GetBlockSize() const override { return 0; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return true; }
|
||||||
|
|
||||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -20,10 +20,16 @@ public:
|
||||||
static std::unique_ptr<ScrubbedBlob> Create(const std::string& path);
|
static std::unique_ptr<ScrubbedBlob> Create(const std::string& path);
|
||||||
|
|
||||||
BlobType GetBlobType() const override { return m_blob_reader->GetBlobType(); }
|
BlobType GetBlobType() const override { return m_blob_reader->GetBlobType(); }
|
||||||
|
|
||||||
u64 GetRawSize() const override { return m_blob_reader->GetRawSize(); }
|
u64 GetRawSize() const override { return m_blob_reader->GetRawSize(); }
|
||||||
u64 GetDataSize() const override { return m_blob_reader->GetDataSize(); }
|
u64 GetDataSize() const override { return m_blob_reader->GetDataSize(); }
|
||||||
bool IsDataSizeAccurate() const override { return m_blob_reader->IsDataSizeAccurate(); }
|
bool IsDataSizeAccurate() const override { return m_blob_reader->IsDataSizeAccurate(); }
|
||||||
|
|
||||||
u64 GetBlockSize() const override { return m_blob_reader->GetBlockSize(); }
|
u64 GetBlockSize() const override { return m_blob_reader->GetBlockSize(); }
|
||||||
|
bool HasFastRandomAccessInBlock() const override
|
||||||
|
{
|
||||||
|
return m_blob_reader->HasFastRandomAccessInBlock();
|
||||||
|
}
|
||||||
|
|
||||||
bool Read(u64 offset, u64 size, u8* out_ptr) override;
|
bool Read(u64 offset, u64 size, u8* out_ptr) override;
|
||||||
|
|
||||||
|
|
|
@ -43,9 +43,14 @@ public:
|
||||||
static std::unique_ptr<TGCFileReader> Create(File::IOFile file);
|
static std::unique_ptr<TGCFileReader> Create(File::IOFile file);
|
||||||
|
|
||||||
BlobType GetBlobType() const override { return BlobType::TGC; }
|
BlobType GetBlobType() const override { return BlobType::TGC; }
|
||||||
|
|
||||||
u64 GetRawSize() const override { return m_size; }
|
u64 GetRawSize() const override { return m_size; }
|
||||||
u64 GetDataSize() const override;
|
u64 GetDataSize() const override;
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
|
u64 GetBlockSize() const override { return 0; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return true; }
|
||||||
|
|
||||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
namespace DiscIO
|
namespace DiscIO
|
||||||
{
|
{
|
||||||
|
class BlobReader;
|
||||||
enum class BlobType;
|
enum class BlobType;
|
||||||
class FileSystem;
|
class FileSystem;
|
||||||
class VolumeWAD;
|
class VolumeWAD;
|
||||||
|
@ -132,6 +133,7 @@ public:
|
||||||
virtual bool IsSizeAccurate() const = 0;
|
virtual bool IsSizeAccurate() const = 0;
|
||||||
// Size on disc (compressed size)
|
// Size on disc (compressed size)
|
||||||
virtual u64 GetRawSize() const = 0;
|
virtual u64 GetRawSize() const = 0;
|
||||||
|
virtual const BlobReader& GetBlobReader() const = 0;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
template <u32 N>
|
template <u32 N>
|
||||||
|
|
|
@ -44,6 +44,16 @@ u64 VolumeFileBlobReader::GetRawSize() const
|
||||||
return GetDataSize();
|
return GetDataSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u64 VolumeFileBlobReader::GetBlockSize() const
|
||||||
|
{
|
||||||
|
return m_volume.GetBlobReader().GetBlockSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool VolumeFileBlobReader::HasFastRandomAccessInBlock() const
|
||||||
|
{
|
||||||
|
return m_volume.GetBlobReader().HasFastRandomAccessInBlock();
|
||||||
|
}
|
||||||
|
|
||||||
bool VolumeFileBlobReader::Read(u64 offset, u64 length, u8* out_ptr)
|
bool VolumeFileBlobReader::Read(u64 offset, u64 length, u8* out_ptr)
|
||||||
{
|
{
|
||||||
if (offset + length > m_file_info->GetSize())
|
if (offset + length > m_file_info->GetSize())
|
||||||
|
|
|
@ -23,9 +23,14 @@ public:
|
||||||
Create(const Volume& volume, const Partition& partition, std::string_view file_path);
|
Create(const Volume& volume, const Partition& partition, std::string_view file_path);
|
||||||
|
|
||||||
BlobType GetBlobType() const override { return BlobType::PLAIN; }
|
BlobType GetBlobType() const override { return BlobType::PLAIN; }
|
||||||
|
|
||||||
u64 GetRawSize() const override;
|
u64 GetRawSize() const override;
|
||||||
u64 GetDataSize() const override;
|
u64 GetDataSize() const override;
|
||||||
bool IsDataSizeAccurate() const override { return true; }
|
bool IsDataSizeAccurate() const override { return true; }
|
||||||
|
|
||||||
|
u64 GetBlockSize() const override;
|
||||||
|
bool HasFastRandomAccessInBlock() const override;
|
||||||
|
|
||||||
bool Read(u64 offset, u64 length, u8* out_ptr) override;
|
bool Read(u64 offset, u64 length, u8* out_ptr) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -188,6 +188,11 @@ u64 VolumeGC::GetRawSize() const
|
||||||
return m_reader->GetRawSize();
|
return m_reader->GetRawSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const BlobReader& VolumeGC::GetBlobReader() const
|
||||||
|
{
|
||||||
|
return *m_reader;
|
||||||
|
}
|
||||||
|
|
||||||
std::optional<u8> VolumeGC::GetDiscNumber(const Partition& partition) const
|
std::optional<u8> VolumeGC::GetDiscNumber(const Partition& partition) const
|
||||||
{
|
{
|
||||||
return ReadSwapped<u8>(6, partition);
|
return ReadSwapped<u8>(6, partition);
|
||||||
|
|
|
@ -54,6 +54,7 @@ public:
|
||||||
u64 GetSize() const override;
|
u64 GetSize() const override;
|
||||||
bool IsSizeAccurate() const override;
|
bool IsSizeAccurate() const override;
|
||||||
u64 GetRawSize() const override;
|
u64 GetRawSize() const override;
|
||||||
|
const BlobReader& GetBlobReader() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static const u32 GC_BANNER_WIDTH = 96;
|
static const u32 GC_BANNER_WIDTH = 96;
|
||||||
|
|
|
@ -327,4 +327,9 @@ u64 VolumeWAD::GetRawSize() const
|
||||||
return m_reader->GetRawSize();
|
return m_reader->GetRawSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const BlobReader& VolumeWAD::GetBlobReader() const
|
||||||
|
{
|
||||||
|
return *m_reader;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace DiscIO
|
} // namespace DiscIO
|
||||||
|
|
|
@ -66,6 +66,7 @@ public:
|
||||||
u64 GetSize() const override;
|
u64 GetSize() const override;
|
||||||
bool IsSizeAccurate() const override;
|
bool IsSizeAccurate() const override;
|
||||||
u64 GetRawSize() const override;
|
u64 GetRawSize() const override;
|
||||||
|
const BlobReader& GetBlobReader() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unique_ptr<BlobReader> m_reader;
|
std::unique_ptr<BlobReader> m_reader;
|
||||||
|
|
|
@ -434,6 +434,11 @@ u64 VolumeWii::GetRawSize() const
|
||||||
return m_reader->GetRawSize();
|
return m_reader->GetRawSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const BlobReader& VolumeWii::GetBlobReader() const
|
||||||
|
{
|
||||||
|
return *m_reader;
|
||||||
|
}
|
||||||
|
|
||||||
bool VolumeWii::CheckH3TableIntegrity(const Partition& partition) const
|
bool VolumeWii::CheckH3TableIntegrity(const Partition& partition) const
|
||||||
{
|
{
|
||||||
auto it = m_partitions.find(partition);
|
auto it = m_partitions.find(partition);
|
||||||
|
|
|
@ -95,6 +95,7 @@ public:
|
||||||
u64 GetSize() const override;
|
u64 GetSize() const override;
|
||||||
bool IsSizeAccurate() const override;
|
bool IsSizeAccurate() const override;
|
||||||
u64 GetRawSize() const override;
|
u64 GetRawSize() const override;
|
||||||
|
const BlobReader& GetBlobReader() const;
|
||||||
|
|
||||||
static bool EncryptGroup(u64 offset, u64 partition_data_offset, u64 partition_data_decrypted_size,
|
static bool EncryptGroup(u64 offset, u64 partition_data_offset, u64 partition_data_decrypted_size,
|
||||||
const std::array<u8, AES_KEY_SIZE>& key, BlobReader* blob,
|
const std::array<u8, AES_KEY_SIZE>& key, BlobReader* blob,
|
||||||
|
|
|
@ -33,6 +33,7 @@ public:
|
||||||
bool IsDataSizeAccurate() const override { return false; }
|
bool IsDataSizeAccurate() const override { return false; }
|
||||||
|
|
||||||
u64 GetBlockSize() const override { return m_wbfs_sector_size; }
|
u64 GetBlockSize() const override { return m_wbfs_sector_size; }
|
||||||
|
bool HasFastRandomAccessInBlock() const override { return true; }
|
||||||
|
|
||||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue