indicate that we should try again, then return NULL instead of a "null frame".
This will prevent Asterisk from trying over and over again, and eventually
causing the system to crash. (issue #8285, john)
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.2@59357
65c4cc65-6c06-0410-ace0-
fbb531ad65f3
0, (struct sockaddr *)&sin, &len);
if (res < 0) {
- if (errno != EAGAIN)
- ast_log(LOG_WARNING, "RTP Read error: %s\n", strerror(errno));
if (errno == EBADF)
CRASH;
+ if (errno != EAGAIN) {
+ ast_log(LOG_WARNING, "RTP Read error: %s. Hanging up now.\n", strerror(errno));
+ return NULL;
+ }
return &null_frame;
}
rtpheader = (unsigned int *)(rtp->rawdata + AST_FRIENDLY_OFFSET);
if (res < 0) {
- if (errno != EAGAIN)
- ast_log(LOG_WARNING, "RTP Read error: %s\n", strerror(errno));
if (errno == EBADF)
CRASH;
+ if (errno != EAGAIN) {
+ ast_log(LOG_WARNING, "RTP Read error: %s. Hanging up now.\n", strerror(errno));
+ return NULL;
+ }
return &null_frame;
}
if (res < hdrlen) {