mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-13 15:18:13 +03:00
lsteamclient: Use plain memory allocation / free for SteamNetworkingMessage_t wrapper.
CW-Bug-Id: #22649
This commit is contained in:
parent
6ed890c9e9
commit
a7bdd61d20
@ -1,113 +0,0 @@
|
|||||||
/* $OpenBSD: queue.h,v 1.45 2018/07/12 14:22:54 sashan Exp $ */
|
|
||||||
/* $NetBSD: queue.h,v 1.11 1996/05/16 05:17:14 mycroft Exp $ */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 1991, 1993
|
|
||||||
* The Regents of the University of California. All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. Neither the name of the University nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* @(#)queue.h 8.5 (Berkeley) 8/20/94
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(QUEUE_MACRO_DEBUG) || (defined(_KERNEL) && defined(DIAGNOSTIC))
|
|
||||||
#define _Q_INVALID ((void *)-1)
|
|
||||||
#define _Q_INVALIDATE(a) (a) = _Q_INVALID
|
|
||||||
#else
|
|
||||||
#define _Q_INVALIDATE(a)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Singly-linked List definitions.
|
|
||||||
*/
|
|
||||||
#define SLIST_HEAD(name, type) \
|
|
||||||
struct name { \
|
|
||||||
struct type *slh_first; /* first element */ \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SLIST_HEAD_INITIALIZER(head) \
|
|
||||||
{ NULL }
|
|
||||||
|
|
||||||
#define SLIST_ENTRY(type) \
|
|
||||||
struct { \
|
|
||||||
struct type *sle_next; /* next element */ \
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Singly-linked List access methods.
|
|
||||||
*/
|
|
||||||
#define SLIST_FIRST(head) ((head)->slh_first)
|
|
||||||
#define SLIST_END(head) NULL
|
|
||||||
#define SLIST_EMPTY(head) (SLIST_FIRST(head) == SLIST_END(head))
|
|
||||||
#define SLIST_NEXT(elm, field) ((elm)->field.sle_next)
|
|
||||||
|
|
||||||
#define SLIST_FOREACH(var, head, field) \
|
|
||||||
for((var) = SLIST_FIRST(head); \
|
|
||||||
(var) != SLIST_END(head); \
|
|
||||||
(var) = SLIST_NEXT(var, field))
|
|
||||||
|
|
||||||
#define SLIST_FOREACH_SAFE(var, head, field, tvar) \
|
|
||||||
for ((var) = SLIST_FIRST(head); \
|
|
||||||
(var) && ((tvar) = SLIST_NEXT(var, field), 1); \
|
|
||||||
(var) = (tvar))
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Singly-linked List functions.
|
|
||||||
*/
|
|
||||||
#define SLIST_INIT(head) { \
|
|
||||||
SLIST_FIRST(head) = SLIST_END(head); \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SLIST_INSERT_AFTER(slistelm, elm, field) do { \
|
|
||||||
(elm)->field.sle_next = (slistelm)->field.sle_next; \
|
|
||||||
(slistelm)->field.sle_next = (elm); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define SLIST_INSERT_HEAD(head, elm, field) do { \
|
|
||||||
(elm)->field.sle_next = (head)->slh_first; \
|
|
||||||
(head)->slh_first = (elm); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define SLIST_REMOVE_AFTER(elm, field) do { \
|
|
||||||
(elm)->field.sle_next = (elm)->field.sle_next->field.sle_next; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define SLIST_REMOVE_HEAD(head, field) do { \
|
|
||||||
(head)->slh_first = (head)->slh_first->field.sle_next; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define SLIST_REMOVE(head, elm, type, field) do { \
|
|
||||||
if ((head)->slh_first == (elm)) { \
|
|
||||||
SLIST_REMOVE_HEAD((head), field); \
|
|
||||||
} else { \
|
|
||||||
struct type *curelm = (head)->slh_first; \
|
|
||||||
\
|
|
||||||
while (curelm->field.sle_next != (elm)) \
|
|
||||||
curelm = curelm->field.sle_next; \
|
|
||||||
curelm->field.sle_next = \
|
|
||||||
curelm->field.sle_next->field.sle_next; \
|
|
||||||
} \
|
|
||||||
_Q_INVALIDATE((elm)->field.sle_next); \
|
|
||||||
} while (0)
|
|
@ -21,8 +21,6 @@ extern "C" {
|
|||||||
#define SDKVER_144
|
#define SDKVER_144
|
||||||
#include "struct_converters.h"
|
#include "struct_converters.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1440
|
#define SDK_VERSION 1440
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -22,8 +22,6 @@ extern "C" {
|
|||||||
#define SDKVER_146
|
#define SDKVER_146
|
||||||
#include "struct_converters.h"
|
#include "struct_converters.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1460
|
#define SDK_VERSION 1460
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -22,8 +22,6 @@ extern "C" {
|
|||||||
#define SDKVER_147
|
#define SDKVER_147
|
||||||
#include "struct_converters.h"
|
#include "struct_converters.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1470
|
#define SDK_VERSION 1470
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -22,8 +22,6 @@ extern "C" {
|
|||||||
#define SDKVER_148a
|
#define SDKVER_148a
|
||||||
#include "struct_converters.h"
|
#include "struct_converters.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1481
|
#define SDK_VERSION 1481
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -23,8 +23,6 @@ extern "C" {
|
|||||||
#include "struct_converters.h"
|
#include "struct_converters.h"
|
||||||
#include "cb_converters.h"
|
#include "cb_converters.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1500
|
#define SDK_VERSION 1500
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -25,8 +25,6 @@ extern "C" {
|
|||||||
#include "cb_converters.h"
|
#include "cb_converters.h"
|
||||||
#include "win_constructors.h"
|
#include "win_constructors.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1531
|
#define SDK_VERSION 1531
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
|
@ -23,8 +23,6 @@ extern "C" {
|
|||||||
#include "cb_converters.h"
|
#include "cb_converters.h"
|
||||||
#include "win_constructors.h"
|
#include "win_constructors.h"
|
||||||
|
|
||||||
#include "queue.h"
|
|
||||||
|
|
||||||
#define SDK_VERSION 1531
|
#define SDK_VERSION 1531
|
||||||
#include "steamclient_manual_common.h"
|
#include "steamclient_manual_common.h"
|
||||||
|
|
||||||
@ -33,15 +31,10 @@ struct msg_wrapper {
|
|||||||
struct SteamNetworkingMessage_t *lin_msg;
|
struct SteamNetworkingMessage_t *lin_msg;
|
||||||
|
|
||||||
void (*orig_FreeData)(SteamNetworkingMessage_t *);
|
void (*orig_FreeData)(SteamNetworkingMessage_t *);
|
||||||
|
|
||||||
SLIST_ENTRY(msg_wrapper) entry;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/***** manual struct converter for SteamNetworkingMessage_t *****/
|
/***** manual struct converter for SteamNetworkingMessage_t *****/
|
||||||
|
|
||||||
static SLIST_HEAD(free_msgs_head, msg_wrapper) free_msgs = SLIST_HEAD_INITIALIZER(free_msgs);
|
|
||||||
static CRITICAL_SECTION free_msgs_lock = { NULL, -1, 0, 0, 0, 0 };
|
|
||||||
|
|
||||||
static void __attribute__((ms_abi)) win_FreeData(struct winSteamNetworkingMessage_t_153a *win_msg)
|
static void __attribute__((ms_abi)) win_FreeData(struct winSteamNetworkingMessage_t_153a *win_msg)
|
||||||
{
|
{
|
||||||
struct msg_wrapper *msg = CONTAINING_RECORD(win_msg, struct msg_wrapper, win_msg);
|
struct msg_wrapper *msg = CONTAINING_RECORD(win_msg, struct msg_wrapper, win_msg);
|
||||||
@ -56,13 +49,11 @@ static void __attribute__((ms_abi)) win_FreeData(struct winSteamNetworkingMessag
|
|||||||
static void __attribute__((ms_abi)) win_Release(struct winSteamNetworkingMessage_t_153a *win_msg)
|
static void __attribute__((ms_abi)) win_Release(struct winSteamNetworkingMessage_t_153a *win_msg)
|
||||||
{
|
{
|
||||||
struct msg_wrapper *msg = CONTAINING_RECORD(win_msg, struct msg_wrapper, win_msg);
|
struct msg_wrapper *msg = CONTAINING_RECORD(win_msg, struct msg_wrapper, win_msg);
|
||||||
|
|
||||||
TRACE("%p\n", msg);
|
TRACE("%p\n", msg);
|
||||||
msg->lin_msg->m_pfnRelease(msg->lin_msg);
|
msg->lin_msg->m_pfnRelease(msg->lin_msg);
|
||||||
msg->lin_msg = NULL;
|
SecureZeroMemory(msg, sizeof(*msg));
|
||||||
msg->orig_FreeData = NULL;
|
HeapFree(GetProcessHeap(), 0, msg);
|
||||||
EnterCriticalSection(&free_msgs_lock);
|
|
||||||
SLIST_INSERT_HEAD(&free_msgs, msg, entry);
|
|
||||||
LeaveCriticalSection(&free_msgs_lock);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void lin_FreeData(struct SteamNetworkingMessage_t *lin_msg)
|
static void lin_FreeData(struct SteamNetworkingMessage_t *lin_msg)
|
||||||
@ -78,22 +69,7 @@ void *network_message_lin_to_win_(void *msg_, unsigned int version)
|
|||||||
struct SteamNetworkingMessage_t *lin_msg = (struct SteamNetworkingMessage_t *)msg_;
|
struct SteamNetworkingMessage_t *lin_msg = (struct SteamNetworkingMessage_t *)msg_;
|
||||||
struct msg_wrapper *msg;
|
struct msg_wrapper *msg;
|
||||||
|
|
||||||
EnterCriticalSection(&free_msgs_lock);
|
msg = (struct msg_wrapper *)HeapAlloc(GetProcessHeap(), 0, sizeof(*msg));
|
||||||
|
|
||||||
msg = SLIST_FIRST(&free_msgs);
|
|
||||||
|
|
||||||
if(!msg){
|
|
||||||
int n;
|
|
||||||
/* allocs can be pricey, so alloc in blocks */
|
|
||||||
#define MSGS_PER_BLOCK 16
|
|
||||||
struct msg_wrapper *msgs = (struct msg_wrapper *)HeapAlloc(GetProcessHeap(), 0, sizeof(struct msg_wrapper) * MSGS_PER_BLOCK);
|
|
||||||
for(n = 1; n < MSGS_PER_BLOCK; ++n)
|
|
||||||
SLIST_INSERT_HEAD(&free_msgs, &msgs[n], entry);
|
|
||||||
msg = &msgs[0];
|
|
||||||
}else
|
|
||||||
SLIST_REMOVE_HEAD(&free_msgs, entry);
|
|
||||||
|
|
||||||
LeaveCriticalSection(&free_msgs_lock);
|
|
||||||
|
|
||||||
TRACE("lin_msg %p, msg %p.\n", lin_msg, msg);
|
TRACE("lin_msg %p, msg %p.\n", lin_msg, msg);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user