select on write for openzap to avoid overrun on the td, channel
git-svn-id: http://svn.openzap.org/svn/openzap/trunk@782 a93c3328-9c30-0410-af19-c9cd2b2d52af
This commit is contained in:
parent
e0ea30c5da
commit
aacd2d68c0
|
@ -664,6 +664,8 @@ static switch_status_t channel_write_frame(switch_core_session_t *session, switc
|
||||||
private_t *tech_pvt = NULL;
|
private_t *tech_pvt = NULL;
|
||||||
zap_size_t len;
|
zap_size_t len;
|
||||||
unsigned char data[SWITCH_RECOMMENDED_BUFFER_SIZE] = {0};
|
unsigned char data[SWITCH_RECOMMENDED_BUFFER_SIZE] = {0};
|
||||||
|
zap_wait_flag_t wflags = ZAP_WRITE;
|
||||||
|
zap_status_t status;
|
||||||
|
|
||||||
channel = switch_core_session_get_channel(session);
|
channel = switch_core_session_get_channel(session);
|
||||||
assert(channel != NULL);
|
assert(channel != NULL);
|
||||||
|
@ -695,6 +697,13 @@ static switch_status_t channel_write_frame(switch_core_session_t *session, switc
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wflags = ZAP_WRITE;
|
||||||
|
status = zap_channel_wait(tech_pvt->zchan, &wflags, tech_pvt->zchan->effective_interval * 4);
|
||||||
|
|
||||||
|
if (!(wflags & ZAP_WRITE)) {
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
len = frame->datalen;
|
len = frame->datalen;
|
||||||
if (zap_channel_write(tech_pvt->zchan, frame->data, frame->buflen, &len) != ZAP_SUCCESS) {
|
if (zap_channel_write(tech_pvt->zchan, frame->data, frame->buflen, &len) != ZAP_SUCCESS) {
|
||||||
if (++tech_pvt->wr_error > 10) {
|
if (++tech_pvt->wr_error > 10) {
|
||||||
|
|
|
@ -1,51 +0,0 @@
|
||||||
Index: src/ozmod/ozmod_wanpipe/ozmod_wanpipe.c
|
|
||||||
===================================================================
|
|
||||||
--- src/ozmod/ozmod_wanpipe/ozmod_wanpipe.c (revision 776)
|
|
||||||
+++ src/ozmod/ozmod_wanpipe/ozmod_wanpipe.c (working copy)
|
|
||||||
@@ -604,6 +604,8 @@
|
|
||||||
return ZAP_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ zap_log(ZAP_LOG_ERROR, "FAIL %d\n", bsent);
|
|
||||||
+
|
|
||||||
return ZAP_FAIL;
|
|
||||||
}
|
|
||||||
|
|
||||||
Index: mod_openzap/mod_openzap.c
|
|
||||||
===================================================================
|
|
||||||
--- mod_openzap/mod_openzap.c (revision 776)
|
|
||||||
+++ mod_openzap/mod_openzap.c (working copy)
|
|
||||||
@@ -674,6 +674,7 @@
|
|
||||||
assert(tech_pvt->zchan != NULL);
|
|
||||||
|
|
||||||
if (switch_test_flag(tech_pvt, TFLAG_DEAD)) {
|
|
||||||
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "DEAD\n");
|
|
||||||
return SWITCH_STATUS_FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -682,6 +683,7 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!switch_test_flag(tech_pvt, TFLAG_IO)) {
|
|
||||||
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "NO FLAG IO\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -689,6 +691,7 @@
|
|
||||||
frame->data = data;
|
|
||||||
frame->buflen = sizeof(data);
|
|
||||||
if ((frame->datalen = tech_pvt->write_codec.implementation->encoded_bytes_per_packet) > frame->buflen) {
|
|
||||||
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "BUF ERR\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
memset(data, 255, frame->datalen);
|
|
||||||
@@ -697,7 +700,9 @@
|
|
||||||
|
|
||||||
len = frame->datalen;
|
|
||||||
if (zap_channel_write(tech_pvt->zchan, frame->data, frame->buflen, &len) != ZAP_SUCCESS) {
|
|
||||||
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "WR ERR\n");
|
|
||||||
if (++tech_pvt->wr_error > 10) {
|
|
||||||
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "10 WR ERR\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
} else {
|
|
|
@ -1,29 +0,0 @@
|
||||||
Index: mod_openzap/mod_openzap.c
|
|
||||||
===================================================================
|
|
||||||
--- mod_openzap/mod_openzap.c (revision 778)
|
|
||||||
+++ mod_openzap/mod_openzap.c (working copy)
|
|
||||||
@@ -664,7 +664,9 @@
|
|
||||||
private_t *tech_pvt = NULL;
|
|
||||||
zap_size_t len;
|
|
||||||
unsigned char data[SWITCH_RECOMMENDED_BUFFER_SIZE] = {0};
|
|
||||||
-
|
|
||||||
+ zap_wait_flag_t wflags = ZAP_WRITE;
|
|
||||||
+ zap_status_t status;
|
|
||||||
+
|
|
||||||
channel = switch_core_session_get_channel(session);
|
|
||||||
assert(channel != NULL);
|
|
||||||
|
|
||||||
@@ -695,6 +697,13 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
+ wflags = ZAP_WRITE;
|
|
||||||
+ status = zap_channel_wait(tech_pvt->zchan, &wflags, tech_pvt->zchan->effective_interval * 4);
|
|
||||||
+
|
|
||||||
+ if (!(wflags & ZAP_WRITE)) {
|
|
||||||
+ goto fail;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
len = frame->datalen;
|
|
||||||
if (zap_channel_write(tech_pvt->zchan, frame->data, frame->buflen, &len) != ZAP_SUCCESS) {
|
|
||||||
if (++tech_pvt->wr_error > 10) {
|
|
Loading…
Reference in New Issue