mirror of
https://github.com/citra-emu/citra-canary.git
synced 2025-01-22 20:11:10 +00:00
service/cecd: Fix buffer writes in ReadData. (#6880)
This commit is contained in:
parent
eb8d2941c9
commit
a27971e723
|
@ -620,9 +620,9 @@ void Module::Interface::SetData(Kernel::HLERequestContext& ctx) {
|
||||||
|
|
||||||
void Module::Interface::ReadData(Kernel::HLERequestContext& ctx) {
|
void Module::Interface::ReadData(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::RequestParser rp(ctx);
|
IPC::RequestParser rp(ctx);
|
||||||
const u32 dest_buffer_size = rp.Pop<u32>();
|
const auto dest_buffer_size = rp.Pop<u32>();
|
||||||
const CecSystemInfoType info_type = rp.PopEnum<CecSystemInfoType>();
|
const auto info_type = rp.PopEnum<CecSystemInfoType>();
|
||||||
const u32 param_buffer_size = rp.Pop<u32>();
|
const auto param_buffer_size = rp.Pop<u32>();
|
||||||
auto& param_buffer = rp.PopMappedBuffer();
|
auto& param_buffer = rp.PopMappedBuffer();
|
||||||
auto& dest_buffer = rp.PopMappedBuffer();
|
auto& dest_buffer = rp.PopMappedBuffer();
|
||||||
|
|
||||||
|
@ -631,22 +631,23 @@ void Module::Interface::ReadData(Kernel::HLERequestContext& ctx) {
|
||||||
std::vector<u8> buffer;
|
std::vector<u8> buffer;
|
||||||
switch (info_type) {
|
switch (info_type) {
|
||||||
case CecSystemInfoType::EulaVersion: {
|
case CecSystemInfoType::EulaVersion: {
|
||||||
auto cfg = Service::CFG::GetModule(cecd->system);
|
const auto cfg = Service::CFG::GetModule(cecd->system);
|
||||||
Service::CFG::EULAVersion version = cfg->GetEULAVersion();
|
const auto version = cfg->GetEULAVersion();
|
||||||
dest_buffer.Write(&version, 0, sizeof(version));
|
buffer = {version.minor, version.major};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case CecSystemInfoType::Eula:
|
case CecSystemInfoType::Eula:
|
||||||
buffer = {0x01}; // Eula agreed
|
buffer = {true}; // Eula agreed
|
||||||
dest_buffer.Write(buffer.data(), 0, buffer.size());
|
|
||||||
break;
|
break;
|
||||||
case CecSystemInfoType::ParentControl:
|
case CecSystemInfoType::ParentControl:
|
||||||
buffer = {0x00}; // No parent control
|
buffer = {false}; // No parent control
|
||||||
dest_buffer.Write(buffer.data(), 0, buffer.size());
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG_ERROR(Service_CECD, "Unknown system info type={:#x}", info_type);
|
LOG_ERROR(Service_CECD, "Unknown system info type={:#x}", info_type);
|
||||||
|
buffer = {};
|
||||||
}
|
}
|
||||||
|
dest_buffer.Write(buffer.data(), 0,
|
||||||
|
std::min(static_cast<size_t>(dest_buffer_size), buffer.size()));
|
||||||
|
|
||||||
rb.Push(RESULT_SUCCESS);
|
rb.Push(RESULT_SUCCESS);
|
||||||
rb.PushMappedBuffer(param_buffer);
|
rb.PushMappedBuffer(param_buffer);
|
||||||
|
|
Loading…
Reference in a new issue