mirror of
https://github.com/GaryOderNichts/WiiUIdent.git
synced 2024-09-10 15:03:21 +02:00
Add DRC/DRH information
This commit is contained in:
parent
6d5b19a8a6
commit
720ed1bb30
@ -32,6 +32,12 @@ WiiUIdent currently displays:
|
||||
- Production Date (MLC only)
|
||||
- Size
|
||||
- CID/CSD
|
||||
- DRC/DRH information
|
||||
- Running Version
|
||||
- Active Version
|
||||
- Board Version
|
||||
- Region
|
||||
- Ext IDs
|
||||
|
||||
## System Database
|
||||
WiiUIdent comes with an option to optionally upload system information to a database. This allows collecting various statistics about Wii U consoles.
|
||||
|
170
source/screens/DRXInfoScreen.cpp
Normal file
170
source/screens/DRXInfoScreen.cpp
Normal file
@ -0,0 +1,170 @@
|
||||
#include "DRXInfoScreen.hpp"
|
||||
#include "Utils.hpp"
|
||||
#include <span>
|
||||
|
||||
#include <nsysccr/cdc.h>
|
||||
#include <nsysccr/cfg.h>
|
||||
|
||||
namespace {
|
||||
|
||||
bool GetEepromValue(uint32_t offset, std::span<uint8_t> value)
|
||||
{
|
||||
uint8_t data[value.size() + 2];
|
||||
if (CCRCFGGetCachedEeprom(0, offset, data, value.size() + 2) != 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t crc = (uint16_t) data[value.size() + 1] << 8 | data[value.size()];
|
||||
if (CCRCDCCalcCRC16(data, value.size()) != crc) {
|
||||
return false;
|
||||
}
|
||||
|
||||
std::copy(data, data + value.size(), value.begin());
|
||||
return true;
|
||||
}
|
||||
|
||||
// from gamepad firmare @0x000b2990
|
||||
const char* kBoardMainVersions[] = {
|
||||
"DK1",
|
||||
"DK1 / EP / DK2",
|
||||
"DP1",
|
||||
"DP2",
|
||||
"DK3",
|
||||
"DK4",
|
||||
"PreDP3 / DP3",
|
||||
"DK5",
|
||||
"DP4",
|
||||
"DKMP",
|
||||
"DP5",
|
||||
"MASS",
|
||||
"DKMP2",
|
||||
"DRC-I",
|
||||
"DKTVMP",
|
||||
};
|
||||
|
||||
// from gamepad firmare @0x000b29cc
|
||||
const char* kBoardSubVersions[] = {
|
||||
"DK1 / EP / DK2",
|
||||
"DP1 / DK3",
|
||||
"DK4",
|
||||
"DP3",
|
||||
"DK5",
|
||||
"DP4",
|
||||
"DKMP",
|
||||
"DP5",
|
||||
"MASS",
|
||||
"DKMP2",
|
||||
"DRC-I",
|
||||
"DKTVMP"
|
||||
};
|
||||
|
||||
// from gamepad firmare @0x000b29fc
|
||||
const char* kRegionStrings[] = {
|
||||
"JAPAN",
|
||||
"AMERICA",
|
||||
"EUROPE",
|
||||
"CHINA",
|
||||
"SOUTH KOREA",
|
||||
"TAIWAN",
|
||||
"AUSTRALIA",
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
DRXInfoScreen::DRXInfoScreen()
|
||||
{
|
||||
CCRCDCSoftwareVersion softwareVersion;
|
||||
if (CCRCDCSoftwareGetVersion(CCR_CDC_DESTINATION_DRC0, &softwareVersion) == 0) {
|
||||
uint32_t v = softwareVersion.runningVersion;
|
||||
mDRCList.push_back({"Running Version:", Utils::sprintf("%d.%d.%d", v >> 24 & 0xff, v >> 16 & 0xff, v & 0xffff)});
|
||||
mDRCList.push_back({"", {Utils::sprintf("(0x%08x)", v), true}});
|
||||
v = softwareVersion.activeVersion;
|
||||
mDRCList.push_back({"Active Version:", Utils::sprintf("%d.%d.%d", v >> 24 & 0xff, v >> 16 & 0xff, v & 0xffff)});
|
||||
mDRCList.push_back({"", {Utils::sprintf("(0x%08x)", v), true}});
|
||||
} else {
|
||||
mDRCList.push_back({"CCRCDCSoftwareGetVersion failed", ""});
|
||||
}
|
||||
|
||||
uint8_t boardInfo;
|
||||
if (GetEepromValue(0x100, std::span(std::addressof(boardInfo), 1))) {
|
||||
uint8_t mainVersion = boardInfo & 0xf;
|
||||
uint8_t subVersion = boardInfo >> 4;
|
||||
mDRCList.push_back({"Board Version:", Utils::sprintf("%d.%d (0x%02x)", mainVersion, subVersion, boardInfo)});
|
||||
mDRCList.push_back({"", Utils::sprintf("(%s / %s)",
|
||||
mainVersion < 0xf ? kBoardMainVersions[mainVersion] : "UNKNOWN",
|
||||
subVersion < 0xc ? kBoardSubVersions[subVersion] : "UNKNOWN")});
|
||||
} else {
|
||||
mDRCList.push_back({"GetEepromValue failed", ""});
|
||||
}
|
||||
|
||||
uint8_t region;
|
||||
if (GetEepromValue(0x103, std::span(std::addressof(region), 1))) {
|
||||
mDRCList.push_back({"Region:", Utils::sprintf("%s (0x%02x)",
|
||||
region < 0x7 ? kRegionStrings[region] : "UNKNOWN", region)});
|
||||
} else {
|
||||
mDRCList.push_back({"GetRegion failed", ""});
|
||||
}
|
||||
|
||||
if (CCRCDCSoftwareGetVersion(CCR_CDC_DESTINATION_DRH, &softwareVersion) == 0) {
|
||||
uint32_t v = softwareVersion.runningVersion;
|
||||
mDRHList.push_back({"Running Version:", Utils::sprintf("%d.%d.%d", v >> 24 & 0xff, v >> 16 & 0xff, v & 0xffff)});
|
||||
mDRHList.push_back({"", {Utils::sprintf("(0x%08x)", v), true}});
|
||||
v = softwareVersion.activeVersion;
|
||||
mDRHList.push_back({"Active Version:", Utils::sprintf("%d.%d.%d", v >> 24 & 0xff, v >> 16 & 0xff, v & 0xffff)});
|
||||
mDRHList.push_back({"", {Utils::sprintf("(0x%08x)", v), true}});
|
||||
} else {
|
||||
mDRHList.push_back({"CCRCDCSoftwareGetVersion failed", ""});
|
||||
}
|
||||
|
||||
uint32_t extId;
|
||||
if (CCRCDCSoftwareGetExtId(CCR_CDC_DESTINATION_DRC0, CCR_CDC_EXT_LANGUAGE, &extId) == 0) {
|
||||
mExtIdList.push_back({"Language:", {Utils::sprintf("0x%08x", extId), true}});
|
||||
mExtIdList.push_back({"", Utils::sprintf("(version: %04d bank: %02d)", extId >> 8 & 0xffff, extId >> 24)});
|
||||
} else {
|
||||
mExtIdList.push_back({"CCRCDCSoftwareGetExtId(CCR_CDC_EXT_LANGUAGE) failed", ""});
|
||||
}
|
||||
|
||||
if (CCRCDCSoftwareGetExtId(CCR_CDC_DESTINATION_DRC0, CCR_CDC_EXT_RC_DATABASE, &extId) == 0) {
|
||||
mExtIdList.push_back({"RC Database:", {Utils::sprintf("0x%08x", extId), true}});
|
||||
} else {
|
||||
mExtIdList.push_back({"CCRCDCSoftwareGetExtId(CCR_CDC_EXT_RC_DATABASE) failed", ""});
|
||||
}
|
||||
|
||||
for (int i = CCR_CDC_EXT_UNK2; i <= CCR_CDC_EXT_UNK4; i++) {
|
||||
if (CCRCDCSoftwareGetExtId(CCR_CDC_DESTINATION_DRC0, (CCRCDCExt) i, &extId) == 0) {
|
||||
mExtIdList.push_back({Utils::sprintf("ID %d:", i), {Utils::sprintf("0x%08x", extId), true}});
|
||||
} else {
|
||||
mExtIdList.push_back({Utils::sprintf("CCRCDCSoftwareGetExtId(%d) failed", i), ""});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DRXInfoScreen::~DRXInfoScreen()
|
||||
{
|
||||
}
|
||||
|
||||
void DRXInfoScreen::Draw()
|
||||
{
|
||||
DrawTopBar("DRC/DRH Information");
|
||||
|
||||
int yOff = 128;
|
||||
yOff = DrawHeader(32, yOff, 896, 0xf11b, "DRC Info");
|
||||
yOff = DrawList(32, yOff, 896, mDRCList);
|
||||
yOff = DrawHeader(32, yOff, 896, 0xf0cb, "DRC Ext IDs");
|
||||
yOff = DrawList(32, yOff, 896, mExtIdList);
|
||||
|
||||
yOff = 128;
|
||||
yOff = DrawHeader(992, yOff, 896, 0xf2db, "DRH Info");
|
||||
yOff = DrawList(992, yOff, 896, mDRHList);
|
||||
|
||||
DrawBottomBar(nullptr, "\ue044 Exit", "\ue001 Back");
|
||||
}
|
||||
|
||||
bool DRXInfoScreen::Update(VPADStatus& input)
|
||||
{
|
||||
if (input.trigger & VPAD_BUTTON_B) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
20
source/screens/DRXInfoScreen.hpp
Normal file
20
source/screens/DRXInfoScreen.hpp
Normal file
@ -0,0 +1,20 @@
|
||||
#pragma once
|
||||
|
||||
#include "Screen.hpp"
|
||||
|
||||
class DRXInfoScreen : public Screen
|
||||
{
|
||||
public:
|
||||
DRXInfoScreen();
|
||||
virtual ~DRXInfoScreen();
|
||||
|
||||
void Draw();
|
||||
|
||||
bool Update(VPADStatus& input);
|
||||
|
||||
private:
|
||||
ScreenList mDRCList;
|
||||
ScreenList mExtIdList;
|
||||
|
||||
ScreenList mDRHList;
|
||||
};
|
@ -1,6 +1,7 @@
|
||||
#include "MenuScreen.hpp"
|
||||
#include "Gfx.hpp"
|
||||
#include "AboutScreen.hpp"
|
||||
#include "DRXInfoScreen.hpp"
|
||||
#include "GeneralScreen.hpp"
|
||||
#include "StorageScreen.hpp"
|
||||
#include "SubmitScreen.hpp"
|
||||
@ -11,6 +12,7 @@ MenuScreen::MenuScreen()
|
||||
: entries({
|
||||
{ MENU_ID_GENERAL, { 0xf085, "General System Information" }},
|
||||
{ MENU_ID_STORAGE, { 0xf7c2, "Storage Information" }},
|
||||
{ MENU_ID_DRX, { 0xf11b, "DRC/DRH Information" }},
|
||||
{ MENU_ID_SUBMIT, { 0xf0ee, "Submit System Information" }},
|
||||
// { MENU_ID_TITLE, { 0xf022, "Title Information" }},
|
||||
{ MENU_ID_ABOUT, { 0xf05a, "About WiiUIdent" }},
|
||||
@ -76,6 +78,9 @@ bool MenuScreen::Update(VPADStatus& input)
|
||||
case MENU_ID_STORAGE:
|
||||
subscreen = std::make_unique<StorageScreen>();
|
||||
break;
|
||||
case MENU_ID_DRX:
|
||||
subscreen = std::make_unique<DRXInfoScreen>();
|
||||
break;
|
||||
case MENU_ID_SUBMIT:
|
||||
subscreen = std::make_unique<SubmitScreen>();
|
||||
break;
|
||||
|
@ -20,6 +20,7 @@ private:
|
||||
enum MenuID {
|
||||
MENU_ID_GENERAL,
|
||||
MENU_ID_STORAGE,
|
||||
MENU_ID_DRX,
|
||||
MENU_ID_SUBMIT,
|
||||
MENU_ID_ABOUT,
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user