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
32d7838d
Commit
32d7838d
authored
May 01, 2019
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
services: Build with msvcrt.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
13eac409
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
61 deletions
+60
-61
Makefile.in
programs/services/Makefile.in
+2
-1
rpc.c
programs/services/rpc.c
+25
-26
services.c
programs/services/services.c
+31
-31
utils.c
programs/services/utils.c
+2
-3
No files found.
programs/services/Makefile.in
View file @
32d7838d
MODULE
=
services.exe
MODULE
=
services.exe
APPMODE
=
-mconsole
IMPORTS
=
rpcrt4 advapi32 userenv
IMPORTS
=
rpcrt4 advapi32 userenv
EXTRADLLFLAGS
=
-mconsole
-mno-cygwin
C_SRCS
=
\
C_SRCS
=
\
rpc.c
\
rpc.c
\
services.c
\
services.c
\
...
...
programs/services/rpc.c
View file @
32d7838d
...
@@ -29,7 +29,6 @@
...
@@ -29,7 +29,6 @@
#include <rpc.h>
#include <rpc.h>
#include "wine/list.h"
#include "wine/list.h"
#include "wine/unicode.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "services.h"
#include "services.h"
...
@@ -277,9 +276,9 @@ DWORD __cdecl svcctl_OpenSCManagerW(
...
@@ -277,9 +276,9 @@ DWORD __cdecl svcctl_OpenSCManagerW(
if
(
DatabaseName
!=
NULL
&&
DatabaseName
[
0
])
if
(
DatabaseName
!=
NULL
&&
DatabaseName
[
0
])
{
{
if
(
strcmpW
(
DatabaseName
,
SERVICES_FAILED_DATABASEW
)
==
0
)
if
(
l
strcmpW
(
DatabaseName
,
SERVICES_FAILED_DATABASEW
)
==
0
)
return
ERROR_DATABASE_DOES_NOT_EXIST
;
return
ERROR_DATABASE_DOES_NOT_EXIST
;
if
(
strcmpW
(
DatabaseName
,
SERVICES_ACTIVE_DATABASEW
)
!=
0
)
if
(
l
strcmpW
(
DatabaseName
,
SERVICES_ACTIVE_DATABASEW
)
!=
0
)
return
ERROR_INVALID_NAME
;
return
ERROR_INVALID_NAME
;
}
}
...
@@ -353,7 +352,7 @@ DWORD __cdecl svcctl_GetServiceDisplayNameW(
...
@@ -353,7 +352,7 @@ DWORD __cdecl svcctl_GetServiceDisplayNameW(
LPCWSTR
name
;
LPCWSTR
name
;
int
len
;
int
len
;
name
=
get_display_name
(
entry
);
name
=
get_display_name
(
entry
);
len
=
strlenW
(
name
);
len
=
l
strlenW
(
name
);
if
(
len
<=
*
cchBufSize
)
if
(
len
<=
*
cchBufSize
)
{
{
err
=
ERROR_SUCCESS
;
err
=
ERROR_SUCCESS
;
...
@@ -395,7 +394,7 @@ DWORD __cdecl svcctl_GetServiceKeyNameW(
...
@@ -395,7 +394,7 @@ DWORD __cdecl svcctl_GetServiceKeyNameW(
if
(
entry
!=
NULL
)
if
(
entry
!=
NULL
)
{
{
int
len
;
int
len
;
len
=
strlenW
(
entry
->
name
);
len
=
l
strlenW
(
entry
->
name
);
if
(
len
<=
*
cchBufSize
)
if
(
len
<=
*
cchBufSize
)
{
{
err
=
ERROR_SUCCESS
;
err
=
ERROR_SUCCESS
;
...
@@ -486,7 +485,7 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
...
@@ -486,7 +485,7 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
while
(
*
ptr
)
while
(
*
ptr
)
{
{
len
=
strlenW
(
ptr
)
+
1
;
len
=
l
strlenW
(
ptr
)
+
1
;
if
(
ptr
[
0
]
==
'+'
&&
ptr
[
1
])
if
(
ptr
[
0
]
==
'+'
&&
ptr
[
1
])
len_groups
+=
len
-
1
;
len_groups
+=
len
-
1
;
else
else
...
@@ -504,10 +503,10 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
...
@@ -504,10 +503,10 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
ptr
=
dependencies
;
ptr
=
dependencies
;
while
(
*
ptr
)
while
(
*
ptr
)
{
{
len
=
strlenW
(
ptr
)
+
1
;
len
=
l
strlenW
(
ptr
)
+
1
;
if
(
*
ptr
!=
'+'
)
if
(
*
ptr
!=
'+'
)
{
{
strcpyW
(
s
,
ptr
);
l
strcpyW
(
s
,
ptr
);
s
+=
len
;
s
+=
len
;
}
}
ptr
+=
len
;
ptr
+=
len
;
...
@@ -528,10 +527,10 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
...
@@ -528,10 +527,10 @@ static DWORD parse_dependencies(const WCHAR *dependencies, struct service_entry
ptr
=
dependencies
;
ptr
=
dependencies
;
while
(
*
ptr
)
while
(
*
ptr
)
{
{
len
=
strlenW
(
ptr
)
+
1
;
len
=
l
strlenW
(
ptr
)
+
1
;
if
(
ptr
[
0
]
==
'+'
&&
ptr
[
1
])
if
(
ptr
[
0
]
==
'+'
&&
ptr
[
1
])
{
{
strcpyW
(
s
,
ptr
+
1
);
l
strcpyW
(
s
,
ptr
+
1
);
s
+=
len
-
1
;
s
+=
len
-
1
;
}
}
ptr
+=
len
;
ptr
+=
len
;
...
@@ -988,14 +987,14 @@ DWORD __cdecl svcctl_QueryServiceConfig2W( SC_RPC_HANDLE hService, DWORD level,
...
@@ -988,14 +987,14 @@ DWORD __cdecl svcctl_QueryServiceConfig2W( SC_RPC_HANDLE hService, DWORD level,
service_lock
(
service
->
service_entry
);
service_lock
(
service
->
service_entry
);
if
(
service
->
service_entry
->
description
)
if
(
service
->
service_entry
->
description
)
total_size
+=
strlenW
(
service
->
service_entry
->
description
)
*
sizeof
(
WCHAR
);
total_size
+=
l
strlenW
(
service
->
service_entry
->
description
)
*
sizeof
(
WCHAR
);
*
needed
=
total_size
;
*
needed
=
total_size
;
if
(
size
>=
total_size
)
if
(
size
>=
total_size
)
{
{
if
(
service
->
service_entry
->
description
)
if
(
service
->
service_entry
->
description
)
{
{
strcpyW
(
desc
->
description
,
service
->
service_entry
->
description
);
l
strcpyW
(
desc
->
description
,
service
->
service_entry
->
description
);
desc
->
size
=
total_size
-
FIELD_OFFSET
(
struct
service_description
,
description
);
desc
->
size
=
total_size
-
FIELD_OFFSET
(
struct
service_description
,
description
);
}
}
else
else
...
@@ -1185,19 +1184,19 @@ BOOL process_send_control(struct process_entry *process, BOOL shared_process, co
...
@@ -1185,19 +1184,19 @@ BOOL process_send_control(struct process_entry *process, BOOL shared_process, co
{
{
control
|=
SERVICE_CONTROL_FORWARD_FLAG
;
control
|=
SERVICE_CONTROL_FORWARD_FLAG
;
data
=
(
BYTE
*
)
name
;
data
=
(
BYTE
*
)
name
;
data_size
=
(
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
);
data_size
=
(
l
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
);
name
=
emptyW
;
name
=
emptyW
;
}
}
/* calculate how much space we need to send the startup info */
/* calculate how much space we need to send the startup info */
len
=
(
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
)
+
data_size
;
len
=
(
l
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
)
+
data_size
;
ssi
=
HeapAlloc
(
GetProcessHeap
(),
0
,
FIELD_OFFSET
(
service_start_info
,
data
[
len
]));
ssi
=
HeapAlloc
(
GetProcessHeap
(),
0
,
FIELD_OFFSET
(
service_start_info
,
data
[
len
]));
ssi
->
magic
=
SERVICE_PROTOCOL_MAGIC
;
ssi
->
magic
=
SERVICE_PROTOCOL_MAGIC
;
ssi
->
control
=
control
;
ssi
->
control
=
control
;
ssi
->
total_size
=
FIELD_OFFSET
(
service_start_info
,
data
[
len
]);
ssi
->
total_size
=
FIELD_OFFSET
(
service_start_info
,
data
[
len
]);
ssi
->
name_size
=
strlenW
(
name
)
+
1
;
ssi
->
name_size
=
l
strlenW
(
name
)
+
1
;
strcpyW
((
WCHAR
*
)
ssi
->
data
,
name
);
l
strcpyW
((
WCHAR
*
)
ssi
->
data
,
name
);
if
(
data_size
)
memcpy
(
&
ssi
->
data
[
ssi
->
name_size
*
sizeof
(
WCHAR
)],
data
,
data_size
);
if
(
data_size
)
memcpy
(
&
ssi
->
data
[
ssi
->
name_size
*
sizeof
(
WCHAR
)],
data
,
data_size
);
r
=
process_send_command
(
process
,
ssi
,
ssi
->
total_size
,
result
);
r
=
process_send_command
(
process
,
ssi
,
ssi
->
total_size
,
result
);
...
@@ -1466,10 +1465,10 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
...
@@ -1466,10 +1465,10 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
))
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
))
{
{
total_size
+=
sizeof
(
*
s
);
total_size
+=
sizeof
(
*
s
);
total_size
+=
(
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
total_size
+=
(
l
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
if
(
service
->
config
.
lpDisplayName
)
if
(
service
->
config
.
lpDisplayName
)
{
{
total_size
+=
(
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
total_size
+=
(
l
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
}
}
num_services
++
;
num_services
++
;
}
}
...
@@ -1487,7 +1486,7 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
...
@@ -1487,7 +1486,7 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
{
{
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
))
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
))
{
{
sz
=
(
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
sz
=
(
l
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
memcpy
(
buffer
+
offset
,
service
->
name
,
sz
);
memcpy
(
buffer
+
offset
,
service
->
name
,
sz
);
s
->
service_name
=
offset
;
s
->
service_name
=
offset
;
offset
+=
sz
;
offset
+=
sz
;
...
@@ -1495,7 +1494,7 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
...
@@ -1495,7 +1494,7 @@ DWORD __cdecl svcctl_EnumServicesStatusW(
if
(
!
service
->
config
.
lpDisplayName
)
s
->
display_name
=
0
;
if
(
!
service
->
config
.
lpDisplayName
)
s
->
display_name
=
0
;
else
else
{
{
sz
=
(
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
sz
=
(
l
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
memcpy
(
buffer
+
offset
,
service
->
config
.
lpDisplayName
,
sz
);
memcpy
(
buffer
+
offset
,
service
->
config
.
lpDisplayName
,
sz
);
s
->
display_name
=
offset
;
s
->
display_name
=
offset
;
offset
+=
sz
;
offset
+=
sz
;
...
@@ -1515,7 +1514,7 @@ static struct service_entry *find_service_by_group(struct scmdatabase *db, const
...
@@ -1515,7 +1514,7 @@ static struct service_entry *find_service_by_group(struct scmdatabase *db, const
struct
service_entry
*
service
;
struct
service_entry
*
service
;
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
{
{
if
(
service
->
config
.
lpLoadOrderGroup
&&
!
strcmpiW
(
group
,
service
->
config
.
lpLoadOrderGroup
))
if
(
service
->
config
.
lpLoadOrderGroup
&&
!
wcsicmp
(
group
,
service
->
config
.
lpLoadOrderGroup
))
return
service
;
return
service
;
}
}
return
NULL
;
return
NULL
;
...
@@ -1525,7 +1524,7 @@ static BOOL match_group(const WCHAR *g1, const WCHAR *g2)
...
@@ -1525,7 +1524,7 @@ static BOOL match_group(const WCHAR *g1, const WCHAR *g2)
{
{
if
(
!
g2
)
return
TRUE
;
if
(
!
g2
)
return
TRUE
;
if
(
!
g2
[
0
]
&&
(
!
g1
||
!
g1
[
0
]))
return
TRUE
;
if
(
!
g2
[
0
]
&&
(
!
g1
||
!
g1
[
0
]))
return
TRUE
;
if
(
g1
&&
!
strcmpW
(
g1
,
g2
))
return
TRUE
;
if
(
g1
&&
!
l
strcmpW
(
g1
,
g2
))
return
TRUE
;
return
FALSE
;
return
FALSE
;
}
}
...
@@ -1590,10 +1589,10 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
...
@@ -1590,10 +1589,10 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
&&
match_group
(
service
->
config
.
lpLoadOrderGroup
,
group
))
&&
match_group
(
service
->
config
.
lpLoadOrderGroup
,
group
))
{
{
total_size
+=
sizeof
(
*
s
);
total_size
+=
sizeof
(
*
s
);
total_size
+=
(
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
total_size
+=
(
l
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
if
(
service
->
config
.
lpDisplayName
)
if
(
service
->
config
.
lpDisplayName
)
{
{
total_size
+=
(
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
total_size
+=
(
l
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
}
}
num_services
++
;
num_services
++
;
}
}
...
@@ -1612,7 +1611,7 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
...
@@ -1612,7 +1611,7 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
)
if
((
service
->
status
.
dwServiceType
&
type
)
&&
map_state
(
service
->
status
.
dwCurrentState
,
state
)
&&
match_group
(
service
->
config
.
lpLoadOrderGroup
,
group
))
&&
match_group
(
service
->
config
.
lpLoadOrderGroup
,
group
))
{
{
sz
=
(
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
sz
=
(
l
strlenW
(
service
->
name
)
+
1
)
*
sizeof
(
WCHAR
);
memcpy
(
buffer
+
offset
,
service
->
name
,
sz
);
memcpy
(
buffer
+
offset
,
service
->
name
,
sz
);
s
->
service_name
=
offset
;
s
->
service_name
=
offset
;
offset
+=
sz
;
offset
+=
sz
;
...
@@ -1620,7 +1619,7 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
...
@@ -1620,7 +1619,7 @@ DWORD __cdecl svcctl_EnumServicesStatusExW(
if
(
!
service
->
config
.
lpDisplayName
)
s
->
display_name
=
0
;
if
(
!
service
->
config
.
lpDisplayName
)
s
->
display_name
=
0
;
else
else
{
{
sz
=
(
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
sz
=
(
l
strlenW
(
service
->
config
.
lpDisplayName
)
+
1
)
*
sizeof
(
WCHAR
);
memcpy
(
buffer
+
offset
,
service
->
config
.
lpDisplayName
,
sz
);
memcpy
(
buffer
+
offset
,
service
->
config
.
lpDisplayName
,
sz
);
s
->
display_name
=
offset
;
s
->
display_name
=
offset
;
offset
+=
sz
;
offset
+=
sz
;
...
...
programs/services/services.c
View file @
32d7838d
...
@@ -21,13 +21,13 @@
...
@@ -21,13 +21,13 @@
#define WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#include <stdarg.h>
#include <stdarg.h>
#include <stdio.h>
#include <assert.h>
#include <assert.h>
#include <windows.h>
#include <windows.h>
#include <winsvc.h>
#include <winsvc.h>
#include <rpc.h>
#include <rpc.h>
#include <userenv.h>
#include <userenv.h>
#include "wine/unicode.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "svcctl.h"
#include "svcctl.h"
...
@@ -192,10 +192,10 @@ static DWORD load_service_config(HKEY hKey, struct service_entry *entry)
...
@@ -192,10 +192,10 @@ static DWORD load_service_config(HKEY hKey, struct service_entry *entry)
WINE_TRACE
(
"Service account name = %s
\n
"
,
wine_dbgstr_w
(
entry
->
config
.
lpServiceStartName
)
);
WINE_TRACE
(
"Service account name = %s
\n
"
,
wine_dbgstr_w
(
entry
->
config
.
lpServiceStartName
)
);
WINE_TRACE
(
"Display name = %s
\n
"
,
wine_dbgstr_w
(
entry
->
config
.
lpDisplayName
)
);
WINE_TRACE
(
"Display name = %s
\n
"
,
wine_dbgstr_w
(
entry
->
config
.
lpDisplayName
)
);
WINE_TRACE
(
"Service dependencies : %s
\n
"
,
entry
->
dependOnServices
[
0
]
?
""
:
"(none)"
);
WINE_TRACE
(
"Service dependencies : %s
\n
"
,
entry
->
dependOnServices
[
0
]
?
""
:
"(none)"
);
for
(
wptr
=
entry
->
dependOnServices
;
*
wptr
;
wptr
+=
strlenW
(
wptr
)
+
1
)
for
(
wptr
=
entry
->
dependOnServices
;
*
wptr
;
wptr
+=
l
strlenW
(
wptr
)
+
1
)
WINE_TRACE
(
" * %s
\n
"
,
wine_dbgstr_w
(
wptr
));
WINE_TRACE
(
" * %s
\n
"
,
wine_dbgstr_w
(
wptr
));
WINE_TRACE
(
"Group dependencies : %s
\n
"
,
entry
->
dependOnGroups
[
0
]
?
""
:
"(none)"
);
WINE_TRACE
(
"Group dependencies : %s
\n
"
,
entry
->
dependOnGroups
[
0
]
?
""
:
"(none)"
);
for
(
wptr
=
entry
->
dependOnGroups
;
*
wptr
;
wptr
+=
strlenW
(
wptr
)
+
1
)
for
(
wptr
=
entry
->
dependOnGroups
;
*
wptr
;
wptr
+=
l
strlenW
(
wptr
)
+
1
)
WINE_TRACE
(
" * %s
\n
"
,
wine_dbgstr_w
(
wptr
));
WINE_TRACE
(
" * %s
\n
"
,
wine_dbgstr_w
(
wptr
));
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
...
@@ -213,7 +213,7 @@ static DWORD reg_set_string_value(HKEY hKey, LPCWSTR value_name, LPCWSTR string)
...
@@ -213,7 +213,7 @@ static DWORD reg_set_string_value(HKEY hKey, LPCWSTR value_name, LPCWSTR string)
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
return
RegSetValueExW
(
hKey
,
value_name
,
0
,
REG_SZ
,
(
const
BYTE
*
)
string
,
sizeof
(
WCHAR
)
*
(
strlenW
(
string
)
+
1
));
return
RegSetValueExW
(
hKey
,
value_name
,
0
,
REG_SZ
,
(
const
BYTE
*
)
string
,
sizeof
(
WCHAR
)
*
(
l
strlenW
(
string
)
+
1
));
}
}
static
DWORD
reg_set_multisz_value
(
HKEY
hKey
,
LPCWSTR
value_name
,
LPCWSTR
string
)
static
DWORD
reg_set_multisz_value
(
HKEY
hKey
,
LPCWSTR
value_name
,
LPCWSTR
string
)
...
@@ -231,7 +231,7 @@ static DWORD reg_set_multisz_value(HKEY hKey, LPCWSTR value_name, LPCWSTR string
...
@@ -231,7 +231,7 @@ static DWORD reg_set_multisz_value(HKEY hKey, LPCWSTR value_name, LPCWSTR string
}
}
ptr
=
string
;
ptr
=
string
;
while
(
*
ptr
)
ptr
+=
strlenW
(
ptr
)
+
1
;
while
(
*
ptr
)
ptr
+=
l
strlenW
(
ptr
)
+
1
;
return
RegSetValueExW
(
hKey
,
value_name
,
0
,
REG_MULTI_SZ
,
(
const
BYTE
*
)
string
,
sizeof
(
WCHAR
)
*
(
ptr
-
string
+
1
));
return
RegSetValueExW
(
hKey
,
value_name
,
0
,
REG_MULTI_SZ
,
(
const
BYTE
*
)
string
,
sizeof
(
WCHAR
)
*
(
ptr
-
string
+
1
));
}
}
...
@@ -405,7 +405,7 @@ static void scmdatabase_wait_terminate(struct scmdatabase *db)
...
@@ -405,7 +405,7 @@ static void scmdatabase_wait_terminate(struct scmdatabase *db)
BOOL
validate_service_name
(
LPCWSTR
name
)
BOOL
validate_service_name
(
LPCWSTR
name
)
{
{
return
(
name
&&
name
[
0
]
&&
!
strchrW
(
name
,
'/'
)
&&
!
strchrW
(
name
,
'\\'
));
return
(
name
&&
name
[
0
]
&&
!
wcschr
(
name
,
'/'
)
&&
!
wcschr
(
name
,
'\\'
));
}
}
BOOL
validate_service_config
(
struct
service_entry
*
entry
)
BOOL
validate_service_config
(
struct
service_entry
*
entry
)
...
@@ -427,7 +427,7 @@ BOOL validate_service_config(struct service_entry *entry)
...
@@ -427,7 +427,7 @@ BOOL validate_service_config(struct service_entry *entry)
case
SERVICE_WIN32_OWN_PROCESS
|
SERVICE_INTERACTIVE_PROCESS
:
case
SERVICE_WIN32_OWN_PROCESS
|
SERVICE_INTERACTIVE_PROCESS
:
case
SERVICE_WIN32_SHARE_PROCESS
|
SERVICE_INTERACTIVE_PROCESS
:
case
SERVICE_WIN32_SHARE_PROCESS
|
SERVICE_INTERACTIVE_PROCESS
:
/* These can be only run as LocalSystem */
/* These can be only run as LocalSystem */
if
(
entry
->
config
.
lpServiceStartName
&&
strcmpiW
(
entry
->
config
.
lpServiceStartName
,
SZ_LOCAL_SYSTEM
)
!=
0
)
if
(
entry
->
config
.
lpServiceStartName
&&
wcsicmp
(
entry
->
config
.
lpServiceStartName
,
SZ_LOCAL_SYSTEM
)
!=
0
)
{
{
WINE_ERR
(
"Service %s is interactive but has a start name
\n
"
,
wine_dbgstr_w
(
entry
->
name
));
WINE_ERR
(
"Service %s is interactive but has a start name
\n
"
,
wine_dbgstr_w
(
entry
->
name
));
return
FALSE
;
return
FALSE
;
...
@@ -466,7 +466,7 @@ struct service_entry *scmdatabase_find_service(struct scmdatabase *db, LPCWSTR n
...
@@ -466,7 +466,7 @@ struct service_entry *scmdatabase_find_service(struct scmdatabase *db, LPCWSTR n
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
{
{
if
(
strcmpiW
(
name
,
service
->
name
)
==
0
)
if
(
wcsicmp
(
name
,
service
->
name
)
==
0
)
return
service
;
return
service
;
}
}
...
@@ -479,7 +479,7 @@ struct service_entry *scmdatabase_find_service_by_displayname(struct scmdatabase
...
@@ -479,7 +479,7 @@ struct service_entry *scmdatabase_find_service_by_displayname(struct scmdatabase
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
LIST_FOR_EACH_ENTRY
(
service
,
&
db
->
services
,
struct
service_entry
,
entry
)
{
{
if
(
service
->
config
.
lpDisplayName
&&
strcmpiW
(
name
,
service
->
config
.
lpDisplayName
)
==
0
)
if
(
service
->
config
.
lpDisplayName
&&
wcsicmp
(
name
,
service
->
config
.
lpDisplayName
)
==
0
)
return
service
;
return
service
;
}
}
...
@@ -667,7 +667,7 @@ static LPWSTR service_get_pipe_name(void)
...
@@ -667,7 +667,7 @@ static LPWSTR service_get_pipe_name(void)
{
{
static
const
WCHAR
format
[]
=
{
'\\'
,
'\\'
,
'.'
,
'\\'
,
'p'
,
'i'
,
'p'
,
'e'
,
'\\'
,
static
const
WCHAR
format
[]
=
{
'\\'
,
'\\'
,
'.'
,
'\\'
,
'p'
,
'i'
,
'p'
,
'e'
,
'\\'
,
'n'
,
'e'
,
't'
,
'\\'
,
'N'
,
't'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'P'
,
'i'
,
'p'
,
'e'
,
'%'
,
'u'
,
0
};
'n'
,
'e'
,
't'
,
'\\'
,
'N'
,
't'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'P'
,
'i'
,
'p'
,
'e'
,
'%'
,
'u'
,
0
};
static
WCHAR
name
[
ARRAY_SIZE
(
format
)
+
10
];
/* strlenW("4294967295") */
static
WCHAR
name
[
ARRAY_SIZE
(
format
)
+
10
];
/*
l
strlenW("4294967295") */
static
DWORD
service_current
=
0
;
static
DWORD
service_current
=
0
;
DWORD
len
,
value
=
-
1
;
DWORD
len
,
value
=
-
1
;
LONG
ret
;
LONG
ret
;
...
@@ -680,7 +680,7 @@ static LPWSTR service_get_pipe_name(void)
...
@@ -680,7 +680,7 @@ static LPWSTR service_get_pipe_name(void)
service_current
=
max
(
service_current
,
value
+
1
);
service_current
=
max
(
service_current
,
value
+
1
);
RegSetValueExW
(
service_current_key
,
NULL
,
0
,
REG_DWORD
,
RegSetValueExW
(
service_current_key
,
NULL
,
0
,
REG_DWORD
,
(
BYTE
*
)
&
service_current
,
sizeof
(
service_current
));
(
BYTE
*
)
&
service_current
,
sizeof
(
service_current
));
s
printfW
(
name
,
format
,
service_current
);
s
wprintf
(
name
,
ARRAY_SIZE
(
name
)
,
format
,
service_current
);
service_current
++
;
service_current
++
;
return
name
;
return
name
;
}
}
...
@@ -702,22 +702,22 @@ static DWORD get_service_binary_path(const struct service_entry *service_entry,
...
@@ -702,22 +702,22 @@ static DWORD get_service_binary_path(const struct service_entry *service_entry,
DWORD
len
;
DWORD
len
;
GetSystemDirectoryW
(
system_dir
,
MAX_PATH
);
GetSystemDirectoryW
(
system_dir
,
MAX_PATH
);
len
=
strlenW
(
system_dir
);
len
=
l
strlenW
(
system_dir
);
if
(
strncmpiW
(
system_dir
,
*
path
,
len
))
if
(
wcsnicmp
(
system_dir
,
*
path
,
len
))
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
GetSystemWow64DirectoryW
(
system_dir
,
MAX_PATH
);
GetSystemWow64DirectoryW
(
system_dir
,
MAX_PATH
);
redirected
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
strlenW
(
*
path
)
+
strlenW
(
system_dir
))
*
sizeof
(
WCHAR
));
redirected
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
lstrlenW
(
*
path
)
+
l
strlenW
(
system_dir
))
*
sizeof
(
WCHAR
));
if
(
!
redirected
)
if
(
!
redirected
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
}
}
strcpyW
(
redirected
,
system_dir
);
l
strcpyW
(
redirected
,
system_dir
);
strcatW
(
redirected
,
&
(
*
path
)[
len
]
);
l
strcatW
(
redirected
,
&
(
*
path
)[
len
]
);
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
*
path
=
redirected
;
*
path
=
redirected
;
TRACE
(
"redirected to %s
\n
"
,
debugstr_w
(
redirected
));
TRACE
(
"redirected to %s
\n
"
,
debugstr_w
(
redirected
));
...
@@ -741,11 +741,11 @@ static DWORD get_winedevice_binary_path(struct service_entry *service_entry, WCH
...
@@ -741,11 +741,11 @@ static DWORD get_winedevice_binary_path(struct service_entry *service_entry, WCH
GetSystemDirectoryW
(
system_dir
,
MAX_PATH
);
GetSystemDirectoryW
(
system_dir
,
MAX_PATH
);
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
HeapFree
(
GetProcessHeap
(),
0
,
*
path
);
if
(
!
(
*
path
=
HeapAlloc
(
GetProcessHeap
(),
0
,
strlenW
(
system_dir
)
*
sizeof
(
WCHAR
)
+
sizeof
(
winedeviceW
))))
if
(
!
(
*
path
=
HeapAlloc
(
GetProcessHeap
(),
0
,
l
strlenW
(
system_dir
)
*
sizeof
(
WCHAR
)
+
sizeof
(
winedeviceW
))))
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
strcpyW
(
*
path
,
system_dir
);
l
strcpyW
(
*
path
,
system_dir
);
strcatW
(
*
path
,
winedeviceW
);
l
strcatW
(
*
path
,
winedeviceW
);
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
...
@@ -764,10 +764,10 @@ static struct process_entry *get_winedevice_process(struct service_entry *servic
...
@@ -764,10 +764,10 @@ static struct process_entry *get_winedevice_process(struct service_entry *servic
if
(
winedevice_entry
->
is_wow64
!=
is_wow64
)
continue
;
if
(
winedevice_entry
->
is_wow64
!=
is_wow64
)
continue
;
if
(
!
winedevice_entry
->
config
.
lpBinaryPathName
)
continue
;
if
(
!
winedevice_entry
->
config
.
lpBinaryPathName
)
continue
;
if
(
strcmpW
(
winedevice_entry
->
config
.
lpBinaryPathName
,
path
))
continue
;
if
(
l
strcmpW
(
winedevice_entry
->
config
.
lpBinaryPathName
,
path
))
continue
;
if
(
!
winedevice_entry
->
config
.
lpLoadOrderGroup
)
continue
;
if
(
!
winedevice_entry
->
config
.
lpLoadOrderGroup
)
continue
;
if
(
strcmpW
(
winedevice_entry
->
config
.
lpLoadOrderGroup
,
service_entry
->
config
.
lpLoadOrderGroup
))
continue
;
if
(
l
strcmpW
(
winedevice_entry
->
config
.
lpLoadOrderGroup
,
service_entry
->
config
.
lpLoadOrderGroup
))
continue
;
return
grab_process
(
winedevice_entry
->
process
);
return
grab_process
(
winedevice_entry
->
process
);
}
}
...
@@ -779,14 +779,14 @@ static DWORD add_winedevice_service(const struct service_entry *service, WCHAR *
...
@@ -779,14 +779,14 @@ static DWORD add_winedevice_service(const struct service_entry *service, WCHAR *
struct
service_entry
**
entry
)
struct
service_entry
**
entry
)
{
{
static
const
WCHAR
format
[]
=
{
'W'
,
'i'
,
'n'
,
'e'
,
'd'
,
'e'
,
'v'
,
'i'
,
'c'
,
'e'
,
'%'
,
'u'
,
0
};
static
const
WCHAR
format
[]
=
{
'W'
,
'i'
,
'n'
,
'e'
,
'd'
,
'e'
,
'v'
,
'i'
,
'c'
,
'e'
,
'%'
,
'u'
,
0
};
static
WCHAR
name
[
ARRAY_SIZE
(
format
)
+
10
];
/* strlenW("4294967295") */
static
WCHAR
name
[
ARRAY_SIZE
(
format
)
+
10
];
/*
l
strlenW("4294967295") */
static
DWORD
current
=
0
;
static
DWORD
current
=
0
;
struct
scmdatabase
*
db
=
service
->
db
;
struct
scmdatabase
*
db
=
service
->
db
;
DWORD
err
;
DWORD
err
;
for
(;;)
for
(;;)
{
{
s
printfW
(
name
,
format
,
++
current
);
s
wprintf
(
name
,
ARRAY_SIZE
(
name
)
,
format
,
++
current
);
if
(
!
scmdatabase_find_service
(
db
,
name
))
break
;
if
(
!
scmdatabase_find_service
(
db
,
name
))
break
;
}
}
...
@@ -1026,21 +1026,21 @@ static DWORD process_send_start_message(struct process_entry *process, BOOL shar
...
@@ -1026,21 +1026,21 @@ static DWORD process_send_start_message(struct process_entry *process, BOOL shar
}
}
}
}
len
=
strlenW
(
name
)
+
1
;
len
=
l
strlenW
(
name
)
+
1
;
for
(
i
=
0
;
i
<
argc
;
i
++
)
for
(
i
=
0
;
i
<
argc
;
i
++
)
len
+=
strlenW
(
argv
[
i
])
+
1
;
len
+=
l
strlenW
(
argv
[
i
])
+
1
;
len
=
(
len
+
1
)
*
sizeof
(
WCHAR
);
len
=
(
len
+
1
)
*
sizeof
(
WCHAR
);
if
(
!
(
str
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
)))
if
(
!
(
str
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
)))
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
return
ERROR_NOT_ENOUGH_SERVER_MEMORY
;
p
=
str
;
p
=
str
;
strcpyW
(
p
,
name
);
l
strcpyW
(
p
,
name
);
p
+=
strlenW
(
name
)
+
1
;
p
+=
l
strlenW
(
name
)
+
1
;
for
(
i
=
0
;
i
<
argc
;
i
++
)
for
(
i
=
0
;
i
<
argc
;
i
++
)
{
{
strcpyW
(
p
,
argv
[
i
]);
l
strcpyW
(
p
,
argv
[
i
]);
p
+=
strlenW
(
p
)
+
1
;
p
+=
l
strlenW
(
p
)
+
1
;
}
}
*
p
=
0
;
*
p
=
0
;
...
@@ -1120,12 +1120,12 @@ static void load_registry_parameters(void)
...
@@ -1120,12 +1120,12 @@ static void load_registry_parameters(void)
count
=
sizeof
(
buffer
);
count
=
sizeof
(
buffer
);
if
(
!
RegQueryValueExW
(
key
,
pipetimeoutW
,
NULL
,
&
type
,
(
BYTE
*
)
buffer
,
&
count
)
&&
if
(
!
RegQueryValueExW
(
key
,
pipetimeoutW
,
NULL
,
&
type
,
(
BYTE
*
)
buffer
,
&
count
)
&&
type
==
REG_SZ
&&
(
val
=
atoiW
(
buffer
)))
type
==
REG_SZ
&&
(
val
=
wcstol
(
buffer
,
NULL
,
10
)))
service_pipe_timeout
=
val
;
service_pipe_timeout
=
val
;
count
=
sizeof
(
buffer
);
count
=
sizeof
(
buffer
);
if
(
!
RegQueryValueExW
(
key
,
killtimeoutW
,
NULL
,
&
type
,
(
BYTE
*
)
buffer
,
&
count
)
&&
if
(
!
RegQueryValueExW
(
key
,
killtimeoutW
,
NULL
,
&
type
,
(
BYTE
*
)
buffer
,
&
count
)
&&
type
==
REG_SZ
&&
(
val
=
atoiW
(
buffer
)))
type
==
REG_SZ
&&
(
val
=
wcstol
(
buffer
,
NULL
,
10
)))
service_kill_timeout
=
val
;
service_kill_timeout
=
val
;
RegCloseKey
(
key
);
RegCloseKey
(
key
);
...
...
programs/services/utils.c
View file @
32d7838d
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
#include <windows.h>
#include <windows.h>
#include <winsvc.h>
#include <winsvc.h>
#include "wine/unicode.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "services.h"
#include "services.h"
...
@@ -37,11 +36,11 @@ LPWSTR strdupW(LPCWSTR str)
...
@@ -37,11 +36,11 @@ LPWSTR strdupW(LPCWSTR str)
if
(
str
==
NULL
)
if
(
str
==
NULL
)
return
NULL
;
return
NULL
;
len
=
strlenW
(
str
);
len
=
l
strlenW
(
str
);
buf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
WCHAR
)
*
(
len
+
1
));
buf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
WCHAR
)
*
(
len
+
1
));
if
(
buf
==
NULL
)
if
(
buf
==
NULL
)
return
NULL
;
return
NULL
;
strcpyW
(
buf
,
str
);
l
strcpyW
(
buf
,
str
);
return
buf
;
return
buf
;
}
}
...
...
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