From e92b7abca083de7acf03b0211ccc8ca935398794 Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Tue, 6 Jan 2009 21:24:30 +0100 Subject: Add a NULL check and some const to dcerpc_floor_get_lhs_data() --- librpc/rpc/binding.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'librpc/rpc/binding.c') diff --git a/librpc/rpc/binding.c b/librpc/rpc/binding.c index a660989d19..4f36faca79 100644 --- a/librpc/rpc/binding.c +++ b/librpc/rpc/binding.c @@ -370,13 +370,19 @@ _PUBLIC_ NTSTATUS dcerpc_parse_binding(TALLOC_CTX *mem_ctx, const char *s, struc return NT_STATUS_OK; } -_PUBLIC_ NTSTATUS dcerpc_floor_get_lhs_data(struct epm_floor *epm_floor, struct ndr_syntax_id *syntax) +_PUBLIC_ NTSTATUS dcerpc_floor_get_lhs_data(const struct epm_floor *epm_floor, + struct ndr_syntax_id *syntax) { TALLOC_CTX *mem_ctx = talloc_init("floor_get_lhs_data"); - struct ndr_pull *ndr = ndr_pull_init_blob(&epm_floor->lhs.lhs_data, mem_ctx, NULL); + struct ndr_pull *ndr; enum ndr_err_code ndr_err; uint16_t if_version=0; + ndr = ndr_pull_init_blob(&epm_floor->lhs.lhs_data, mem_ctx, NULL); + if (ndr == NULL) { + talloc_free(mem_ctx); + return NT_STATUS_NO_MEMORY; + } ndr->flags |= LIBNDR_FLAG_NOALIGN; ndr_err = ndr_pull_GUID(ndr, NDR_SCALARS | NDR_BUFFERS, &syntax->uuid); -- cgit