#include "steamclient_private.h" WINE_DEFAULT_DEBUG_CHANNEL(steamclient); struct networking_message_pool { LONG ref; void *message_data; struct networking_message messages[]; }; C_ASSERT( sizeof(struct networking_message_pool) == offsetof( struct networking_message_pool, messages[0] ) ); static void networking_message_pool_release( struct networking_message_pool *pool ) { if (!InterlockedDecrement( &pool->ref )) { HeapFree( GetProcessHeap(), 0, pool->message_data ); HeapFree( GetProcessHeap(), 0, pool ); } } static BOOL networking_message_pool_alloc_data( uint32_t count, struct networking_message_pool *pool ) { uint32_t i, size; char *ptr; for (i = 0, size = 0; i < count; i++) size += *pool->messages[i].p_size; if (!(pool->message_data = HeapAlloc( GetProcessHeap(), 0, size ))) { ERR( "Failed to allocate memory for networking messages\n" ); return FALSE; } for (i = 0, ptr = pool->message_data; i < count; i++) { *pool->messages[i].p_data = ptr; ptr += *pool->messages[i].p_size; } return TRUE; } static void W_STDCALL w_SteamNetworkingMessage_t_144_FreeData( w_SteamNetworkingMessage_t_144 *msg ) { if (msg->m_pData) SecureZeroMemory( msg->m_pData, msg->m_cbSize ); } static void W_STDCALL w_SteamNetworkingMessage_t_144_Release( w_SteamNetworkingMessage_t_144 *msg ) { struct networking_message *message = CONTAINING_RECORD( msg, struct networking_message, w_msg_144 ); if (msg->m_pfnFreeData) msg->m_pfnFreeData( msg ); SecureZeroMemory( msg, sizeof(*msg) ); networking_message_pool_release( message->pool ); } static w_SteamNetworkingMessage_t_144 *networking_message_init_144( struct networking_message *message, struct networking_message_pool *pool ) { message->pool = pool; message->p_data = &message->w_msg_144.m_pData; message->p_size = &message->w_msg_144.m_cbSize; message->w_msg_144.m_pfnFreeData = w_SteamNetworkingMessage_t_144_FreeData; message->w_msg_144.m_pfnRelease = w_SteamNetworkingMessage_t_144_Release; return &message->w_msg_144; } static BOOL networking_message_pool_create_144( uint32_t count, w_SteamNetworkingMessage_t_144 **messages ) { uint32_t size = offsetof( struct networking_message_pool, messages[count] ); struct networking_message_pool *pool; if (!(pool = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, size ))) { ERR( "Failed to allocate memory for networking messages\n" ); return FALSE; } pool->ref = count; while (count--) messages[count] = networking_message_init_144( &pool->messages[count], pool ); return TRUE; } static BOOL networking_message_pool_receive_144( int32_t capacity, int32_t count, w_SteamNetworkingMessage_t_144 **messages ) { struct networking_message_pool *pool = CONTAINING_RECORD( messages[0], struct networking_message, w_msg_144 )->pool; int32_t i; for (i = count; i < capacity; i++) messages[i]->m_pfnRelease( messages[i] ); if (count > 0) { struct steamclient_networking_messages_receive_144_params params = {.count = count, .w_msgs = messages}; if (!networking_message_pool_alloc_data( count, pool )) return FALSE; STEAMCLIENT_CALL( steamclient_networking_messages_receive_144, ¶ms ); } return TRUE; } static void W_STDCALL w_SteamNetworkingMessage_t_147_FreeData( w_SteamNetworkingMessage_t_147 *msg ) { struct networking_message *message = CONTAINING_RECORD( msg, struct networking_message, w_msg_147 ); if (msg->m_pData) SecureZeroMemory( msg->m_pData, msg->m_cbSize ); if (!message->pool) HeapFree( GetProcessHeap(), 0, msg->m_pData ); } static void W_STDCALL w_SteamNetworkingMessage_t_147_Release( w_SteamNetworkingMessage_t_147 *msg ) { struct networking_message *message = CONTAINING_RECORD( msg, struct networking_message, w_msg_147 ); if (msg->m_pfnFreeData) msg->m_pfnFreeData( msg ); SecureZeroMemory( msg, sizeof(*msg) ); if (message->pool) networking_message_pool_release( message->pool ); else { struct steamclient_networking_message_release_147_params params = {.w_msg = msg}; STEAMCLIENT_CALL( steamclient_networking_message_release_147, ¶ms ); HeapFree( GetProcessHeap(), 0, message ); } } static w_SteamNetworkingMessage_t_147 *networking_message_init_147( struct networking_message *message, struct networking_message_pool *pool ) { message->pool = pool; message->p_data = &message->w_msg_147.m_pData; message->p_size = (uint32_t *)&message->w_msg_147.m_cbSize; message->w_msg_147.m_pfnFreeData = w_SteamNetworkingMessage_t_147_FreeData; message->w_msg_147.m_pfnRelease = w_SteamNetworkingMessage_t_147_Release; return &message->w_msg_147; } static BOOL networking_message_pool_create_147( uint32_t count, w_SteamNetworkingMessage_t_147 **messages ) { uint32_t size = offsetof( struct networking_message_pool, messages[count] ); struct networking_message_pool *pool; if (!(pool = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, size ))) { ERR( "Failed to allocate memory for networking messages\n" ); return FALSE; } pool->ref = count; while (count--) messages[count] = networking_message_init_147( &pool->messages[count], pool ); return TRUE; } static BOOL networking_message_pool_receive_147( uint32_t capacity, uint32_t count, w_SteamNetworkingMessage_t_147 **messages ) { struct networking_message_pool *pool = CONTAINING_RECORD( messages[0], struct networking_message, w_msg_147 )->pool; uint32_t i; for (i = count; i < capacity; i++) messages[i]->m_pfnRelease( messages[i] ); if (count) { struct steamclient_networking_messages_receive_147_params params = {.count = count, .w_msgs = messages}; if (!networking_message_pool_alloc_data( count, pool )) return FALSE; STEAMCLIENT_CALL( steamclient_networking_messages_receive_147, ¶ms ); } return TRUE; } static void W_STDCALL w_SteamNetworkingMessage_t_153a_FreeData( w_SteamNetworkingMessage_t_153a *msg ) { struct networking_message *message = CONTAINING_RECORD( msg, struct networking_message, w_msg_153a ); if (msg->m_pData) SecureZeroMemory( msg->m_pData, msg->m_cbSize ); if (!message->pool) HeapFree( GetProcessHeap(), 0, msg->m_pData ); } static void W_STDCALL w_SteamNetworkingMessage_t_153a_Release( w_SteamNetworkingMessage_t_153a *msg ) { struct networking_message *message = CONTAINING_RECORD( msg, struct networking_message, w_msg_153a ); if (msg->m_pfnFreeData) msg->m_pfnFreeData( msg ); SecureZeroMemory( msg, sizeof(*msg) ); if (message->pool) networking_message_pool_release( message->pool ); else { struct steamclient_networking_message_release_153a_params params = {.w_msg = msg}; STEAMCLIENT_CALL( steamclient_networking_message_release_153a, ¶ms ); HeapFree( GetProcessHeap(), 0, message ); } } static w_SteamNetworkingMessage_t_153a *networking_message_init_153a( struct networking_message *message, struct networking_message_pool *pool ) { message->pool = pool; message->p_data = &message->w_msg_153a.m_pData; message->p_size = (uint32_t *)&message->w_msg_153a.m_cbSize; message->w_msg_153a.m_pfnFreeData = w_SteamNetworkingMessage_t_153a_FreeData; message->w_msg_153a.m_pfnRelease = w_SteamNetworkingMessage_t_153a_Release; return &message->w_msg_153a; } static BOOL networking_message_pool_create_153a( uint32_t count, w_SteamNetworkingMessage_t_153a **messages ) { uint32_t size = offsetof( struct networking_message_pool, messages[count] ); struct networking_message_pool *pool; if (!(pool = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, size ))) { ERR( "Failed to allocate memory for networking messages\n" ); return FALSE; } pool->ref = count; while (count--) messages[count] = networking_message_init_153a( &pool->messages[count], pool ); return TRUE; } static BOOL networking_message_pool_receive_153a( uint32_t capacity, uint32_t count, w_SteamNetworkingMessage_t_153a **messages ) { struct networking_message_pool *pool = CONTAINING_RECORD( messages[0], struct networking_message, w_msg_153a )->pool; uint32_t i; for (i = count; i < capacity; i++) messages[i]->m_pfnRelease( messages[i] ); if (count) { struct steamclient_networking_messages_receive_153a_params params = {.count = count, .w_msgs = messages}; if (!networking_message_pool_alloc_data( count, pool )) return FALSE; STEAMCLIENT_CALL( steamclient_networking_messages_receive_153a, ¶ms ); } return TRUE; } /* ISteamNetworkingSockets_SteamNetworkingSockets002 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_144 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_144( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_144( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnListenSocket( struct w_steam_iface *_this, uint32_t hSocket, w_SteamNetworkingMessage_t_144 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnListenSocket_params params = { .linux_side = _this->u_iface, .hSocket = hSocket, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_144( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets002_ReceiveMessagesOnListenSocket, ¶ms ); if (!networking_message_pool_receive_144( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } /* ISteamNetworkingSockets_SteamNetworkingSockets004 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_144 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_144( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_144( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnListenSocket( struct w_steam_iface *_this, uint32_t hSocket, w_SteamNetworkingMessage_t_144 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnListenSocket_params params = { .linux_side = _this->u_iface, .hSocket = hSocket, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_144( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets004_ReceiveMessagesOnListenSocket, ¶ms ); if (!networking_message_pool_receive_144( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } /* ISteamNetworkingSockets_SteamNetworkingSockets006 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnListenSocket( struct w_steam_iface *_this, uint32_t hSocket, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnListenSocket_params params = { .linux_side = _this->u_iface, .hSocket = hSocket, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets006_ReceiveMessagesOnListenSocket, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } void __thiscall winISteamNetworkingSockets_SteamNetworkingSockets006_SendMessages(struct w_steam_iface *_this, int32_t nMessages, w_SteamNetworkingMessage_t_147 **pMessages, int64_t *pOutMessageNumberOrResult) { struct ISteamNetworkingSockets_SteamNetworkingSockets006_SendMessages_params params = { .linux_side = _this->u_iface, .nMessages = nMessages, .pMessages = pMessages, .pOutMessageNumberOrResult = pOutMessageNumberOrResult, }; int64_t i; TRACE("%p\n", _this); STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets006_SendMessages, ¶ms ); for (i = 0; i < nMessages; i++) pMessages[i]->m_pfnRelease( pMessages[i] ); } /* ISteamNetworkingSockets_SteamNetworkingSockets008 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnPollGroup( struct w_steam_iface *_this, uint32_t hPollGroup, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnPollGroup_params params = { .linux_side = _this->u_iface, .hPollGroup = hPollGroup, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets008_ReceiveMessagesOnPollGroup, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } void __thiscall winISteamNetworkingSockets_SteamNetworkingSockets008_SendMessages(struct w_steam_iface *_this, int32_t nMessages, w_SteamNetworkingMessage_t_147 *const *pMessages, int64_t *pOutMessageNumberOrResult) { struct ISteamNetworkingSockets_SteamNetworkingSockets008_SendMessages_params params = { .linux_side = _this->u_iface, .nMessages = nMessages, .pMessages = pMessages, .pOutMessageNumberOrResult = pOutMessageNumberOrResult, }; int64_t i; TRACE("%p\n", _this); STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets008_SendMessages, ¶ms ); for (i = 0; i < nMessages; i++) pMessages[i]->m_pfnRelease( pMessages[i] ); } /* ISteamNetworkingSockets_SteamNetworkingSockets009 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnPollGroup( struct w_steam_iface *_this, uint32_t hPollGroup, w_SteamNetworkingMessage_t_147 **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnPollGroup_params params = { .linux_side = _this->u_iface, .hPollGroup = hPollGroup, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_147( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets009_ReceiveMessagesOnPollGroup, ¶ms ); if (!networking_message_pool_receive_147( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } void __thiscall winISteamNetworkingSockets_SteamNetworkingSockets009_SendMessages(struct w_steam_iface *_this, int32_t nMessages, w_SteamNetworkingMessage_t_147 *const *pMessages, int64_t *pOutMessageNumberOrResult) { struct ISteamNetworkingSockets_SteamNetworkingSockets009_SendMessages_params params = { .linux_side = _this->u_iface, .nMessages = nMessages, .pMessages = pMessages, .pOutMessageNumberOrResult = pOutMessageNumberOrResult, }; int64_t i; TRACE("%p\n", _this); STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets009_SendMessages, ¶ms ); for (i = 0; i < nMessages; i++) pMessages[i]->m_pfnRelease( pMessages[i] ); } /* ISteamNetworkingUtils_SteamNetworkingUtils003 */ w_SteamNetworkingMessage_t_147 *__thiscall winISteamNetworkingUtils_SteamNetworkingUtils003_AllocateMessage( struct w_steam_iface *_this, int32_t cbAllocateBuffer ) { struct ISteamNetworkingUtils_SteamNetworkingUtils003_AllocateMessage_params params = { .linux_side = _this->u_iface, .cbAllocateBuffer = cbAllocateBuffer, }; struct networking_message *message; TRACE( "%p\n", _this ); if (!(message = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*message) ))) return NULL; if ((message->w_msg_147.m_cbSize = cbAllocateBuffer) && !(message->w_msg_147.m_pData = HeapAlloc( GetProcessHeap(), 0, cbAllocateBuffer ))) { HeapFree( GetProcessHeap(), 0, message ); return NULL; } message->w_msg_147.m_pfnFreeData = w_SteamNetworkingMessage_t_147_FreeData; message->w_msg_147.m_pfnRelease = w_SteamNetworkingMessage_t_147_Release; params._ret = &message->w_msg_147; STEAMCLIENT_CALL( ISteamNetworkingUtils_SteamNetworkingUtils003_AllocateMessage, ¶ms ); return params._ret; } /* ISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001 */ void __thiscall winISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_DestroyFakeUDPPort( struct w_steam_iface *_this ) { struct ISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_DestroyFakeUDPPort_params params = {.linux_side = _this->u_iface}; TRACE( "%p\n", _this ); STEAMCLIENT_CALL( ISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_DestroyFakeUDPPort, ¶ms ); HeapFree( GetProcessHeap(), 0, _this ); } int32_t __thiscall winISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_ReceiveMessages( struct w_steam_iface *_this, w_SteamNetworkingMessage_t_153a **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_ReceiveMessages_params params = { .linux_side = _this->u_iface, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_153a( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingFakeUDPPort_SteamNetworkingFakeUDPPort001_ReceiveMessages, ¶ms ); if (!networking_message_pool_receive_153a( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } /* ISteamNetworkingMessages_SteamNetworkingMessages002 */ int32_t __thiscall winISteamNetworkingMessages_SteamNetworkingMessages002_ReceiveMessagesOnChannel( struct w_steam_iface *_this, int32_t nLocalChannel, w_SteamNetworkingMessage_t_153a **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingMessages_SteamNetworkingMessages002_ReceiveMessagesOnChannel_params params = { .linux_side = _this->u_iface, .nLocalChannel = nLocalChannel, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_153a( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingMessages_SteamNetworkingMessages002_ReceiveMessagesOnChannel, ¶ms ); if (!networking_message_pool_receive_153a( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } /* ISteamNetworkingSockets_SteamNetworkingSockets012 */ int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnConnection( struct w_steam_iface *_this, uint32_t hConn, w_SteamNetworkingMessage_t_153a **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnConnection_params params = { .linux_side = _this->u_iface, .hConn = hConn, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_153a( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnConnection, ¶ms ); if (!networking_message_pool_receive_153a( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } int32_t __thiscall winISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnPollGroup( struct w_steam_iface *_this, uint32_t hPollGroup, w_SteamNetworkingMessage_t_153a **ppOutMessages, int32_t nMaxMessages ) { struct ISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnPollGroup_params params = { .linux_side = _this->u_iface, .hPollGroup = hPollGroup, .ppOutMessages = ppOutMessages, .nMaxMessages = nMaxMessages, }; TRACE( "%p\n", _this ); if (!networking_message_pool_create_153a( nMaxMessages, params.ppOutMessages )) return 0; STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets012_ReceiveMessagesOnPollGroup, ¶ms ); if (!networking_message_pool_receive_153a( nMaxMessages, params._ret, params.ppOutMessages )) return 0; return params._ret; } /* ISteamNetworkingUtils_SteamNetworkingUtils004 */ void __thiscall winISteamNetworkingSockets_SteamNetworkingSockets012_SendMessages(struct w_steam_iface *_this, int32_t nMessages, w_SteamNetworkingMessage_t_153a *const *pMessages, int64_t *pOutMessageNumberOrResult) { struct ISteamNetworkingSockets_SteamNetworkingSockets012_SendMessages_params params = { .linux_side = _this->u_iface, .nMessages = nMessages, .pMessages = pMessages, .pOutMessageNumberOrResult = pOutMessageNumberOrResult, }; int64_t i; TRACE("%p\n", _this); STEAMCLIENT_CALL( ISteamNetworkingSockets_SteamNetworkingSockets012_SendMessages, ¶ms ); for (i = 0; i < nMessages; i++) pMessages[i]->m_pfnRelease( pMessages[i] ); } w_SteamNetworkingMessage_t_153a *__thiscall winISteamNetworkingUtils_SteamNetworkingUtils004_AllocateMessage( struct w_steam_iface *_this, int32_t cbAllocateBuffer ) { struct ISteamNetworkingUtils_SteamNetworkingUtils004_AllocateMessage_params params = { .linux_side = _this->u_iface, .cbAllocateBuffer = cbAllocateBuffer, }; struct networking_message *message; TRACE( "%p\n", _this ); if (!(message = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*message) ))) return NULL; if ((message->w_msg_153a.m_cbSize = cbAllocateBuffer) && !(message->w_msg_153a.m_pData = HeapAlloc( GetProcessHeap(), 0, cbAllocateBuffer ))) { HeapFree( GetProcessHeap(), 0, message ); return NULL; } message->w_msg_153a.m_pfnFreeData = w_SteamNetworkingMessage_t_153a_FreeData; message->w_msg_153a.m_pfnRelease = w_SteamNetworkingMessage_t_153a_Release; params._ret = &message->w_msg_153a; STEAMCLIENT_CALL( ISteamNetworkingUtils_SteamNetworkingUtils004_AllocateMessage, ¶ms ); return params._ret; }