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
0e6b7275
Commit
0e6b7275
authored
May 28, 2022
by
Nikolay Sivov
Committed by
Alexandre Julliard
May 30, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kerberos: Use 64-bit integer for context handles.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
parent
5c56d719
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
69 additions
and
24 deletions
+69
-24
krb5_ap.c
dlls/kerberos/krb5_ap.c
+49
-10
unixlib.c
dlls/kerberos/unixlib.c
+6
-5
unixlib.h
dlls/kerberos/unixlib.h
+14
-9
No files found.
dlls/kerberos/krb5_ap.c
View file @
0e6b7275
...
@@ -82,6 +82,24 @@ struct cred_handle
...
@@ -82,6 +82,24 @@ struct cred_handle
UINT64
handle
;
UINT64
handle
;
};
};
struct
context_handle
{
UINT64
handle
;
};
static
LSA_SEC_HANDLE
create_context_handle
(
struct
context_handle
*
ctx
,
UINT64
new_context
)
{
UINT64
context
=
ctx
?
ctx
->
handle
:
0
;
if
(
new_context
&&
new_context
!=
context
)
{
struct
context_handle
*
new_ctx
=
malloc
(
sizeof
(
*
new_ctx
));
new_ctx
->
handle
=
new_context
;
return
(
LSA_SEC_HANDLE
)
new_ctx
;
}
else
return
(
LSA_SEC_HANDLE
)
ctx
;
}
static
const
char
*
debugstr_us
(
const
UNICODE_STRING
*
us
)
static
const
char
*
debugstr_us
(
const
UNICODE_STRING
*
us
)
{
{
if
(
!
us
)
return
"<null>"
;
if
(
!
us
)
return
"<null>"
;
...
@@ -370,14 +388,16 @@ static NTSTATUS NTAPI kerberos_SpInitLsaModeContext( LSA_SEC_HANDLE credential,
...
@@ -370,14 +388,16 @@ static NTSTATUS NTAPI kerberos_SpInitLsaModeContext( LSA_SEC_HANDLE credential,
else
else
{
{
struct
cred_handle
*
cred_handle
=
(
struct
cred_handle
*
)
credential
;
struct
cred_handle
*
cred_handle
=
(
struct
cred_handle
*
)
credential
;
struct
context_handle
*
context_handle
=
(
struct
context_handle
*
)
context
;
struct
initialize_context_params
params
;
struct
initialize_context_params
params
;
UINT64
new_context_handle
=
0
;
params
.
credential
=
cred_handle
?
cred_handle
->
handle
:
0
;
params
.
credential
=
cred_handle
?
cred_handle
->
handle
:
0
;
params
.
context
=
context
;
params
.
context
=
context
_handle
?
context_handle
->
handle
:
0
;
params
.
target_name
=
target
;
params
.
target_name
=
target
;
params
.
context_req
=
context_req
;
params
.
context_req
=
context_req
;
params
.
input
=
input
;
params
.
input
=
input
;
params
.
new_context
=
new_context
;
params
.
new_context
=
&
new_context_handle
;
params
.
output
=
output
;
params
.
output
=
output
;
params
.
context_attr
=
context_attr
;
params
.
context_attr
=
context_attr
;
params
.
expiry
=
&
exptime
;
params
.
expiry
=
&
exptime
;
...
@@ -385,6 +405,7 @@ static NTSTATUS NTAPI kerberos_SpInitLsaModeContext( LSA_SEC_HANDLE credential,
...
@@ -385,6 +405,7 @@ static NTSTATUS NTAPI kerberos_SpInitLsaModeContext( LSA_SEC_HANDLE credential,
status
=
KRB5_CALL
(
initialize_context
,
&
params
);
status
=
KRB5_CALL
(
initialize_context
,
&
params
);
if
(
!
status
)
if
(
!
status
)
{
{
*
new_context
=
create_context_handle
(
context_handle
,
new_context_handle
);
*
mapped_context
=
TRUE
;
*
mapped_context
=
TRUE
;
expiry_to_timestamp
(
exptime
,
expiry
);
expiry_to_timestamp
(
exptime
,
expiry
);
}
}
...
@@ -408,12 +429,14 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
...
@@ -408,12 +429,14 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
if
(
context
||
input
||
credential
)
if
(
context
||
input
||
credential
)
{
{
struct
cred_handle
*
cred_handle
=
(
struct
cred_handle
*
)
credential
;
struct
cred_handle
*
cred_handle
=
(
struct
cred_handle
*
)
credential
;
struct
context_handle
*
context_handle
=
(
struct
context_handle
*
)
context
;
struct
accept_context_params
params
;
struct
accept_context_params
params
;
UINT64
new_context_handle
=
0
;
params
.
credential
=
cred_handle
?
cred_handle
->
handle
:
0
;
params
.
credential
=
cred_handle
?
cred_handle
->
handle
:
0
;
params
.
context
=
context
;
params
.
context
=
context
_handle
?
context_handle
->
handle
:
0
;
params
.
input
=
input
;
params
.
input
=
input
;
params
.
new_context
=
new_context
;
params
.
new_context
=
&
new_context_handle
;
params
.
output
=
output
;
params
.
output
=
output
;
params
.
context_attr
=
context_attr
;
params
.
context_attr
=
context_attr
;
params
.
expiry
=
&
exptime
;
params
.
expiry
=
&
exptime
;
...
@@ -421,6 +444,7 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
...
@@ -421,6 +444,7 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
status
=
KRB5_CALL
(
accept_context
,
&
params
);
status
=
KRB5_CALL
(
accept_context
,
&
params
);
if
(
!
status
)
if
(
!
status
)
{
{
*
new_context
=
create_context_handle
(
context_handle
,
new_context_handle
);
*
mapped_context
=
TRUE
;
*
mapped_context
=
TRUE
;
expiry_to_timestamp
(
exptime
,
expiry
);
expiry_to_timestamp
(
exptime
,
expiry
);
}
}
...
@@ -431,9 +455,18 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
...
@@ -431,9 +455,18 @@ static NTSTATUS NTAPI kerberos_SpAcceptLsaModeContext( LSA_SEC_HANDLE credential
static
NTSTATUS
NTAPI
kerberos_SpDeleteContext
(
LSA_SEC_HANDLE
context
)
static
NTSTATUS
NTAPI
kerberos_SpDeleteContext
(
LSA_SEC_HANDLE
context
)
{
{
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
struct
delete_context_params
params
;
NTSTATUS
status
;
TRACE
(
"%Ix
\n
"
,
context
);
TRACE
(
"%Ix
\n
"
,
context
);
if
(
!
context
)
return
SEC_E_INVALID_HANDLE
;
if
(
!
context
)
return
SEC_E_INVALID_HANDLE
;
return
KRB5_CALL
(
delete_context
,
(
void
*
)
context
);
params
.
context
=
context_handle
->
handle
;
status
=
KRB5_CALL
(
delete_context
,
&
params
);
free
(
context_handle
);
return
status
;
}
}
static
SecPkgInfoW
*
build_package_info
(
const
SecPkgInfoW
*
info
)
static
SecPkgInfoW
*
build_package_info
(
const
SecPkgInfoW
*
info
)
...
@@ -456,6 +489,8 @@ static SecPkgInfoW *build_package_info( const SecPkgInfoW *info )
...
@@ -456,6 +489,8 @@ static SecPkgInfoW *build_package_info( const SecPkgInfoW *info )
static
NTSTATUS
NTAPI
kerberos_SpQueryContextAttributes
(
LSA_SEC_HANDLE
context
,
ULONG
attribute
,
void
*
buffer
)
static
NTSTATUS
NTAPI
kerberos_SpQueryContextAttributes
(
LSA_SEC_HANDLE
context
,
ULONG
attribute
,
void
*
buffer
)
{
{
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
TRACE
(
"%Ix, %lu, %p
\n
"
,
context
,
attribute
,
buffer
);
TRACE
(
"%Ix, %lu, %p
\n
"
,
context
,
attribute
,
buffer
);
if
(
!
context
)
return
SEC_E_INVALID_HANDLE
;
if
(
!
context
)
return
SEC_E_INVALID_HANDLE
;
...
@@ -477,7 +512,7 @@ static NTSTATUS NTAPI kerberos_SpQueryContextAttributes( LSA_SEC_HANDLE context,
...
@@ -477,7 +512,7 @@ static NTSTATUS NTAPI kerberos_SpQueryContextAttributes( LSA_SEC_HANDLE context,
X
(
SECPKG_ATTR_TARGET_INFORMATION
);
X
(
SECPKG_ATTR_TARGET_INFORMATION
);
case
SECPKG_ATTR_SIZES
:
case
SECPKG_ATTR_SIZES
:
{
{
struct
query_context_attributes_params
params
=
{
context
,
attribute
,
buffer
};
struct
query_context_attributes_params
params
=
{
context
_handle
->
handle
,
attribute
,
buffer
};
return
KRB5_CALL
(
query_context_attributes
,
&
params
);
return
KRB5_CALL
(
query_context_attributes
,
&
params
);
}
}
case
SECPKG_ATTR_NEGOTIATION_INFO
:
case
SECPKG_ATTR_NEGOTIATION_INFO
:
...
@@ -584,7 +619,8 @@ static NTSTATUS SEC_ENTRY kerberos_SpMakeSignature( LSA_SEC_HANDLE context, ULON
...
@@ -584,7 +619,8 @@ static NTSTATUS SEC_ENTRY kerberos_SpMakeSignature( LSA_SEC_HANDLE context, ULON
if
(
context
)
if
(
context
)
{
{
struct
make_signature_params
params
=
{
context
,
message
};
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
struct
make_signature_params
params
=
{
context_handle
->
handle
,
message
};
return
KRB5_CALL
(
make_signature
,
&
params
);
return
KRB5_CALL
(
make_signature
,
&
params
);
}
}
else
return
SEC_E_INVALID_HANDLE
;
else
return
SEC_E_INVALID_HANDLE
;
...
@@ -598,7 +634,8 @@ static NTSTATUS NTAPI kerberos_SpVerifySignature( LSA_SEC_HANDLE context, SecBuf
...
@@ -598,7 +634,8 @@ static NTSTATUS NTAPI kerberos_SpVerifySignature( LSA_SEC_HANDLE context, SecBuf
if
(
context
)
if
(
context
)
{
{
struct
verify_signature_params
params
=
{
context
,
message
,
quality_of_protection
};
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
struct
verify_signature_params
params
=
{
context_handle
->
handle
,
message
,
quality_of_protection
};
return
KRB5_CALL
(
verify_signature
,
&
params
);
return
KRB5_CALL
(
verify_signature
,
&
params
);
}
}
else
return
SEC_E_INVALID_HANDLE
;
else
return
SEC_E_INVALID_HANDLE
;
...
@@ -612,7 +649,8 @@ static NTSTATUS NTAPI kerberos_SpSealMessage( LSA_SEC_HANDLE context, ULONG qual
...
@@ -612,7 +649,8 @@ static NTSTATUS NTAPI kerberos_SpSealMessage( LSA_SEC_HANDLE context, ULONG qual
if
(
context
)
if
(
context
)
{
{
struct
seal_message_params
params
=
{
context
,
message
,
quality_of_protection
};
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
struct
seal_message_params
params
=
{
context_handle
->
handle
,
message
,
quality_of_protection
};
return
KRB5_CALL
(
seal_message
,
&
params
);
return
KRB5_CALL
(
seal_message
,
&
params
);
}
}
else
return
SEC_E_INVALID_HANDLE
;
else
return
SEC_E_INVALID_HANDLE
;
...
@@ -626,7 +664,8 @@ static NTSTATUS NTAPI kerberos_SpUnsealMessage( LSA_SEC_HANDLE context, SecBuffe
...
@@ -626,7 +664,8 @@ static NTSTATUS NTAPI kerberos_SpUnsealMessage( LSA_SEC_HANDLE context, SecBuffe
if
(
context
)
if
(
context
)
{
{
struct
unseal_message_params
params
=
{
context
,
message
,
quality_of_protection
};
struct
context_handle
*
context_handle
=
(
void
*
)
context
;
struct
unseal_message_params
params
=
{
context_handle
->
handle
,
message
,
quality_of_protection
};
return
KRB5_CALL
(
unseal_message
,
&
params
);
return
KRB5_CALL
(
unseal_message
,
&
params
);
}
}
else
return
SEC_E_INVALID_HANDLE
;
else
return
SEC_E_INVALID_HANDLE
;
...
...
dlls/kerberos/unixlib.c
View file @
0e6b7275
...
@@ -486,9 +486,9 @@ static void trace_gss_status( OM_uint32 major_status, OM_uint32 minor_status )
...
@@ -486,9 +486,9 @@ static void trace_gss_status( OM_uint32 major_status, OM_uint32 minor_status )
}
}
}
}
static
inline
gss_ctx_id_t
ctxhandle_sspi_to_gss
(
LSA_SEC_HANDLE
handle
)
static
inline
gss_ctx_id_t
ctxhandle_sspi_to_gss
(
UINT64
handle
)
{
{
return
(
gss_ctx_id_t
)
handle
;
return
(
gss_ctx_id_t
)
(
ULONG_PTR
)
handle
;
}
}
static
inline
gss_cred_id_t
credhandle_sspi_to_gss
(
UINT64
handle
)
static
inline
gss_cred_id_t
credhandle_sspi_to_gss
(
UINT64
handle
)
...
@@ -496,9 +496,9 @@ static inline gss_cred_id_t credhandle_sspi_to_gss( UINT64 handle )
...
@@ -496,9 +496,9 @@ static inline gss_cred_id_t credhandle_sspi_to_gss( UINT64 handle )
return
(
gss_cred_id_t
)(
ULONG_PTR
)
handle
;
return
(
gss_cred_id_t
)(
ULONG_PTR
)
handle
;
}
}
static
inline
void
ctxhandle_gss_to_sspi
(
gss_ctx_id_t
handle
,
LSA_SEC_HANDLE
*
ctx
)
static
inline
void
ctxhandle_gss_to_sspi
(
gss_ctx_id_t
handle
,
UINT64
*
ctx
)
{
{
*
ctx
=
(
LSA_SEC_HANDLE
)
handle
;
*
ctx
=
(
ULONG_PTR
)
handle
;
}
}
static
inline
void
credhandle_gss_to_sspi
(
gss_cred_id_t
handle
,
UINT64
*
cred
)
static
inline
void
credhandle_gss_to_sspi
(
gss_cred_id_t
handle
,
UINT64
*
cred
)
...
@@ -654,8 +654,9 @@ static NTSTATUS acquire_credentials_handle( void *args )
...
@@ -654,8 +654,9 @@ static NTSTATUS acquire_credentials_handle( void *args )
static
NTSTATUS
delete_context
(
void
*
args
)
static
NTSTATUS
delete_context
(
void
*
args
)
{
{
const
struct
delete_context_params
*
params
=
args
;
OM_uint32
ret
,
minor_status
;
OM_uint32
ret
,
minor_status
;
gss_ctx_id_t
ctx_handle
=
ctxhandle_sspi_to_gss
(
(
LSA_SEC_HANDLE
)
args
);
gss_ctx_id_t
ctx_handle
=
ctxhandle_sspi_to_gss
(
params
->
context
);
ret
=
pgss_delete_sec_context
(
&
minor_status
,
&
ctx_handle
,
GSS_C_NO_BUFFER
);
ret
=
pgss_delete_sec_context
(
&
minor_status
,
&
ctx_handle
,
GSS_C_NO_BUFFER
);
TRACE
(
"gss_delete_sec_context returned %#x minor status %#x
\n
"
,
ret
,
minor_status
);
TRACE
(
"gss_delete_sec_context returned %#x minor status %#x
\n
"
,
ret
,
minor_status
);
...
...
dlls/kerberos/unixlib.h
View file @
0e6b7275
...
@@ -26,9 +26,9 @@
...
@@ -26,9 +26,9 @@
struct
accept_context_params
struct
accept_context_params
{
{
UINT64
credential
;
UINT64
credential
;
LSA_SEC_HANDLE
context
;
UINT64
context
;
SecBufferDesc
*
input
;
SecBufferDesc
*
input
;
LSA_SEC_HANDLE
*
new_context
;
UINT64
*
new_context
;
SecBufferDesc
*
output
;
SecBufferDesc
*
output
;
ULONG
*
context_attr
;
ULONG
*
context_attr
;
ULONG
*
expiry
;
ULONG
*
expiry
;
...
@@ -44,6 +44,11 @@ struct acquire_credentials_handle_params
...
@@ -44,6 +44,11 @@ struct acquire_credentials_handle_params
ULONG
*
expiry
;
ULONG
*
expiry
;
};
};
struct
delete_context_params
{
UINT64
context
;
};
struct
free_credentials_handle_params
struct
free_credentials_handle_params
{
{
UINT64
credential
;
UINT64
credential
;
...
@@ -52,11 +57,11 @@ struct free_credentials_handle_params
...
@@ -52,11 +57,11 @@ struct free_credentials_handle_params
struct
initialize_context_params
struct
initialize_context_params
{
{
UINT64
credential
;
UINT64
credential
;
LSA_SEC_HANDLE
context
;
UINT64
context
;
const
char
*
target_name
;
const
char
*
target_name
;
ULONG
context_req
;
ULONG
context_req
;
SecBufferDesc
*
input
;
SecBufferDesc
*
input
;
LSA_SEC_HANDLE
*
new_context
;
UINT64
*
new_context
;
SecBufferDesc
*
output
;
SecBufferDesc
*
output
;
ULONG
*
context_attr
;
ULONG
*
context_attr
;
ULONG
*
expiry
;
ULONG
*
expiry
;
...
@@ -64,13 +69,13 @@ struct initialize_context_params
...
@@ -64,13 +69,13 @@ struct initialize_context_params
struct
make_signature_params
struct
make_signature_params
{
{
LSA_SEC_HANDLE
context
;
UINT64
context
;
SecBufferDesc
*
msg
;
SecBufferDesc
*
msg
;
};
};
struct
query_context_attributes_params
struct
query_context_attributes_params
{
{
LSA_SEC_HANDLE
context
;
UINT64
context
;
unsigned
attr
;
unsigned
attr
;
void
*
buf
;
void
*
buf
;
};
};
...
@@ -83,21 +88,21 @@ struct query_ticket_cache_params
...
@@ -83,21 +88,21 @@ struct query_ticket_cache_params
struct
seal_message_params
struct
seal_message_params
{
{
LSA_SEC_HANDLE
context
;
UINT64
context
;
SecBufferDesc
*
msg
;
SecBufferDesc
*
msg
;
unsigned
qop
;
unsigned
qop
;
};
};
struct
unseal_message_params
struct
unseal_message_params
{
{
LSA_SEC_HANDLE
context
;
UINT64
context
;
SecBufferDesc
*
msg
;
SecBufferDesc
*
msg
;
ULONG
*
qop
;
ULONG
*
qop
;
};
};
struct
verify_signature_params
struct
verify_signature_params
{
{
LSA_SEC_HANDLE
context
;
UINT64
context
;
SecBufferDesc
*
msg
;
SecBufferDesc
*
msg
;
ULONG
*
qop
;
ULONG
*
qop
;
};
};
...
...
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