}
/**
- * \brief Retrieves an event from a ftdm channel
- * \param ftdmchan Channel to retrieve event from
- * \param event FreeTDM event to return
- * \return Success or failure
+ * \brief Process an event from a ftdmchan and set the proper OOB event_id. The channel must be locked.
+ * \param fchan Channel to retrieve event from
+ * \param event_id Pointer to OOB event id
+ * \param zt_event_id Zaptel event id
+ * \return FTDM_SUCCESS or FTDM_FAIL
*/
-FIO_CHANNEL_NEXT_EVENT_FUNCTION(zt_channel_next_event)
+static __inline__ ftdm_status_t zt_channel_process_event(ftdm_channel_t *fchan, ftdm_oob_event_t *event_id, zt_event_t zt_event_id)
{
- uint32_t i, event_id = FTDM_OOB_INVALID;
- zt_event_t zt_event_id = 0;
- ftdm_span_t *span = ftdmchan->span;
-
- if (ftdm_test_flag(ftdmchan, FTDM_CHANNEL_EVENT)) {
- ftdm_clear_flag(ftdmchan, FTDM_CHANNEL_EVENT);
- }
-
- if (ioctl(ftdmchan->sockfd, codes.GETEVENT, &zt_event_id) == -1) {
- ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Failed retrieving event from channel: %s\n",
- strerror(errno));
- return FTDM_FAIL;
- }
-
switch(zt_event_id) {
case ZT_EVENT_RINGEROFF:
{
break;
case ZT_EVENT_RINGBEGIN:
{
- event_id = FTDM_OOB_RING_START;
+ *event_id = FTDM_OOB_RING_START;
}
break;
case ZT_EVENT_ONHOOK:
{
- event_id = FTDM_OOB_ONHOOK;
+ *event_id = FTDM_OOB_ONHOOK;
}
break;
case ZT_EVENT_WINKFLASH:
{
- if (ftdmchan->state == FTDM_CHANNEL_STATE_DOWN || ftdmchan->state == FTDM_CHANNEL_STATE_DIALING) {
- event_id = FTDM_OOB_WINK;
+ if (fchan->state == FTDM_CHANNEL_STATE_DOWN || fchan->state == FTDM_CHANNEL_STATE_DIALING) {
+ *event_id = FTDM_OOB_WINK;
} else {
- event_id = FTDM_OOB_FLASH;
+ *event_id = FTDM_OOB_FLASH;
}
}
break;
case ZT_EVENT_RINGOFFHOOK:
{
- if (ftdmchan->type == FTDM_CHAN_TYPE_FXS || (ftdmchan->type == FTDM_CHAN_TYPE_EM && ftdmchan->state != FTDM_CHANNEL_STATE_UP)) {
- ftdm_set_flag(ftdmchan, FTDM_CHANNEL_OFFHOOK);
- event_id = FTDM_OOB_OFFHOOK;
- } else if (ftdmchan->type == FTDM_CHAN_TYPE_FXO) {
- event_id = FTDM_OOB_RING_START;
+ if (fchan->type == FTDM_CHAN_TYPE_FXS || (fchan->type == FTDM_CHAN_TYPE_EM && fchan->state != FTDM_CHANNEL_STATE_UP)) {
+ ftdm_set_flag_locked(fchan, FTDM_CHANNEL_OFFHOOK);
+ *event_id = FTDM_OOB_OFFHOOK;
+ } else if (fchan->type == FTDM_CHAN_TYPE_FXO) {
+ *event_id = FTDM_OOB_RING_START;
} else {
- event_id = FTDM_OOB_NOOP;
+ *event_id = FTDM_OOB_NOOP;
}
}
break;
case ZT_EVENT_ALARM:
{
- event_id = FTDM_OOB_ALARM_TRAP;
+ *event_id = FTDM_OOB_ALARM_TRAP;
}
break;
case ZT_EVENT_NOALARM:
{
- event_id = FTDM_OOB_ALARM_CLEAR;
+ *event_id = FTDM_OOB_ALARM_CLEAR;
}
break;
case ZT_EVENT_BITSCHANGED:
{
- event_id = FTDM_OOB_CAS_BITS_CHANGE;
+ *event_id = FTDM_OOB_CAS_BITS_CHANGE;
int bits = 0;
- int err = ioctl(ftdmchan->sockfd, codes.GETRXBITS, &bits);
+ int err = ioctl(fchan->sockfd, codes.GETRXBITS, &bits);
if (err) {
return FTDM_FAIL;
}
- ftdmchan->rx_cas_bits = bits;
+ fchan->rx_cas_bits = bits;
}
break;
default:
{
- ftdm_log_chan(ftdmchan, FTDM_LOG_WARNING, "Unhandled event %d for %d:%d\n", zt_event_id, span->span_id, i);
- event_id = FTDM_OOB_INVALID;
+ ftdm_log_chan(fchan, FTDM_LOG_WARNING, "Unhandled event %d\n", zt_event_id);
+ *event_id = FTDM_OOB_INVALID;
}
break;
}
+ return FTDM_SUCCESS;
+}
+
+/**
+ * \brief Retrieves an event from a ftdm channel
+ * \param ftdmchan Channel to retrieve event from
+ * \param event FreeTDM event to return
+ * \return Success or failure
+ */
+FIO_CHANNEL_NEXT_EVENT_FUNCTION(zt_channel_next_event)
+{
+ uint32_t event_id = FTDM_OOB_INVALID;
+ zt_event_t zt_event_id = 0;
+ ftdm_span_t *span = ftdmchan->span;
+
+ if (ftdm_test_flag(ftdmchan, FTDM_CHANNEL_EVENT)) {
+ ftdm_clear_flag(ftdmchan, FTDM_CHANNEL_EVENT);
+ }
+
+ if (ioctl(ftdmchan->sockfd, codes.GETEVENT, &zt_event_id) == -1) {
+ ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Failed retrieving event from channel: %s\n",
+ strerror(errno));
+ return FTDM_FAIL;
+ }
+
+ if ((zt_channel_process_event(ftdmchan, &event_id, zt_event_id)) != FTDM_SUCCESS) {
+ ftdm_log_chan_msg(ftdmchan, FTDM_LOG_ERROR, "Failed to process event from channel\n");
+ return FTDM_FAIL;
+ }
ftdmchan->last_event_time = 0;
span->event_header.e_type = FTDM_EVENT_OOB;
zt_event_t zt_event_id = 0;
for(i = 1; i <= span->chan_count; i++) {
- if (ftdm_test_flag(span->channels[i], FTDM_CHANNEL_EVENT)) {
- ftdm_clear_flag(span->channels[i], FTDM_CHANNEL_EVENT);
- if (ioctl(span->channels[i]->sockfd, codes.GETEVENT, &zt_event_id) == -1) {
- snprintf(span->last_error, sizeof(span->last_error), "%s", strerror(errno));
- return FTDM_FAIL;
- }
-
- switch(zt_event_id) {
- case ZT_EVENT_RINGEROFF:
- {
- return FTDM_FAIL;
- }
- break;
- case ZT_EVENT_RINGERON:
- {
- return FTDM_FAIL;
- }
- break;
- case ZT_EVENT_RINGBEGIN:
- {
- event_id = FTDM_OOB_RING_START;
- }
- break;
- case ZT_EVENT_ONHOOK:
- {
- event_id = FTDM_OOB_ONHOOK;
- }
- break;
- case ZT_EVENT_WINKFLASH:
- {
- if (span->channels[i]->state == FTDM_CHANNEL_STATE_DOWN || span->channels[i]->state == FTDM_CHANNEL_STATE_DIALING) {
- event_id = FTDM_OOB_WINK;
- } else {
- event_id = FTDM_OOB_FLASH;
- }
- }
- break;
- case ZT_EVENT_RINGOFFHOOK:
- {
- if (span->channels[i]->type == FTDM_CHAN_TYPE_FXS || (span->channels[i]->type == FTDM_CHAN_TYPE_EM && span->channels[i]->state != FTDM_CHANNEL_STATE_UP)) {
- ftdm_set_flag_locked(span->channels[i], FTDM_CHANNEL_OFFHOOK);
- event_id = FTDM_OOB_OFFHOOK;
- } else if (span->channels[i]->type == FTDM_CHAN_TYPE_FXO) {
- event_id = FTDM_OOB_RING_START;
- } else {
- event_id = FTDM_OOB_NOOP;
- }
- }
- break;
- case ZT_EVENT_ALARM:
- {
- event_id = FTDM_OOB_ALARM_TRAP;
- }
- break;
- case ZT_EVENT_NOALARM:
- {
- event_id = FTDM_OOB_ALARM_CLEAR;
- }
- break;
- case ZT_EVENT_BITSCHANGED:
- {
- event_id = FTDM_OOB_CAS_BITS_CHANGE;
- int bits = 0;
- int err = ioctl(span->channels[i]->sockfd, codes.GETRXBITS, &bits);
- if (err) {
- return FTDM_FAIL;
- }
- span->channels[i]->rx_cas_bits = bits;
- }
- break;
- default:
- {
- ftdm_log(FTDM_LOG_WARNING, "Unhandled event %d for %d:%d\n", zt_event_id, span->span_id, i);
- event_id = FTDM_OOB_INVALID;
- }
- break;
- }
+ ftdm_channel_t *fchan = span->channels[i];
+ if (ftdm_test_flag(fchan, FTDM_CHANNEL_EVENT)) {
+ ftdm_clear_flag(fchan, FTDM_CHANNEL_EVENT);
+ }
+ if (ioctl(fchan->sockfd, codes.GETEVENT, &zt_event_id) == -1) {
+ snprintf(span->last_error, sizeof(span->last_error), "%s", strerror(errno));
+ return FTDM_FAIL;
+ }
- span->channels[i]->last_event_time = 0;
- span->event_header.e_type = FTDM_EVENT_OOB;
- span->event_header.enum_id = event_id;
- span->event_header.channel = span->channels[i];
- *event = &span->event_header;
- return FTDM_SUCCESS;
+ if ((zt_channel_process_event(fchan, &event_id, zt_event_id)) != FTDM_SUCCESS) {
+ ftdm_log_chan_msg(fchan, FTDM_LOG_ERROR, "Failed to process event from channel\n");
+ return FTDM_FAIL;
}
+
+ fchan->last_event_time = 0;
+ span->event_header.e_type = FTDM_EVENT_OOB;
+ span->event_header.enum_id = event_id;
+ span->event_header.channel = fchan;
+ *event = &span->event_header;
+ return FTDM_SUCCESS;
}
return FTDM_FAIL;