From 42639a8f66e8d4241b24935772552f235f863096 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Wed, 19 Nov 2003 23:18:35 +0000 Subject: [PATCH] fixed wkssvc idl and test code for TransportEnum --- source/librpc/idl/wkssvc.idl | 9 +--- source/librpc/ndr/ndr_wkssvc.c | 81 +++++++--------------------------- source/librpc/ndr/ndr_wkssvc.h | 12 ++--- source/torture/rpc/wkssvc.c | 12 ++--- 4 files changed, 26 insertions(+), 88 deletions(-) diff --git a/source/librpc/idl/wkssvc.idl b/source/librpc/idl/wkssvc.idl index 3e3471d7950..e42e7ae4f0a 100644 --- a/source/librpc/idl/wkssvc.idl +++ b/source/librpc/idl/wkssvc.idl @@ -127,17 +127,12 @@ typedef union { case(0) wkssvc_TransportInfoArray *array; - } wkssvc_TransportUnion; - - typedef struct { - uint32 level; - [switch_is(level)] wkssvc_TransportUnion u; } wkssvc_TransportInfo; WERROR wkssvc_TransportEnum ( [in] unistr *server_name, - [in] uint32 level, - [in,out,ref] wkssvc_TransportInfo *info, + [in,out] uint32 level, + [in,out,switch_is(level)] wkssvc_TransportInfo info, [in] uint32 max_buffer, [out] uint32 totalentries, [in,out] uint32 *resume_handle diff --git a/source/librpc/ndr/ndr_wkssvc.c b/source/librpc/ndr/ndr_wkssvc.c index 07852795a2f..40006a59827 100644 --- a/source/librpc/ndr/ndr_wkssvc.c +++ b/source/librpc/ndr/ndr_wkssvc.c @@ -78,7 +78,7 @@ done: return NT_STATUS_OK; } -NTSTATUS ndr_push_wkssvc_TransportUnion(struct ndr_push *ndr, int ndr_flags, uint16 level, union wkssvc_TransportUnion *r) +NTSTATUS ndr_push_wkssvc_TransportInfo(struct ndr_push *ndr, int ndr_flags, uint16 level, union wkssvc_TransportInfo *r) { if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_push_struct_start(ndr)); @@ -107,23 +107,6 @@ done: return NT_STATUS_OK; } -NTSTATUS ndr_push_wkssvc_TransportInfo(struct ndr_push *ndr, int ndr_flags, struct wkssvc_TransportInfo *r) -{ - if (!(ndr_flags & NDR_SCALARS)) goto buffers; - NDR_CHECK(ndr_push_struct_start(ndr)); - NDR_CHECK(ndr_push_align(ndr, 4)); - NDR_CHECK(ndr_push_uint32(ndr, r->level)); - NDR_CHECK(ndr_push_uint32(ndr, r->level)); - NDR_CHECK(ndr_push_wkssvc_TransportUnion(ndr, NDR_SCALARS, r->level, &r->u)); - ndr_push_struct_end(ndr); -buffers: - if (!(ndr_flags & NDR_BUFFERS)) goto done; - NDR_CHECK(ndr_push_uint32(ndr, r->level)); - NDR_CHECK(ndr_push_wkssvc_TransportUnion(ndr, NDR_BUFFERS, r->level, &r->u)); -done: - return NT_STATUS_OK; -} - NTSTATUS ndr_push_wkssvc_TransportEnum(struct ndr_push *ndr, struct wkssvc_TransportEnum *r) { NDR_CHECK(ndr_push_ptr(ndr, r->in.server_name)); @@ -131,7 +114,8 @@ NTSTATUS ndr_push_wkssvc_TransportEnum(struct ndr_push *ndr, struct wkssvc_Trans NDR_CHECK(ndr_push_unistr(ndr, r->in.server_name)); } NDR_CHECK(ndr_push_uint32(ndr, r->in.level)); - NDR_CHECK(ndr_push_wkssvc_TransportInfo(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.info)); + NDR_CHECK(ndr_push_uint32(ndr, r->in.level)); + NDR_CHECK(ndr_push_wkssvc_TransportInfo(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.level, &r->in.info)); NDR_CHECK(ndr_push_uint32(ndr, r->in.max_buffer)); NDR_CHECK(ndr_push_ptr(ndr, r->in.resume_handle)); if (r->in.resume_handle) { @@ -654,7 +638,7 @@ done: return NT_STATUS_OK; } -NTSTATUS ndr_pull_wkssvc_TransportUnion(struct ndr_pull *ndr, int ndr_flags, uint16 level, union wkssvc_TransportUnion *r) +NTSTATUS ndr_pull_wkssvc_TransportInfo(struct ndr_pull *ndr, int ndr_flags, uint16 level, union wkssvc_TransportInfo *r) { if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_pull_struct_start(ndr)); @@ -689,35 +673,16 @@ done: return NT_STATUS_OK; } -NTSTATUS ndr_pull_wkssvc_TransportInfo(struct ndr_pull *ndr, int ndr_flags, struct wkssvc_TransportInfo *r) -{ - NDR_CHECK(ndr_pull_struct_start(ndr)); - if (!(ndr_flags & NDR_SCALARS)) goto buffers; - NDR_CHECK(ndr_pull_align(ndr, 4)); - NDR_CHECK(ndr_pull_uint32(ndr, &r->level)); - if ((NDR_SCALARS) & NDR_SCALARS) { - uint32 _level; - NDR_CHECK(ndr_pull_uint32(ndr, &_level)); - if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in u"); - } - NDR_CHECK(ndr_pull_wkssvc_TransportUnion(ndr, NDR_SCALARS, r->level, &r->u)); - ndr_pull_struct_end(ndr); -buffers: - if (!(ndr_flags & NDR_BUFFERS)) goto done; - if ((NDR_BUFFERS) & NDR_SCALARS) { - uint32 _level; - NDR_CHECK(ndr_pull_uint32(ndr, &_level)); - if (_level != r->level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in u"); - } - NDR_CHECK(ndr_pull_wkssvc_TransportUnion(ndr, NDR_BUFFERS, r->level, &r->u)); -done: - return NT_STATUS_OK; -} - NTSTATUS ndr_pull_wkssvc_TransportEnum(struct ndr_pull *ndr, struct wkssvc_TransportEnum *r) { uint32 _ptr_resume_handle; - NDR_CHECK(ndr_pull_wkssvc_TransportInfo(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.info)); + NDR_CHECK(ndr_pull_uint32(ndr, &r->out.level)); + if ((NDR_SCALARS|NDR_BUFFERS) & NDR_SCALARS) { + uint32 _level; + NDR_CHECK(ndr_pull_uint32(ndr, &_level)); + if (_level != r->in.level) return ndr_pull_error(ndr, NDR_ERR_BAD_SWITCH, "Bad switch value %u in info"); + } + NDR_CHECK(ndr_pull_wkssvc_TransportInfo(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.level, &r->out.info)); NDR_CHECK(ndr_pull_uint32(ndr, &r->out.totalentries)); NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_resume_handle)); if (_ptr_resume_handle) { @@ -1208,9 +1173,9 @@ void ndr_print_wkssvc_TransportInfoArray(struct ndr_print *ndr, const char *name ndr->depth--; } -void ndr_print_wkssvc_TransportUnion(struct ndr_print *ndr, const char *name, uint16 level, union wkssvc_TransportUnion *r) +void ndr_print_wkssvc_TransportInfo(struct ndr_print *ndr, const char *name, uint16 level, union wkssvc_TransportInfo *r) { - ndr_print_union(ndr, name, level, "wkssvc_TransportUnion"); + ndr_print_union(ndr, name, level, "wkssvc_TransportInfo"); switch (level) { case 0: ndr_print_ptr(ndr, "array", r->array); @@ -1226,15 +1191,6 @@ void ndr_print_wkssvc_TransportUnion(struct ndr_print *ndr, const char *name, ui } } -void ndr_print_wkssvc_TransportInfo(struct ndr_print *ndr, const char *name, struct wkssvc_TransportInfo *r) -{ - ndr_print_struct(ndr, name, "wkssvc_TransportInfo"); - ndr->depth++; - ndr_print_uint32(ndr, "level", r->level); - ndr_print_wkssvc_TransportUnion(ndr, "u", r->level, &r->u); - ndr->depth--; -} - void ndr_print_wkssvc_TransportEnum(struct ndr_print *ndr, const char *name, int flags, struct wkssvc_TransportEnum *r) { ndr_print_struct(ndr, name, "wkssvc_TransportEnum"); @@ -1249,10 +1205,7 @@ void ndr_print_wkssvc_TransportEnum(struct ndr_print *ndr, const char *name, int } ndr->depth--; ndr_print_uint32(ndr, "level", r->in.level); - ndr_print_ptr(ndr, "info", r->in.info); - ndr->depth++; - ndr_print_wkssvc_TransportInfo(ndr, "info", r->in.info); - ndr->depth--; + ndr_print_wkssvc_TransportInfo(ndr, "info", r->in.level, &r->in.info); ndr_print_uint32(ndr, "max_buffer", r->in.max_buffer); ndr_print_ptr(ndr, "resume_handle", r->in.resume_handle); ndr->depth++; @@ -1265,10 +1218,8 @@ void ndr_print_wkssvc_TransportEnum(struct ndr_print *ndr, const char *name, int if (flags & NDR_OUT) { ndr_print_struct(ndr, "out", "wkssvc_TransportEnum"); ndr->depth++; - ndr_print_ptr(ndr, "info", r->out.info); - ndr->depth++; - ndr_print_wkssvc_TransportInfo(ndr, "info", r->out.info); - ndr->depth--; + ndr_print_uint32(ndr, "level", r->out.level); + ndr_print_wkssvc_TransportInfo(ndr, "info", r->in.level, &r->out.info); ndr_print_uint32(ndr, "totalentries", r->out.totalentries); ndr_print_ptr(ndr, "resume_handle", r->out.resume_handle); ndr->depth++; diff --git a/source/librpc/ndr/ndr_wkssvc.h b/source/librpc/ndr/ndr_wkssvc.h index 7c8b1dd3177..9a245dfe5f3 100644 --- a/source/librpc/ndr/ndr_wkssvc.h +++ b/source/librpc/ndr/ndr_wkssvc.h @@ -175,26 +175,22 @@ struct wkssvc_TransportInfoArray { struct wkssvc_TransportInfo0 *transports; }; -union wkssvc_TransportUnion { +union wkssvc_TransportInfo { /* [case(0)] */ struct wkssvc_TransportInfoArray *array; }; -struct wkssvc_TransportInfo { - uint32 level; - union wkssvc_TransportUnion u; -}; - struct wkssvc_TransportEnum { struct { const char *server_name; uint32 level; - struct wkssvc_TransportInfo *info; + union wkssvc_TransportInfo info; uint32 max_buffer; uint32 *resume_handle; } in; struct { - struct wkssvc_TransportInfo *info; + uint32 level; + union wkssvc_TransportInfo info; uint32 totalentries; uint32 *resume_handle; WERROR result; diff --git a/source/torture/rpc/wkssvc.c b/source/torture/rpc/wkssvc.c index 9d576c2020d..ed1f5d44009 100644 --- a/source/torture/rpc/wkssvc.c +++ b/source/torture/rpc/wkssvc.c @@ -53,18 +53,14 @@ static BOOL test_TransportEnum(struct dcerpc_pipe *p, NTSTATUS status; struct wkssvc_TransportEnum r; BOOL ret = True; - struct wkssvc_TransportInfo info; uint32 resume_handle = 0; - struct wkssvc_TransportInfoArray info_array; + struct wkssvc_TransportInfoArray array; - ZERO_STRUCT(info); - ZERO_STRUCT(info_array); - - info.u.array = NULL; + ZERO_STRUCT(array); r.in.server_name = dcerpc_server_name(p); - r.in.info = &info; - r.out.info = &info; + r.in.level = 0; + r.in.info.array = &array; r.in.max_buffer = (uint32)-1; r.in.resume_handle = &resume_handle; r.out.resume_handle = &resume_handle;