mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 06:26:41 +00:00 
			
		
		
		
	core_unreal.c: Fix memory leak in ast_unreal_new_channels()
When the channel tech is multistream capable, the reference to chan_topology was passed to the new channel. When the channel tech isn't multistream capable, the reference to chan_topology was never released. "Local" channels are multistream capable so it didn't affect them but the confbridge "CBAnn" and the bridge_media "Recorder" channels are not so they caused a leak every time one of them was created. Also added tracing to ast_stream_topology_alloc() and stream_topology_destroy() to assist with debugging. Resolves: #938
This commit is contained in:
		
				
					committed by
					
						![asterisk-org-access-app[bot]](/avatar/58a64b62d62d5b23df7bc832f016f9db?size=40) asterisk-org-access-app[bot]
						asterisk-org-access-app[bot]
					
				
			
			
				
	
			
			
			
						parent
						
							cb2b263756
						
					
				
				
					commit
					eecc0469c1
				
			| @@ -1168,7 +1168,7 @@ struct ast_channel *ast_unreal_new_channels(struct ast_unreal_pvt *p, | ||||
| 	struct ast_assigned_ids id1 = {NULL, NULL}; | ||||
| 	struct ast_assigned_ids id2 = {NULL, NULL}; | ||||
| 	int generated_seqno = ast_atomic_fetchadd_int((int *) &name_sequence, +1); | ||||
| 	struct ast_stream_topology *topology; | ||||
| 	RAII_VAR(struct ast_stream_topology *, topology, NULL, ast_stream_topology_free); | ||||
|  | ||||
| 	/* set unique ids for the two channels */ | ||||
| 	if (assignedids && !ast_strlen_zero(assignedids->uniqueid)) { | ||||
| @@ -1186,14 +1186,6 @@ struct ast_channel *ast_unreal_new_channels(struct ast_unreal_pvt *p, | ||||
| 		id2.uniqueid = uniqueid2; | ||||
| 	} | ||||
|  | ||||
| 	/* We need to create a topology to place on the first channel, as we can't | ||||
| 	 * share a single one between both. | ||||
| 	 */ | ||||
| 	topology = ast_stream_topology_clone(p->reqtopology); | ||||
| 	if (!topology) { | ||||
| 		return NULL; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Allocate two new Asterisk channels | ||||
| 	 * | ||||
| @@ -1206,7 +1198,6 @@ struct ast_channel *ast_unreal_new_channels(struct ast_unreal_pvt *p, | ||||
| 		"%s/%s-%08x;1", tech->type, p->name, (unsigned)generated_seqno); | ||||
| 	if (!owner) { | ||||
| 		ast_log(LOG_WARNING, "Unable to allocate owner channel structure\n"); | ||||
| 		ast_stream_topology_free(topology); | ||||
| 		return NULL; | ||||
| 	} | ||||
|  | ||||
| @@ -1221,7 +1212,15 @@ struct ast_channel *ast_unreal_new_channels(struct ast_unreal_pvt *p, | ||||
| 	ast_channel_nativeformats_set(owner, p->reqcap); | ||||
|  | ||||
| 	if (ast_channel_is_multistream(owner)) { | ||||
| 		ast_channel_set_stream_topology(owner, topology); | ||||
| 		/* | ||||
| 		 * We need to create a topology to place on the first channel, as we can't | ||||
| 		 * share a single one between both. | ||||
| 		 */ | ||||
| 		topology = ast_stream_topology_clone(p->reqtopology); | ||||
| 		if (!topology) { | ||||
| 			return NULL; | ||||
| 		} | ||||
| 		ast_channel_set_stream_topology(owner, ao2_bump(topology)); | ||||
| 	} | ||||
|  | ||||
| 	/* Determine our read/write format and set it on each channel */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user