Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
8a571b26
Commit
8a571b26
authored
Oct 03, 2023
by
Paul Gofman
Committed by
Alexandre Julliard
Oct 04, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
secur32: Synchronize access to schannel handle table.
parent
fcfe2972
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
13 deletions
+34
-13
schannel.c
dlls/secur32/schannel.c
+34
-13
No files found.
dlls/secur32/schannel.c
View file @
8a571b26
...
@@ -71,6 +71,7 @@ static struct schan_handle *schan_handle_table;
...
@@ -71,6 +71,7 @@ static struct schan_handle *schan_handle_table;
static
struct
schan_handle
*
schan_free_handles
;
static
struct
schan_handle
*
schan_free_handles
;
static
SIZE_T
schan_handle_table_size
;
static
SIZE_T
schan_handle_table_size
;
static
SIZE_T
schan_handle_count
;
static
SIZE_T
schan_handle_count
;
static
SRWLOCK
handle_table_lock
=
SRWLOCK_INIT
;
/* Protocols enabled, only those may be used for the connection. */
/* Protocols enabled, only those may be used for the connection. */
static
DWORD
config_enabled_protocols
;
static
DWORD
config_enabled_protocols
;
...
@@ -81,22 +82,24 @@ static DWORD config_default_disabled_protocols;
...
@@ -81,22 +82,24 @@ static DWORD config_default_disabled_protocols;
static
ULONG_PTR
schan_alloc_handle
(
void
*
object
,
enum
schan_handle_type
type
)
static
ULONG_PTR
schan_alloc_handle
(
void
*
object
,
enum
schan_handle_type
type
)
{
{
struct
schan_handle
*
handle
;
struct
schan_handle
*
handle
;
ULONG_PTR
index
=
SCHAN_INVALID_HANDLE
;
AcquireSRWLockExclusive
(
&
handle_table_lock
);
if
(
schan_free_handles
)
if
(
schan_free_handles
)
{
{
DWORD
index
=
schan_free_handles
-
schan_handle_table
;
/* Use a free handle */
/* Use a free handle */
handle
=
schan_free_handles
;
handle
=
schan_free_handles
;
if
(
handle
->
type
!=
SCHAN_HANDLE_FREE
)
if
(
handle
->
type
!=
SCHAN_HANDLE_FREE
)
{
{
ERR
(
"Handle %
ld(%p) is in the free list, but has type %#x.
\n
"
,
index
,
handle
,
handle
->
type
);
ERR
(
"Handle %
p is in the free list, but has type %#x.
\n
"
,
handle
,
handle
->
type
);
return
SCHAN_INVALID_HANDLE
;
goto
done
;
}
}
index
=
schan_free_handles
-
schan_handle_table
;
schan_free_handles
=
handle
->
object
;
schan_free_handles
=
handle
->
object
;
handle
->
object
=
object
;
handle
->
object
=
object
;
handle
->
type
=
type
;
handle
->
type
=
type
;
return
index
;
goto
done
;
}
}
if
(
!
(
schan_handle_count
<
schan_handle_table_size
))
if
(
!
(
schan_handle_count
<
schan_handle_table_size
))
{
{
...
@@ -106,7 +109,7 @@ static ULONG_PTR schan_alloc_handle(void *object, enum schan_handle_type type)
...
@@ -106,7 +109,7 @@ static ULONG_PTR schan_alloc_handle(void *object, enum schan_handle_type type)
if
(
!
new_table
)
if
(
!
new_table
)
{
{
ERR
(
"Failed to grow the handle table
\n
"
);
ERR
(
"Failed to grow the handle table
\n
"
);
return
SCHAN_INVALID_HANDLE
;
goto
done
;
}
}
schan_handle_table
=
new_table
;
schan_handle_table
=
new_table
;
schan_handle_table_size
=
new_size
;
schan_handle_table_size
=
new_size
;
...
@@ -116,21 +119,30 @@ static ULONG_PTR schan_alloc_handle(void *object, enum schan_handle_type type)
...
@@ -116,21 +119,30 @@ static ULONG_PTR schan_alloc_handle(void *object, enum schan_handle_type type)
handle
->
object
=
object
;
handle
->
object
=
object
;
handle
->
type
=
type
;
handle
->
type
=
type
;
return
handle
-
schan_handle_table
;
index
=
handle
-
schan_handle_table
;
done:
ReleaseSRWLockExclusive
(
&
handle_table_lock
);
return
index
;
}
}
static
void
*
schan_free_handle
(
ULONG_PTR
handle_idx
,
enum
schan_handle_type
type
)
static
void
*
schan_free_handle
(
ULONG_PTR
handle_idx
,
enum
schan_handle_type
type
)
{
{
struct
schan_handle
*
handle
;
struct
schan_handle
*
handle
;
void
*
object
;
void
*
object
=
NULL
;
if
(
handle_idx
==
SCHAN_INVALID_HANDLE
)
return
NULL
;
if
(
handle_idx
==
SCHAN_INVALID_HANDLE
)
return
NULL
;
if
(
handle_idx
>=
schan_handle_count
)
return
NULL
;
AcquireSRWLockExclusive
(
&
handle_table_lock
);
if
(
handle_idx
>=
schan_handle_count
)
goto
done
;
handle
=
&
schan_handle_table
[
handle_idx
];
handle
=
&
schan_handle_table
[
handle_idx
];
if
(
handle
->
type
!=
type
)
if
(
handle
->
type
!=
type
)
{
{
ERR
(
"Handle %Id(%p) is not of type %#x
\n
"
,
handle_idx
,
handle
,
type
);
ERR
(
"Handle %Id(%p) is not of type %#x
\n
"
,
handle_idx
,
handle
,
type
);
return
NULL
;
goto
done
;
}
}
object
=
handle
->
object
;
object
=
handle
->
object
;
...
@@ -138,23 +150,32 @@ static void *schan_free_handle(ULONG_PTR handle_idx, enum schan_handle_type type
...
@@ -138,23 +150,32 @@ static void *schan_free_handle(ULONG_PTR handle_idx, enum schan_handle_type type
handle
->
type
=
SCHAN_HANDLE_FREE
;
handle
->
type
=
SCHAN_HANDLE_FREE
;
schan_free_handles
=
handle
;
schan_free_handles
=
handle
;
done:
ReleaseSRWLockExclusive
(
&
handle_table_lock
);
return
object
;
return
object
;
}
}
static
void
*
schan_get_object
(
ULONG_PTR
handle_idx
,
enum
schan_handle_type
type
)
static
void
*
schan_get_object
(
ULONG_PTR
handle_idx
,
enum
schan_handle_type
type
)
{
{
struct
schan_handle
*
handle
;
struct
schan_handle
*
handle
;
void
*
object
=
NULL
;
if
(
handle_idx
==
SCHAN_INVALID_HANDLE
)
return
NULL
;
if
(
handle_idx
==
SCHAN_INVALID_HANDLE
)
return
NULL
;
if
(
handle_idx
>=
schan_handle_count
)
return
NULL
;
AcquireSRWLockShared
(
&
handle_table_lock
);
if
(
handle_idx
>=
schan_handle_count
)
goto
done
;
handle
=
&
schan_handle_table
[
handle_idx
];
handle
=
&
schan_handle_table
[
handle_idx
];
if
(
handle
->
type
!=
type
)
if
(
handle
->
type
!=
type
)
{
{
ERR
(
"Handle %Id(%p) is not of type %#x
\n
"
,
handle_idx
,
handle
,
type
);
ERR
(
"Handle %Id(%p) is not of type %#x
(%#x)
\n
"
,
handle_idx
,
handle
,
type
,
handle
->
type
);
return
NULL
;
goto
done
;
}
}
object
=
handle
->
object
;
return
handle
->
object
;
done:
ReleaseSRWLockShared
(
&
handle_table_lock
);
return
object
;
}
}
static
void
read_config
(
void
)
static
void
read_config
(
void
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment