diff options
| author | Stephen Crane <steve.crane@rococosoft.com> | 2004-08-27 14:37:54 +0000 | 
|---|---|---|
| committer | Stephen Crane <steve.crane@rococosoft.com> | 2004-08-27 14:37:54 +0000 | 
| commit | 49c565df53bf26483c097b511547c203c81f4d41 (patch) | |
| tree | e0f05b11b55114acabb25a6344131af56f2e0622 | |
| parent | 885fe862f39efde91f3b5017b8c6019c8c1f6541 (diff) | |
fix memory leaks
| -rw-r--r-- | pand/main.c | 3 | ||||
| -rw-r--r-- | pand/sdp.c | 16 | 
2 files changed, 15 insertions, 4 deletions
| diff --git a/pand/main.c b/pand/main.c index 4afc095f..e57c80be 100644 --- a/pand/main.c +++ b/pand/main.c @@ -551,7 +551,6 @@ int main(int argc, char **argv)  		case 'Q':  			mode = CONNECT; -			dst  = NULL;  			if (optarg)  				search_duration = atoi(optarg);  			break; @@ -565,7 +564,6 @@ int main(int argc, char **argv)  		case 'K':  			mode = KILL;  			detach = 0; -			dst  = NULL;  			break;  		case 'S': @@ -700,6 +698,7 @@ int main(int argc, char **argv)  		strncpy(cache.dst, dst, sizeof(cache.dst) - 1);  		str2ba(dst, &cache.bdaddr);  		cache.valid = 1; +		free(dst);  	}  	switch (mode) { @@ -63,6 +63,7 @@ int bnep_sdp_register(uint16_t role)  	uuid_t root_uuid, pan, l2cap, bnep;  	sdp_profile_desc_t profile[1];  	sdp_list_t *proto[2]; +	sdp_data_t *v, *p;  	uint16_t psm = 15, version = 0x0100;  	int status; @@ -84,15 +85,18 @@ int bnep_sdp_register(uint16_t role)  	sdp_uuid16_create(&root_uuid, PUBLIC_BROWSE_GROUP);  	root = sdp_list_append(NULL, &root_uuid);  	sdp_set_browse_groups(record, root); +	sdp_list_free(root, 0);  	sdp_uuid16_create(&l2cap, L2CAP_UUID);  	proto[0] = sdp_list_append(NULL, &l2cap); -	proto[0] = sdp_list_append(proto[0], sdp_data_alloc(SDP_UINT16, &psm)); +	p = sdp_data_alloc(SDP_UINT16, &psm); +	proto[0] = sdp_list_append(proto[0], p);  	apseq    = sdp_list_append(NULL, proto[0]);  	sdp_uuid16_create(&bnep, BNEP_UUID);  	proto[1] = sdp_list_append(NULL, &bnep); -	proto[1] = sdp_list_append(proto[1], sdp_data_alloc(SDP_UINT16, &version)); +	v = sdp_data_alloc(SDP_UINT16, &version); +	proto[1] = sdp_list_append(proto[1], v);  	/* Supported protocols */  	{ @@ -118,6 +122,12 @@ int bnep_sdp_register(uint16_t role)  	aproto   = sdp_list_append(NULL, apseq);  	sdp_set_access_protos(record, aproto); +	sdp_list_free(proto[0], NULL); +	sdp_list_free(proto[1], NULL); +	sdp_list_free(apseq, NULL); +	sdp_list_free(aproto, NULL); +	sdp_data_free(p); +	sdp_data_free(v);  	switch (role) {  	case BNEP_SVC_NAP: @@ -150,11 +160,13 @@ int bnep_sdp_register(uint16_t role)  		sdp_uuid16_create(&pan, PANU_SVCLASS_ID);  		svclass = sdp_list_append(NULL, &pan);  		sdp_set_service_classes(record, svclass); +		sdp_list_free(svclass, 0);  		sdp_uuid16_create(&profile[0].uuid, PANU_PROFILE_ID);  		profile[0].version = 0x0100;  		pfseq = sdp_list_append(NULL, &profile[0]);  		sdp_set_profile_descs(record, pfseq); +		sdp_list_free(pfseq, 0);  		sdp_set_info_attr(record, "PAN User", NULL, NULL);  		break; | 
