diff options
author | Subv <subv2112@gmail.com> | 2017-06-13 21:50:22 -0500 |
---|---|---|
committer | Subv <subv2112@gmail.com> | 2017-06-15 12:08:54 -0500 |
commit | 61ce89a55ac6ff12f881e3bba0220ac3f04fbf50 (patch) | |
tree | 94f6a763cbc68198317556551ae31fe43a1cc44f /src | |
parent | 7efb64132db95ef787481026a22d5b8244627a04 (diff) |
UDS: Return the correct error messages in SendTo when not connected to a network or trying to send to itself.
Diffstat (limited to 'src')
-rw-r--r-- | src/core/hle/service/nwm/nwm_uds.cpp | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/src/core/hle/service/nwm/nwm_uds.cpp b/src/core/hle/service/nwm/nwm_uds.cpp index f6125825f..c43c5ca44 100644 --- a/src/core/hle/service/nwm/nwm_uds.cpp +++ b/src/core/hle/service/nwm/nwm_uds.cpp @@ -404,15 +404,22 @@ static void SendTo(Interface* self) { const VAddr input_address = rp.PopStaticBuffer(&desc_size, false); ASSERT(desc_size == data_size); - // TODO(Subv): Figure out the error if this is called while not connected to a network. - if (connection_status.status == static_cast<u32>(NetworkStatus::ConnectedAsClient) || - connection_status.status == static_cast<u32>(NetworkStatus::ConnectedAsHost)) { - ASSERT_MSG(false, "Not connected to a network (unimplemented)"); + IPC::RequestBuilder rb = rp.MakeBuilder(1, 0); + + if (connection_status.status != static_cast<u32>(NetworkStatus::ConnectedAsClient) && + connection_status.status != static_cast<u32>(NetworkStatus::ConnectedAsHost)) { + rb.Push(ResultCode(ErrorDescription::NotAuthorized, ErrorModule::UDS, + ErrorSummary::InvalidState, ErrorLevel::Status)); + return; } - // TODO(Subv): Do something with the flags. + if (dest_node_id == connection_status.network_node_id) { + rb.Push(ResultCode(ErrorDescription::NotFound, ErrorModule::UDS, + ErrorSummary::WrongArgument, ErrorLevel::Status)); + return; + } - IPC::RequestBuilder rb = rp.MakeBuilder(1, 0); + // TODO(Subv): Do something with the flags. constexpr size_t MaxSize = 0x5C6; if (data_size > MaxSize) { |