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:
Tilka 2020-06-14 15:03:32 +01:00 committed by GitHub
commit f9f4734237
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 78 additions and 1 deletions

View File

@ -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,

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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
{ {

View File

@ -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);

View File

@ -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:

View File

@ -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;

View File

@ -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:

View File

@ -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>

View File

@ -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())

View File

@ -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:

View File

@ -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);

View File

@ -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;

View File

@ -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

View File

@ -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;

View File

@ -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);

View File

@ -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,

View File

@ -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;