aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/surface/call.c
diff options
context:
space:
mode:
authorGravatar Craig Tiller <craig.tiller@gmail.com>2015-02-05 08:43:49 -0800
committerGravatar Craig Tiller <craig.tiller@gmail.com>2015-02-05 08:43:49 -0800
commit37bbead4839127701d8442ff3329fc131cd7a699 (patch)
tree95125e905b0b7506c18e0080f78804632bec1ffd /src/core/surface/call.c
parentea3697bf4cf24d647568a493d209c8bded7510ce (diff)
Fix memory leaks
Diffstat (limited to 'src/core/surface/call.c')
-rw-r--r--src/core/surface/call.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/core/surface/call.c b/src/core/surface/call.c
index 4a45f67e1d..d118daa45a 100644
--- a/src/core/surface/call.c
+++ b/src/core/surface/call.c
@@ -273,6 +273,7 @@ static void destroy_call(void *call, int ignored_success) {
if (c->legacy_state) {
destroy_legacy_state(c->legacy_state);
}
+ grpc_bbq_destroy(&c->incoming_queue);
gpr_free(c);
}
@@ -941,6 +942,8 @@ struct legacy_state {
char *details;
grpc_status_code status;
+ char *send_details;
+
size_t msg_in_read_idx;
grpc_byte_buffer *msg_in;
@@ -967,6 +970,7 @@ static void destroy_legacy_state(legacy_state *ls) {
gpr_free(ls->initial_md_in.metadata);
gpr_free(ls->trailing_md_in.metadata);
gpr_free(ls->details);
+ gpr_free(ls->send_details);
gpr_free(ls);
}
@@ -1215,8 +1219,7 @@ grpc_call_error grpc_call_start_write_status_old(grpc_call *call,
reqs[0].data.send_metadata.metadata = ls->md_out[ls->md_out_buffer];
reqs[1].op = GRPC_IOREQ_SEND_STATUS;
reqs[1].data.send_status.code = status;
- /* MEMLEAK */
- reqs[1].data.send_status.details = gpr_strdup(details);
+ reqs[1].data.send_status.details = ls->send_details = gpr_strdup(details);
reqs[2].op = GRPC_IOREQ_SEND_CLOSE;
err = start_ioreq(call, reqs, 3, finish_finish, tag);
unlock(call);