fix bounds check issue
git-svn-id: http://svn.openzap.org/svn/openzap/trunk@480 a93c3328-9c30-0410-af19-c9cd2b2d52af
This commit is contained in:
parent
a649b013ac
commit
c1d46e371c
|
@ -718,6 +718,12 @@ zap_status_t zap_channel_open_any(uint32_t span_id, zap_direction_t direction, z
|
||||||
uint32_t span_max;
|
uint32_t span_max;
|
||||||
|
|
||||||
if (span_id) {
|
if (span_id) {
|
||||||
|
if (span_id >= ZAP_MAX_SPANS_INTERFACE) {
|
||||||
|
zap_log(ZAP_LOG_CRIT, "SPAN NOT DEFINED!\n");
|
||||||
|
*zchan = NULL;
|
||||||
|
return ZAP_FAIL;
|
||||||
|
}
|
||||||
|
|
||||||
if (globals.spans[span_id].active_count >= globals.spans[span_id].chan_count) {
|
if (globals.spans[span_id].active_count >= globals.spans[span_id].chan_count) {
|
||||||
zap_log(ZAP_LOG_CRIT, "All circuits are busy.\n");
|
zap_log(ZAP_LOG_CRIT, "All circuits are busy.\n");
|
||||||
*zchan = NULL;
|
*zchan = NULL;
|
||||||
|
@ -907,14 +913,14 @@ zap_status_t zap_channel_open(uint32_t span_id, uint32_t chan_id, zap_channel_t
|
||||||
|
|
||||||
zap_mutex_lock(globals.mutex);
|
zap_mutex_lock(globals.mutex);
|
||||||
|
|
||||||
if (span_id && globals.spans[span_id].channel_request) {
|
|
||||||
zap_log(ZAP_LOG_ERROR, "Individual channel selection not implemented on this span.\n");
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (span_id < ZAP_MAX_SPANS_INTERFACE && chan_id < ZAP_MAX_CHANNELS_SPAN) {
|
if (span_id < ZAP_MAX_SPANS_INTERFACE && chan_id < ZAP_MAX_CHANNELS_SPAN) {
|
||||||
zap_channel_t *check;
|
zap_channel_t *check;
|
||||||
|
|
||||||
|
if (globals.spans[span_id].channel_request) {
|
||||||
|
zap_log(ZAP_LOG_ERROR, "Individual channel selection not implemented on this span.\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
check = &globals.spans[span_id].channels[chan_id];
|
check = &globals.spans[span_id].channels[chan_id];
|
||||||
|
|
||||||
if (zap_test_flag(check, ZAP_CHANNEL_SUSPENDED) ||
|
if (zap_test_flag(check, ZAP_CHANNEL_SUSPENDED) ||
|
||||||
|
|
|
@ -813,6 +813,7 @@ static void *zap_isdn_run(zap_thread_t *me, void *obj)
|
||||||
zap_log(ZAP_LOG_ERROR, "D-Chan Read Error!\n");
|
zap_log(ZAP_LOG_ERROR, "D-Chan Read Error!\n");
|
||||||
snprintf(span->last_error, sizeof(span->last_error), "D-Chan Read Error!");
|
snprintf(span->last_error, sizeof(span->last_error), "D-Chan Read Error!");
|
||||||
if (++errs == 10) {
|
if (++errs == 10) {
|
||||||
|
isdn_data->dchan->state = ZAP_CHANNEL_STATE_UP;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -913,6 +914,7 @@ zap_status_t zap_isdn_configure_span(zap_span_t *span, Q921NetUser_t mode, Q931D
|
||||||
} else {
|
} else {
|
||||||
if (zap_channel_open(span->span_id, i, &dchans[x]) == ZAP_SUCCESS) {
|
if (zap_channel_open(span->span_id, i, &dchans[x]) == ZAP_SUCCESS) {
|
||||||
zap_log(ZAP_LOG_DEBUG, "opening d-channel #%d %d:%d\n", x, dchans[x]->span_id, dchans[x]->chan_id);
|
zap_log(ZAP_LOG_DEBUG, "opening d-channel #%d %d:%d\n", x, dchans[x]->span_id, dchans[x]->chan_id);
|
||||||
|
dchans[x]->state = ZAP_CHANNEL_STATE_UP;
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue