> ==31087== 4,986,528 (77,472 direct, 4,909,056 indirect) bytes in 4,842 > blocks are definitely lost in loss record 813 of 813 > ==31087== at 0x4027434: malloc (vg_replace_malloc.c:291) > ==31087== by 0x80970B3: gw_native_malloc (gwmem-native.c:87) > ==31087== by 0x80A37A1: octstr_create_from_data_real (octstr.c:263) > ==31087== by 0x80A3916: octstr_create_real (octstr.c:245) > ==31087== by 0x80A908E: octstr_format_valist_real (octstr.c:2480) > ==31087== by 0x80A9366: octstr_format (octstr.c:2469) > ==31087== by 0x80534F5: boxc_route_msg_to_smsc (opensmppbox.c:1791) > ==31087== by 0x8057AAE: smpp_to_bearerbox (opensmppbox.c:1638) > ==31087== by 0x80983AE: new_thread (gwthread-pthread.c:385) > ==31087== by 0x46F9C38: start_thread (pthread_create.c:304) > ==31087== by 0x482F78D: clone (clone.S:130)
this seems to be a leak in opensmppbox in this code segment (handle_pdu) in opensmppbox.c around line 1634 case submit_sm: msg = pdu_to_msg(box, pdu, &reason); msg2 = msg; if (msg == NULL) { resp = smpp_pdu_create(generic_nack, pdu->u.submit_sm.sequence_number); resp->u.generic_nack.command_status = SMPP_ESME_RUNKNOWNERR; } else { Octstr *smsc_id = boxc_route_msg_to_smsc(box, msg); <-smsc_id is allocated but never freeed. check_multipart(box, msg, &msg_to_send, &msg2, &parts_list); msg->sms.smsc_id = smsc_id ? octstr_duplicate(smsc_id) : NULL; /* its duplicated here... */ msg->sms.boxc_id = octstr_duplicate(box->boxc_id); msg_dump(msg, 0); resp = smpp_pdu_create(submit_sm_resp, pdu->u.submit_sm.sequence_number); msgid = generate_smppid(msg); msg->sms.dlr_url = octstr_duplicate(msgid); resp->u.submit_sm_resp.message_id = msgid; if (msg_to_send) { if (DLR_IS_ENABLED(msg2->sms.dlr_mask)) { hold_service = msg2->sms.service; msg2->sms.service = octstr_format("%ld", msg2->sms.time); msgid = generate_smppid(msg2); if (parts_list) { msg2->sms.dlr_url = concat_msgids(msgid, parts_list); } dlr_add(box->boxc_id, msgid, msg2); octstr_destroy(msgid); octstr_destroy(msg2->sms.service); msg2->sms.service = hold_service; } uuid_unparse(msg2->sms.id, id); msgid = octstr_create(id); dict_put(box->msg_acks, msgid, resp); octstr_destroy(msgid); resp = NULL; send_msg(box->bearerbox_connection, box, msg2); if (parts_list) { /* destroy values */ gwlist_destroy(parts_list, msg_destroy_item); } } octstr_destroy(smsc_id); /* fix for this leak */ } break; This is a leak which would leak a few bytes per SMS.
signature.asc
Description: Message signed with OpenPGP using GPGMail