NDR_PRINT_IN_DEBUG(svcctl_CloseServiceHandle, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CLOSESERVICEHANDLE,
NDR_PRINT_IN_DEBUG(svcctl_ControlService, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CONTROLSERVICE,
NDR_PRINT_IN_DEBUG(svcctl_DeleteService, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_DELETESERVICE,
NDR_PRINT_IN_DEBUG(svcctl_LockServiceDatabase, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_LOCKSERVICEDATABASE,
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceObjectSecurity, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICEOBJECTSECURITY,
NDR_PRINT_IN_DEBUG(svcctl_SetServiceObjectSecurity, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_SETSERVICEOBJECTSECURITY,
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceStatus, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICESTATUS,
NDR_PRINT_IN_DEBUG(svcctl_SetServiceStatus, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_SETSERVICESTATUS,
NDR_PRINT_IN_DEBUG(svcctl_UnlockServiceDatabase, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_UNLOCKSERVICEDATABASE,
NDR_PRINT_IN_DEBUG(svcctl_NotifyBootConfigStatus, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_NOTIFYBOOTCONFIGSTATUS,
NDR_PRINT_IN_DEBUG(svcctl_SCSetServiceBitsW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_SCSETSERVICEBITSW,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
uint32_t type /* [in] */,
- uint32_t start /* [in] */,
- uint32_t error /* [in] */,
+ enum svcctl_StartType start_type /* [in] */,
+ enum svcctl_ErrorControl error_control /* [in] */,
const char *binary_path /* [in] [unique,charset(UTF16)] */,
const char *load_order_group /* [in] [unique,charset(UTF16)] */,
uint32_t *tag_id /* [out] [ref] */,
/* In parameters */
r.in.handle = handle;
r.in.type = type;
- r.in.start = start;
- r.in.error = error;
+ r.in.start_type = start_type;
+ r.in.error_control = error_control;
r.in.binary_path = binary_path;
r.in.load_order_group = load_order_group;
r.in.dependencies = dependencies;
NDR_PRINT_IN_DEBUG(svcctl_ChangeServiceConfigW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CHANGESERVICECONFIGW,
const char *DisplayName /* [in] [unique,charset(UTF16)] */,
uint32_t desired_access /* [in] */,
uint32_t type /* [in] */,
- uint32_t start_type /* [in] */,
- uint32_t error_control /* [in] */,
+ enum svcctl_StartType start_type /* [in] */,
+ enum svcctl_ErrorControl error_control /* [in] */,
const char *binary_path /* [in] [charset(UTF16)] */,
const char *LoadOrderGroupKey /* [in] [unique,charset(UTF16)] */,
uint32_t *TagId /* [in,out] [unique] */,
NDR_PRINT_IN_DEBUG(svcctl_CreateServiceW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CREATESERVICEW,
TALLOC_CTX *mem_ctx,
struct policy_handle *service /* [in] [ref] */,
uint32_t state /* [in] */,
- uint8_t *service_status /* [out] [ref,size_is(buf_size)] */,
- uint32_t buf_size /* [in] [range(0,0x40000)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,0x40000)] */,
+ uint8_t *service_status /* [out] [ref,size_is(offered)] */,
+ uint32_t offered /* [in] [range(0,0x40000)] */,
+ uint32_t *needed /* [out] [ref,range(0,0x40000)] */,
uint32_t *services_returned /* [out] [ref,range(0,0x40000)] */,
WERROR *werror)
{
/* In parameters */
r.in.service = service;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_EnumDependentServicesW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_ENUMDEPENDENTSERVICESW,
}
/* Return variables */
- memcpy(service_status, r.out.service_status, r.in.buf_size * sizeof(*service_status));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(service_status, r.out.service_status, r.in.offered * sizeof(*service_status));
+ *needed = *r.out.needed;
*services_returned = *r.out.services_returned;
/* Return result */
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
uint32_t type /* [in] */,
- uint32_t state /* [in] */,
- uint8_t *service /* [out] [ref,size_is(buf_size)] */,
- uint32_t buf_size /* [in] [range(0,262144)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,262144)] */,
- uint32_t *services_returned /* [out] [ref,range(0,262144)] */,
+ enum svcctl_ServiceState state /* [in] */,
+ uint8_t *service /* [out] [ref,size_is(offered)] */,
+ uint32_t offered /* [in] [range(0,0x40000)] */,
+ uint32_t *needed /* [out] [ref,range(0,0x40000)] */,
+ uint32_t *services_returned /* [out] [ref,range(0,0x40000)] */,
uint32_t *resume_handle /* [in,out] [unique] */,
WERROR *werror)
{
r.in.handle = handle;
r.in.type = type;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
r.in.resume_handle = resume_handle;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_EnumServicesStatusW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_ENUMSERVICESSTATUSW,
}
/* Return variables */
- memcpy(service, r.out.service, r.in.buf_size * sizeof(*service));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(service, r.out.service, r.in.offered * sizeof(*service));
+ *needed = *r.out.needed;
*services_returned = *r.out.services_returned;
if (resume_handle && r.out.resume_handle) {
*resume_handle = *r.out.resume_handle;
NDR_PRINT_IN_DEBUG(svcctl_OpenSCManagerW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_OPENSCMANAGERW,
NDR_PRINT_IN_DEBUG(svcctl_OpenServiceW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_OPENSERVICEW,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
struct QUERY_SERVICE_CONFIG *query /* [out] [ref] */,
- uint32_t buf_size /* [in] [range(0,8192)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,8192)] */,
+ uint32_t offered /* [in] [range(0,8192)] */,
+ uint32_t *needed /* [out] [ref,range(0,8192)] */,
WERROR *werror)
{
struct svcctl_QueryServiceConfigW r;
/* In parameters */
r.in.handle = handle;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceConfigW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICECONFIGW,
/* Return variables */
*query = *r.out.query;
- *bytes_needed = *r.out.bytes_needed;
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NTSTATUS rpccli_svcctl_QueryServiceLockStatusW(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
- uint32_t buf_size /* [in] */,
+ uint32_t offered /* [in] */,
struct SERVICE_LOCK_STATUS *lock_status /* [out] [ref] */,
- uint32_t *required_buf_size /* [out] [ref] */,
+ uint32_t *needed /* [out] [ref] */,
WERROR *werror)
{
struct svcctl_QueryServiceLockStatusW r;
/* In parameters */
r.in.handle = handle;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceLockStatusW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICELOCKSTATUSW,
/* Return variables */
*lock_status = *r.out.lock_status;
- *required_buf_size = *r.out.required_buf_size;
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NDR_PRINT_IN_DEBUG(svcctl_StartServiceW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_STARTSERVICEW,
NDR_PRINT_IN_DEBUG(svcctl_GetServiceDisplayNameW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_GETSERVICEDISPLAYNAMEW,
NDR_PRINT_IN_DEBUG(svcctl_GetServiceKeyNameW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_GETSERVICEKEYNAMEW,
NDR_PRINT_IN_DEBUG(svcctl_SCSetServiceBitsA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_SCSETSERVICEBITSA,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
uint32_t type /* [in] */,
- uint32_t start /* [in] */,
- uint32_t error /* [in] */,
+ enum svcctl_StartType start_type /* [in] */,
+ enum svcctl_ErrorControl error_control /* [in] */,
const char *binary_path /* [in] [unique,charset(UTF16)] */,
const char *load_order_group /* [in] [unique,charset(UTF16)] */,
uint32_t *tag_id /* [out] [ref] */,
/* In parameters */
r.in.handle = handle;
r.in.type = type;
- r.in.start = start;
- r.in.error = error;
+ r.in.start_type = start_type;
+ r.in.error_control = error_control;
r.in.binary_path = binary_path;
r.in.load_order_group = load_order_group;
r.in.dependencies = dependencies;
NDR_PRINT_IN_DEBUG(svcctl_ChangeServiceConfigA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CHANGESERVICECONFIGA,
const char *DisplayName /* [in] [unique,charset(UTF16)] */,
uint32_t desired_access /* [in] */,
uint32_t type /* [in] */,
- uint32_t start_type /* [in] */,
- uint32_t error_control /* [in] */,
+ enum svcctl_StartType start_type /* [in] */,
+ enum svcctl_ErrorControl error_control /* [in] */,
const char *binary_path /* [in] [unique,charset(UTF16)] */,
const char *LoadOrderGroupKey /* [in] [unique,charset(UTF16)] */,
uint32_t *TagId /* [out] [unique] */,
NDR_PRINT_IN_DEBUG(svcctl_CreateServiceA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CREATESERVICEA,
TALLOC_CTX *mem_ctx,
struct policy_handle *service /* [in] [ref] */,
uint32_t state /* [in] */,
- struct ENUM_SERVICE_STATUS *service_status /* [out] [unique] */,
- uint32_t buf_size /* [in] */,
- uint32_t *bytes_needed /* [out] [ref] */,
+ struct ENUM_SERVICE_STATUSA *service_status /* [out] [unique] */,
+ uint32_t offered /* [in] */,
+ uint32_t *needed /* [out] [ref] */,
uint32_t *services_returned /* [out] [ref] */,
WERROR *werror)
{
/* In parameters */
r.in.service = service;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_EnumDependentServicesA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_ENUMDEPENDENTSERVICESA,
if (service_status && r.out.service_status) {
*service_status = *r.out.service_status;
}
- *bytes_needed = *r.out.bytes_needed;
+ *needed = *r.out.needed;
*services_returned = *r.out.services_returned;
/* Return result */
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
uint32_t type /* [in] */,
- uint32_t state /* [in] */,
- uint32_t buf_size /* [in] */,
- uint8_t *service /* [out] [size_is(buf_size)] */,
- uint32_t *bytes_needed /* [out] [ref] */,
+ enum svcctl_ServiceState state /* [in] */,
+ uint32_t offered /* [in] */,
+ uint8_t *service /* [out] [size_is(offered)] */,
+ uint32_t *needed /* [out] [ref] */,
uint32_t *services_returned /* [out] [ref] */,
uint32_t *resume_handle /* [in,out] [unique] */,
WERROR *werror)
r.in.handle = handle;
r.in.type = type;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
r.in.resume_handle = resume_handle;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_EnumServicesStatusA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_ENUMSERVICESSTATUSA,
}
/* Return variables */
- memcpy(service, r.out.service, r.in.buf_size * sizeof(*service));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(service, r.out.service, r.in.offered * sizeof(*service));
+ *needed = *r.out.needed;
*services_returned = *r.out.services_returned;
if (resume_handle && r.out.resume_handle) {
*resume_handle = *r.out.resume_handle;
NDR_PRINT_IN_DEBUG(svcctl_OpenSCManagerA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_OPENSCMANAGERA,
NDR_PRINT_IN_DEBUG(svcctl_OpenServiceA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_OPENSERVICEA,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
uint8_t *query /* [out] */,
- uint32_t buf_size /* [in] */,
- uint32_t *bytes_needed /* [out] [ref] */,
+ uint32_t offered /* [in] */,
+ uint32_t *needed /* [out] [ref] */,
WERROR *werror)
{
struct svcctl_QueryServiceConfigA r;
/* In parameters */
r.in.handle = handle;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceConfigA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICECONFIGA,
}
/* Return variables */
- memcpy(query, r.out.query, r.in.buf_size * sizeof(*query));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(query, r.out.query, r.in.offered * sizeof(*query));
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NTSTATUS rpccli_svcctl_QueryServiceLockStatusA(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
- uint32_t buf_size /* [in] */,
+ uint32_t offered /* [in] */,
struct SERVICE_LOCK_STATUS *lock_status /* [out] [ref] */,
- uint32_t *required_buf_size /* [out] [ref] */,
+ uint32_t *needed /* [out] [ref] */,
WERROR *werror)
{
struct svcctl_QueryServiceLockStatusA r;
/* In parameters */
r.in.handle = handle;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceLockStatusA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICELOCKSTATUSA,
/* Return variables */
*lock_status = *r.out.lock_status;
- *required_buf_size = *r.out.required_buf_size;
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NDR_PRINT_IN_DEBUG(svcctl_StartServiceA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_STARTSERVICEA,
NDR_PRINT_IN_DEBUG(svcctl_GetServiceDisplayNameA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_GETSERVICEDISPLAYNAMEA,
NDR_PRINT_IN_DEBUG(svcctl_GetServiceKeyNameA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_GETSERVICEKEYNAMEA,
NDR_PRINT_IN_DEBUG(svcctl_GetCurrentGroupeStateW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_GETCURRENTGROUPESTATEW,
NDR_PRINT_IN_DEBUG(svcctl_EnumServiceGroupW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_ENUMSERVICEGROUPW,
NDR_PRINT_IN_DEBUG(svcctl_ChangeServiceConfig2A, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CHANGESERVICECONFIG2A,
NDR_PRINT_IN_DEBUG(svcctl_ChangeServiceConfig2W, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_CHANGESERVICECONFIG2W,
NTSTATUS rpccli_svcctl_QueryServiceConfig2A(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
- uint32_t info_level /* [in] */,
+ enum svcctl_ConfigLevel info_level /* [in] */,
uint8_t *buffer /* [out] */,
- uint32_t buf_size /* [in] */,
- uint32_t *bytes_needed /* [out] [ref] */,
+ uint32_t offered /* [in] */,
+ uint32_t *needed /* [out] [ref] */,
WERROR *werror)
{
struct svcctl_QueryServiceConfig2A r;
/* In parameters */
r.in.handle = handle;
r.in.info_level = info_level;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceConfig2A, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICECONFIG2A,
}
/* Return variables */
- memcpy(buffer, r.out.buffer, r.in.buf_size * sizeof(*buffer));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(buffer, r.out.buffer, r.in.offered * sizeof(*buffer));
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NTSTATUS rpccli_svcctl_QueryServiceConfig2W(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
- uint32_t info_level /* [in] */,
- uint8_t *buffer /* [out] [ref,size_is(buf_size)] */,
- uint32_t buf_size /* [in] [range(0,8192)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,8192)] */,
+ enum svcctl_ConfigLevel info_level /* [in] */,
+ uint8_t *buffer /* [out] [ref,size_is(offered)] */,
+ uint32_t offered /* [in] [range(0,8192)] */,
+ uint32_t *needed /* [out] [ref,range(0,8192)] */,
WERROR *werror)
{
struct svcctl_QueryServiceConfig2W r;
/* In parameters */
r.in.handle = handle;
r.in.info_level = info_level;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceConfig2W, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICECONFIG2W,
}
/* Return variables */
- memcpy(buffer, r.out.buffer, r.in.buf_size * sizeof(*buffer));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(buffer, r.out.buffer, r.in.offered * sizeof(*buffer));
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
NTSTATUS rpccli_svcctl_QueryServiceStatusEx(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle /* [in] [ref] */,
- uint32_t info_level /* [in] */,
- uint8_t *buffer /* [out] [ref,size_is(buf_size)] */,
- uint32_t buf_size /* [in] [range(0,8192)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,8192)] */,
+ enum svcctl_StatusLevel info_level /* [in] */,
+ uint8_t *buffer /* [out] [ref,size_is(offered)] */,
+ uint32_t offered /* [in] [range(0,8192)] */,
+ uint32_t *needed /* [out] [ref,range(0,8192)] */,
WERROR *werror)
{
struct svcctl_QueryServiceStatusEx r;
/* In parameters */
r.in.handle = handle;
r.in.info_level = info_level;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(svcctl_QueryServiceStatusEx, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_QUERYSERVICESTATUSEX,
}
/* Return variables */
- memcpy(buffer, r.out.buffer, r.in.buf_size * sizeof(*buffer));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(buffer, r.out.buffer, r.in.offered * sizeof(*buffer));
+ *needed = *r.out.needed;
/* Return result */
if (werror) {
struct policy_handle *scmanager /* [in] [ref] */,
uint32_t info_level /* [in] */,
uint32_t type /* [in] */,
- uint32_t state /* [in] */,
+ enum svcctl_ServiceState state /* [in] */,
uint8_t *services /* [out] */,
- uint32_t buf_size /* [in] */,
- uint32_t *bytes_needed /* [out] [ref] */,
+ uint32_t offered /* [in] */,
+ uint32_t *needed /* [out] [ref] */,
uint32_t *service_returned /* [out] [ref] */,
uint32_t *resume_handle /* [in,out] [unique] */,
const char **group_name /* [out] [ref,charset(UTF16)] */,
r.in.info_level = info_level;
r.in.type = type;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
r.in.resume_handle = resume_handle;
if (DEBUGLEVEL >= 10) {
NDR_PRINT_IN_DEBUG(EnumServicesStatusExA, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_ENUMSERVICESSTATUSEXA,
}
/* Return variables */
- memcpy(services, r.out.services, r.in.buf_size * sizeof(*services));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(services, r.out.services, r.in.offered * sizeof(*services));
+ *needed = *r.out.needed;
*service_returned = *r.out.service_returned;
if (resume_handle && r.out.resume_handle) {
*resume_handle = *r.out.resume_handle;
struct policy_handle *scmanager /* [in] [ref] */,
uint32_t info_level /* [in] */,
uint32_t type /* [in] */,
- uint32_t state /* [in] */,
- uint8_t *services /* [out] [ref,size_is(buf_size)] */,
- uint32_t buf_size /* [in] [range(0,262144)] */,
- uint32_t *bytes_needed /* [out] [ref,range(0,262144)] */,
- uint32_t *service_returned /* [out] [ref,range(0,262144)] */,
- uint32_t *resume_handle /* [in,out] [unique,range(0,262144)] */,
+ enum svcctl_ServiceState state /* [in] */,
+ uint8_t *services /* [out] [ref,size_is(offered)] */,
+ uint32_t offered /* [in] [range(0,0x40000)] */,
+ uint32_t *needed /* [out] [ref,range(0,0x40000)] */,
+ uint32_t *service_returned /* [out] [ref,range(0,0x40000)] */,
+ uint32_t *resume_handle /* [in,out] [unique,range(0,0x40000)] */,
const char *group_name /* [in] [unique,charset(UTF16)] */,
WERROR *werror)
{
r.in.info_level = info_level;
r.in.type = type;
r.in.state = state;
- r.in.buf_size = buf_size;
+ r.in.offered = offered;
r.in.resume_handle = resume_handle;
r.in.group_name = group_name;
NDR_PRINT_IN_DEBUG(EnumServicesStatusExW, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_ENUMSERVICESSTATUSEXW,
}
/* Return variables */
- memcpy(services, r.out.services, r.in.buf_size * sizeof(*services));
- *bytes_needed = *r.out.bytes_needed;
+ memcpy(services, r.out.services, r.in.offered * sizeof(*services));
+ *needed = *r.out.needed;
*service_returned = *r.out.service_returned;
if (resume_handle && r.out.resume_handle) {
*resume_handle = *r.out.resume_handle;
NDR_PRINT_IN_DEBUG(svcctl_SCSendTSMessage, &r);
}
- status = cli_do_rpc_ndr(cli,
+ status = cli->dispatch(cli,
mem_ctx,
&ndr_table_svcctl,
NDR_SVCCTL_SCSENDTSMESSAGE,