IOS/SO: Re-implement GetInterfaceOpt(0x4003)
Use the newly added GetSystemDefaultInterfaceOrFallback() to return actual information for the default interface, not just dummy interface details. This also fixes GetInterfaceOpt(0x4003) and gethostid() returning inconsistent information. Prior to this change, GetInterfaceOpt(0x4003) would return 10.0.1.30 and gethostid would give a totally unrelated IP.
This commit is contained in:
parent
3ce271991b
commit
32d51f1699
|
@ -884,11 +884,16 @@ IPCCommandResult NetIPTop::HandleGetInterfaceOptRequest(const IOCtlVRequest& req
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x4003: // ip addr table
|
case 0x4003: // ip addr table
|
||||||
|
{
|
||||||
|
// XXX: this isn't exactly right; the buffer can be larger than 12 bytes, in which case
|
||||||
|
// SO can write 12 more bytes.
|
||||||
Memory::Write_U32(0xC, request.io_vectors[1].address);
|
Memory::Write_U32(0xC, request.io_vectors[1].address);
|
||||||
Memory::Write_U32(inet_addr(10, 0, 1, 30), request.io_vectors[0].address);
|
const DefaultInterface interface = GetSystemDefaultInterfaceOrFallback();
|
||||||
Memory::Write_U32(inet_addr(255, 255, 255, 0), request.io_vectors[0].address + 4);
|
Memory::Write_U32(Common::swap32(interface.inet), request.io_vectors[0].address);
|
||||||
Memory::Write_U32(inet_addr(10, 0, 255, 255), request.io_vectors[0].address + 8);
|
Memory::Write_U32(Common::swap32(interface.netmask), request.io_vectors[0].address + 4);
|
||||||
|
Memory::Write_U32(Common::swap32(interface.broadcast), request.io_vectors[0].address + 8);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case 0x4005: // hardcoded value
|
case 0x4005: // hardcoded value
|
||||||
Memory::Write_U32(0x20, request.io_vectors[0].address);
|
Memory::Write_U32(0x20, request.io_vectors[0].address);
|
||||||
|
|
Loading…
Reference in New Issue