|
|
dd89bb |
/********************************************************/
|
|
|
dd89bb |
/* ntapi: Native API core library */
|
|
|
4256e2 |
/* Copyright (C) 2013--2016 Z. Gilboa */
|
|
|
dd89bb |
/* Released under GPLv2 and GPLv3; see COPYING.NTAPI. */
|
|
|
dd89bb |
/********************************************************/
|
|
|
dd89bb |
|
|
|
dd89bb |
#include <psxtypes/psxtypes.h>
|
|
|
dd89bb |
#include <ntapi/nt_object.h>
|
|
|
dd89bb |
#include <ntapi/nt_file.h>
|
|
|
dd89bb |
#include <ntapi/nt_socket.h>
|
|
|
dd89bb |
#include <ntapi/ntapi.h>
|
|
|
dd89bb |
#include "ntapi_impl.h"
|
|
|
dd89bb |
|
|
|
dd89bb |
/* weed in Redmond during the 1990's anyone? */
|
|
|
dd89bb |
typedef struct _nt_afd_connect_request {
|
|
|
dd89bb |
uintptr_t unknown;
|
|
|
dd89bb |
void * paddr;
|
|
|
dd89bb |
void * hasync;
|
|
|
dd89bb |
uint32_t type;
|
|
|
dd89bb |
uint32_t service_flags;
|
|
|
dd89bb |
char sa_data[14];
|
|
|
dd89bb |
uint16_t hangover;
|
|
|
dd89bb |
uint32_t unused;
|
|
|
dd89bb |
} nt_afd_connect_request;
|
|
|
dd89bb |
|
|
|
dd89bb |
typedef struct __addr_memcpy {
|
|
|
dd89bb |
uint16_t d0;
|
|
|
dd89bb |
uint16_t d1;
|
|
|
dd89bb |
uint16_t d2;
|
|
|
dd89bb |
uint16_t d3;
|
|
|
dd89bb |
uint16_t d4;
|
|
|
dd89bb |
uint16_t d5;
|
|
|
dd89bb |
uint16_t d6;
|
|
|
dd89bb |
uint16_t d7;
|
|
|
dd89bb |
} _addr_memcpy;
|
|
|
dd89bb |
|
|
|
dd89bb |
int32_t __cdecl __ntapi_sc_connect_v1(
|
|
|
dd89bb |
__in nt_socket * hssocket,
|
|
|
dd89bb |
__in nt_sockaddr * addr,
|
|
|
dd89bb |
__in uintptr_t addrlen,
|
|
|
dd89bb |
__in uintptr_t service_flags __optional,
|
|
|
dd89bb |
__out nt_io_status_block * iosb __optional)
|
|
|
dd89bb |
{
|
|
|
dd89bb |
nt_io_status_block siosb;
|
|
|
dd89bb |
nt_afd_connect_request afd_connect_req;
|
|
|
dd89bb |
|
|
|
dd89bb |
_addr_memcpy * src;
|
|
|
dd89bb |
_addr_memcpy * dst;
|
|
|
dd89bb |
|
|
|
dd89bb |
iosb = iosb ? iosb : &siosb;
|
|
|
dd89bb |
|
|
|
dd89bb |
/* service_flags */
|
|
|
dd89bb |
if (!service_flags)
|
|
|
dd89bb |
service_flags = 0x2000E;
|
|
|
dd89bb |
|
|
|
dd89bb |
/* afd_connect_req */
|
|
|
dd89bb |
afd_connect_req.type = hssocket->type;
|
|
|
dd89bb |
afd_connect_req.service_flags = (uint32_t)service_flags;
|
|
|
dd89bb |
|
|
|
dd89bb |
afd_connect_req.paddr = (void *)0;
|
|
|
dd89bb |
afd_connect_req.hasync = (void *)0;
|
|
|
dd89bb |
|
|
|
dd89bb |
afd_connect_req.unknown = 0;
|
|
|
dd89bb |
afd_connect_req.unused = 0;
|
|
|
dd89bb |
afd_connect_req.hangover = 0;
|
|
|
dd89bb |
|
|
|
dd89bb |
src = (_addr_memcpy *)addr;
|
|
|
dd89bb |
dst = (_addr_memcpy *)&(afd_connect_req.sa_data);
|
|
|
dd89bb |
|
|
|
dd89bb |
dst->d0 = src->d1;
|
|
|
dd89bb |
dst->d1 = src->d2;
|
|
|
dd89bb |
dst->d2 = src->d3;
|
|
|
dd89bb |
dst->d3 = src->d4;
|
|
|
dd89bb |
dst->d4 = src->d5;
|
|
|
dd89bb |
dst->d5 = src->d6;
|
|
|
dd89bb |
dst->d6 = src->d7;
|
|
|
dd89bb |
|
|
|
dd89bb |
hssocket->iostatus = __ntapi->zw_device_io_control_file(
|
|
|
dd89bb |
hssocket->hsocket,
|
|
|
dd89bb |
hssocket->hevent,
|
|
|
dd89bb |
0,
|
|
|
dd89bb |
0,
|
|
|
dd89bb |
iosb,
|
|
|
dd89bb |
NT_AFD_IOCTL_CONNECT,
|
|
|
dd89bb |
&afd_connect_req,
|
|
|
dd89bb |
sizeof(afd_connect_req),
|
|
|
dd89bb |
(void *)0,
|
|
|
dd89bb |
0);
|
|
|
dd89bb |
|
|
|
dd89bb |
return hssocket->iostatus
|
|
|
dd89bb |
? __ntapi->sc_wait(hssocket,iosb,0)
|
|
|
dd89bb |
: NT_STATUS_SUCCESS;
|
|
|
dd89bb |
}
|