summaryrefslogtreecommitdiff
path: root/pjsip/src
diff options
context:
space:
mode:
authorBenny Prijono <bennylp@teluu.com>2005-11-19 20:28:08 +0000
committerBenny Prijono <bennylp@teluu.com>2005-11-19 20:28:08 +0000
commit934277a3b49d493187f195899fcc49b838d16cdb (patch)
treeb4ec4fe403981553fe92adc2a581092b0239119d /pjsip/src
parent87b05ce12596910229d12c59aebfe566d00e8a96 (diff)
Changed transaction to refrect new transport changes
git-svn-id: http://svn.pjsip.org/repos/pjproject/trunk@58 74dad513-b988-da41-8d7b-12977e46ad98
Diffstat (limited to 'pjsip/src')
-rw-r--r--pjsip/src/pjsip/sip_transaction.c37
-rw-r--r--pjsip/src/pjsip/sip_transport.c14
-rw-r--r--pjsip/src/pjsip/sip_transport_udp.c67
-rw-r--r--pjsip/src/test-pjsip/main.c (renamed from pjsip/src/tests/pjsip-core/main.c)0
-rw-r--r--pjsip/src/test-pjsip/test.h (renamed from pjsip/src/tests/pjsip-core/test.h)0
-rw-r--r--pjsip/src/test-pjsip/test_msg.c (renamed from pjsip/src/tests/pjsip-core/test_msg.c)0
-rw-r--r--pjsip/src/test-pjsip/test_uri.c (renamed from pjsip/src/tests/pjsip-core/test_uri.c)0
7 files changed, 80 insertions, 38 deletions
diff --git a/pjsip/src/pjsip/sip_transaction.c b/pjsip/src/pjsip/sip_transaction.c
index f186f28a..f4818817 100644
--- a/pjsip/src/pjsip/sip_transaction.c
+++ b/pjsip/src/pjsip/sip_transaction.c
@@ -717,6 +717,7 @@ static void tsx_resolver_callback(pj_status_t status,
{
pjsip_transaction *tsx = token;
struct tsx_lock_data lck;
+ pjsip_transport *tp;
PJ_LOG(4, (tsx->obj_name, "resolver job complete, status=%d", status));
@@ -741,10 +742,10 @@ static void tsx_resolver_callback(pj_status_t status,
pj_ntohs(addr->entry[0].addr.sin_port)));
tsx->transport_state = PJSIP_TSX_TRANSPORT_STATE_CONNECTING;
- pjsip_endpt_get_transport(tsx->endpt, tsx->pool,
- addr->entry[0].type, &addr->entry[0].addr,
- tsx,
- &tsx_transport_callback);
+ status = pjsip_endpt_alloc_transport( tsx->endpt, addr->entry[0].type,
+ &addr->entry[0].addr,
+ &tp);
+ tsx_transport_callback(tp, tsx, status);
/* Unlock transaction */
unlock_tsx(tsx, &lck);
@@ -940,8 +941,7 @@ PJ_DEF(pj_status_t) pjsip_tsx_init_uas( pjsip_transaction *tsx,
tsx->current_addr = 0;
tsx->remote_addr.count = 1;
- tsx->remote_addr.entry[0].type =
- pjsip_transport_get_type(tsx->transport);
+ tsx->remote_addr.entry[0].type = tsx->transport->type;
pj_memcpy(&tsx->remote_addr.entry[0].addr,
&rdata->pkt_info.addr, rdata->pkt_info.addr_len);
@@ -1181,6 +1181,20 @@ PJ_DEF(void) pjsip_tsx_terminate( pjsip_transaction *tsx, int code )
}
/*
+ * Transport send completion callback.
+ */
+static void tsx_on_send_complete(void *token, pjsip_tx_data *tdata,
+ pj_ssize_t bytes_sent)
+{
+ PJ_UNUSED_ARG(token);
+ PJ_UNUSED_ARG(tdata);
+
+ if (bytes_sent <= 0) {
+ PJ_TODO(HANDLE_TRANSPORT_ERROR);
+ }
+}
+
+/*
* Send message to the transport.
* If transport is not yet available, then do nothing. The message will be
* transmitted when transport connection completion callback is called.
@@ -1193,7 +1207,6 @@ static pj_status_t tsx_send_msg( pjsip_transaction *tsx,
PJ_LOG(5,(tsx->obj_name, "sending msg (tdata=%p)", tdata));
if (tsx->transport_state == PJSIP_TSX_TRANSPORT_STATE_FINAL) {
- pj_ssize_t sent;
pjsip_event before_tx_event;
pj_assert(tsx->transport != NULL);
@@ -1227,11 +1240,11 @@ static pj_status_t tsx_send_msg( pjsip_transaction *tsx,
pjsip_endpt_send_tsx_event( tsx->endpt, &before_tx_event );
tsx->has_unsent_msg = 0;
- status = pjsip_transport_send_msg(
- tsx->transport, tdata,
- &tsx->remote_addr.entry[tsx->current_addr].addr,
- &sent);
- if (status != PJ_SUCCESS) {
+ status = pjsip_transport_send(tsx->transport, tdata,
+ &tsx->remote_addr.entry[tsx->current_addr].addr,
+ tsx, &tsx_on_send_complete);
+ if (status != PJ_SUCCESS && status != PJ_EPENDING) {
+ PJ_TODO(HANDLE_TRANSPORT_ERROR);
goto on_error;
}
} else {
diff --git a/pjsip/src/pjsip/sip_transport.c b/pjsip/src/pjsip/sip_transport.c
index 013e45ea..307f9e5e 100644
--- a/pjsip/src/pjsip/sip_transport.c
+++ b/pjsip/src/pjsip/sip_transport.c
@@ -172,7 +172,7 @@ PJ_DEF(pj_status_t) pjsip_tx_data_create( pjsip_tpmgr *mgr,
return status;
}
- pj_ioqueue_op_key_init(&tdata->op_key, sizeof(tdata->op_key));
+ pj_ioqueue_op_key_init(&tdata->op_key.key, sizeof(tdata->op_key));
*p_tdata = tdata;
return PJ_SUCCESS;
@@ -244,7 +244,7 @@ typedef struct transport_key
static void transport_send_callback(pjsip_transport *transport,
void *token,
- pj_status_t status)
+ pj_ssize_t size)
{
pjsip_tx_data *tdata = token;
@@ -257,7 +257,7 @@ static void transport_send_callback(pjsip_transport *transport,
/* Call callback, if any. */
if (tdata->cb) {
- (*tdata->cb)(tdata->token, tdata, status);
+ (*tdata->cb)(tdata->token, tdata, size);
}
/* Decrement reference count. */
@@ -273,7 +273,7 @@ PJ_DEF(pj_status_t) pjsip_transport_send( pjsip_transport *tr,
void *token,
void (*cb)(void *token,
pjsip_tx_data *tdata,
- pj_status_t))
+ pj_ssize_t))
{
pj_status_t status;
@@ -317,10 +317,8 @@ PJ_DEF(pj_status_t) pjsip_transport_send( pjsip_transport *tr,
tdata->is_pending = 1;
/* Send to transport. */
- status = (*tr->send_msg)(tr, tdata->buf.start,
- tdata->buf.cur - tdata->buf.start,
- &tdata->op_key,
- addr, tdata, &transport_send_callback);
+ status = (*tr->send_msg)(tr, tdata, addr, (void*)tdata,
+ &transport_send_callback);
if (status != PJ_EPENDING) {
tdata->is_pending = 0;
diff --git a/pjsip/src/pjsip/sip_transport_udp.c b/pjsip/src/pjsip/sip_transport_udp.c
index dfe8492f..a6729ffa 100644
--- a/pjsip/src/pjsip/sip_transport_udp.c
+++ b/pjsip/src/pjsip/sip_transport_udp.c
@@ -109,6 +109,7 @@ static void on_read_complete( pj_ioqueue_key_t *key,
/* Read next packet. */
bytes_read = sizeof(rdata->pkt_info.packet);
+ rdata->pkt_info.addr_len = sizeof(rdata->pkt_info.addr);
status = pj_ioqueue_recvfrom(key, op_key,
rdata->pkt_info.packet,
&bytes_read, flags,
@@ -160,6 +161,8 @@ static void on_write_complete( pj_ioqueue_key_t *key,
struct udp_transport *tp = pj_ioqueue_get_user_data(key);
pjsip_tx_data_op_key *tdata_op_key = (pjsip_tx_data_op_key*)op_key;
+ tdata_op_key->tdata = NULL;
+
if (tdata_op_key->callback) {
tdata_op_key->callback(&tp->base, tdata_op_key->token, bytes_sent);
}
@@ -183,7 +186,8 @@ static pj_status_t transport_send_msg( pjsip_transport *transport,
pj_ssize_t size;
PJ_ASSERT_RETURN(transport && tdata, PJ_EINVAL);
-
+ PJ_ASSERT_RETURN(tdata->op_key.tdata == NULL, PJSIP_EPENDINGTX);
+
/* Init op key. */
tdata->op_key.tdata = tdata;
tdata->op_key.token = token;
@@ -239,21 +243,22 @@ static pj_status_t transport_destroy( pjsip_transport *transport )
/*
- * pjsip_udp_transport_start()
+ * pjsip_udp_transport_attach()
*
- * Start an UDP transport/listener.
+ * Attach UDP socket and start transport.
*/
-PJ_DEF(pj_status_t) pjsip_udp_transport_start( pjsip_endpoint *endpt,
- const pj_sockaddr_in *local,
- const pj_sockaddr_in *pub_addr,
- unsigned async_cnt,
- pjsip_transport **p_transport)
+PJ_DEF(pj_status_t) pjsip_udp_transport_attach( pjsip_endpoint *endpt,
+ pj_sock_t sock,
+ const pj_sockaddr_in *pub_addr,
+ unsigned async_cnt,
+ pjsip_transport **p_transport)
{
pj_pool_t *pool;
struct udp_transport *tp;
pj_ioqueue_t *ioqueue;
pj_ioqueue_callback ioqueue_cb;
unsigned i;
+ int addrlen;
pj_status_t status;
/* Create pool. */
@@ -272,7 +277,12 @@ PJ_DEF(pj_status_t) pjsip_udp_transport_start( pjsip_endpoint *endpt,
tp->base.flag = pjsip_transport_get_flag_from_type(PJSIP_TRANSPORT_UDP);
/* Init addresses. */
- pj_memcpy(&tp->base.local_addr, local, sizeof(pj_sockaddr_in));
+ addrlen = sizeof(tp->base.local_addr);
+ status = pj_sock_getsockname(sock, &tp->base.local_addr, &addrlen);
+ if (status != PJ_SUCCESS) {
+ pjsip_endpt_destroy_pool(endpt, pool);
+ return status;
+ }
pj_memcpy(&tp->base.public_addr, pub_addr, sizeof(pj_sockaddr_in));
tp->base.rem_addr.sin_family = PJ_AF_INET;
@@ -286,15 +296,8 @@ PJ_DEF(pj_status_t) pjsip_udp_transport_start( pjsip_endpoint *endpt,
if (status != PJ_SUCCESS)
goto on_error;
- /* Create socket. */
- status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &tp->sock);
- if (status != PJ_SUCCESS)
- goto on_error;
-
- /* Bind socket. */
- status = pj_sock_bind(tp->sock, local, sizeof(pj_sockaddr_in));
- if (status != PJ_SUCCESS)
- goto on_error;
+ /* Attach socket. */
+ tp->sock = sock;
/* Register to ioqueue. */
ioqueue = pjsip_endpt_get_ioqueue(endpt);
@@ -376,4 +379,32 @@ on_error:
return status;
}
+/*
+ * pjsip_udp_transport_start()
+ *
+ * Start an UDP transport/listener.
+ */
+PJ_DEF(pj_status_t) pjsip_udp_transport_start( pjsip_endpoint *endpt,
+ const pj_sockaddr_in *local,
+ const pj_sockaddr_in *pub_addr,
+ unsigned async_cnt,
+ pjsip_transport **p_transport)
+{
+ pj_sock_t sock;
+ pj_status_t status;
+
+ status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock);
+ if (status != PJ_SUCCESS)
+ return status;
+
+ status = pj_sock_bind(sock, local, sizeof(*local));
+ if (status != PJ_SUCCESS) {
+ pj_sock_close(sock);
+ return status;
+ }
+
+ return pjsip_udp_transport_attach( endpt, sock, pub_addr, async_cnt,
+ p_transport );
+}
+
diff --git a/pjsip/src/tests/pjsip-core/main.c b/pjsip/src/test-pjsip/main.c
index 621bac61..621bac61 100644
--- a/pjsip/src/tests/pjsip-core/main.c
+++ b/pjsip/src/test-pjsip/main.c
diff --git a/pjsip/src/tests/pjsip-core/test.h b/pjsip/src/test-pjsip/test.h
index d5f84031..d5f84031 100644
--- a/pjsip/src/tests/pjsip-core/test.h
+++ b/pjsip/src/test-pjsip/test.h
diff --git a/pjsip/src/tests/pjsip-core/test_msg.c b/pjsip/src/test-pjsip/test_msg.c
index 94ac25ce..94ac25ce 100644
--- a/pjsip/src/tests/pjsip-core/test_msg.c
+++ b/pjsip/src/test-pjsip/test_msg.c
diff --git a/pjsip/src/tests/pjsip-core/test_uri.c b/pjsip/src/test-pjsip/test_uri.c
index cfb3afd7..cfb3afd7 100644
--- a/pjsip/src/tests/pjsip-core/test_uri.c
+++ b/pjsip/src/test-pjsip/test_uri.c