mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-26 01:49:46 +00:00 
			
		
		
		
	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:
		
					parent
					
						
							
								a5904b522d
							
						
					
				
			
			
				commit
				
					
						a0cd753060
					
				
			
		
					 12 changed files with 79 additions and 39 deletions
				
			
		|  | @ -90,7 +90,7 @@ public: | |||
| 	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::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 std::string GetApploaderDate() const = 0; | ||||
| 	// 0 is the first disc, 1 is the second disc
 | ||||
|  | @ -108,6 +108,8 @@ public: | |||
| 	// Size on disc (compressed size)
 | ||||
| 	virtual u64 GetRawSize() const = 0; | ||||
| 
 | ||||
| 	static std::vector<u32> GetWiiBanner(int* width, int* height, u64 title_id); | ||||
| 
 | ||||
| protected: | ||||
| 	template <u32 N> | ||||
| 	std::string DecodeString(const char(&data)[N]) const | ||||
|  |  | |||
|  | @ -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_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; | ||||
| 	*height = 0; | ||||
| 
 | ||||
| 	u64 title_id = 0; | ||||
| 	GetTitleID(&title_id); | ||||
| 
 | ||||
| 	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); | ||||
| 	if (!File::Exists(file_name)) | ||||
|  |  | |||
|  | @ -183,7 +183,8 @@ IVolume::ECountry CVolumeDirectory::GetCountry() const | |||
| 
 | ||||
| std::string CVolumeDirectory::GetMakerID() const | ||||
| { | ||||
| 	return "VOID"; | ||||
| 	// Not implemented
 | ||||
| 	return "00"; | ||||
| } | ||||
| 
 | ||||
| std::string CVolumeDirectory::GetInternalName() const | ||||
|  | @ -204,6 +205,14 @@ std::map<IVolume::ELanguage, std::string> CVolumeDirectory::GetNames(bool prefer | |||
| 	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) | ||||
| { | ||||
| 	size_t length = name.length(); | ||||
|  | @ -216,11 +225,13 @@ void CVolumeDirectory::SetName(const std::string& name) | |||
| 
 | ||||
| u64 CVolumeDirectory::GetFSTSize() const | ||||
| { | ||||
| 	// Not implemented
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| std::string CVolumeDirectory::GetApploaderDate() const | ||||
| { | ||||
| 	// Not implemented
 | ||||
| 	return "VOID"; | ||||
| } | ||||
| 
 | ||||
|  | @ -239,12 +250,14 @@ BlobType CVolumeDirectory::GetBlobType() const | |||
| 
 | ||||
| u64 CVolumeDirectory::GetSize() const | ||||
| { | ||||
| 	// Not implemented
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| u64 CVolumeDirectory::GetRawSize() const | ||||
| { | ||||
| 	return GetSize(); | ||||
| 	// Not implemented
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| std::string CVolumeDirectory::ExtractDirectoryName(const std::string& _rDirectory) | ||||
|  |  | |||
|  | @ -43,6 +43,7 @@ public: | |||
| 	u16 GetRevision() const override { return 0; } | ||||
| 	std::string GetInternalName() 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&); | ||||
| 
 | ||||
| 	u64 GetFSTSize() const override; | ||||
|  |  | |||
|  | @ -127,6 +127,18 @@ std::map<IVolume::ELanguage, std::string> CVolumeWAD::GetNames(bool prefer_long) | |||
| 	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 | ||||
| { | ||||
| 	return m_pReader ? m_pReader->GetBlobType() : BlobType::PLAIN; | ||||
|  |  | |||
|  | @ -32,6 +32,7 @@ public: | |||
| 	u16 GetRevision() const override; | ||||
| 	std::string GetInternalName() const override { return ""; } | ||||
| 	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; } | ||||
| 	std::string GetApploaderDate() const override { return ""; } | ||||
| 
 | ||||
|  |  | |||
|  | @ -212,6 +212,18 @@ std::map<IVolume::ELanguage, std::string> CVolumeWiiCrypted::GetNames(bool prefe | |||
| 	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 | ||||
| { | ||||
| 	if (m_pReader == nullptr) | ||||
|  |  | |||
|  | @ -32,6 +32,7 @@ public: | |||
| 	u16 GetRevision() const override; | ||||
| 	std::string GetInternalName() 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; | ||||
| 	std::string GetApploaderDate() const override; | ||||
| 	u8 GetDiscNumber() const override; | ||||
|  |  | |||
|  | @ -24,7 +24,7 @@ | |||
| 
 | ||||
| #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 QMap<DiscIO::IVolume::ELanguage, QString> ConvertLocalizedStrings(std::map<DiscIO::IVolume::ELanguage, std::string> strings) | ||||
|  | @ -84,13 +84,11 @@ GameFile::GameFile(const QString& fileName) | |||
| 		// if a banner has become available after the cache was made.
 | ||||
| 		if (m_banner.isNull()) | ||||
| 		{ | ||||
| 			std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(fileName.toStdString())); | ||||
| 			if (volume != nullptr) | ||||
| 			{ | ||||
| 				ReadBanner(*volume); | ||||
| 				if (!m_banner.isNull()) | ||||
| 					SaveToCache(); | ||||
| 			} | ||||
| 			int width, height; | ||||
| 			std::vector<u32> buffer = DiscIO::IVolume::GetWiiBanner(&width, &height, m_title_id); | ||||
| 			ReadBanner(buffer, width, height); | ||||
| 			if (!m_banner.isNull()) | ||||
| 				SaveToCache(); | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
|  | @ -112,10 +110,13 @@ GameFile::GameFile(const QString& fileName) | |||
| 			m_volume_size = volume->GetSize(); | ||||
| 
 | ||||
| 			m_unique_id = QString::fromStdString(volume->GetUniqueID()); | ||||
| 			volume->GetTitleID(&m_title_id); | ||||
| 			m_disc_number = volume->GetDiscNumber(); | ||||
| 			m_revision = volume->GetRevision(); | ||||
| 
 | ||||
| 			ReadBanner(*volume); | ||||
| 			int width, height; | ||||
| 			std::vector<u32> buffer = volume->GetBanner(&width, &height); | ||||
| 			ReadBanner(buffer, width, height); | ||||
| 
 | ||||
| 			m_valid = true; | ||||
| 			SaveToCache(); | ||||
|  | @ -188,6 +189,7 @@ bool GameFile::LoadFromCache() | |||
| 	       >> descriptions | ||||
| 	       >> m_company | ||||
| 	       >> m_unique_id | ||||
| 	       >> m_title_id | ||||
| 	       >> blob_type | ||||
| 	       >> m_file_size | ||||
| 	       >> m_volume_size | ||||
|  | @ -231,6 +233,7 @@ void GameFile::SaveToCache() | |||
| 	       << CastLocalizedStrings<u8>(m_descriptions) | ||||
| 	       << m_company | ||||
| 	       << m_unique_id | ||||
| 	       << m_title_id | ||||
| 	       << (u32)m_blob_type | ||||
| 	       << m_file_size | ||||
| 	       << m_volume_size | ||||
|  | @ -267,10 +270,8 @@ QString GameFile::CreateCacheFilename() const | |||
| } | ||||
| 
 | ||||
| // 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); | ||||
| 	for (int i = 0; i < width * height; i++) | ||||
| 	{ | ||||
|  |  | |||
|  | @ -64,6 +64,7 @@ private: | |||
| 	QString m_company; | ||||
| 
 | ||||
| 	QString m_unique_id; | ||||
| 	u64 m_title_id; | ||||
| 
 | ||||
| 	QString m_issues; | ||||
| 	int m_emu_state = 0; | ||||
|  | @ -87,7 +88,7 @@ private: | |||
| 	QString CreateCacheFilename() const; | ||||
| 
 | ||||
| 	// 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.
 | ||||
| 	// Returns whether a file was found, not whether it contained useful data.
 | ||||
| 	bool ReadXML(const QString& file_path); | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ | |||
| #include "DolphinWX/ISOFile.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_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) | ||||
| 	: m_FileName(_rFileName) | ||||
| 	, m_title_id(0) | ||||
| 	, m_emu_state(0) | ||||
| 	, m_FileSize(0) | ||||
| 	, m_Country(DiscIO::IVolume::COUNTRY_UNKNOWN) | ||||
|  | @ -82,13 +83,10 @@ GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_m | |||
| 		// if a banner has become available after the cache was made.
 | ||||
| 		if (m_pImage.empty()) | ||||
| 		{ | ||||
| 			std::unique_ptr<DiscIO::IVolume> volume(DiscIO::CreateVolumeFromFilename(_rFileName)); | ||||
| 			if (volume != nullptr) | ||||
| 			{ | ||||
| 				ReadVolumeBanner(*volume); | ||||
| 				if (!m_pImage.empty()) | ||||
| 					SaveToCache(); | ||||
| 			} | ||||
| 			std::vector<u32> buffer = DiscIO::IVolume::GetWiiBanner(&m_ImageWidth, &m_ImageHeight, m_title_id); | ||||
| 			ReadVolumeBanner(buffer, m_ImageWidth, m_ImageHeight); | ||||
| 			if (!m_pImage.empty()) | ||||
| 				SaveToCache(); | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
|  | @ -109,10 +107,12 @@ GameListItem::GameListItem(const std::string& _rFileName, const std::unordered_m | |||
| 			m_VolumeSize = volume->GetSize(); | ||||
| 
 | ||||
| 			m_UniqueID = volume->GetUniqueID(); | ||||
| 			volume->GetTitleID(&m_title_id); | ||||
| 			m_disc_number = volume->GetDiscNumber(); | ||||
| 			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; | ||||
| 			SaveToCache(); | ||||
|  | @ -202,6 +202,7 @@ void GameListItem::DoState(PointerWrap &p) | |||
| 	p.Do(m_descriptions); | ||||
| 	p.Do(m_company); | ||||
| 	p.Do(m_UniqueID); | ||||
| 	p.Do(m_title_id); | ||||
| 	p.Do(m_FileSize); | ||||
| 	p.Do(m_VolumeSize); | ||||
| 	p.Do(m_Country); | ||||
|  | @ -243,17 +244,14 @@ std::string GameListItem::CreateCacheFilename() const | |||
| } | ||||
| 
 | ||||
| // 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); | ||||
| 	u32* pData = Buffer.data(); | ||||
| 	m_pImage.resize(m_ImageWidth * m_ImageHeight * 3); | ||||
| 
 | ||||
| 	for (int i = 0; i < m_ImageWidth * m_ImageHeight; i++) | ||||
| 	m_pImage.resize(width * height * 3); | ||||
| 	for (int i = 0; i < width * height; i++) | ||||
| 	{ | ||||
| 		m_pImage[i * 3 + 0] = (pData[i] & 0xFF0000) >> 16; | ||||
| 		m_pImage[i * 3 + 1] = (pData[i] & 0x00FF00) >> 8; | ||||
| 		m_pImage[i * 3 + 2] = (pData[i] & 0x0000FF) >> 0; | ||||
| 		m_pImage[i * 3 + 0] = (buffer[i] & 0xFF0000) >> 16; | ||||
| 		m_pImage[i * 3 + 1] = (buffer[i] & 0x00FF00) >> 8; | ||||
| 		m_pImage[i * 3 + 2] = (buffer[i] & 0x0000FF) >> 0; | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -65,6 +65,7 @@ private: | |||
| 	std::string m_company; | ||||
| 
 | ||||
| 	std::string m_UniqueID; | ||||
| 	u64 m_title_id; | ||||
| 
 | ||||
| 	std::string m_issues; | ||||
| 	int m_emu_state; | ||||
|  | @ -95,7 +96,7 @@ private: | |||
| 	std::string CreateCacheFilename() const; | ||||
| 
 | ||||
| 	// 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
 | ||||
| 	bool ReadPNGBanner(const std::string& path); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue