1
0

qcacld-3.0: Allocate memory for set_offload and program at once

qcacld-2.0 to qcacld-3.0 propagation

Presently, in BPF set_offload structure and the filter program are
allocated separately. In certain error paths the program is not
freed correctly because of which there can be memory leaks.
Have a single allocation for the set_offload and program to avoid any
memory leaks.

Change-Id: I097d3408cc89c26e015fd6aee8668f53e8f64cf7
CRs-Fixed: 1006522
Este cometimento está contido em:
Arun Khandavalli
2016-04-26 20:53:35 +05:30
cometido por qcabuildsw
ascendente 87499b66d7
cometimento ca198b5eb5
2 ficheiros modificados com 4 adições e 14 eliminações

Ver ficheiro

@@ -16064,7 +16064,8 @@ QDF_STATUS sme_set_bpf_instructions(tHalHandle hal,
cds_msg_t cds_msg;
struct sir_bpf_set_offload *set_offload;
set_offload = qdf_mem_malloc(sizeof(*set_offload));
set_offload = qdf_mem_malloc(sizeof(*set_offload) +
req->current_length);
if (NULL == set_offload) {
QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_ERROR,
@@ -16078,14 +16079,8 @@ QDF_STATUS sme_set_bpf_instructions(tHalHandle hal,
set_offload->total_length = req->total_length;
set_offload->current_length = req->current_length;
if (set_offload->total_length) {
set_offload->program = qdf_mem_malloc(sizeof(uint8_t) *
req->current_length);
if (NULL == set_offload->program) {
QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_ERROR,
FL("Failed to alloc instruction memory"));
qdf_mem_free(set_offload);
return QDF_STATUS_E_NOMEM;
}
set_offload->program = ((uint8_t *)set_offload) +
sizeof(*set_offload);
qdf_mem_copy(set_offload->program, req->program,
set_offload->current_length);
}
@@ -16100,16 +16095,12 @@ QDF_STATUS sme_set_bpf_instructions(tHalHandle hal,
QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_ERROR,
FL("Post BPF set offload msg fail"));
status = QDF_STATUS_E_FAILURE;
if (set_offload->total_length)
qdf_mem_free(set_offload->program);
qdf_mem_free(set_offload);
}
sme_release_global_lock(&mac_ctx->sme);
} else {
QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_ERROR,
FL("sme_acquire_global_lock failed"));
if (set_offload->total_length)
qdf_mem_free(set_offload->program);
qdf_mem_free(set_offload);
}
return status;

Ver ficheiro

@@ -7907,7 +7907,6 @@ QDF_STATUS wma_set_bpf_instructions(tp_wma_handle wma,
buf_ptr += WMI_TLV_HDR_SIZE;
qdf_mem_copy(buf_ptr, bpf_set_offload->program,
bpf_set_offload->current_length);
qdf_mem_free(bpf_set_offload->program);
}
if (wmi_unified_cmd_send(wma->wmi_handle, wmi_buf, len,