diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 50cf13fab092f9d74dab132427a4ea3c303b67b9..856fe24033ee178c74214b3e51f1c8cfd611ad3e 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -12121,10 +12121,11 @@ static int sipsock_read(int *id, int fd, short events, void *ignore) ast_log(LOG_WARNING, "Recv error: %s\n", strerror(errno)); return 1; } - if (option_debug && res == sizeof(req.data)) + if (option_debug && res == sizeof(req.data)) { ast_log(LOG_DEBUG, "Received packet exceeds buffer. Data is possibly lost\n"); - - req.data[res] = '\0'; + req.data[sizeof(req.data) - 1] = '\0'; + } else + req.data[res] = '\0'; req.len = res; if(sip_debug_test_addr(&sin)) /* Set the debug flag early on packet level */ ast_set_flag(&req, SIP_PKT_DEBUG);