Don't read from volume when reloading Wii banners

Should make loading cached Wii games that lack banners slightly faster.
This commit is contained in:
JosJuice 2015-12-03 17:29:59 +01:00
parent a5904b522d
commit a0cd753060
12 changed files with 79 additions and 39 deletions

View File

@ -90,7 +90,7 @@ public:
virtual std::map<ELanguage, std::string> GetNames(bool prefer_long) const = 0; virtual std::map<ELanguage, std::string> GetNames(bool prefer_long) const = 0;
virtual std::map<ELanguage, std::string> GetDescriptions() const { return std::map<ELanguage, std::string>(); } virtual std::map<ELanguage, std::string> GetDescriptions() const { return std::map<ELanguage, std::string>(); }
virtual std::string GetCompany() const { return std::string(); } virtual std::string GetCompany() const { return std::string(); }
virtual std::vector<u32> GetBanner(int* width, int* height) const; virtual std::vector<u32> GetBanner(int* width, int* height) const = 0;
virtual u64 GetFSTSize() const = 0; virtual u64 GetFSTSize() const = 0;
virtual std::string GetApploaderDate() const = 0; virtual std::string GetApploaderDate() const = 0;
// 0 is the first disc, 1 is the second disc // 0 is the first disc, 1 is the second disc
@ -108,6 +108,8 @@ public:
// Size on disc (compressed size) // Size on disc (compressed size)
virtual u64 GetRawSize() const = 0; virtual u64 GetRawSize() const = 0;
static std::vector<u32> GetWiiBanner(int* width, int* height, u64 title_id);
protected: protected:
template <u32 N> template <u32 N>
std::string DecodeString(const char(&data)[N]) const std::string DecodeString(const char(&data)[N]) const

View File

@ -24,14 +24,11 @@ static const unsigned int WII_BANNER_HEIGHT = 64;
static const unsigned int WII_BANNER_SIZE = WII_BANNER_WIDTH * WII_BANNER_HEIGHT * 2; static const unsigned int WII_BANNER_SIZE = WII_BANNER_WIDTH * WII_BANNER_HEIGHT * 2;
static const unsigned int WII_BANNER_OFFSET = 0xA0; static const unsigned int WII_BANNER_OFFSET = 0xA0;
std::vector<u32> IVolume::GetBanner(int* width, int* height) const std::vector<u32> IVolume::GetWiiBanner(int* width, int* height, u64 title_id)
{ {
*width = 0; *width = 0;
*height = 0; *height = 0;
u64 title_id = 0;
GetTitleID(&title_id);
std::string file_name = StringFromFormat("%s/title/%08x/%08x/data/banner.bin", std::string file_name = StringFromFormat("%s/title/%08x/%08x/data/banner.bin",
File::GetUserPath(D_WIIROOT_IDX).c_str(), (u32)(title_id >> 32), (u32)title_id); File::GetUserPath(D_WIIROOT_IDX).c_str(), (u32)(title_id >> 32), (u32)title_id);
if (!File::Exists(file_name)) if (!File::Exists(file_name))

View File

@ -183,7 +183,8 @@ IVolume::ECountry CVolumeDirectory::GetCountry() const
std::string CVolumeDirectory::GetMakerID() const std::string CVolumeDirectory::GetMakerID() const
{ {
return "VOID"; // Not implemented
return "00";
} }
std::string CVolumeDirectory::GetInternalName() const std::string CVolumeDirectory::GetInternalName() const
@ -204,6 +205,14 @@ std::map<IVolume::ELanguage, std::string> CVolumeDirectory::GetNames(bool prefer
return names; return names;
} }
std::vector<u32> CVolumeDirectory::GetBanner(int* width, int* height) const
{
// Not implemented
*width = 0;
*height = 0;
return std::vector<u32>();
}
void CVolumeDirectory::SetName(const std::string& name) void CVolumeDirectory::SetName(const std::string& name)
{ {
size_t length = name.length(); size_t length = name.length();
@ -216,11 +225,13 @@ void CVolumeDirectory::SetName(const std::string& name)
u64 CVolumeDirectory::GetFSTSize() const u64 CVolumeDirectory::GetFSTSize() const
{ {
// Not implemented
return 0; return 0;
} }
std::string CVolumeDirectory::GetApploaderDate() const std::string CVolumeDirectory::GetApploaderDate() const
{ {
// Not implemented
return "VOID"; return "VOID";
} }
@ -239,12 +250,14 @@ BlobType CVolumeDirectory::GetBlobType() const
u64 CVolumeDirectory::GetSize() const u64 CVolumeDirectory::GetSize() const
{ {
// Not implemented
return 0; return 0;
} }
u64 CVolumeDirectory::GetRawSize() const u64 CVolumeDirectory::GetRawSize() const
{ {
return GetSize(); // Not implemented
return 0;
} }
std::string CVolumeDirectory::ExtractDirectoryName(const std::string& _rDirectory) std::string CVolumeDirectory::ExtractDirectoryName(const std::string& _rDirectory)

View File

@ -43,6 +43,7 @@ public:
u16 GetRevision() const override { return 0; } u16 GetRevision() const override { return 0; }
std::string GetInternalName() const override; std::string GetInternalName() const override;
std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override; std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override;
std::vector<u32> GetBanner(int* width, int* height) const override;
void SetName(const std::string&); void SetName(const std::string&);
u64 GetFSTSize() const override; u64 GetFSTSize() const override;

View File

@ -127,6 +127,18 @@ std::map<IVolume::ELanguage, std::string> CVolumeWAD::GetNames(bool prefer_long)
return ReadWiiNames(name_data); return ReadWiiNames(name_data);
} }
std::vector<u32> CVolumeWAD::GetBanner(int* width, int* height) const
{
*width = 0;
*height = 0;
u64 title_id;
if (!GetTitleID(&title_id))
return std::vector<u32>();
return GetWiiBanner(width, height, title_id);
}
BlobType CVolumeWAD::GetBlobType() const BlobType CVolumeWAD::GetBlobType() const
{ {
return m_pReader ? m_pReader->GetBlobType() : BlobType::PLAIN; return m_pReader ? m_pReader->GetBlobType() : BlobType::PLAIN;

View File

@ -32,6 +32,7 @@ public:
u16 GetRevision() const override; u16 GetRevision() const override;
std::string GetInternalName() const override { return ""; } std::string GetInternalName() const override { return ""; }
std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override; std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override;
std::vector<u32> GetBanner(int* width, int* height) const override;
u64 GetFSTSize() const override { return 0; } u64 GetFSTSize() const override { return 0; }
std::string GetApploaderDate() const override { return ""; } std::string GetApploaderDate() const override { return ""; }

View File

@ -212,6 +212,18 @@ std::map<IVolume::ELanguage, std::string> CVolumeWiiCrypted::GetNames(bool prefe
return ReadWiiNames(opening_bnr); return ReadWiiNames(opening_bnr);
} }
std::vector<u32> CVolumeWiiCrypted::GetBanner(int* width, int* height) const
{
*width = 0;
*height = 0;
u64 title_id;
if (!GetTitleID(&title_id))
return std::vector<u32>();
return GetWiiBanner(width, height, title_id);
}
u64 CVolumeWiiCrypted::GetFSTSize() const u64 CVolumeWiiCrypted::GetFSTSize() const
{ {
if (m_pReader == nullptr) if (m_pReader == nullptr)

View File

@ -32,6 +32,7 @@ public:
u16 GetRevision() const override; u16 GetRevision() const override;
std::string GetInternalName() const override; std::string GetInternalName() const override;
std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override; std::map<IVolume::ELanguage, std::string> GetNames(bool prefer_long) const override;
std::vector<u32> GetBanner(int* width, int* height) const override;
u64 GetFSTSize() const override; u64 GetFSTSize() const override;
std::string GetApploaderDate() const override; std::string GetApploaderDate() const override;
u8 GetDiscNumber() const override; u8 GetDiscNumber() const override;

View File

@ -24,7 +24,7 @@
#include "DolphinQt/GameList/GameFile.h" #include "DolphinQt/GameList/GameFile.h"
static const u32 CACHE_REVISION = 0x00D; // Last changed in PR 3097 static const u32 CACHE_REVISION = 0x00E; // Last changed in PR 3309
static const u32 DATASTREAM_REVISION = 15; // Introduced in Qt 5.2 static const u32 DATASTREAM_REVISION = 15; // Introduced in Qt 5.2
static QMap<DiscIO::IVolume::ELanguage, QString> ConvertLocalizedStrings(std::map<DiscIO::IVolume::ELanguage, std::string> strings) static QMap<DiscIO::IVolume::ELanguage, QString> ConvertLocalizedStrings(std::map<DiscIO::IVolume::ELanguage, std::string> strings)
@ -84,15 +84,13 @@ GameFile::GameFile(const QString& fileName)
// if a banner has become available after the cache was made. // if a banner has become available after the cache was made.
if (m_banner.isNull()) if (m_banner.isNull())
{ {
std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(fileName.toStdString())); int width, height;
if (volume != nullptr) std::vector<u32> buffer = DiscIO::IVolume::GetWiiBanner(&width, &height, m_title_id);
{ ReadBanner(buffer, width, height);
ReadBanner(*volume);
if (!m_banner.isNull()) if (!m_banner.isNull())
SaveToCache(); SaveToCache();
} }
} }
}
else else
{ {
std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(fileName.toStdString())); std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(fileName.toStdString()));
@ -112,10 +110,13 @@ GameFile::GameFile(const QString& fileName)
m_volume_size = volume->GetSize(); m_volume_size = volume->GetSize();
m_unique_id = QString::fromStdString(volume->GetUniqueID()); m_unique_id = QString::fromStdString(volume->GetUniqueID());
volume->GetTitleID(&m_title_id);
m_disc_number = volume->GetDiscNumber(); m_disc_number = volume->GetDiscNumber();
m_revision = volume->GetRevision(); m_revision = volume->GetRevision();
ReadBanner(*volume); int width, height;
std::vector<u32> buffer = volume->GetBanner(&width, &height);
ReadBanner(buffer, width, height);
m_valid = true; m_valid = true;
SaveToCache(); SaveToCache();
@ -188,6 +189,7 @@ bool GameFile::LoadFromCache()
>> descriptions >> descriptions
>> m_company >> m_company
>> m_unique_id >> m_unique_id
>> m_title_id
>> blob_type >> blob_type
>> m_file_size >> m_file_size
>> m_volume_size >> m_volume_size
@ -231,6 +233,7 @@ void GameFile::SaveToCache()
<< CastLocalizedStrings<u8>(m_descriptions) << CastLocalizedStrings<u8>(m_descriptions)
<< m_company << m_company
<< m_unique_id << m_unique_id
<< m_title_id
<< (u32)m_blob_type << (u32)m_blob_type
<< m_file_size << m_file_size
<< m_volume_size << m_volume_size
@ -267,10 +270,8 @@ QString GameFile::CreateCacheFilename() const
} }
// Outputs to m_banner // Outputs to m_banner
void GameFile::ReadBanner(const DiscIO::IVolume& volume) void GameFile::ReadBanner(const std::vector<u32>& buffer, int width, int height)
{ {
int width, height;
std::vector<u32> buffer = volume.GetBanner(&width, &height);
QImage banner(width, height, QImage::Format_RGB888); QImage banner(width, height, QImage::Format_RGB888);
for (int i = 0; i < width * height; i++) for (int i = 0; i < width * height; i++)
{ {

View File

@ -64,6 +64,7 @@ private:
QString m_company; QString m_company;
QString m_unique_id; QString m_unique_id;
u64 m_title_id;
QString m_issues; QString m_issues;
int m_emu_state = 0; int m_emu_state = 0;
@ -87,7 +88,7 @@ private:
QString CreateCacheFilename() const; QString CreateCacheFilename() const;
// Outputs to m_banner // Outputs to m_banner
void ReadBanner(const DiscIO::IVolume& volume); void ReadBanner(const std::vector<u32>& buffer, int width, int height);
// Outputs to m_short_names, m_long_names, m_descriptions, m_company. // Outputs to m_short_names, m_long_names, m_descriptions, m_company.
// Returns whether a file was found, not whether it contained useful data. // Returns whether a file was found, not whether it contained useful data.
bool ReadXML(const QString& file_path); bool ReadXML(const QString& file_path);

View File

@ -34,7 +34,7 @@
#include "DolphinWX/ISOFile.h" #include "DolphinWX/ISOFile.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
static const u32 CACHE_REVISION = 0x126; // Last changed in PR 3097 static const u32 CACHE_REVISION = 0x127; // Last changed in PR 3309
#define DVD_BANNER_WIDTH 96 #define DVD_BANNER_WIDTH 96
#define DVD_BANNER_HEIGHT 32 #define DVD_BANNER_HEIGHT 32
@ -63,6 +63,7 @@ static std::string GetLanguageString(DiscIO::IVolume::ELanguage language, std::m
GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_map<std::string, std::string>& custom_titles) GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_map<std::string, std::string>& custom_titles)
: m_FileName(_rFileName) : m_FileName(_rFileName)
, m_title_id(0)
, m_emu_state(0) , m_emu_state(0)
, m_FileSize(0) , m_FileSize(0)
, m_Country(DiscIO::IVolume::COUNTRY_UNKNOWN) , m_Country(DiscIO::IVolume::COUNTRY_UNKNOWN)
@ -82,15 +83,12 @@ GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_m
// if a banner has become available after the cache was made. // if a banner has become available after the cache was made.
if (m_pImage.empty()) if (m_pImage.empty())
{ {
std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(_rFileName)); std::vector<u32> buffer = DiscIO::IVolume::GetWiiBanner(&m_ImageWidth, &m_ImageHeight, m_title_id);
if (volume != nullptr) ReadVolumeBanner(buffer, m_ImageWidth, m_ImageHeight);
{
ReadVolumeBanner(*volume);
if (!m_pImage.empty()) if (!m_pImage.empty())
SaveToCache(); SaveToCache();
} }
} }
}
else else
{ {
std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(_rFileName)); std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(_rFileName));
@ -109,10 +107,12 @@ GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_m
m_VolumeSize = volume->GetSize(); m_VolumeSize = volume->GetSize();
m_UniqueID = volume->GetUniqueID(); m_UniqueID = volume->GetUniqueID();
volume->GetTitleID(&m_title_id);
m_disc_number = volume->GetDiscNumber(); m_disc_number = volume->GetDiscNumber();
m_Revision = volume->GetRevision(); m_Revision = volume->GetRevision();
ReadVolumeBanner(*volume); std::vector<u32> buffer = volume->GetBanner(&m_ImageWidth, &m_ImageHeight);
ReadVolumeBanner(buffer, m_ImageWidth, m_ImageHeight);
m_Valid = true; m_Valid = true;
SaveToCache(); SaveToCache();
@ -202,6 +202,7 @@ void GameListItem::DoState(PointerWrap &p)
p.Do(m_descriptions); p.Do(m_descriptions);
p.Do(m_company); p.Do(m_company);
p.Do(m_UniqueID); p.Do(m_UniqueID);
p.Do(m_title_id);
p.Do(m_FileSize); p.Do(m_FileSize);
p.Do(m_VolumeSize); p.Do(m_VolumeSize);
p.Do(m_Country); p.Do(m_Country);
@ -243,17 +244,14 @@ std::string GameListItem::CreateCacheFilename() const
} }
// Outputs to m_pImage // Outputs to m_pImage
void GameListItem::ReadVolumeBanner(const DiscIO::IVolume& volume) void GameListItem::ReadVolumeBanner(const std::vector<u32>& buffer, int width, int height)
{ {
std::vector<u32> Buffer = volume.GetBanner(&m_ImageWidth, &m_ImageHeight); m_pImage.resize(width * height * 3);
u32* pData = Buffer.data(); for (int i = 0; i < width * height; i++)
m_pImage.resize(m_ImageWidth * m_ImageHeight * 3);
for (int i = 0; i < m_ImageWidth * m_ImageHeight; i++)
{ {
m_pImage[i * 3 + 0] = (pData[i] & 0xFF0000) >> 16; m_pImage[i * 3 + 0] = (buffer[i] & 0xFF0000) >> 16;
m_pImage[i * 3 + 1] = (pData[i] & 0x00FF00) >> 8; m_pImage[i * 3 + 1] = (buffer[i] & 0x00FF00) >> 8;
m_pImage[i * 3 + 2] = (pData[i] & 0x0000FF) >> 0; m_pImage[i * 3 + 2] = (buffer[i] & 0x0000FF) >> 0;
} }
} }

View File

@ -65,6 +65,7 @@ private:
std::string m_company; std::string m_company;
std::string m_UniqueID; std::string m_UniqueID;
u64 m_title_id;
std::string m_issues; std::string m_issues;
int m_emu_state; int m_emu_state;
@ -95,7 +96,7 @@ private:
std::string CreateCacheFilename() const; std::string CreateCacheFilename() const;
// Outputs to m_pImage // Outputs to m_pImage
void ReadVolumeBanner(const DiscIO::IVolume& volume); void ReadVolumeBanner(const std::vector<u32>& buffer, int width, int height);
// Outputs to m_Bitmap // Outputs to m_Bitmap
bool ReadPNGBanner(const std::string& path); bool ReadPNGBanner(const std::string& path);