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
9a51a9c4
Commit
9a51a9c4
authored
Aug 11, 2021
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msv1_0: Move context allocation to the PE side.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
b45deaa4
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
27 additions
and
25 deletions
+27
-25
main.c
dlls/msv1_0/main.c
+17
-4
unixlib.c
dlls/msv1_0/unixlib.c
+9
-20
unixlib.h
dlls/msv1_0/unixlib.h
+1
-1
No files found.
dlls/msv1_0/main.c
View file @
9a51a9c4
...
@@ -655,7 +655,9 @@ static NTSTATUS NTAPI ntlm_SpInitLsaModeContext( LSA_SEC_HANDLE cred_handle, LSA
...
@@ -655,7 +655,9 @@ static NTSTATUS NTAPI ntlm_SpInitLsaModeContext( LSA_SEC_HANDLE cred_handle, LSA
argv
[
4
]
=
NULL
;
argv
[
4
]
=
NULL
;
}
}
if
((
status
=
ntlm_funcs
->
fork
(
argv
,
&
ctx
))
!=
SEC_E_OK
)
goto
done
;
if
(
!
(
ctx
=
calloc
(
1
,
sizeof
(
*
ctx
)
)))
goto
done
;
if
((
status
=
ntlm_funcs
->
fork
(
ctx
,
argv
))
!=
SEC_E_OK
)
goto
done
;
status
=
SEC_E_INSUFFICIENT_MEMORY
;
status
=
SEC_E_INSUFFICIENT_MEMORY
;
ctx
->
mode
=
MODE_CLIENT
;
ctx
->
mode
=
MODE_CLIENT
;
...
@@ -838,7 +840,11 @@ static NTSTATUS NTAPI ntlm_SpInitLsaModeContext( LSA_SEC_HANDLE cred_handle, LSA
...
@@ -838,7 +840,11 @@ static NTSTATUS NTAPI ntlm_SpInitLsaModeContext( LSA_SEC_HANDLE cred_handle, LSA
}
}
done:
done:
if
(
status
!=
SEC_E_OK
&&
status
!=
SEC_I_CONTINUE_NEEDED
)
ntlm_funcs
->
cleanup
(
ctx
);
if
(
status
!=
SEC_E_OK
&&
status
!=
SEC_I_CONTINUE_NEEDED
)
{
ntlm_funcs
->
cleanup
(
ctx
);
free
(
ctx
);
}
free
(
username
);
free
(
username
);
free
(
domain
);
free
(
domain
);
free
(
password
);
free
(
password
);
...
@@ -892,10 +898,12 @@ static NTSTATUS NTAPI ntlm_SpAcceptLsaModeContext( LSA_SEC_HANDLE cred_handle, L
...
@@ -892,10 +898,12 @@ static NTSTATUS NTAPI ntlm_SpAcceptLsaModeContext( LSA_SEC_HANDLE cred_handle, L
}
}
else
bin_len
=
input
->
pBuffers
[
0
].
cbBuffer
;
else
bin_len
=
input
->
pBuffers
[
0
].
cbBuffer
;
if
(
!
(
ctx
=
calloc
(
1
,
sizeof
(
*
ctx
)
)))
goto
done
;
argv
[
0
]
=
(
char
*
)
"ntlm_auth"
;
argv
[
0
]
=
(
char
*
)
"ntlm_auth"
;
argv
[
1
]
=
(
char
*
)
"--helper-protocol=squid-2.5-ntlmssp"
;
argv
[
1
]
=
(
char
*
)
"--helper-protocol=squid-2.5-ntlmssp"
;
argv
[
2
]
=
NULL
;
argv
[
2
]
=
NULL
;
if
((
status
=
ntlm_funcs
->
fork
(
argv
,
&
ctx
))
!=
SEC_E_OK
)
goto
done
;
if
((
status
=
ntlm_funcs
->
fork
(
ctx
,
argv
))
!=
SEC_E_OK
)
goto
done
;
ctx
->
mode
=
MODE_SERVER
;
ctx
->
mode
=
MODE_SERVER
;
if
(
!
(
want_flags
=
malloc
(
73
)))
if
(
!
(
want_flags
=
malloc
(
73
)))
...
@@ -1048,7 +1056,11 @@ static NTSTATUS NTAPI ntlm_SpAcceptLsaModeContext( LSA_SEC_HANDLE cred_handle, L
...
@@ -1048,7 +1056,11 @@ static NTSTATUS NTAPI ntlm_SpAcceptLsaModeContext( LSA_SEC_HANDLE cred_handle, L
}
}
done:
done:
if
(
status
!=
SEC_E_OK
&&
status
!=
SEC_I_CONTINUE_NEEDED
)
ntlm_funcs
->
cleanup
(
ctx
);
if
(
status
!=
SEC_E_OK
&&
status
!=
SEC_I_CONTINUE_NEEDED
)
{
ntlm_funcs
->
cleanup
(
ctx
);
free
(
ctx
);
}
free
(
buf
);
free
(
buf
);
free
(
bin
);
free
(
bin
);
free
(
want_flags
);
free
(
want_flags
);
...
@@ -1065,6 +1077,7 @@ static NTSTATUS NTAPI ntlm_SpDeleteContext( LSA_SEC_HANDLE handle )
...
@@ -1065,6 +1077,7 @@ static NTSTATUS NTAPI ntlm_SpDeleteContext( LSA_SEC_HANDLE handle )
if
(
!
ctx
)
return
SEC_E_INVALID_HANDLE
;
if
(
!
ctx
)
return
SEC_E_INVALID_HANDLE
;
ntlm_funcs
->
cleanup
(
ctx
);
ntlm_funcs
->
cleanup
(
ctx
);
free
(
ctx
);
return
SEC_E_OK
;
return
SEC_E_OK
;
}
}
...
...
dlls/msv1_0/unixlib.c
View file @
9a51a9c4
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#endif
#endif
#include <stdarg.h>
#include <stdarg.h>
#include <stdlib.h>
#include <unistd.h>
#include <unistd.h>
#include <fcntl.h>
#include <fcntl.h>
#include <errno.h>
#include <errno.h>
...
@@ -49,7 +50,7 @@ static SECURITY_STATUS read_line( struct ntlm_ctx *ctx, unsigned int *offset )
...
@@ -49,7 +50,7 @@ static SECURITY_STATUS read_line( struct ntlm_ctx *ctx, unsigned int *offset )
if
(
!
ctx
->
com_buf
)
if
(
!
ctx
->
com_buf
)
{
{
if
(
!
(
ctx
->
com_buf
=
RtlAllocateHeap
(
GetProcessHeap
(),
0
,
INITIAL_BUFFER_SIZE
)))
if
(
!
(
ctx
->
com_buf
=
malloc
(
INITIAL_BUFFER_SIZE
)))
return
SEC_E_INSUFFICIENT_MEMORY
;
return
SEC_E_INSUFFICIENT_MEMORY
;
ctx
->
com_buf_size
=
INITIAL_BUFFER_SIZE
;
ctx
->
com_buf_size
=
INITIAL_BUFFER_SIZE
;
ctx
->
com_buf_offset
=
0
;
ctx
->
com_buf_offset
=
0
;
...
@@ -60,7 +61,7 @@ static SECURITY_STATUS read_line( struct ntlm_ctx *ctx, unsigned int *offset )
...
@@ -60,7 +61,7 @@ static SECURITY_STATUS read_line( struct ntlm_ctx *ctx, unsigned int *offset )
ssize_t
size
;
ssize_t
size
;
if
(
ctx
->
com_buf_offset
+
INITIAL_BUFFER_SIZE
>
ctx
->
com_buf_size
)
if
(
ctx
->
com_buf_offset
+
INITIAL_BUFFER_SIZE
>
ctx
->
com_buf_size
)
{
{
char
*
buf
=
RtlReAllocateHeap
(
GetProcessHeap
(),
0
,
ctx
->
com_buf
,
ctx
->
com_buf_size
+
INITIAL_BUFFER_SIZE
);
char
*
buf
=
realloc
(
ctx
->
com_buf
,
ctx
->
com_buf_size
+
INITIAL_BUFFER_SIZE
);
if
(
!
buf
)
return
SEC_E_INSUFFICIENT_MEMORY
;
if
(
!
buf
)
return
SEC_E_INSUFFICIENT_MEMORY
;
ctx
->
com_buf_size
+=
INITIAL_BUFFER_SIZE
;
ctx
->
com_buf_size
+=
INITIAL_BUFFER_SIZE
;
ctx
->
com_buf
=
buf
;
ctx
->
com_buf
=
buf
;
...
@@ -125,14 +126,12 @@ static void CDECL ntlm_cleanup( struct ntlm_ctx *ctx )
...
@@ -125,14 +126,12 @@ static void CDECL ntlm_cleanup( struct ntlm_ctx *ctx )
}
while
(
ret
<
0
&&
errno
==
EINTR
);
}
while
(
ret
<
0
&&
errno
==
EINTR
);
}
}
RtlFreeHeap
(
GetProcessHeap
(),
0
,
ctx
->
com_buf
);
free
(
ctx
->
com_buf
);
RtlFreeHeap
(
GetProcessHeap
(),
0
,
ctx
);
}
}
static
SECURITY_STATUS
CDECL
ntlm_fork
(
char
**
argv
,
struct
ntlm_ctx
**
ret_ctx
)
static
SECURITY_STATUS
CDECL
ntlm_fork
(
struct
ntlm_ctx
*
ctx
,
char
**
argv
)
{
{
int
pipe_in
[
2
],
pipe_out
[
2
];
int
pipe_in
[
2
],
pipe_out
[
2
];
struct
ntlm_ctx
*
ctx
;
#ifdef HAVE_PIPE2
#ifdef HAVE_PIPE2
if
(
pipe2
(
pipe_in
,
O_CLOEXEC
)
<
0
)
if
(
pipe2
(
pipe_in
,
O_CLOEXEC
)
<
0
)
...
@@ -156,15 +155,6 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
...
@@ -156,15 +155,6 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
fcntl
(
pipe_out
[
1
],
F_SETFD
,
FD_CLOEXEC
);
fcntl
(
pipe_out
[
1
],
F_SETFD
,
FD_CLOEXEC
);
}
}
if
(
!
(
ctx
=
RtlAllocateHeap
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
*
ctx
)
)))
{
close
(
pipe_in
[
0
]
);
close
(
pipe_in
[
1
]
);
close
(
pipe_out
[
0
]
);
close
(
pipe_out
[
1
]
);
return
SEC_E_INSUFFICIENT_MEMORY
;
}
if
(
!
(
ctx
->
pid
=
fork
()))
/* child */
if
(
!
(
ctx
->
pid
=
fork
()))
/* child */
{
{
dup2
(
pipe_out
[
0
],
0
);
dup2
(
pipe_out
[
0
],
0
);
...
@@ -186,7 +176,6 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
...
@@ -186,7 +176,6 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
close
(
pipe_in
[
1
]
);
close
(
pipe_in
[
1
]
);
ctx
->
pipe_out
=
pipe_out
[
1
];
ctx
->
pipe_out
=
pipe_out
[
1
];
close
(
pipe_out
[
0
]
);
close
(
pipe_out
[
0
]
);
*
ret_ctx
=
ctx
;
}
}
return
SEC_E_OK
;
return
SEC_E_OK
;
...
@@ -198,7 +187,7 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
...
@@ -198,7 +187,7 @@ static SECURITY_STATUS CDECL ntlm_fork( char **argv, struct ntlm_ctx **ret_ctx )
static
BOOL
check_version
(
void
)
static
BOOL
check_version
(
void
)
{
{
struct
ntlm_ctx
*
ctx
;
struct
ntlm_ctx
ctx
=
{
0
}
;
char
*
argv
[
3
],
buf
[
80
];
char
*
argv
[
3
],
buf
[
80
];
BOOL
ret
=
FALSE
;
BOOL
ret
=
FALSE
;
int
len
;
int
len
;
...
@@ -206,9 +195,9 @@ static BOOL check_version( void )
...
@@ -206,9 +195,9 @@ static BOOL check_version( void )
argv
[
0
]
=
(
char
*
)
"ntlm_auth"
;
argv
[
0
]
=
(
char
*
)
"ntlm_auth"
;
argv
[
1
]
=
(
char
*
)
"--version"
;
argv
[
1
]
=
(
char
*
)
"--version"
;
argv
[
2
]
=
NULL
;
argv
[
2
]
=
NULL
;
if
(
ntlm_fork
(
argv
,
&
ctx
)
!=
SEC_E_OK
)
return
FALSE
;
if
(
ntlm_fork
(
&
ctx
,
argv
)
!=
SEC_E_OK
)
return
FALSE
;
if
((
len
=
read
(
ctx
->
pipe_in
,
buf
,
sizeof
(
buf
)
-
1
))
>
8
)
if
((
len
=
read
(
ctx
.
pipe_in
,
buf
,
sizeof
(
buf
)
-
1
))
>
8
)
{
{
char
*
newline
;
char
*
newline
;
int
major
=
0
,
minor
=
0
,
micro
=
0
;
int
major
=
0
,
minor
=
0
,
micro
=
0
;
...
@@ -233,7 +222,7 @@ static BOOL check_version( void )
...
@@ -233,7 +222,7 @@ static BOOL check_version( void )
"Make sure that ntlm_auth >= %d.%d.%d is in your path. "
"Make sure that ntlm_auth >= %d.%d.%d is in your path. "
"Usually, you can find it in the winbind package of your distribution.
\n
"
,
"Usually, you can find it in the winbind package of your distribution.
\n
"
,
NTLM_AUTH_MAJOR_VERSION
,
NTLM_AUTH_MINOR_VERSION
,
NTLM_AUTH_MICRO_VERSION
);
NTLM_AUTH_MAJOR_VERSION
,
NTLM_AUTH_MINOR_VERSION
,
NTLM_AUTH_MICRO_VERSION
);
ntlm_cleanup
(
ctx
);
ntlm_cleanup
(
&
ctx
);
return
ret
;
return
ret
;
}
}
...
...
dlls/msv1_0/unixlib.h
View file @
9a51a9c4
...
@@ -92,7 +92,7 @@ struct ntlm_funcs
...
@@ -92,7 +92,7 @@ struct ntlm_funcs
{
{
SECURITY_STATUS
(
CDECL
*
chat
)(
struct
ntlm_ctx
*
,
char
*
,
unsigned
int
,
unsigned
int
*
);
SECURITY_STATUS
(
CDECL
*
chat
)(
struct
ntlm_ctx
*
,
char
*
,
unsigned
int
,
unsigned
int
*
);
void
(
CDECL
*
cleanup
)(
struct
ntlm_ctx
*
);
void
(
CDECL
*
cleanup
)(
struct
ntlm_ctx
*
);
SECURITY_STATUS
(
CDECL
*
fork
)(
char
**
,
struct
ntlm_ctx
**
);
SECURITY_STATUS
(
CDECL
*
fork
)(
struct
ntlm_ctx
*
,
char
**
);
};
};
extern
const
struct
ntlm_funcs
*
ntlm_funcs
;
extern
const
struct
ntlm_funcs
*
ntlm_funcs
;
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