HI Andrei
thanks a lot!
>> Hi Ser Gurus:
>>
>> How to parse msg stored in the tm correctly?
>>
>> e.g in the reply msg, we can get the corresponding request from tm:
>>
>> msg = t->uas.request;
>>
>> The sip_msg_cloner seems copy only via/from/to/cseq/auth headers and
>> parsed headers to the shm, right?
>>
>> what if we want to parse the other headers,
>>
>> e.g: parse_headers(msg, HDR_ROUTE_F, 0)<0)
>
>By default all headers are parsed before creating the transaction, so
>you'll have all the headers in the shm copy.
>What you don't always have parsed is the content of a header (but that
>depends on the header type).
Oh I see, what we need is a parsed content of route header.
>>
>> The parse_headers uses pkg_alloc, thus the parsed result is
>> pkg_alloced and stored the tm structure, then it never get freed until
>> tm is destoried ( but even in this case tm may call shm_free instead of
>> pkg_free???? )
>
>In general one calls parse_headers only on a copy of the message stored
>in tm (see fake_req()).
I see.
>>
>> So how can we parsed the tm-stored msg and how to do it correctly?
>
>If you could be more specific (what headers do you need and from where,
>e.g. failure route or a tm hook) it would help.
Here is the detailed case:
U1 --> p-cscf --> U2
U1 call U2, U2 reply with 183 and 200 OK.
The p-cscf handles the 183/200 reply in two different processes,
we need to get original request's route header and its parsed content.
the old psudocode is like which cause memory leak/crash the sytem:
msg = t->uas.request;
parse_headers(msg, HDR_ROUTE_F, 0)
parse_rr(h);
according to your email, it seems should be something like :
msg = fake_req(t->uas.request);
parse_headers(msg, HDR_ROUTE_F, 0)
parse_rr(h);
free_faked_req(msg);
since 183/200 are in different process and need the same parsed route header
content, is there a way to copied the parsed content to shm to avoid duplicate parsing?
Or is there a way to copy the parsed-header's content to shm before creating the transaction?
Kind regards
Min Wang