mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
Merge pull request #5329 from leoetlino/clear
IOS/ES: Drop unnecessary memset for vectors
This commit is contained in:
commit
8028564a07
@ -72,12 +72,6 @@ IOCtlVRequest::IOCtlVRequest(const u32 address_) : Request(address_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IOCtlVRequest::HasInputVectorWithAddress(const u32 vector_address) const
|
|
||||||
{
|
|
||||||
return std::any_of(in_vectors.begin(), in_vectors.end(),
|
|
||||||
[&](const auto& in_vector) { return in_vector.address == vector_address; });
|
|
||||||
}
|
|
||||||
|
|
||||||
bool IOCtlVRequest::HasNumberOfValidVectors(const size_t in_count, const size_t io_count) const
|
bool IOCtlVRequest::HasNumberOfValidVectors(const size_t in_count, const size_t io_count) const
|
||||||
{
|
{
|
||||||
if (in_vectors.size() != in_count || io_vectors.size() != io_count)
|
if (in_vectors.size() != in_count || io_vectors.size() != io_count)
|
||||||
|
@ -153,7 +153,6 @@ struct IOCtlVRequest final : Request
|
|||||||
std::vector<IOVector> in_vectors;
|
std::vector<IOVector> in_vectors;
|
||||||
std::vector<IOVector> io_vectors;
|
std::vector<IOVector> io_vectors;
|
||||||
explicit IOCtlVRequest(u32 address);
|
explicit IOCtlVRequest(u32 address);
|
||||||
bool HasInputVectorWithAddress(u32 vector_address) const;
|
|
||||||
bool HasNumberOfValidVectors(size_t in_count, size_t io_count) const;
|
bool HasNumberOfValidVectors(size_t in_count, size_t io_count) const;
|
||||||
void Dump(const std::string& description, LogTypes::LOG_TYPE type = LogTypes::IOS,
|
void Dump(const std::string& description, LogTypes::LOG_TYPE type = LogTypes::IOS,
|
||||||
LogTypes::LOG_LEVELS level = LogTypes::LINFO) const;
|
LogTypes::LOG_LEVELS level = LogTypes::LINFO) const;
|
||||||
|
@ -345,13 +345,6 @@ IPCCommandResult ES::IOCtlV(const IOCtlVRequest& request)
|
|||||||
{
|
{
|
||||||
DEBUG_LOG(IOS_ES, "%s (0x%x)", GetDeviceName().c_str(), request.request);
|
DEBUG_LOG(IOS_ES, "%s (0x%x)", GetDeviceName().c_str(), request.request);
|
||||||
|
|
||||||
// Clear the IO buffers. Note that this is unsafe for other ioctlvs.
|
|
||||||
for (const auto& io_vector : request.io_vectors)
|
|
||||||
{
|
|
||||||
if (!request.HasInputVectorWithAddress(io_vector.address))
|
|
||||||
Memory::Memset(io_vector.address, 0, io_vector.size);
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (request.request)
|
switch (request.request)
|
||||||
{
|
{
|
||||||
case IOCTL_ES_ADDTICKET:
|
case IOCTL_ES_ADDTICKET:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user