diff options
author | Volker Lendecke <vl@samba.org> | 2008-05-20 17:29:40 +0200 |
---|---|---|
committer | Volker Lendecke <vl@samba.org> | 2008-05-20 17:30:19 +0200 |
commit | fb0a25d59ddd28ea1d5af33ec7d9f817fac3fb9d (patch) | |
tree | f8e48accb4f3b7aa16e08be132acf747d0d41271 /source/rpc_server/srv_samr_nt.c | |
parent | f2993160a14ec286627af53b88d6fa535d8c9437 (diff) | |
download | samba-fb0a25d59ddd28ea1d5af33ec7d9f817fac3fb9d.tar.gz samba-fb0a25d59ddd28ea1d5af33ec7d9f817fac3fb9d.tar.xz samba-fb0a25d59ddd28ea1d5af33ec7d9f817fac3fb9d.zip |
Fix a valgrind error in _samr_LookupNames
Diffstat (limited to 'source/rpc_server/srv_samr_nt.c')
-rw-r--r-- | source/rpc_server/srv_samr_nt.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/source/rpc_server/srv_samr_nt.c b/source/rpc_server/srv_samr_nt.c index f28c771d3ed..42431bd4825 100644 --- a/source/rpc_server/srv_samr_nt.c +++ b/source/rpc_server/srv_samr_nt.c @@ -1786,8 +1786,8 @@ NTSTATUS _samr_LookupNames(pipes_struct *p, struct samr_LookupNames *r) { NTSTATUS status; - uint32 rid[MAX_SAM_ENTRIES]; - enum lsa_SidType type[MAX_SAM_ENTRIES]; + uint32 *rid; + enum lsa_SidType *type; int i; int num_rids = r->in.num_names; DOM_SID pol_sid; @@ -1796,9 +1796,6 @@ NTSTATUS _samr_LookupNames(pipes_struct *p, DEBUG(5,("_samr_LookupNames: %d\n", __LINE__)); - ZERO_ARRAY(rid); - ZERO_ARRAY(type); - if (!get_lsa_policy_samr_sid(p, r->in.domain_handle, &pol_sid, &acc_granted, NULL)) { return NT_STATUS_OBJECT_TYPE_MISMATCH; } @@ -1815,6 +1812,12 @@ NTSTATUS _samr_LookupNames(pipes_struct *p, DEBUG(5,("_samr_LookupNames: truncating entries to %d\n", num_rids)); } + rid = talloc_array(p->mem_ctx, uint32, num_rids); + NT_STATUS_HAVE_NO_MEMORY(rid); + + type = talloc_array(p->mem_ctx, enum lsa_SidType, num_rids); + NT_STATUS_HAVE_NO_MEMORY(rid); + DEBUG(5,("_samr_LookupNames: looking name on SID %s\n", sid_string_dbg(&pol_sid))); |