[asterisk-bugs] [JIRA] (ASTERISK-25615) res_pjsip: Setting transport async_operations > 1 causes segfault on tls transports

George Joseph (JIRA) noreply at issues.asterisk.org
Tue Dec 8 10:36:32 CST 2015


     [ https://issues.asterisk.org/jira/browse/ASTERISK-25615?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

George Joseph updated ASTERISK-25615:
-------------------------------------

    Description: 
Originally reported issue:
{quote}
If async_operations is set greater than 1 on a tls transport, asterisk segfaults in pjproject just after the tls negotiation.
Test scenario and backtrace attached.
Use the Wiki Secure Calls page and contrib/scripts/ast_tls_cert script to create the keys and certs
Then from the /etc/asterisk/keys directory, run: sipp localhost:41061 -sf ./register.xml -t l1 -tls_cert ./1175.crt -tls_key 1175.key -p 5061 -max_socket 10 -m 1 -s 1175 -ap fordst1175
{quote}

However, I can now reproduce this issue solely using pjsua for both client and server...
Steps to reproduce (assuming pjproject-2.4.5):
* Modify pjsip/src/pjsua-lib/pjsua_core.c:2279 to set async_cnt to 2.
* Compile (no need to install)
* Create suitable TLS keys and certificates for a server
* Run 
{code}pjsip-apps/bin/pjsua-x86_64-unknown-linux-gnu --use-tls --tls-ca-file ca.crt --tls-cert-file server.crt --tls-privkey-file server.key{code}
* From another command prompt, run 
{code}
LD_LIBRARY_PATH=./pjsip/lib pjsip-apps/bin/pjsua-x86_64-unknown-linux-gnu --local-port 7070 --use-tls <<EOF
S
OPTIONS
sips:bob at localhost:5061
S
OPTIONS
sips:bob at localhost:5061
q
{code}
* The server side will segfault.





  was:
Originally reported issue:
{quote}
If async_operations is set greater than 1 on a tls transport, asterisk segfaults in pjproject just after the tls negotiation.
Test scenario and backtrace attached.
Use the Wiki Secure Calls page and contrib/scripts/ast_tls_cert script to create the keys and certs
Then from the /etc/asterisk/keys directory, run: sipp localhost:41061 -sf ./register.xml -t l1 -tls_cert ./1175.crt -tls_key 1175.key -p 5061 -max_socket 10 -m 1 -s 1175 -ap fordst1175
{quote}

However, I can now reproduce this issue solely using pjsua for both client and server...
Steps to reproduce (assuming pjproject-2.4.5):
* Modify pjsip/src/pjsua-lib/pjsua_core.c:2279 to set async_cnt to 2.
* Compile and install
* Create suitable TLS keys and certificates for a server
* Run {{pjsua --use-tls --tls-ca-file ca.crt --tls-cert-file server.crt --tls-privkey-file server.key}}
* From another command prompt, run 
{code}
pjsua --local-port 7070 --use-tls <<EOF
S
OPTIONS
sips:bob at localhost:5061
S
OPTIONS
sips:bob at localhost:5061
q
{code}
* The first command will segfault.





> res_pjsip: Setting transport async_operations > 1 causes segfault on tls transports
> -----------------------------------------------------------------------------------
>
>                 Key: ASTERISK-25615
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-25615
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>          Components: pjproject/pjsip
>    Affects Versions: 13.6.0
>         Environment: Fedora 23 x86_64
> Asterisk from current 13 branch
> pjproject 2.4
>            Reporter: George Joseph
>            Assignee: George Joseph
>            Severity: Critical
>         Attachments: backtrace.txt, pjsip.conf, register.xml
>
>
> Originally reported issue:
> {quote}
> If async_operations is set greater than 1 on a tls transport, asterisk segfaults in pjproject just after the tls negotiation.
> Test scenario and backtrace attached.
> Use the Wiki Secure Calls page and contrib/scripts/ast_tls_cert script to create the keys and certs
> Then from the /etc/asterisk/keys directory, run: sipp localhost:41061 -sf ./register.xml -t l1 -tls_cert ./1175.crt -tls_key 1175.key -p 5061 -max_socket 10 -m 1 -s 1175 -ap fordst1175
> {quote}
> However, I can now reproduce this issue solely using pjsua for both client and server...
> Steps to reproduce (assuming pjproject-2.4.5):
> * Modify pjsip/src/pjsua-lib/pjsua_core.c:2279 to set async_cnt to 2.
> * Compile (no need to install)
> * Create suitable TLS keys and certificates for a server
> * Run 
> {code}pjsip-apps/bin/pjsua-x86_64-unknown-linux-gnu --use-tls --tls-ca-file ca.crt --tls-cert-file server.crt --tls-privkey-file server.key{code}
> * From another command prompt, run 
> {code}
> LD_LIBRARY_PATH=./pjsip/lib pjsip-apps/bin/pjsua-x86_64-unknown-linux-gnu --local-port 7070 --use-tls <<EOF
> S
> OPTIONS
> sips:bob at localhost:5061
> S
> OPTIONS
> sips:bob at localhost:5061
> q
> {code}
> * The server side will segfault.



--
This message was sent by Atlassian JIRA
(v6.2#6252)



More information about the asterisk-bugs mailing list