mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
r22590: Make TALLOC_ARRAY consistent across all uses.
That should be it....
Jeremy.
(This used to be commit 603233a98b
)
This commit is contained in:
parent
be8b0685a5
commit
56a5d05b8b
@ -122,8 +122,12 @@ NTSTATUS sec_ace_del_sid(TALLOC_CTX *ctx, SEC_ACE **pp_new, SEC_ACE *old, uint32
|
|||||||
|
|
||||||
if (!ctx || !pp_new || !old || !sid || !num) return NT_STATUS_INVALID_PARAMETER;
|
if (!ctx || !pp_new || !old || !sid || !num) return NT_STATUS_INVALID_PARAMETER;
|
||||||
|
|
||||||
|
if (*num) {
|
||||||
if((pp_new[0] = TALLOC_ZERO_ARRAY(ctx, SEC_ACE, *num )) == 0)
|
if((pp_new[0] = TALLOC_ZERO_ARRAY(ctx, SEC_ACE, *num )) == 0)
|
||||||
return NT_STATUS_NO_MEMORY;
|
return NT_STATUS_NO_MEMORY;
|
||||||
|
} else {
|
||||||
|
pp_new[0] = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < *num; i ++) {
|
for (i = 0; i < *num; i ++) {
|
||||||
if (sid_compare(&old[i].trustee, sid) != 0)
|
if (sid_compare(&old[i].trustee, sid) != 0)
|
||||||
|
@ -355,11 +355,15 @@ static NTSTATUS ads_dns_lookup_srv( TALLOC_CTX *ctx, const char *name, struct dn
|
|||||||
DEBUG(4,("ads_dns_lookup_srv: %d records returned in the answer section.\n",
|
DEBUG(4,("ads_dns_lookup_srv: %d records returned in the answer section.\n",
|
||||||
answer_count));
|
answer_count));
|
||||||
|
|
||||||
|
if (answer_count) {
|
||||||
if ( (dcs = TALLOC_ZERO_ARRAY(ctx, struct dns_rr_srv, answer_count)) == NULL ) {
|
if ( (dcs = TALLOC_ZERO_ARRAY(ctx, struct dns_rr_srv, answer_count)) == NULL ) {
|
||||||
DEBUG(0,("ads_dns_lookup_srv: talloc() failure for %d char*'s\n",
|
DEBUG(0,("ads_dns_lookup_srv: talloc() failure for %d char*'s\n",
|
||||||
answer_count));
|
answer_count));
|
||||||
return NT_STATUS_NO_MEMORY;
|
return NT_STATUS_NO_MEMORY;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
dcs = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* now skip the header */
|
/* now skip the header */
|
||||||
|
|
||||||
|
@ -47,12 +47,17 @@ ADS_STATUS ads_parse_gp_ext(TALLOC_CTX *mem_ctx,
|
|||||||
|
|
||||||
gp_ext->num_exts = i;
|
gp_ext->num_exts = i;
|
||||||
|
|
||||||
|
if (gp_ext->num_exts) {
|
||||||
gp_ext->extensions = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
gp_ext->extensions = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
||||||
gp_ext->extensions_guid = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
gp_ext->extensions_guid = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
||||||
gp_ext->snapins = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
gp_ext->snapins = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
||||||
gp_ext->snapins_guid = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
gp_ext->snapins_guid = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_ext->num_exts);
|
||||||
|
} else {
|
||||||
gp_ext->gp_extension = talloc_strdup(mem_ctx, extension_raw);
|
gp_ext->extensions = NULL;
|
||||||
|
gp_ext->extensions_guid = NULL;
|
||||||
|
gp_ext->snapins = NULL;
|
||||||
|
gp_ext->snapins_guid = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (gp_ext->extensions == NULL || gp_ext->extensions_guid == NULL ||
|
if (gp_ext->extensions == NULL || gp_ext->extensions_guid == NULL ||
|
||||||
gp_ext->snapins == NULL || gp_ext->snapins_guid == NULL ||
|
gp_ext->snapins == NULL || gp_ext->snapins_guid == NULL ||
|
||||||
@ -60,6 +65,8 @@ ADS_STATUS ads_parse_gp_ext(TALLOC_CTX *mem_ctx,
|
|||||||
goto parse_error;
|
goto parse_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gp_ext->gp_extension = talloc_strdup(mem_ctx, extension_raw);
|
||||||
|
|
||||||
for (i = 0; ext_list[i] != NULL; i++) {
|
for (i = 0; ext_list[i] != NULL; i++) {
|
||||||
|
|
||||||
int k;
|
int k;
|
||||||
@ -161,8 +168,13 @@ ADS_STATUS ads_parse_gplink(TALLOC_CTX *mem_ctx,
|
|||||||
gp_link->gp_opts = options;
|
gp_link->gp_opts = options;
|
||||||
gp_link->num_links = i;
|
gp_link->num_links = i;
|
||||||
|
|
||||||
|
if (gp_link->num_links) {
|
||||||
gp_link->link_names = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_link->num_links);
|
gp_link->link_names = TALLOC_ZERO_ARRAY(mem_ctx, char *, gp_link->num_links);
|
||||||
gp_link->link_opts = TALLOC_ZERO_ARRAY(mem_ctx, uint32, gp_link->num_links);
|
gp_link->link_opts = TALLOC_ZERO_ARRAY(mem_ctx, uint32, gp_link->num_links);
|
||||||
|
} else {
|
||||||
|
gp_link->link_names = NULL;
|
||||||
|
gp_link->link_opts = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
gp_link->gp_link = talloc_strdup(mem_ctx, gp_link_raw);
|
gp_link->gp_link = talloc_strdup(mem_ctx, gp_link_raw);
|
||||||
|
|
||||||
|
@ -713,9 +713,13 @@ CacService *cac_MakeServiceArray( TALLOC_CTX * mem_ctx,
|
|||||||
if ( !mem_ctx || !svc )
|
if ( !mem_ctx || !svc )
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
if (num_services) {
|
||||||
services = TALLOC_ZERO_ARRAY( mem_ctx, CacService, num_services );
|
services = TALLOC_ZERO_ARRAY( mem_ctx, CacService, num_services );
|
||||||
if ( !services )
|
if ( !services )
|
||||||
return NULL;
|
return NULL;
|
||||||
|
} else {
|
||||||
|
services = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for ( i = 0; i < num_services; i++ ) {
|
for ( i = 0; i < num_services; i++ ) {
|
||||||
services[i].service_name =
|
services[i].service_name =
|
||||||
|
@ -1026,9 +1026,15 @@ static NTSTATUS idmap_backends_sids_to_unixids(struct id_map **ids)
|
|||||||
|
|
||||||
/* split list per domain */
|
/* split list per domain */
|
||||||
|
|
||||||
|
if (num_domains) {
|
||||||
dom_ids = TALLOC_ZERO_ARRAY(ctx, struct id_map **, num_domains);
|
dom_ids = TALLOC_ZERO_ARRAY(ctx, struct id_map **, num_domains);
|
||||||
IDMAP_CHECK_ALLOC(dom_ids);
|
IDMAP_CHECK_ALLOC(dom_ids);
|
||||||
counters = TALLOC_ZERO_ARRAY(ctx, int, num_domains);
|
counters = TALLOC_ZERO_ARRAY(ctx, int, num_domains);
|
||||||
|
IDMAP_CHECK_ALLOC(counters);
|
||||||
|
} else {
|
||||||
|
dom_ids = NULL;
|
||||||
|
counters = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* partition the requests by domain */
|
/* partition the requests by domain */
|
||||||
|
|
||||||
|
@ -907,17 +907,22 @@ static NTSTATUS lookup_groupmem(struct winbindd_domain *domain,
|
|||||||
the problem is that the members are in the form of distinguised names
|
the problem is that the members are in the form of distinguised names
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (num_members) {
|
||||||
(*sid_mem) = TALLOC_ZERO_ARRAY(mem_ctx, DOM_SID, num_members);
|
(*sid_mem) = TALLOC_ZERO_ARRAY(mem_ctx, DOM_SID, num_members);
|
||||||
(*name_types) = TALLOC_ZERO_ARRAY(mem_ctx, uint32, num_members);
|
(*name_types) = TALLOC_ZERO_ARRAY(mem_ctx, uint32, num_members);
|
||||||
(*names) = TALLOC_ZERO_ARRAY(mem_ctx, char *, num_members);
|
(*names) = TALLOC_ZERO_ARRAY(mem_ctx, char *, num_members);
|
||||||
|
|
||||||
if ((num_members != 0) &&
|
if ((members == NULL) || (*sid_mem == NULL) ||
|
||||||
((members == NULL) || (*sid_mem == NULL) ||
|
(*name_types == NULL) || (*names == NULL)) {
|
||||||
(*name_types == NULL) || (*names == NULL))) {
|
|
||||||
DEBUG(1, ("talloc failed\n"));
|
DEBUG(1, ("talloc failed\n"));
|
||||||
status = NT_STATUS_NO_MEMORY;
|
status = NT_STATUS_NO_MEMORY;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
(*sid_mem) = NULL;
|
||||||
|
(*name_types) = NULL;
|
||||||
|
(*names) = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for (i=0;i<num_members;i++) {
|
for (i=0;i<num_members;i++) {
|
||||||
uint32 name_type;
|
uint32 name_type;
|
||||||
|
@ -1823,8 +1823,12 @@ static int hashrec_cmp( REGF_HASH_REC *h1, REGF_HASH_REC *h2 )
|
|||||||
memcpy( nk->subkeys.header, "lf", REC_HDR_SIZE );
|
memcpy( nk->subkeys.header, "lf", REC_HDR_SIZE );
|
||||||
|
|
||||||
nk->subkeys.num_keys = nk->num_subkeys;
|
nk->subkeys.num_keys = nk->num_subkeys;
|
||||||
|
if (nk->subkeys.num_keys) {
|
||||||
if ( !(nk->subkeys.hashes = TALLOC_ZERO_ARRAY( file->mem_ctx, REGF_HASH_REC, nk->subkeys.num_keys )) )
|
if ( !(nk->subkeys.hashes = TALLOC_ZERO_ARRAY( file->mem_ctx, REGF_HASH_REC, nk->subkeys.num_keys )) )
|
||||||
return NULL;
|
return NULL;
|
||||||
|
} else {
|
||||||
|
nk->subkeys.hashes = NULL;
|
||||||
|
}
|
||||||
nk->subkey_index = 0;
|
nk->subkey_index = 0;
|
||||||
|
|
||||||
/* update the max_bytes_subkey{name,classname} fields */
|
/* update the max_bytes_subkey{name,classname} fields */
|
||||||
|
@ -264,11 +264,15 @@ static BOOL parse_msdfs_symlink(TALLOC_CTX *ctx,
|
|||||||
|
|
||||||
DEBUG(10,("parse_msdfs_symlink: count=%d\n", count));
|
DEBUG(10,("parse_msdfs_symlink: count=%d\n", count));
|
||||||
|
|
||||||
|
if (count) {
|
||||||
reflist = *preflist = TALLOC_ZERO_ARRAY(ctx, struct referral, count);
|
reflist = *preflist = TALLOC_ZERO_ARRAY(ctx, struct referral, count);
|
||||||
if(reflist == NULL) {
|
if(reflist == NULL) {
|
||||||
DEBUG(0,("parse_msdfs_symlink: talloc failed!\n"));
|
DEBUG(0,("parse_msdfs_symlink: talloc failed!\n"));
|
||||||
return False;
|
return False;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
reflist = *preflist = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for(i=0;i<count;i++) {
|
for(i=0;i<count;i++) {
|
||||||
char *p;
|
char *p;
|
||||||
|
@ -670,11 +670,15 @@ static NTSTATUS fetch_group_mem_info(uint32 rid, SAM_GROUP_MEM_INFO *delta)
|
|||||||
return NT_STATUS_NO_MEMORY;
|
return NT_STATUS_NO_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (delta->num_members) {
|
||||||
if ((nt_members = TALLOC_ZERO_ARRAY(t, char *, delta->num_members)) == NULL) {
|
if ((nt_members = TALLOC_ZERO_ARRAY(t, char *, delta->num_members)) == NULL) {
|
||||||
DEBUG(0, ("talloc failed\n"));
|
DEBUG(0, ("talloc failed\n"));
|
||||||
talloc_free(t);
|
talloc_free(t);
|
||||||
return NT_STATUS_NO_MEMORY;
|
return NT_STATUS_NO_MEMORY;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
nt_members = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for (i=0; i<delta->num_members; i++) {
|
for (i=0; i<delta->num_members; i++) {
|
||||||
struct samu *member = NULL;
|
struct samu *member = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user