aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/asterisk/Makefile12
-rw-r--r--net/asterisk/distinfo12
-rw-r--r--net/asterisk/files/codecnego-patch-Makefile35
-rw-r--r--net/asterisk/files/dtmf_debug.diff38
-rw-r--r--net/asterisk/files/nocodecnego-patch-Makefile38
-rw-r--r--net/asterisk/files/patch-Makefile.rules25
-rw-r--r--net/asterisk/files/patch-channels::Makefile13
-rw-r--r--net/asterisk/files/patch-configure29
-rw-r--r--net/asterisk/files/patch-main::Makefile20
-rw-r--r--net/asterisk/files/patch-suppress_log_dups.diff270
-rw-r--r--net/asterisk/files/rtp_force_dtmf-codecnego.diff64
-rw-r--r--net/asterisk/files/rtp_force_dtmf-nocodecnego.diff17
-rw-r--r--net/asterisk/pkg-plist18
-rw-r--r--net/asterisk10/Makefile12
-rw-r--r--net/asterisk10/distinfo12
-rw-r--r--net/asterisk10/files/codecnego-patch-Makefile35
-rw-r--r--net/asterisk10/files/dtmf_debug.diff38
-rw-r--r--net/asterisk10/files/nocodecnego-patch-Makefile38
-rw-r--r--net/asterisk10/files/patch-Makefile.rules25
-rw-r--r--net/asterisk10/files/patch-channels::Makefile13
-rw-r--r--net/asterisk10/files/patch-configure29
-rw-r--r--net/asterisk10/files/patch-main::Makefile20
-rw-r--r--net/asterisk10/files/patch-suppress_log_dups.diff270
-rw-r--r--net/asterisk10/files/rtp_force_dtmf-codecnego.diff64
-rw-r--r--net/asterisk10/files/rtp_force_dtmf-nocodecnego.diff17
-rw-r--r--net/asterisk10/pkg-plist18
-rw-r--r--net/asterisk14/Makefile12
-rw-r--r--net/asterisk14/distinfo12
-rw-r--r--net/asterisk14/files/codecnego-patch-Makefile35
-rw-r--r--net/asterisk14/files/dtmf_debug.diff38
-rw-r--r--net/asterisk14/files/nocodecnego-patch-Makefile38
-rw-r--r--net/asterisk14/files/patch-Makefile.rules25
-rw-r--r--net/asterisk14/files/patch-channels::Makefile13
-rw-r--r--net/asterisk14/files/patch-configure29
-rw-r--r--net/asterisk14/files/patch-main::Makefile20
-rw-r--r--net/asterisk14/files/patch-suppress_log_dups.diff270
-rw-r--r--net/asterisk14/files/rtp_force_dtmf-codecnego.diff64
-rw-r--r--net/asterisk14/files/rtp_force_dtmf-nocodecnego.diff17
-rw-r--r--net/asterisk14/pkg-plist18
39 files changed, 1254 insertions, 519 deletions
diff --git a/net/asterisk/Makefile b/net/asterisk/Makefile
index 035e291fa93c..90cbd55a5c21 100644
--- a/net/asterisk/Makefile
+++ b/net/asterisk/Makefile
@@ -6,8 +6,7 @@
#
PORTNAME= asterisk
-PORTVERSION= 1.4.26.2
-PORTREVISION= 1
+PORTVERSION= 1.4.29
CATEGORIES= net
MASTER_SITES= http://downloads.asterisk.org/pub/telephony/asterisk/ \
http://downloads.asterisk.org/pub/telephony/asterisk/old-releases/
@@ -32,14 +31,13 @@ CPPFLAGS= -I${LOCALBASE}/include -I${LOCALBASE}/include/openh323
USE_GMAKE= yes
USE_BISON= build
USE_RC_SUBR= asterisk.sh
-MAKE_ENV= PTHREAD_CFLAGS="${PTHREAD_CFLAGS}" \
- PTHREAD_LIBS="${PTHREAD_LIBS}" \
- MKDIR="${MKDIR}" \
+MAKE_ENV= MKDIR="${MKDIR}" \
PWLIBDIR=${LOCALBASE}/share/pwlib \
OPENH323DIR=${LOCALBASE}/share/openh323 \
OSVERSION=${OSVERSION} \
NOISY_BUILD=YES \
- ASTCFLAGS="${CFLAGS}"
+ ASTCFLAGS="${PTHREAD_CFLAGS} ${CFLAGS}" \
+ ASTLDFLAGS="${PTHREAD_LIBS} -L${LOCALBASE}/lib"
MAN8= asterisk.8 astgenkey.8 autosupport.8 safe_asterisk.8
CONFLICTS= asterisk*-1.2* asterisk*-1.6*
@@ -171,7 +169,7 @@ EXTRA_PATCHES+= ${PATCHDIR}/ilbc_enable.diff
.endif
.if defined(WITH_CODEC_PATCH)
-PATCHFILES= asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz
+PATCHFILES= asterisk-1.4.27-codec-negotiation-20091120.diff.gz
PATCH_SITES= http://b2bua.org/chrome/site/
EXTRA_PATCHES+= ${PATCHDIR}/codecnego-patch-Makefile
.else
diff --git a/net/asterisk/distinfo b/net/asterisk/distinfo
index 3efa703cbbc7..1c21b1a25ead 100644
--- a/net/asterisk/distinfo
+++ b/net/asterisk/distinfo
@@ -1,6 +1,6 @@
-MD5 (asterisk-1.4.26.2.tar.gz) = 58181c29d998f883f567dc9757a04167
-SHA256 (asterisk-1.4.26.2.tar.gz) = 384e080e359ae28ca9323800a3fa0586210342039b96ecbdced9ea285516efe9
-SIZE (asterisk-1.4.26.2.tar.gz) = 21436723
-MD5 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = ae433b0c9574e0616cf014703641f62a
-SHA256 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 65bd0d773a2ddc56bfa60a1bd9269eded2edf0062adf4f8afe393c6d41f27039
-SIZE (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 40621
+MD5 (asterisk-1.4.29.tar.gz) = b49d0a269e11b6e85c75edce577b5103
+SHA256 (asterisk-1.4.29.tar.gz) = ecb1202f50fc5d7738d1b5bf6451b28e356f3469266dd64bcd637be71f91bd09
+SIZE (asterisk-1.4.29.tar.gz) = 21534219
+MD5 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 4dedd23b3c9c00bcdcc69b8be878f15c
+SHA256 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 68f895de29f30296a47d32a5eaab8df367d92ae87b01ea9f2262556a1f1e5cbb
+SIZE (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 40455
diff --git a/net/asterisk/files/codecnego-patch-Makefile b/net/asterisk/files/codecnego-patch-Makefile
index e19ba9db1f69..e39dd6f62082 100644
--- a/net/asterisk/files/codecnego-patch-Makefile
+++ b/net/asterisk/files/codecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-10-20 14:49:16.000000000 -0700
-+++ Makefile 2009-10-20 14:49:55.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-11-20 17:48:05.000000000 +0200
++++ Makefile 2009-11-20 17:50:33.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,28 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
- rm -f build_tools/menuselect-deps
-
- datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+@@ -416,15 +418,15 @@
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +60,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +140,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +149,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +189,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -662,20 +656,23 @@
+@@ -670,20 +664,23 @@
echo "; Default: strict"; \
echo ";"; \
echo ";translation_algorithm = strict"; \
diff --git a/net/asterisk/files/dtmf_debug.diff b/net/asterisk/files/dtmf_debug.diff
index 968554880ac3..2a5b6bc9ea33 100644
--- a/net/asterisk/files/dtmf_debug.diff
+++ b/net/asterisk/files/dtmf_debug.diff
@@ -49,9 +49,9 @@
/*! \brief Set rtp timeout */
void ast_rtp_set_rtptimeout(struct ast_rtp *rtp, int timeout);
/*! \brief Set rtp hold timeout */
---- main/rtp.c.orig 2009-05-13 16:38:01.000000000 +0300
-+++ main/rtp.c 2009-05-26 12:52:30.000000000 +0300
-@@ -80,6 +80,7 @@
+--- main/rtp.c.orig 2009-11-20 17:51:49.000000000 +0200
++++ main/rtp.c 2009-11-20 17:53:11.000000000 +0200
+@@ -81,6 +81,7 @@
static int rtpstart; /*!< First port for RTP sessions (set in rtp.conf) */
static int rtpend; /*!< Last port for RTP sessions (set in rtp.conf) */
static int rtpdebug; /*!< Are we debugging? */
@@ -59,16 +59,16 @@
static int rtcpdebug; /*!< Are we debugging RTCP? */
static int rtcpstats; /*!< Are we debugging RTCP? */
static int rtcpinterval = RTCP_DEFAULT_INTERVALMS; /*!< Time between rtcp reports in millisecs */
-@@ -173,6 +174,8 @@
- struct ast_codec_pref pref;
+@@ -170,6 +171,8 @@
struct ast_rtp *bridged; /*!< Who we are Packet bridged to */
int set_marker_bit:1; /*!< Whether to set the marker bit or not */
-+ char chan_name[100];
-+ char chan_id[100];
+ unsigned int constantssrc:1;
++ char chan_name[100];
++ char chan_id[100];
};
/* Forward declarations */
-@@ -673,8 +676,8 @@
+@@ -676,8 +679,8 @@
struct ast_frame *f = NULL;
event = ntohl(*((unsigned int *)(data)));
event &= 0x001F;
@@ -79,7 +79,7 @@
if (event < 10) {
resp = '0' + event;
} else if (event < 11) {
-@@ -688,12 +691,25 @@
+@@ -691,12 +694,25 @@
}
if (rtp->resp && (rtp->resp != resp)) {
f = send_dtmf(rtp, AST_FRAME_DTMF_END);
@@ -105,7 +105,7 @@
/*!
* \brief Process RTP DTMF and events according to RFC 2833.
*
-@@ -1090,6 +1106,10 @@
+@@ -1101,6 +1117,10 @@
struct rtpPayloadType rtpPT;
int reconstruct = ntohl(rtpheader[0]);
@@ -116,7 +116,7 @@
/* Get fields from packet */
payload = (reconstruct & 0x7f0000) >> 16;
mark = (((reconstruct & 0x800000) >> 23) != 0);
-@@ -1097,10 +1117,6 @@
+@@ -1108,10 +1128,6 @@
/* Check what the payload value should be */
rtpPT = ast_rtp_lookup_pt(rtp, payload);
@@ -127,7 +127,7 @@
/* Otherwise adjust bridged payload to match */
bridged_payload = ast_rtp_lookup_code(bridged, rtpPT.isAstFormat, rtpPT.code);
-@@ -1293,11 +1309,12 @@
+@@ -1306,11 +1322,12 @@
/* This is special in-band data that's not one of our codecs */
if (rtpPT.code == AST_RTP_DTMF) {
/* It's special -- rfc2833 process it */
@@ -141,7 +141,7 @@
data = rtp->rawdata + AST_FRIENDLY_OFFSET + hdrlen;
event = ntohl(*((unsigned int *)(data)));
event >>= 24;
-@@ -1306,9 +1323,12 @@
+@@ -1319,9 +1336,12 @@
event_end >>= 24;
duration = ntohl(*((unsigned int *)(data)));
duration &= 0xFFFF;
@@ -155,7 +155,7 @@
} else if (rtpPT.code == AST_RTP_CISCO_DTMF) {
/* It's really special -- process it the Cisco way */
if (rtp->lastevent <= seqno || (rtp->lastevent >= 65530 && seqno <= 6)) {
-@@ -2272,8 +2292,9 @@
+@@ -2287,8 +2307,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%u: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -167,7 +167,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
/* Increment sequence number */
-@@ -2316,8 +2337,9 @@
+@@ -2331,8 +2352,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%d: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -179,7 +179,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), rtp->send_payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
-@@ -3609,6 +3631,16 @@
+@@ -3621,6 +3643,16 @@
return RESULT_SUCCESS;
}
@@ -196,7 +196,7 @@
static int rtp_do_debug(int fd, int argc, char *argv[])
{
if (argc != 2) {
-@@ -3669,6 +3701,7 @@
+@@ -3681,6 +3713,7 @@
if (argc != 3)
return RESULT_SHOWUSAGE;
rtpdebug = 0;
@@ -204,7 +204,7 @@
ast_cli(fd,"RTP Debugging Disabled\n");
return RESULT_SUCCESS;
}
-@@ -3729,7 +3762,7 @@
+@@ -3741,7 +3774,7 @@
}
static char debug_usage[] =
@@ -213,7 +213,7 @@
" Enable dumping of all RTP packets to and from host.\n";
static char no_debug_usage[] =
-@@ -3804,6 +3837,10 @@
+@@ -3816,6 +3849,10 @@
rtp_do_debug, "Enable RTP debugging",
debug_usage },
diff --git a/net/asterisk/files/nocodecnego-patch-Makefile b/net/asterisk/files/nocodecnego-patch-Makefile
index 78a3b3b45d23..c5df459f1b2c 100644
--- a/net/asterisk/files/nocodecnego-patch-Makefile
+++ b/net/asterisk/files/nocodecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-06-11 15:20:31.000000000 -0700
-+++ Makefile 2009-09-18 02:47:39.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-10-23 17:00:01.000000000 +0300
++++ Makefile 2009-11-23 16:44:36.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,37 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
+@@ -410,21 +412,21 @@
rm -f build_tools/menuselect-deps
datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+- if [ `$(ID) -u` = 0 ]; then \
+- CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
+- fi
++ #if [ `$(ID) -u` = 0 ]; then \
++ # CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
++ #fi
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +69,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +149,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +158,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +198,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -621,20 +615,23 @@
+@@ -629,20 +623,23 @@
echo ";astctlowner = root" ; \
echo ";astctlgroup = apache" ; \
echo ";astctl = asterisk.ctl" ; \
diff --git a/net/asterisk/files/patch-Makefile.rules b/net/asterisk/files/patch-Makefile.rules
index d129d9784b3c..f90430ec9ddd 100644
--- a/net/asterisk/files/patch-Makefile.rules
+++ b/net/asterisk/files/patch-Makefile.rules
@@ -1,21 +1,16 @@
-
-$FreeBSD$
-
---- Makefile.rules
-+++ Makefile.rules
-@@ -27,6 +27,7 @@
- CMD_PREFIX=
- endif
+--- Makefile.rules.orig 2009-09-28 22:09:25.000000000 +0300
++++ Makefile.rules 2009-11-23 16:15:23.000000000 +0200
+@@ -37,11 +37,13 @@
+
+ OPTIMIZE?=-O6
+ifneq ($(OSARCH),FreeBSD)
ifeq ($(findstring DONT_OPTIMIZE,$(MENUSELECT_CFLAGS)),)
- # More GSM codec optimization
- # Uncomment to enable MMXTM optimizations for x86 architecture CPU's
-@@ -37,6 +38,7 @@
- OPTIMIZE?=-O6
- ASTCFLAGS+=$(OPTIMIZE)
+ _ASTCFLAGS+=$(OPTIMIZE)
+ else
+ _ASTCFLAGS+=-O0
endif
+endif
- %.o: %.c
- $(ECHO_PREFIX) echo " [CC] $< -> $@"
+ # shortcuts for common combinations of flags; these must be recursively expanded so that
+ # per-target settings will be applied
diff --git a/net/asterisk/files/patch-channels::Makefile b/net/asterisk/files/patch-channels::Makefile
index fa5a90a988fa..bb9d20047899 100644
--- a/net/asterisk/files/patch-channels::Makefile
+++ b/net/asterisk/files/patch-channels::Makefile
@@ -1,8 +1,5 @@
-
-$FreeBSD$
-
---- channels/Makefile.orig
-+++ channels/Makefile
+--- channels/Makefile.orig 2009-07-21 16:04:44.000000000 +0300
++++ channels/Makefile 2009-11-20 18:05:45.000000000 +0200
@@ -32,9 +32,10 @@
endif
@@ -36,16 +33,16 @@ $FreeBSD$
endif
dist-clean::
-@@ -113,8 +115,12 @@
+@@ -111,8 +113,12 @@
else
chan_h323.so: chan_h323.o h323/libchanh323.a
$(ECHO_PREFIX) echo " [LD] $^ -> $@"
+ifeq ($(OSARCH),FreeBSD)
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) $(H323LDFLAGS) -o $@ $< h323/libchanh323.a $(H323LDLIBS) $(CHANH323LIB)
+else
- $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(_ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat $(ASTLDFLAGS)
endif
+endif
- chan_misdn.o: ASTCFLAGS+=-Imisdn
+ chan_misdn.o: _ASTCFLAGS+=-Imisdn
diff --git a/net/asterisk/files/patch-configure b/net/asterisk/files/patch-configure
index 0782453c279b..93432489e415 100644
--- a/net/asterisk/files/patch-configure
+++ b/net/asterisk/files/patch-configure
@@ -1,6 +1,9 @@
---- configure.orig 2009-04-27 22:29:46.000000000 +0300
-+++ configure 2009-05-26 12:59:22.000000000 +0300
-@@ -4064,8 +4064,6 @@
+
+$FreeBSD$
+
+--- configure.orig
++++ configure
+@@ -4308,8 +4308,6 @@
case "${host_os}" in
freebsd*)
ac_default_prefix=/usr/local
@@ -9,7 +12,7 @@
;;
darwin*)
-@@ -27145,7 +27143,7 @@
+@@ -16837,7 +16835,7 @@
fi
@@ -17,20 +20,4 @@
+ PLATFORM_OPENH323="h323_${OPENH323_SUFFIX}"
if test "${HAS_OPENH323:-unset}" != "unset"; then
- { $as_echo "$as_me:$LINENO: checking OpenH323 installation validity" >&5
-@@ -31624,6 +31622,7 @@
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
- $ac_includes_default
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- rm -f conftest.$ac_objext
-@@ -31665,6 +31664,7 @@
- cat confdefs.h >>conftest.$ac_ext
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- if { (ac_try="$ac_cpp conftest.$ac_ext"
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking OpenH323 installation validity" >&5
diff --git a/net/asterisk/files/patch-main::Makefile b/net/asterisk/files/patch-main::Makefile
index 418714ab7f21..a4758b78bdc9 100644
--- a/net/asterisk/files/patch-main::Makefile
+++ b/net/asterisk/files/patch-main::Makefile
@@ -1,13 +1,13 @@
---- main/Makefile.orig 2009-04-09 07:31:38.000000000 +0300
-+++ main/Makefile 2009-05-26 13:07:50.000000000 +0300
+--- main/Makefile.orig 2009-08-01 03:52:00.000000000 +0300
++++ main/Makefile 2009-11-20 18:09:06.000000000 +0200
@@ -92,8 +92,8 @@
- cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(ASTCFLAGS:-Werror=))" LDFLAGS="$(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
+ cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(_ASTCFLAGS:-Werror=)) $(ASTCFLAGS)" LDFLAGS="$(_ASTLDFLAGS) $(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
$(MAKE) -C editline libedit.a
-db1-ast/libdb1.a:
-- CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
+- _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
+#db1-ast/libdb1.a:
-+# CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
++# _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
ast_expr2.c ast_expr2.h:
bison -o $@ -d --name-prefix=ast_yy ast_expr2.y
@@ -22,15 +22,15 @@
mv $(ASTTOPDIR)/include/asterisk/build.h.tmp $(ASTTOPDIR)/include/asterisk/build.h ; \
fi
@rm -f $(ASTTOPDIR)/include/asterisk/build.h.tmp
- @$(CC) -c -o buildinfo.o $(ASTCFLAGS) buildinfo.c
+ @$(CC) -c -o buildinfo.o $(_ASTCFLAGS) buildinfo.c $(ASTCFLAGS)
- $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) -> $@"
+ $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) -> $@"
ifneq ($(findstring chan_h323,$(MENUSELECT_CHANNELS)),)
-- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
-+ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
+- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
else
-- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
-+ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
+- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
endif
clean::
diff --git a/net/asterisk/files/patch-suppress_log_dups.diff b/net/asterisk/files/patch-suppress_log_dups.diff
new file mode 100644
index 000000000000..115b69f21ca1
--- /dev/null
+++ b/net/asterisk/files/patch-suppress_log_dups.diff
@@ -0,0 +1,270 @@
+Index: main/logger.c
+===================================================================
+--- main/logger.c (revision 188505)
++++ main/logger.c (working copy)
+@@ -140,6 +140,17 @@
+ AST_THREADSTORAGE(log_buf, log_buf_init);
+ #define LOG_BUF_INIT_SIZE 128
+
++/*
++ * Storage for previous log message to prevent log storms
++ */
++static int stored_log_level;
++static int stored_log_dup_count = 0;
++static char *stored_log_msg = NULL;
++static const char *stored_log_file;
++static int stored_log_line;
++static const char *stored_log_function;
++static ast_mutex_t stored_log_msg_lock;
++
+ static int make_components(char *s, int lineno)
+ {
+ char *w;
+@@ -591,6 +602,8 @@
+ char tmp[256];
+ int res = 0;
+
++ ast_mutex_init(&stored_log_msg_lock);
++
+ /* auto rotate if sig SIGXFSZ comes a-knockin */
+ (void) signal(SIGXFSZ,(void *) handle_SIGXFSZ);
+
+@@ -655,14 +668,14 @@
+ return;
+ }
+
+-static void __attribute__((format(printf, 5, 0))) ast_log_vsyslog(int level, const char *file, int line, const char *function, const char *fmt, va_list args)
++static void ast_log_syslog(int level, const char *file, int line, const char *function, const char *msg)
+ {
+ char buf[BUFSIZ];
+ char *s;
+
+ if (level >= SYSLOG_NLEVELS) {
+ /* we are locked here, so cannot ast_log() */
+- fprintf(stderr, "ast_log_vsyslog called with bogus level: %d\n", level);
++ fprintf(stderr, "ast_log_syslog called with bogus level: %d\n", level);
+ return;
+ }
+ if (level == __LOG_VERBOSE) {
+@@ -676,27 +689,20 @@
+ levels[level], (long)GETTID(), file, line, function);
+ }
+ s = buf + strlen(buf);
+- vsnprintf(s, sizeof(buf) - strlen(buf), fmt, args);
++ snprintf(s, sizeof(buf) - strlen(buf), "%s", msg);
+ term_strip(s, s, strlen(s) + 1);
+ syslog(syslog_level_map[level], "%s", buf);
+ }
+
+-/*!
+- * \brief send log messages to syslog and/or the console
+- */
+-void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++static void __ast_log(int level, const char *file, int line, const char *function, char *msg, int msglen)
+ {
+ struct logchannel *chan;
+- struct ast_dynamic_str *buf;
+ time_t t;
+ struct tm tm;
+ char date[256];
++ char buf[2048];
++ int res;
+
+- va_list ap;
+-
+- if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
+- return;
+-
+ if (AST_LIST_EMPTY(&logchannels))
+ {
+ /*
+@@ -704,35 +710,12 @@
+ * so just log to stdout
+ */
+ if (level != __LOG_VERBOSE) {
+- int res;
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_filter_escapes(buf->str);
+- fputs(buf->str, stdout);
+- }
++ term_filter_escapes(msg);
++ fputs(msg, stdout);
+ }
+ return;
+ }
+
+- /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
+- are non-zero; LOG_DEBUG messages can still be displayed if option_debug
+- is zero, if option_verbose is non-zero (this allows for 'level zero'
+- LOG_DEBUG messages to be displayed, if the logmask on any channel
+- allows it)
+- */
+- if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
+- return;
+-
+- /* Ignore anything that never gets logged anywhere */
+- if (!(global_logmask & (1 << level)))
+- return;
+-
+- /* Ignore anything other than the currently debugged file if there is one */
+- if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
+- return;
+-
+ time(&t);
+ ast_localtime(&t, &tm, NULL);
+ strftime(date, sizeof(date), dateformat, &tm);
+@@ -740,13 +723,8 @@
+ AST_LIST_LOCK(&logchannels);
+
+ if (logfiles.event_log && level == __LOG_EVENT) {
+- va_start(ap, fmt);
+-
+- fprintf(eventlog, "%s asterisk[%ld]: ", date, (long)getpid());
+- vfprintf(eventlog, fmt, ap);
++ fprintf(eventlog, "%s asterisk[%ld]: %s", date, (long)getpid(), msg);
+ fflush(eventlog);
+-
+- va_end(ap);
+ AST_LIST_UNLOCK(&logchannels);
+ return;
+ }
+@@ -756,18 +734,15 @@
+ break;
+ /* Check syslog channels */
+ if (chan->type == LOGTYPE_SYSLOG && (chan->logmask & (1 << level))) {
+- va_start(ap, fmt);
+- ast_log_vsyslog(level, file, line, function, fmt, ap);
+- va_end(ap);
++ ast_log_syslog(level, file, line, function, msg);
+ /* Console channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->type == LOGTYPE_CONSOLE)) {
+ char linestr[128];
+ char tmp1[80], tmp2[80], tmp3[80], tmp4[80];
+
+ if (level != __LOG_VERBOSE) {
+- int res;
+ sprintf(linestr, "%d", line);
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld]: %s:%s %s: ",
+ date,
+ term_color(tmp1, levels[level], colors[level], 0, sizeof(tmp1)),
+@@ -776,23 +751,17 @@
+ term_color(tmp3, linestr, COLOR_BRWHITE, 0, sizeof(tmp3)),
+ term_color(tmp4, function, COLOR_BRWHITE, 0, sizeof(tmp4)));
+ /*filter to the console!*/
+- term_filter_escapes(buf->str);
+- ast_console_puts_mutable(buf->str);
+-
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED)
+- ast_console_puts_mutable(buf->str);
++ term_filter_escapes(buf);
++ ast_console_puts_mutable(buf);
++ ast_console_puts_mutable(msg);
+ }
+ /* File channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->fileptr)) {
+- int res;
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld] %s: ",
+ date, levels[level], (long)GETTID(), file);
+- res = fprintf(chan->fileptr, "%s", buf->str);
+- if (res <= 0 && !ast_strlen_zero(buf->str)) { /* Error, no characters printed */
++ res = fprintf(chan->fileptr, "%s", buf);
++ if (res <= 0 && !ast_strlen_zero(buf)) { /* Error, no characters printed */
+ fprintf(stderr,"**** Asterisk Logging Error: ***********\n");
+ if (errno == ENOMEM || errno == ENOSPC) {
+ fprintf(stderr, "Asterisk logging error: Out of disk space, can't log to log file %s\n", chan->filename);
+@@ -801,16 +770,10 @@
+ manager_event(EVENT_FLAG_SYSTEM, "LogChannel", "Channel: %s\r\nEnabled: No\r\nReason: %d - %s\r\n", chan->filename, errno, strerror(errno));
+ chan->disabled = 1;
+ } else {
+- int res;
+ /* No error message, continue printing */
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_strip(buf->str, buf->str, buf->len);
+- fputs(buf->str, chan->fileptr);
+- fflush(chan->fileptr);
+- }
++ term_strip(msg, msg, msglen);
++ fputs(msg, chan->fileptr);
++ fflush(chan->fileptr);
+ }
+ }
+ }
+@@ -825,6 +788,65 @@
+ }
+ }
+
++/*!
++ * \brief send log messages to syslog and/or the console
++ */
++void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++{
++ struct ast_dynamic_str *buf;
++ int res;
++ va_list ap;
++
++ if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
++ return;
++
++ va_start(ap, fmt);
++ res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
++ va_end(ap);
++ if (res == AST_DYNSTR_BUILD_FAILED)
++ return;
++
++ /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
++ are non-zero; LOG_DEBUG messages can still be displayed if option_debug
++ is zero, if option_verbose is non-zero (this allows for 'level zero'
++ LOG_DEBUG messages to be displayed, if the logmask on any channel
++ allows it)
++ */
++ if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
++ return;
++
++ /* Ignore anything that never gets logged anywhere */
++ if (!(global_logmask & (1 << level)))
++ return;
++
++ /* Ignore anything other than the currently debugged file if there is one */
++ if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
++ return;
++
++ ast_mutex_lock(&stored_log_msg_lock);
++ if (stored_log_msg == NULL || stored_log_level != level || strcmp(buf->str, stored_log_msg) != 0) {
++ if (stored_log_dup_count > 0) {
++ char buf2[1024];
++
++ snprintf(buf2, sizeof(buf2), "Last message repeated %d times\n", stored_log_dup_count);
++ __ast_log(stored_log_level, stored_log_file, stored_log_line, stored_log_function, buf2, strlen(buf2));
++ }
++ if (stored_log_msg != NULL)
++ ast_free(stored_log_msg);
++ stored_log_msg = ast_strdup(buf->str);
++ stored_log_level = level;
++ stored_log_dup_count = 0;
++ stored_log_file = file;
++ stored_log_line = line;
++ stored_log_function = function;
++ __ast_log(level, file, line, function, buf->str, buf->len);
++ }
++ else
++ ++stored_log_dup_count;
++
++ ast_mutex_unlock(&stored_log_msg_lock);
++}
++
+ void ast_backtrace(void)
+ {
+ #ifdef linux
diff --git a/net/asterisk/files/rtp_force_dtmf-codecnego.diff b/net/asterisk/files/rtp_force_dtmf-codecnego.diff
index 723bd8703c06..a670364ba603 100644
--- a/net/asterisk/files/rtp_force_dtmf-codecnego.diff
+++ b/net/asterisk/files/rtp_force_dtmf-codecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-03-12 17:37:00.000000000 +0200
-+++ channels/chan_sip.c 2008-03-12 18:17:33.000000000 +0200
-@@ -554,6 +554,9 @@
+--- channels/chan_sip.c.orig 2009-11-20 17:56:30.000000000 +0200
++++ channels/chan_sip.c 2009-11-20 17:59:43.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,37 +10,37 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -4983,6 +4986,8 @@
- int codec_index = 0;
- int codec_pt_order[256];
+@@ -5329,6 +5332,7 @@
+ int x;
+ int codec_index = 0;
+ int codec_pt_order[256];
++ int dtmf_present = 0;
-+ int dtmf_present = 0;
+ /* Host information */
+ struct ast_hostent audiohp;
+@@ -5600,12 +5604,21 @@
+ for (x = 0; x < codec_index; ++x) {
+ struct rtpPayloadType pt;
+ pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
++ if (pt.code == AST_RTP_DTMF)
++ dtmf_present = 1;
+ if (!pt.isAstFormat && !pt.code && p->vrtp)
+ pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
+ if (pt.isAstFormat)
+ ast_codec_pref_append(&p->formats, pt.code);
+ }
+ ast_codec_pref_remove2(&p->formats, ~p->usercapability);
++ if (!dtmf_present && global_force_dtmf_relay) {
++ newnoncodeccapability |= AST_RTP_DTMF;
++ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
++ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
++ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
++ }
+
- if (!p->rtp) {
- ast_log(LOG_ERROR, "Got SDP but have no RTP session allocated.\n");
- return -1;
-@@ -5408,12 +5413,20 @@
- for (x = 0; x < codec_index; ++x) {
- struct rtpPayloadType pt;
- pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
-+ if (pt.code == AST_RTP_DTMF)
-+ dtmf_present = 1;
- if (!pt.isAstFormat && !pt.code && p->vrtp)
- pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
- if (pt.isAstFormat)
- ast_codec_pref_append(&p->formats, pt.code);
- }
- ast_codec_pref_remove2(&p->formats, ~p->usercapability);
-+ if (!dtmf_present && global_force_dtmf_relay) {
-+ newnoncodeccapability |= AST_RTP_DTMF;
-+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
-+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
-+ }
-
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
-@@ -16845,6 +16858,9 @@
+@@ -18369,6 +18382,9 @@
global_matchexterniplocally = FALSE;
@@ -50,7 +50,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -16901,6 +16917,18 @@
+@@ -18431,6 +18447,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -67,7 +67,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-04-25 08:53:52.000000000 -0700
+++ configs/sip.conf.sample 2008-06-10 00:45:37.000000000 -0700
diff --git a/net/asterisk/files/rtp_force_dtmf-nocodecnego.diff b/net/asterisk/files/rtp_force_dtmf-nocodecnego.diff
index 9b1d521fa0e3..9dcb7d8b134f 100644
--- a/net/asterisk/files/rtp_force_dtmf-nocodecnego.diff
+++ b/net/asterisk/files/rtp_force_dtmf-nocodecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-09-09 00:10:10.000000000 +0300
-+++ channels/chan_sip.c 2008-12-12 17:02:05.000000000 +0200
-@@ -557,6 +557,9 @@
+--- channels/chan_sip.c.orig 2009-11-23 17:28:47.000000000 +0200
++++ channels/chan_sip.c 2009-11-23 17:29:29.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,21 +10,20 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -5504,6 +5507,13 @@
-
+@@ -5593,6 +5596,12 @@
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
+ /* Add telephone-event */
+ if (global_force_dtmf_relay && !(peernoncodeccapability & AST_RTP_DTMF)) {
+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ found_rtpmap_codecs[last_rtpmap_codec++] = global_force_dtmf_relay_pt;
+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
+ peernoncodeccapability |= AST_RTP_DTMF;
+ }
ast_rtp_get_current_formats(newvideortp, &vpeercapability, &vpeernoncodeccapability);
newjointcapability = p->capability & (peercapability | vpeercapability);
-@@ -17440,6 +17450,9 @@
+@@ -18366,6 +18375,9 @@
global_matchexterniplocally = FALSE;
@@ -34,7 +33,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -17496,6 +17509,18 @@
+@@ -18428,6 +18440,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -51,7 +50,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-08-16 01:33:42.000000000 +0300
+++ configs/sip.conf.sample 2008-12-12 17:03:11.000000000 +0200
diff --git a/net/asterisk/pkg-plist b/net/asterisk/pkg-plist
index 465dbb095d9d..fa747b6e8a6e 100644
--- a/net/asterisk/pkg-plist
+++ b/net/asterisk/pkg-plist
@@ -435,23 +435,22 @@ share/asterisk/agi-bin/agi-test.agi
share/asterisk/agi-bin/eagi-sphinx-test
share/asterisk/agi-bin/eagi-test
share/asterisk/agi-bin/jukebox.agi
-share/asterisk/firmware/iax/iaxy.bin
share/asterisk/images/asterisk-intro.jpg
share/asterisk/keys/freeworlddialup.pub
share/asterisk/keys/iaxtel.pub
-share/asterisk/moh/.asterisk-moh-freeplay-wav
-share/asterisk/moh/CHANGES-asterisk-moh-opsound-2.01
-share/asterisk/moh/CREDITS-asterisk-moh-opsound-2.01
-share/asterisk/moh/LICENSE-asterisk-moh-opsound-2.01
+share/asterisk/moh/.asterisk-moh-opsound-wav
+share/asterisk/moh/CHANGES-asterisk-moh-opsound-wav
+share/asterisk/moh/CREDITS-asterisk-moh-opsound-wav
+share/asterisk/moh/LICENSE-asterisk-moh-opsound-wav
share/asterisk/moh/macroform-cold_day.wav
share/asterisk/moh/macroform-robot_dity.wav
share/asterisk/moh/macroform-the_simplicity.wav
share/asterisk/moh/manolo_camp-morning_coffee.wav
share/asterisk/moh/reno_project-system.wav
-share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.15
-share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.15
-share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.15
-share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.15
+share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.17
+share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.17
+share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.17
+share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.17
share/asterisk/sounds/agent-alreadyon.gsm
share/asterisk/sounds/agent-incorrect.gsm
share/asterisk/sounds/agent-loggedoff.gsm
@@ -842,6 +841,7 @@ share/asterisk/sounds/vm-opts.gsm
share/asterisk/sounds/vm-opts-full.gsm
share/asterisk/sounds/vm-passchanged.gsm
share/asterisk/sounds/vm-password.gsm
+share/asterisk/sounds/vm-pls-try-again.gsm
share/asterisk/sounds/vm-press.gsm
share/asterisk/sounds/vm-prev.gsm
share/asterisk/sounds/vm-reachoper.gsm
diff --git a/net/asterisk10/Makefile b/net/asterisk10/Makefile
index 035e291fa93c..90cbd55a5c21 100644
--- a/net/asterisk10/Makefile
+++ b/net/asterisk10/Makefile
@@ -6,8 +6,7 @@
#
PORTNAME= asterisk
-PORTVERSION= 1.4.26.2
-PORTREVISION= 1
+PORTVERSION= 1.4.29
CATEGORIES= net
MASTER_SITES= http://downloads.asterisk.org/pub/telephony/asterisk/ \
http://downloads.asterisk.org/pub/telephony/asterisk/old-releases/
@@ -32,14 +31,13 @@ CPPFLAGS= -I${LOCALBASE}/include -I${LOCALBASE}/include/openh323
USE_GMAKE= yes
USE_BISON= build
USE_RC_SUBR= asterisk.sh
-MAKE_ENV= PTHREAD_CFLAGS="${PTHREAD_CFLAGS}" \
- PTHREAD_LIBS="${PTHREAD_LIBS}" \
- MKDIR="${MKDIR}" \
+MAKE_ENV= MKDIR="${MKDIR}" \
PWLIBDIR=${LOCALBASE}/share/pwlib \
OPENH323DIR=${LOCALBASE}/share/openh323 \
OSVERSION=${OSVERSION} \
NOISY_BUILD=YES \
- ASTCFLAGS="${CFLAGS}"
+ ASTCFLAGS="${PTHREAD_CFLAGS} ${CFLAGS}" \
+ ASTLDFLAGS="${PTHREAD_LIBS} -L${LOCALBASE}/lib"
MAN8= asterisk.8 astgenkey.8 autosupport.8 safe_asterisk.8
CONFLICTS= asterisk*-1.2* asterisk*-1.6*
@@ -171,7 +169,7 @@ EXTRA_PATCHES+= ${PATCHDIR}/ilbc_enable.diff
.endif
.if defined(WITH_CODEC_PATCH)
-PATCHFILES= asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz
+PATCHFILES= asterisk-1.4.27-codec-negotiation-20091120.diff.gz
PATCH_SITES= http://b2bua.org/chrome/site/
EXTRA_PATCHES+= ${PATCHDIR}/codecnego-patch-Makefile
.else
diff --git a/net/asterisk10/distinfo b/net/asterisk10/distinfo
index 3efa703cbbc7..1c21b1a25ead 100644
--- a/net/asterisk10/distinfo
+++ b/net/asterisk10/distinfo
@@ -1,6 +1,6 @@
-MD5 (asterisk-1.4.26.2.tar.gz) = 58181c29d998f883f567dc9757a04167
-SHA256 (asterisk-1.4.26.2.tar.gz) = 384e080e359ae28ca9323800a3fa0586210342039b96ecbdced9ea285516efe9
-SIZE (asterisk-1.4.26.2.tar.gz) = 21436723
-MD5 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = ae433b0c9574e0616cf014703641f62a
-SHA256 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 65bd0d773a2ddc56bfa60a1bd9269eded2edf0062adf4f8afe393c6d41f27039
-SIZE (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 40621
+MD5 (asterisk-1.4.29.tar.gz) = b49d0a269e11b6e85c75edce577b5103
+SHA256 (asterisk-1.4.29.tar.gz) = ecb1202f50fc5d7738d1b5bf6451b28e356f3469266dd64bcd637be71f91bd09
+SIZE (asterisk-1.4.29.tar.gz) = 21534219
+MD5 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 4dedd23b3c9c00bcdcc69b8be878f15c
+SHA256 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 68f895de29f30296a47d32a5eaab8df367d92ae87b01ea9f2262556a1f1e5cbb
+SIZE (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 40455
diff --git a/net/asterisk10/files/codecnego-patch-Makefile b/net/asterisk10/files/codecnego-patch-Makefile
index e19ba9db1f69..e39dd6f62082 100644
--- a/net/asterisk10/files/codecnego-patch-Makefile
+++ b/net/asterisk10/files/codecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-10-20 14:49:16.000000000 -0700
-+++ Makefile 2009-10-20 14:49:55.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-11-20 17:48:05.000000000 +0200
++++ Makefile 2009-11-20 17:50:33.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,28 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
- rm -f build_tools/menuselect-deps
-
- datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+@@ -416,15 +418,15 @@
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +60,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +140,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +149,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +189,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -662,20 +656,23 @@
+@@ -670,20 +664,23 @@
echo "; Default: strict"; \
echo ";"; \
echo ";translation_algorithm = strict"; \
diff --git a/net/asterisk10/files/dtmf_debug.diff b/net/asterisk10/files/dtmf_debug.diff
index 968554880ac3..2a5b6bc9ea33 100644
--- a/net/asterisk10/files/dtmf_debug.diff
+++ b/net/asterisk10/files/dtmf_debug.diff
@@ -49,9 +49,9 @@
/*! \brief Set rtp timeout */
void ast_rtp_set_rtptimeout(struct ast_rtp *rtp, int timeout);
/*! \brief Set rtp hold timeout */
---- main/rtp.c.orig 2009-05-13 16:38:01.000000000 +0300
-+++ main/rtp.c 2009-05-26 12:52:30.000000000 +0300
-@@ -80,6 +80,7 @@
+--- main/rtp.c.orig 2009-11-20 17:51:49.000000000 +0200
++++ main/rtp.c 2009-11-20 17:53:11.000000000 +0200
+@@ -81,6 +81,7 @@
static int rtpstart; /*!< First port for RTP sessions (set in rtp.conf) */
static int rtpend; /*!< Last port for RTP sessions (set in rtp.conf) */
static int rtpdebug; /*!< Are we debugging? */
@@ -59,16 +59,16 @@
static int rtcpdebug; /*!< Are we debugging RTCP? */
static int rtcpstats; /*!< Are we debugging RTCP? */
static int rtcpinterval = RTCP_DEFAULT_INTERVALMS; /*!< Time between rtcp reports in millisecs */
-@@ -173,6 +174,8 @@
- struct ast_codec_pref pref;
+@@ -170,6 +171,8 @@
struct ast_rtp *bridged; /*!< Who we are Packet bridged to */
int set_marker_bit:1; /*!< Whether to set the marker bit or not */
-+ char chan_name[100];
-+ char chan_id[100];
+ unsigned int constantssrc:1;
++ char chan_name[100];
++ char chan_id[100];
};
/* Forward declarations */
-@@ -673,8 +676,8 @@
+@@ -676,8 +679,8 @@
struct ast_frame *f = NULL;
event = ntohl(*((unsigned int *)(data)));
event &= 0x001F;
@@ -79,7 +79,7 @@
if (event < 10) {
resp = '0' + event;
} else if (event < 11) {
-@@ -688,12 +691,25 @@
+@@ -691,12 +694,25 @@
}
if (rtp->resp && (rtp->resp != resp)) {
f = send_dtmf(rtp, AST_FRAME_DTMF_END);
@@ -105,7 +105,7 @@
/*!
* \brief Process RTP DTMF and events according to RFC 2833.
*
-@@ -1090,6 +1106,10 @@
+@@ -1101,6 +1117,10 @@
struct rtpPayloadType rtpPT;
int reconstruct = ntohl(rtpheader[0]);
@@ -116,7 +116,7 @@
/* Get fields from packet */
payload = (reconstruct & 0x7f0000) >> 16;
mark = (((reconstruct & 0x800000) >> 23) != 0);
-@@ -1097,10 +1117,6 @@
+@@ -1108,10 +1128,6 @@
/* Check what the payload value should be */
rtpPT = ast_rtp_lookup_pt(rtp, payload);
@@ -127,7 +127,7 @@
/* Otherwise adjust bridged payload to match */
bridged_payload = ast_rtp_lookup_code(bridged, rtpPT.isAstFormat, rtpPT.code);
-@@ -1293,11 +1309,12 @@
+@@ -1306,11 +1322,12 @@
/* This is special in-band data that's not one of our codecs */
if (rtpPT.code == AST_RTP_DTMF) {
/* It's special -- rfc2833 process it */
@@ -141,7 +141,7 @@
data = rtp->rawdata + AST_FRIENDLY_OFFSET + hdrlen;
event = ntohl(*((unsigned int *)(data)));
event >>= 24;
-@@ -1306,9 +1323,12 @@
+@@ -1319,9 +1336,12 @@
event_end >>= 24;
duration = ntohl(*((unsigned int *)(data)));
duration &= 0xFFFF;
@@ -155,7 +155,7 @@
} else if (rtpPT.code == AST_RTP_CISCO_DTMF) {
/* It's really special -- process it the Cisco way */
if (rtp->lastevent <= seqno || (rtp->lastevent >= 65530 && seqno <= 6)) {
-@@ -2272,8 +2292,9 @@
+@@ -2287,8 +2307,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%u: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -167,7 +167,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
/* Increment sequence number */
-@@ -2316,8 +2337,9 @@
+@@ -2331,8 +2352,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%d: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -179,7 +179,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), rtp->send_payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
-@@ -3609,6 +3631,16 @@
+@@ -3621,6 +3643,16 @@
return RESULT_SUCCESS;
}
@@ -196,7 +196,7 @@
static int rtp_do_debug(int fd, int argc, char *argv[])
{
if (argc != 2) {
-@@ -3669,6 +3701,7 @@
+@@ -3681,6 +3713,7 @@
if (argc != 3)
return RESULT_SHOWUSAGE;
rtpdebug = 0;
@@ -204,7 +204,7 @@
ast_cli(fd,"RTP Debugging Disabled\n");
return RESULT_SUCCESS;
}
-@@ -3729,7 +3762,7 @@
+@@ -3741,7 +3774,7 @@
}
static char debug_usage[] =
@@ -213,7 +213,7 @@
" Enable dumping of all RTP packets to and from host.\n";
static char no_debug_usage[] =
-@@ -3804,6 +3837,10 @@
+@@ -3816,6 +3849,10 @@
rtp_do_debug, "Enable RTP debugging",
debug_usage },
diff --git a/net/asterisk10/files/nocodecnego-patch-Makefile b/net/asterisk10/files/nocodecnego-patch-Makefile
index 78a3b3b45d23..c5df459f1b2c 100644
--- a/net/asterisk10/files/nocodecnego-patch-Makefile
+++ b/net/asterisk10/files/nocodecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-06-11 15:20:31.000000000 -0700
-+++ Makefile 2009-09-18 02:47:39.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-10-23 17:00:01.000000000 +0300
++++ Makefile 2009-11-23 16:44:36.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,37 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
+@@ -410,21 +412,21 @@
rm -f build_tools/menuselect-deps
datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+- if [ `$(ID) -u` = 0 ]; then \
+- CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
+- fi
++ #if [ `$(ID) -u` = 0 ]; then \
++ # CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
++ #fi
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +69,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +149,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +158,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +198,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -621,20 +615,23 @@
+@@ -629,20 +623,23 @@
echo ";astctlowner = root" ; \
echo ";astctlgroup = apache" ; \
echo ";astctl = asterisk.ctl" ; \
diff --git a/net/asterisk10/files/patch-Makefile.rules b/net/asterisk10/files/patch-Makefile.rules
index d129d9784b3c..f90430ec9ddd 100644
--- a/net/asterisk10/files/patch-Makefile.rules
+++ b/net/asterisk10/files/patch-Makefile.rules
@@ -1,21 +1,16 @@
-
-$FreeBSD$
-
---- Makefile.rules
-+++ Makefile.rules
-@@ -27,6 +27,7 @@
- CMD_PREFIX=
- endif
+--- Makefile.rules.orig 2009-09-28 22:09:25.000000000 +0300
++++ Makefile.rules 2009-11-23 16:15:23.000000000 +0200
+@@ -37,11 +37,13 @@
+
+ OPTIMIZE?=-O6
+ifneq ($(OSARCH),FreeBSD)
ifeq ($(findstring DONT_OPTIMIZE,$(MENUSELECT_CFLAGS)),)
- # More GSM codec optimization
- # Uncomment to enable MMXTM optimizations for x86 architecture CPU's
-@@ -37,6 +38,7 @@
- OPTIMIZE?=-O6
- ASTCFLAGS+=$(OPTIMIZE)
+ _ASTCFLAGS+=$(OPTIMIZE)
+ else
+ _ASTCFLAGS+=-O0
endif
+endif
- %.o: %.c
- $(ECHO_PREFIX) echo " [CC] $< -> $@"
+ # shortcuts for common combinations of flags; these must be recursively expanded so that
+ # per-target settings will be applied
diff --git a/net/asterisk10/files/patch-channels::Makefile b/net/asterisk10/files/patch-channels::Makefile
index fa5a90a988fa..bb9d20047899 100644
--- a/net/asterisk10/files/patch-channels::Makefile
+++ b/net/asterisk10/files/patch-channels::Makefile
@@ -1,8 +1,5 @@
-
-$FreeBSD$
-
---- channels/Makefile.orig
-+++ channels/Makefile
+--- channels/Makefile.orig 2009-07-21 16:04:44.000000000 +0300
++++ channels/Makefile 2009-11-20 18:05:45.000000000 +0200
@@ -32,9 +32,10 @@
endif
@@ -36,16 +33,16 @@ $FreeBSD$
endif
dist-clean::
-@@ -113,8 +115,12 @@
+@@ -111,8 +113,12 @@
else
chan_h323.so: chan_h323.o h323/libchanh323.a
$(ECHO_PREFIX) echo " [LD] $^ -> $@"
+ifeq ($(OSARCH),FreeBSD)
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) $(H323LDFLAGS) -o $@ $< h323/libchanh323.a $(H323LDLIBS) $(CHANH323LIB)
+else
- $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(_ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat $(ASTLDFLAGS)
endif
+endif
- chan_misdn.o: ASTCFLAGS+=-Imisdn
+ chan_misdn.o: _ASTCFLAGS+=-Imisdn
diff --git a/net/asterisk10/files/patch-configure b/net/asterisk10/files/patch-configure
index 0782453c279b..93432489e415 100644
--- a/net/asterisk10/files/patch-configure
+++ b/net/asterisk10/files/patch-configure
@@ -1,6 +1,9 @@
---- configure.orig 2009-04-27 22:29:46.000000000 +0300
-+++ configure 2009-05-26 12:59:22.000000000 +0300
-@@ -4064,8 +4064,6 @@
+
+$FreeBSD$
+
+--- configure.orig
++++ configure
+@@ -4308,8 +4308,6 @@
case "${host_os}" in
freebsd*)
ac_default_prefix=/usr/local
@@ -9,7 +12,7 @@
;;
darwin*)
-@@ -27145,7 +27143,7 @@
+@@ -16837,7 +16835,7 @@
fi
@@ -17,20 +20,4 @@
+ PLATFORM_OPENH323="h323_${OPENH323_SUFFIX}"
if test "${HAS_OPENH323:-unset}" != "unset"; then
- { $as_echo "$as_me:$LINENO: checking OpenH323 installation validity" >&5
-@@ -31624,6 +31622,7 @@
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
- $ac_includes_default
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- rm -f conftest.$ac_objext
-@@ -31665,6 +31664,7 @@
- cat confdefs.h >>conftest.$ac_ext
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- if { (ac_try="$ac_cpp conftest.$ac_ext"
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking OpenH323 installation validity" >&5
diff --git a/net/asterisk10/files/patch-main::Makefile b/net/asterisk10/files/patch-main::Makefile
index 418714ab7f21..a4758b78bdc9 100644
--- a/net/asterisk10/files/patch-main::Makefile
+++ b/net/asterisk10/files/patch-main::Makefile
@@ -1,13 +1,13 @@
---- main/Makefile.orig 2009-04-09 07:31:38.000000000 +0300
-+++ main/Makefile 2009-05-26 13:07:50.000000000 +0300
+--- main/Makefile.orig 2009-08-01 03:52:00.000000000 +0300
++++ main/Makefile 2009-11-20 18:09:06.000000000 +0200
@@ -92,8 +92,8 @@
- cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(ASTCFLAGS:-Werror=))" LDFLAGS="$(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
+ cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(_ASTCFLAGS:-Werror=)) $(ASTCFLAGS)" LDFLAGS="$(_ASTLDFLAGS) $(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
$(MAKE) -C editline libedit.a
-db1-ast/libdb1.a:
-- CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
+- _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
+#db1-ast/libdb1.a:
-+# CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
++# _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
ast_expr2.c ast_expr2.h:
bison -o $@ -d --name-prefix=ast_yy ast_expr2.y
@@ -22,15 +22,15 @@
mv $(ASTTOPDIR)/include/asterisk/build.h.tmp $(ASTTOPDIR)/include/asterisk/build.h ; \
fi
@rm -f $(ASTTOPDIR)/include/asterisk/build.h.tmp
- @$(CC) -c -o buildinfo.o $(ASTCFLAGS) buildinfo.c
+ @$(CC) -c -o buildinfo.o $(_ASTCFLAGS) buildinfo.c $(ASTCFLAGS)
- $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) -> $@"
+ $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) -> $@"
ifneq ($(findstring chan_h323,$(MENUSELECT_CHANNELS)),)
-- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
-+ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
+- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
else
-- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
-+ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
+- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
endif
clean::
diff --git a/net/asterisk10/files/patch-suppress_log_dups.diff b/net/asterisk10/files/patch-suppress_log_dups.diff
new file mode 100644
index 000000000000..115b69f21ca1
--- /dev/null
+++ b/net/asterisk10/files/patch-suppress_log_dups.diff
@@ -0,0 +1,270 @@
+Index: main/logger.c
+===================================================================
+--- main/logger.c (revision 188505)
++++ main/logger.c (working copy)
+@@ -140,6 +140,17 @@
+ AST_THREADSTORAGE(log_buf, log_buf_init);
+ #define LOG_BUF_INIT_SIZE 128
+
++/*
++ * Storage for previous log message to prevent log storms
++ */
++static int stored_log_level;
++static int stored_log_dup_count = 0;
++static char *stored_log_msg = NULL;
++static const char *stored_log_file;
++static int stored_log_line;
++static const char *stored_log_function;
++static ast_mutex_t stored_log_msg_lock;
++
+ static int make_components(char *s, int lineno)
+ {
+ char *w;
+@@ -591,6 +602,8 @@
+ char tmp[256];
+ int res = 0;
+
++ ast_mutex_init(&stored_log_msg_lock);
++
+ /* auto rotate if sig SIGXFSZ comes a-knockin */
+ (void) signal(SIGXFSZ,(void *) handle_SIGXFSZ);
+
+@@ -655,14 +668,14 @@
+ return;
+ }
+
+-static void __attribute__((format(printf, 5, 0))) ast_log_vsyslog(int level, const char *file, int line, const char *function, const char *fmt, va_list args)
++static void ast_log_syslog(int level, const char *file, int line, const char *function, const char *msg)
+ {
+ char buf[BUFSIZ];
+ char *s;
+
+ if (level >= SYSLOG_NLEVELS) {
+ /* we are locked here, so cannot ast_log() */
+- fprintf(stderr, "ast_log_vsyslog called with bogus level: %d\n", level);
++ fprintf(stderr, "ast_log_syslog called with bogus level: %d\n", level);
+ return;
+ }
+ if (level == __LOG_VERBOSE) {
+@@ -676,27 +689,20 @@
+ levels[level], (long)GETTID(), file, line, function);
+ }
+ s = buf + strlen(buf);
+- vsnprintf(s, sizeof(buf) - strlen(buf), fmt, args);
++ snprintf(s, sizeof(buf) - strlen(buf), "%s", msg);
+ term_strip(s, s, strlen(s) + 1);
+ syslog(syslog_level_map[level], "%s", buf);
+ }
+
+-/*!
+- * \brief send log messages to syslog and/or the console
+- */
+-void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++static void __ast_log(int level, const char *file, int line, const char *function, char *msg, int msglen)
+ {
+ struct logchannel *chan;
+- struct ast_dynamic_str *buf;
+ time_t t;
+ struct tm tm;
+ char date[256];
++ char buf[2048];
++ int res;
+
+- va_list ap;
+-
+- if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
+- return;
+-
+ if (AST_LIST_EMPTY(&logchannels))
+ {
+ /*
+@@ -704,35 +710,12 @@
+ * so just log to stdout
+ */
+ if (level != __LOG_VERBOSE) {
+- int res;
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_filter_escapes(buf->str);
+- fputs(buf->str, stdout);
+- }
++ term_filter_escapes(msg);
++ fputs(msg, stdout);
+ }
+ return;
+ }
+
+- /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
+- are non-zero; LOG_DEBUG messages can still be displayed if option_debug
+- is zero, if option_verbose is non-zero (this allows for 'level zero'
+- LOG_DEBUG messages to be displayed, if the logmask on any channel
+- allows it)
+- */
+- if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
+- return;
+-
+- /* Ignore anything that never gets logged anywhere */
+- if (!(global_logmask & (1 << level)))
+- return;
+-
+- /* Ignore anything other than the currently debugged file if there is one */
+- if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
+- return;
+-
+ time(&t);
+ ast_localtime(&t, &tm, NULL);
+ strftime(date, sizeof(date), dateformat, &tm);
+@@ -740,13 +723,8 @@
+ AST_LIST_LOCK(&logchannels);
+
+ if (logfiles.event_log && level == __LOG_EVENT) {
+- va_start(ap, fmt);
+-
+- fprintf(eventlog, "%s asterisk[%ld]: ", date, (long)getpid());
+- vfprintf(eventlog, fmt, ap);
++ fprintf(eventlog, "%s asterisk[%ld]: %s", date, (long)getpid(), msg);
+ fflush(eventlog);
+-
+- va_end(ap);
+ AST_LIST_UNLOCK(&logchannels);
+ return;
+ }
+@@ -756,18 +734,15 @@
+ break;
+ /* Check syslog channels */
+ if (chan->type == LOGTYPE_SYSLOG && (chan->logmask & (1 << level))) {
+- va_start(ap, fmt);
+- ast_log_vsyslog(level, file, line, function, fmt, ap);
+- va_end(ap);
++ ast_log_syslog(level, file, line, function, msg);
+ /* Console channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->type == LOGTYPE_CONSOLE)) {
+ char linestr[128];
+ char tmp1[80], tmp2[80], tmp3[80], tmp4[80];
+
+ if (level != __LOG_VERBOSE) {
+- int res;
+ sprintf(linestr, "%d", line);
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld]: %s:%s %s: ",
+ date,
+ term_color(tmp1, levels[level], colors[level], 0, sizeof(tmp1)),
+@@ -776,23 +751,17 @@
+ term_color(tmp3, linestr, COLOR_BRWHITE, 0, sizeof(tmp3)),
+ term_color(tmp4, function, COLOR_BRWHITE, 0, sizeof(tmp4)));
+ /*filter to the console!*/
+- term_filter_escapes(buf->str);
+- ast_console_puts_mutable(buf->str);
+-
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED)
+- ast_console_puts_mutable(buf->str);
++ term_filter_escapes(buf);
++ ast_console_puts_mutable(buf);
++ ast_console_puts_mutable(msg);
+ }
+ /* File channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->fileptr)) {
+- int res;
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld] %s: ",
+ date, levels[level], (long)GETTID(), file);
+- res = fprintf(chan->fileptr, "%s", buf->str);
+- if (res <= 0 && !ast_strlen_zero(buf->str)) { /* Error, no characters printed */
++ res = fprintf(chan->fileptr, "%s", buf);
++ if (res <= 0 && !ast_strlen_zero(buf)) { /* Error, no characters printed */
+ fprintf(stderr,"**** Asterisk Logging Error: ***********\n");
+ if (errno == ENOMEM || errno == ENOSPC) {
+ fprintf(stderr, "Asterisk logging error: Out of disk space, can't log to log file %s\n", chan->filename);
+@@ -801,16 +770,10 @@
+ manager_event(EVENT_FLAG_SYSTEM, "LogChannel", "Channel: %s\r\nEnabled: No\r\nReason: %d - %s\r\n", chan->filename, errno, strerror(errno));
+ chan->disabled = 1;
+ } else {
+- int res;
+ /* No error message, continue printing */
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_strip(buf->str, buf->str, buf->len);
+- fputs(buf->str, chan->fileptr);
+- fflush(chan->fileptr);
+- }
++ term_strip(msg, msg, msglen);
++ fputs(msg, chan->fileptr);
++ fflush(chan->fileptr);
+ }
+ }
+ }
+@@ -825,6 +788,65 @@
+ }
+ }
+
++/*!
++ * \brief send log messages to syslog and/or the console
++ */
++void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++{
++ struct ast_dynamic_str *buf;
++ int res;
++ va_list ap;
++
++ if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
++ return;
++
++ va_start(ap, fmt);
++ res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
++ va_end(ap);
++ if (res == AST_DYNSTR_BUILD_FAILED)
++ return;
++
++ /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
++ are non-zero; LOG_DEBUG messages can still be displayed if option_debug
++ is zero, if option_verbose is non-zero (this allows for 'level zero'
++ LOG_DEBUG messages to be displayed, if the logmask on any channel
++ allows it)
++ */
++ if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
++ return;
++
++ /* Ignore anything that never gets logged anywhere */
++ if (!(global_logmask & (1 << level)))
++ return;
++
++ /* Ignore anything other than the currently debugged file if there is one */
++ if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
++ return;
++
++ ast_mutex_lock(&stored_log_msg_lock);
++ if (stored_log_msg == NULL || stored_log_level != level || strcmp(buf->str, stored_log_msg) != 0) {
++ if (stored_log_dup_count > 0) {
++ char buf2[1024];
++
++ snprintf(buf2, sizeof(buf2), "Last message repeated %d times\n", stored_log_dup_count);
++ __ast_log(stored_log_level, stored_log_file, stored_log_line, stored_log_function, buf2, strlen(buf2));
++ }
++ if (stored_log_msg != NULL)
++ ast_free(stored_log_msg);
++ stored_log_msg = ast_strdup(buf->str);
++ stored_log_level = level;
++ stored_log_dup_count = 0;
++ stored_log_file = file;
++ stored_log_line = line;
++ stored_log_function = function;
++ __ast_log(level, file, line, function, buf->str, buf->len);
++ }
++ else
++ ++stored_log_dup_count;
++
++ ast_mutex_unlock(&stored_log_msg_lock);
++}
++
+ void ast_backtrace(void)
+ {
+ #ifdef linux
diff --git a/net/asterisk10/files/rtp_force_dtmf-codecnego.diff b/net/asterisk10/files/rtp_force_dtmf-codecnego.diff
index 723bd8703c06..a670364ba603 100644
--- a/net/asterisk10/files/rtp_force_dtmf-codecnego.diff
+++ b/net/asterisk10/files/rtp_force_dtmf-codecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-03-12 17:37:00.000000000 +0200
-+++ channels/chan_sip.c 2008-03-12 18:17:33.000000000 +0200
-@@ -554,6 +554,9 @@
+--- channels/chan_sip.c.orig 2009-11-20 17:56:30.000000000 +0200
++++ channels/chan_sip.c 2009-11-20 17:59:43.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,37 +10,37 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -4983,6 +4986,8 @@
- int codec_index = 0;
- int codec_pt_order[256];
+@@ -5329,6 +5332,7 @@
+ int x;
+ int codec_index = 0;
+ int codec_pt_order[256];
++ int dtmf_present = 0;
-+ int dtmf_present = 0;
+ /* Host information */
+ struct ast_hostent audiohp;
+@@ -5600,12 +5604,21 @@
+ for (x = 0; x < codec_index; ++x) {
+ struct rtpPayloadType pt;
+ pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
++ if (pt.code == AST_RTP_DTMF)
++ dtmf_present = 1;
+ if (!pt.isAstFormat && !pt.code && p->vrtp)
+ pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
+ if (pt.isAstFormat)
+ ast_codec_pref_append(&p->formats, pt.code);
+ }
+ ast_codec_pref_remove2(&p->formats, ~p->usercapability);
++ if (!dtmf_present && global_force_dtmf_relay) {
++ newnoncodeccapability |= AST_RTP_DTMF;
++ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
++ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
++ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
++ }
+
- if (!p->rtp) {
- ast_log(LOG_ERROR, "Got SDP but have no RTP session allocated.\n");
- return -1;
-@@ -5408,12 +5413,20 @@
- for (x = 0; x < codec_index; ++x) {
- struct rtpPayloadType pt;
- pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
-+ if (pt.code == AST_RTP_DTMF)
-+ dtmf_present = 1;
- if (!pt.isAstFormat && !pt.code && p->vrtp)
- pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
- if (pt.isAstFormat)
- ast_codec_pref_append(&p->formats, pt.code);
- }
- ast_codec_pref_remove2(&p->formats, ~p->usercapability);
-+ if (!dtmf_present && global_force_dtmf_relay) {
-+ newnoncodeccapability |= AST_RTP_DTMF;
-+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
-+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
-+ }
-
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
-@@ -16845,6 +16858,9 @@
+@@ -18369,6 +18382,9 @@
global_matchexterniplocally = FALSE;
@@ -50,7 +50,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -16901,6 +16917,18 @@
+@@ -18431,6 +18447,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -67,7 +67,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-04-25 08:53:52.000000000 -0700
+++ configs/sip.conf.sample 2008-06-10 00:45:37.000000000 -0700
diff --git a/net/asterisk10/files/rtp_force_dtmf-nocodecnego.diff b/net/asterisk10/files/rtp_force_dtmf-nocodecnego.diff
index 9b1d521fa0e3..9dcb7d8b134f 100644
--- a/net/asterisk10/files/rtp_force_dtmf-nocodecnego.diff
+++ b/net/asterisk10/files/rtp_force_dtmf-nocodecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-09-09 00:10:10.000000000 +0300
-+++ channels/chan_sip.c 2008-12-12 17:02:05.000000000 +0200
-@@ -557,6 +557,9 @@
+--- channels/chan_sip.c.orig 2009-11-23 17:28:47.000000000 +0200
++++ channels/chan_sip.c 2009-11-23 17:29:29.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,21 +10,20 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -5504,6 +5507,13 @@
-
+@@ -5593,6 +5596,12 @@
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
+ /* Add telephone-event */
+ if (global_force_dtmf_relay && !(peernoncodeccapability & AST_RTP_DTMF)) {
+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ found_rtpmap_codecs[last_rtpmap_codec++] = global_force_dtmf_relay_pt;
+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
+ peernoncodeccapability |= AST_RTP_DTMF;
+ }
ast_rtp_get_current_formats(newvideortp, &vpeercapability, &vpeernoncodeccapability);
newjointcapability = p->capability & (peercapability | vpeercapability);
-@@ -17440,6 +17450,9 @@
+@@ -18366,6 +18375,9 @@
global_matchexterniplocally = FALSE;
@@ -34,7 +33,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -17496,6 +17509,18 @@
+@@ -18428,6 +18440,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -51,7 +50,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-08-16 01:33:42.000000000 +0300
+++ configs/sip.conf.sample 2008-12-12 17:03:11.000000000 +0200
diff --git a/net/asterisk10/pkg-plist b/net/asterisk10/pkg-plist
index 465dbb095d9d..fa747b6e8a6e 100644
--- a/net/asterisk10/pkg-plist
+++ b/net/asterisk10/pkg-plist
@@ -435,23 +435,22 @@ share/asterisk/agi-bin/agi-test.agi
share/asterisk/agi-bin/eagi-sphinx-test
share/asterisk/agi-bin/eagi-test
share/asterisk/agi-bin/jukebox.agi
-share/asterisk/firmware/iax/iaxy.bin
share/asterisk/images/asterisk-intro.jpg
share/asterisk/keys/freeworlddialup.pub
share/asterisk/keys/iaxtel.pub
-share/asterisk/moh/.asterisk-moh-freeplay-wav
-share/asterisk/moh/CHANGES-asterisk-moh-opsound-2.01
-share/asterisk/moh/CREDITS-asterisk-moh-opsound-2.01
-share/asterisk/moh/LICENSE-asterisk-moh-opsound-2.01
+share/asterisk/moh/.asterisk-moh-opsound-wav
+share/asterisk/moh/CHANGES-asterisk-moh-opsound-wav
+share/asterisk/moh/CREDITS-asterisk-moh-opsound-wav
+share/asterisk/moh/LICENSE-asterisk-moh-opsound-wav
share/asterisk/moh/macroform-cold_day.wav
share/asterisk/moh/macroform-robot_dity.wav
share/asterisk/moh/macroform-the_simplicity.wav
share/asterisk/moh/manolo_camp-morning_coffee.wav
share/asterisk/moh/reno_project-system.wav
-share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.15
-share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.15
-share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.15
-share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.15
+share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.17
+share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.17
+share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.17
+share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.17
share/asterisk/sounds/agent-alreadyon.gsm
share/asterisk/sounds/agent-incorrect.gsm
share/asterisk/sounds/agent-loggedoff.gsm
@@ -842,6 +841,7 @@ share/asterisk/sounds/vm-opts.gsm
share/asterisk/sounds/vm-opts-full.gsm
share/asterisk/sounds/vm-passchanged.gsm
share/asterisk/sounds/vm-password.gsm
+share/asterisk/sounds/vm-pls-try-again.gsm
share/asterisk/sounds/vm-press.gsm
share/asterisk/sounds/vm-prev.gsm
share/asterisk/sounds/vm-reachoper.gsm
diff --git a/net/asterisk14/Makefile b/net/asterisk14/Makefile
index 035e291fa93c..90cbd55a5c21 100644
--- a/net/asterisk14/Makefile
+++ b/net/asterisk14/Makefile
@@ -6,8 +6,7 @@
#
PORTNAME= asterisk
-PORTVERSION= 1.4.26.2
-PORTREVISION= 1
+PORTVERSION= 1.4.29
CATEGORIES= net
MASTER_SITES= http://downloads.asterisk.org/pub/telephony/asterisk/ \
http://downloads.asterisk.org/pub/telephony/asterisk/old-releases/
@@ -32,14 +31,13 @@ CPPFLAGS= -I${LOCALBASE}/include -I${LOCALBASE}/include/openh323
USE_GMAKE= yes
USE_BISON= build
USE_RC_SUBR= asterisk.sh
-MAKE_ENV= PTHREAD_CFLAGS="${PTHREAD_CFLAGS}" \
- PTHREAD_LIBS="${PTHREAD_LIBS}" \
- MKDIR="${MKDIR}" \
+MAKE_ENV= MKDIR="${MKDIR}" \
PWLIBDIR=${LOCALBASE}/share/pwlib \
OPENH323DIR=${LOCALBASE}/share/openh323 \
OSVERSION=${OSVERSION} \
NOISY_BUILD=YES \
- ASTCFLAGS="${CFLAGS}"
+ ASTCFLAGS="${PTHREAD_CFLAGS} ${CFLAGS}" \
+ ASTLDFLAGS="${PTHREAD_LIBS} -L${LOCALBASE}/lib"
MAN8= asterisk.8 astgenkey.8 autosupport.8 safe_asterisk.8
CONFLICTS= asterisk*-1.2* asterisk*-1.6*
@@ -171,7 +169,7 @@ EXTRA_PATCHES+= ${PATCHDIR}/ilbc_enable.diff
.endif
.if defined(WITH_CODEC_PATCH)
-PATCHFILES= asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz
+PATCHFILES= asterisk-1.4.27-codec-negotiation-20091120.diff.gz
PATCH_SITES= http://b2bua.org/chrome/site/
EXTRA_PATCHES+= ${PATCHDIR}/codecnego-patch-Makefile
.else
diff --git a/net/asterisk14/distinfo b/net/asterisk14/distinfo
index 3efa703cbbc7..1c21b1a25ead 100644
--- a/net/asterisk14/distinfo
+++ b/net/asterisk14/distinfo
@@ -1,6 +1,6 @@
-MD5 (asterisk-1.4.26.2.tar.gz) = 58181c29d998f883f567dc9757a04167
-SHA256 (asterisk-1.4.26.2.tar.gz) = 384e080e359ae28ca9323800a3fa0586210342039b96ecbdced9ea285516efe9
-SIZE (asterisk-1.4.26.2.tar.gz) = 21436723
-MD5 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = ae433b0c9574e0616cf014703641f62a
-SHA256 (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 65bd0d773a2ddc56bfa60a1bd9269eded2edf0062adf4f8afe393c6d41f27039
-SIZE (asterisk-1.4.26.2-codec-negotiation-20090916.diff.gz) = 40621
+MD5 (asterisk-1.4.29.tar.gz) = b49d0a269e11b6e85c75edce577b5103
+SHA256 (asterisk-1.4.29.tar.gz) = ecb1202f50fc5d7738d1b5bf6451b28e356f3469266dd64bcd637be71f91bd09
+SIZE (asterisk-1.4.29.tar.gz) = 21534219
+MD5 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 4dedd23b3c9c00bcdcc69b8be878f15c
+SHA256 (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 68f895de29f30296a47d32a5eaab8df367d92ae87b01ea9f2262556a1f1e5cbb
+SIZE (asterisk-1.4.27-codec-negotiation-20091120.diff.gz) = 40455
diff --git a/net/asterisk14/files/codecnego-patch-Makefile b/net/asterisk14/files/codecnego-patch-Makefile
index e19ba9db1f69..e39dd6f62082 100644
--- a/net/asterisk14/files/codecnego-patch-Makefile
+++ b/net/asterisk14/files/codecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-10-20 14:49:16.000000000 -0700
-+++ Makefile 2009-10-20 14:49:55.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-11-20 17:48:05.000000000 +0200
++++ Makefile 2009-11-20 17:50:33.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,28 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
- rm -f build_tools/menuselect-deps
-
- datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+@@ -416,15 +418,15 @@
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +60,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +140,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +149,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +189,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -662,20 +656,23 @@
+@@ -670,20 +664,23 @@
echo "; Default: strict"; \
echo ";"; \
echo ";translation_algorithm = strict"; \
diff --git a/net/asterisk14/files/dtmf_debug.diff b/net/asterisk14/files/dtmf_debug.diff
index 968554880ac3..2a5b6bc9ea33 100644
--- a/net/asterisk14/files/dtmf_debug.diff
+++ b/net/asterisk14/files/dtmf_debug.diff
@@ -49,9 +49,9 @@
/*! \brief Set rtp timeout */
void ast_rtp_set_rtptimeout(struct ast_rtp *rtp, int timeout);
/*! \brief Set rtp hold timeout */
---- main/rtp.c.orig 2009-05-13 16:38:01.000000000 +0300
-+++ main/rtp.c 2009-05-26 12:52:30.000000000 +0300
-@@ -80,6 +80,7 @@
+--- main/rtp.c.orig 2009-11-20 17:51:49.000000000 +0200
++++ main/rtp.c 2009-11-20 17:53:11.000000000 +0200
+@@ -81,6 +81,7 @@
static int rtpstart; /*!< First port for RTP sessions (set in rtp.conf) */
static int rtpend; /*!< Last port for RTP sessions (set in rtp.conf) */
static int rtpdebug; /*!< Are we debugging? */
@@ -59,16 +59,16 @@
static int rtcpdebug; /*!< Are we debugging RTCP? */
static int rtcpstats; /*!< Are we debugging RTCP? */
static int rtcpinterval = RTCP_DEFAULT_INTERVALMS; /*!< Time between rtcp reports in millisecs */
-@@ -173,6 +174,8 @@
- struct ast_codec_pref pref;
+@@ -170,6 +171,8 @@
struct ast_rtp *bridged; /*!< Who we are Packet bridged to */
int set_marker_bit:1; /*!< Whether to set the marker bit or not */
-+ char chan_name[100];
-+ char chan_id[100];
+ unsigned int constantssrc:1;
++ char chan_name[100];
++ char chan_id[100];
};
/* Forward declarations */
-@@ -673,8 +676,8 @@
+@@ -676,8 +679,8 @@
struct ast_frame *f = NULL;
event = ntohl(*((unsigned int *)(data)));
event &= 0x001F;
@@ -79,7 +79,7 @@
if (event < 10) {
resp = '0' + event;
} else if (event < 11) {
-@@ -688,12 +691,25 @@
+@@ -691,12 +694,25 @@
}
if (rtp->resp && (rtp->resp != resp)) {
f = send_dtmf(rtp, AST_FRAME_DTMF_END);
@@ -105,7 +105,7 @@
/*!
* \brief Process RTP DTMF and events according to RFC 2833.
*
-@@ -1090,6 +1106,10 @@
+@@ -1101,6 +1117,10 @@
struct rtpPayloadType rtpPT;
int reconstruct = ntohl(rtpheader[0]);
@@ -116,7 +116,7 @@
/* Get fields from packet */
payload = (reconstruct & 0x7f0000) >> 16;
mark = (((reconstruct & 0x800000) >> 23) != 0);
-@@ -1097,10 +1117,6 @@
+@@ -1108,10 +1128,6 @@
/* Check what the payload value should be */
rtpPT = ast_rtp_lookup_pt(rtp, payload);
@@ -127,7 +127,7 @@
/* Otherwise adjust bridged payload to match */
bridged_payload = ast_rtp_lookup_code(bridged, rtpPT.isAstFormat, rtpPT.code);
-@@ -1293,11 +1309,12 @@
+@@ -1306,11 +1322,12 @@
/* This is special in-band data that's not one of our codecs */
if (rtpPT.code == AST_RTP_DTMF) {
/* It's special -- rfc2833 process it */
@@ -141,7 +141,7 @@
data = rtp->rawdata + AST_FRIENDLY_OFFSET + hdrlen;
event = ntohl(*((unsigned int *)(data)));
event >>= 24;
-@@ -1306,9 +1323,12 @@
+@@ -1319,9 +1336,12 @@
event_end >>= 24;
duration = ntohl(*((unsigned int *)(data)));
duration &= 0xFFFF;
@@ -155,7 +155,7 @@
} else if (rtpPT.code == AST_RTP_CISCO_DTMF) {
/* It's really special -- process it the Cisco way */
if (rtp->lastevent <= seqno || (rtp->lastevent >= 65530 && seqno <= 6)) {
-@@ -2272,8 +2292,9 @@
+@@ -2287,8 +2307,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%u: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -167,7 +167,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
/* Increment sequence number */
-@@ -2316,8 +2337,9 @@
+@@ -2331,8 +2352,9 @@
ast_log(LOG_ERROR, "RTP Transmission error to %s:%d: %s\n",
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), strerror(errno));
@@ -179,7 +179,7 @@
ast_inet_ntoa(rtp->them.sin_addr),
ntohs(rtp->them.sin_port), rtp->send_payload, rtp->seqno, rtp->lastdigitts, res - hdrlen);
-@@ -3609,6 +3631,16 @@
+@@ -3621,6 +3643,16 @@
return RESULT_SUCCESS;
}
@@ -196,7 +196,7 @@
static int rtp_do_debug(int fd, int argc, char *argv[])
{
if (argc != 2) {
-@@ -3669,6 +3701,7 @@
+@@ -3681,6 +3713,7 @@
if (argc != 3)
return RESULT_SHOWUSAGE;
rtpdebug = 0;
@@ -204,7 +204,7 @@
ast_cli(fd,"RTP Debugging Disabled\n");
return RESULT_SUCCESS;
}
-@@ -3729,7 +3762,7 @@
+@@ -3741,7 +3774,7 @@
}
static char debug_usage[] =
@@ -213,7 +213,7 @@
" Enable dumping of all RTP packets to and from host.\n";
static char no_debug_usage[] =
-@@ -3804,6 +3837,10 @@
+@@ -3816,6 +3849,10 @@
rtp_do_debug, "Enable RTP debugging",
debug_usage },
diff --git a/net/asterisk14/files/nocodecnego-patch-Makefile b/net/asterisk14/files/nocodecnego-patch-Makefile
index 78a3b3b45d23..c5df459f1b2c 100644
--- a/net/asterisk14/files/nocodecnego-patch-Makefile
+++ b/net/asterisk14/files/nocodecnego-patch-Makefile
@@ -1,6 +1,6 @@
---- Makefile.orig 2009-06-11 15:20:31.000000000 -0700
-+++ Makefile 2009-09-18 02:47:39.000000000 -0700
-@@ -95,7 +95,7 @@
+--- Makefile.orig 2009-10-23 17:00:01.000000000 +0300
++++ Makefile 2009-11-23 16:44:36.000000000 +0200
+@@ -101,7 +101,7 @@
OVERWRITE=y
# Include debug and macro symbols in the executables (-g) and profiling info (-pg)
@@ -9,7 +9,7 @@
# Staging directory
# Files are copied here temporarily during the install process
-@@ -129,7 +129,7 @@
+@@ -135,7 +135,7 @@
ASTMANDIR=$(mandir)
ifneq ($(findstring BSD,$(OSARCH)),)
ASTVARLIBDIR=$(prefix)/share/asterisk
@@ -18,33 +18,37 @@
else
ASTVARLIBDIR=$(localstatedir)/lib/asterisk
endif
-@@ -219,9 +219,11 @@
- ASTLDFLAGS+=-L/usr/local/lib
+@@ -225,9 +225,11 @@
+ _ASTLDFLAGS+=-L/usr/local/lib
endif
+ifneq ($(OSARCH),FreeBSD)
ifneq ($(PROC),ultrasparc)
- ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
+ _ASTCFLAGS+=$(shell if $(CC) -march=$(PROC) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; then echo "-march=$(PROC)"; fi)
endif
+endif
ifeq ($(PROC),ppc)
- ASTCFLAGS+=-fsigned-char
-@@ -229,7 +231,7 @@
+ _ASTCFLAGS+=-fsigned-char
+@@ -235,7 +237,7 @@
ifeq ($(OSARCH),FreeBSD)
# -V is understood by BSD Make, not by GNU make.
- BSDVERSION=$(shell make -V OSVERSION -f /usr/share/mk/bsd.port.subdir.mk)
+ BSDVERSION=$(OSVERSION)
- ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
+ _ASTCFLAGS+=$(shell if test $(BSDVERSION) -lt 500016 ; then echo "-D_THREAD_SAFE"; fi)
AST_LIBS+=$(shell if test $(BSDVERSION) -lt 502102 ; then echo "-lc_r"; else echo "-pthread"; fi)
endif
-@@ -404,19 +406,19 @@
+@@ -410,21 +412,21 @@
rm -f build_tools/menuselect-deps
datafiles: _all
-- if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
-+ #if [ x`$(ID) -un` = xroot ]; then CFLAGS="$(ASTCFLAGS)" bash build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; fi
+- if [ `$(ID) -u` = 0 ]; then \
+- CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
+- fi
++ #if [ `$(ID) -u` = 0 ]; then \
++ # CFLAGS="$(_ASTCFLAGS) $(ASTCFLAGS)" build_tools/mkpkgconfig $(DESTDIR)/usr/lib/pkgconfig; \
++ #fi
# Should static HTTP be installed during make samples or even with its own target ala
# webvoicemail? There are portions here that *could* be customized but might also be
# improved a lot. I'll put it here for now.
@@ -65,7 +69,7 @@
$(MAKE) -C sounds install
update:
-@@ -437,47 +439,47 @@
+@@ -445,47 +447,47 @@
OLDHEADERS=$(filter-out $(NEWHEADERS),$(notdir $(wildcard $(DESTDIR)$(ASTHEADERDIR)/*.h)))
installdirs:
@@ -145,7 +149,7 @@
fi
$(SUBDIRS_INSTALL):
-@@ -513,7 +515,7 @@
+@@ -521,7 +523,7 @@
@exit 1
endif
@@ -154,7 +158,7 @@
@if [ -x /usr/sbin/asterisk-post-install ]; then \
/usr/sbin/asterisk-post-install $(DESTDIR) . ; \
fi
-@@ -551,31 +553,23 @@
+@@ -559,31 +561,23 @@
upgrade: bininstall
adsi:
@@ -194,7 +198,7 @@
( \
echo "[directories]" ; \
echo "astetcdir => $(ASTETCDIR)" ; \
-@@ -621,20 +615,23 @@
+@@ -629,20 +623,23 @@
echo ";astctlowner = root" ; \
echo ";astctlgroup = apache" ; \
echo ";astctl = asterisk.ctl" ; \
diff --git a/net/asterisk14/files/patch-Makefile.rules b/net/asterisk14/files/patch-Makefile.rules
index d129d9784b3c..f90430ec9ddd 100644
--- a/net/asterisk14/files/patch-Makefile.rules
+++ b/net/asterisk14/files/patch-Makefile.rules
@@ -1,21 +1,16 @@
-
-$FreeBSD$
-
---- Makefile.rules
-+++ Makefile.rules
-@@ -27,6 +27,7 @@
- CMD_PREFIX=
- endif
+--- Makefile.rules.orig 2009-09-28 22:09:25.000000000 +0300
++++ Makefile.rules 2009-11-23 16:15:23.000000000 +0200
+@@ -37,11 +37,13 @@
+
+ OPTIMIZE?=-O6
+ifneq ($(OSARCH),FreeBSD)
ifeq ($(findstring DONT_OPTIMIZE,$(MENUSELECT_CFLAGS)),)
- # More GSM codec optimization
- # Uncomment to enable MMXTM optimizations for x86 architecture CPU's
-@@ -37,6 +38,7 @@
- OPTIMIZE?=-O6
- ASTCFLAGS+=$(OPTIMIZE)
+ _ASTCFLAGS+=$(OPTIMIZE)
+ else
+ _ASTCFLAGS+=-O0
endif
+endif
- %.o: %.c
- $(ECHO_PREFIX) echo " [CC] $< -> $@"
+ # shortcuts for common combinations of flags; these must be recursively expanded so that
+ # per-target settings will be applied
diff --git a/net/asterisk14/files/patch-channels::Makefile b/net/asterisk14/files/patch-channels::Makefile
index fa5a90a988fa..bb9d20047899 100644
--- a/net/asterisk14/files/patch-channels::Makefile
+++ b/net/asterisk14/files/patch-channels::Makefile
@@ -1,8 +1,5 @@
-
-$FreeBSD$
-
---- channels/Makefile.orig
-+++ channels/Makefile
+--- channels/Makefile.orig 2009-07-21 16:04:44.000000000 +0300
++++ channels/Makefile 2009-11-20 18:05:45.000000000 +0200
@@ -32,9 +32,10 @@
endif
@@ -36,16 +33,16 @@ $FreeBSD$
endif
dist-clean::
-@@ -113,8 +115,12 @@
+@@ -111,8 +113,12 @@
else
chan_h323.so: chan_h323.o h323/libchanh323.a
$(ECHO_PREFIX) echo " [LD] $^ -> $@"
+ifeq ($(OSARCH),FreeBSD)
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) $(H323LDFLAGS) -o $@ $< h323/libchanh323.a $(H323LDLIBS) $(CHANH323LIB)
+else
- $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat
+ $(CMD_PREFIX) $(CXX) $(PTHREAD_CFLAGS) $(_ASTLDFLAGS) $(SOLINK) -o $@ $< h323/libchanh323.a $(CHANH323LIB) -L$(PWLIBDIR)/lib $(PTLIB) -L$(OPENH323DIR)/lib $(H323LIB) -L/usr/lib -lcrypto -lssl -lexpat $(ASTLDFLAGS)
endif
+endif
- chan_misdn.o: ASTCFLAGS+=-Imisdn
+ chan_misdn.o: _ASTCFLAGS+=-Imisdn
diff --git a/net/asterisk14/files/patch-configure b/net/asterisk14/files/patch-configure
index 0782453c279b..93432489e415 100644
--- a/net/asterisk14/files/patch-configure
+++ b/net/asterisk14/files/patch-configure
@@ -1,6 +1,9 @@
---- configure.orig 2009-04-27 22:29:46.000000000 +0300
-+++ configure 2009-05-26 12:59:22.000000000 +0300
-@@ -4064,8 +4064,6 @@
+
+$FreeBSD$
+
+--- configure.orig
++++ configure
+@@ -4308,8 +4308,6 @@
case "${host_os}" in
freebsd*)
ac_default_prefix=/usr/local
@@ -9,7 +12,7 @@
;;
darwin*)
-@@ -27145,7 +27143,7 @@
+@@ -16837,7 +16835,7 @@
fi
@@ -17,20 +20,4 @@
+ PLATFORM_OPENH323="h323_${OPENH323_SUFFIX}"
if test "${HAS_OPENH323:-unset}" != "unset"; then
- { $as_echo "$as_me:$LINENO: checking OpenH323 installation validity" >&5
-@@ -31624,6 +31622,7 @@
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
- $ac_includes_default
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- rm -f conftest.$ac_objext
-@@ -31665,6 +31664,7 @@
- cat confdefs.h >>conftest.$ac_ext
- cat >>conftest.$ac_ext <<_ACEOF
- /* end confdefs.h. */
-+#include <ptlib.h>
- #include <h323.h>
- _ACEOF
- if { (ac_try="$ac_cpp conftest.$ac_ext"
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking OpenH323 installation validity" >&5
diff --git a/net/asterisk14/files/patch-main::Makefile b/net/asterisk14/files/patch-main::Makefile
index 418714ab7f21..a4758b78bdc9 100644
--- a/net/asterisk14/files/patch-main::Makefile
+++ b/net/asterisk14/files/patch-main::Makefile
@@ -1,13 +1,13 @@
---- main/Makefile.orig 2009-04-09 07:31:38.000000000 +0300
-+++ main/Makefile 2009-05-26 13:07:50.000000000 +0300
+--- main/Makefile.orig 2009-08-01 03:52:00.000000000 +0300
++++ main/Makefile 2009-11-20 18:09:06.000000000 +0200
@@ -92,8 +92,8 @@
- cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(ASTCFLAGS:-Werror=))" LDFLAGS="$(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
+ cd editline && test -f config.h || CFLAGS="$(PTHREAD_CFLAGS) $(subst $(ASTTOPDIR),../../,$(_ASTCFLAGS:-Werror=)) $(ASTCFLAGS)" LDFLAGS="$(_ASTLDFLAGS) $(ASTLDFLAGS)" ./configure --build=$(BUILD_PLATFORM) --host=$(HOST_PLATFORM) --with-ncurses=$(NCURSES_DIR) --with-curses=$(CURSES_DIR) --with-termcap=$(TERMCAP_DIR) --with-tinfo=$(TINFO_DIR)
$(MAKE) -C editline libedit.a
-db1-ast/libdb1.a:
-- CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
+- _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
+#db1-ast/libdb1.a:
-+# CFLAGS="$(subst $(ASTTOPDIR),../../,$(ASTCFLAGS))" LDFLAGS="$(ASTLDFLAGS)" $(MAKE) -C db1-ast libdb1.a
++# _ASTCFLAGS="$(_ASTCFLAGS)" ASTCFLAGS="$(ASTCFLAGS) -Wno-strict-aliasing" $(MAKE) -C db1-ast libdb1.a
ast_expr2.c ast_expr2.h:
bison -o $@ -d --name-prefix=ast_yy ast_expr2.y
@@ -22,15 +22,15 @@
mv $(ASTTOPDIR)/include/asterisk/build.h.tmp $(ASTTOPDIR)/include/asterisk/build.h ; \
fi
@rm -f $(ASTTOPDIR)/include/asterisk/build.h.tmp
- @$(CC) -c -o buildinfo.o $(ASTCFLAGS) buildinfo.c
+ @$(CC) -c -o buildinfo.o $(_ASTCFLAGS) buildinfo.c $(ASTCFLAGS)
- $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) -> $@"
+ $(ECHO_PREFIX) echo " [LD] $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) -> $@"
ifneq ($(findstring chan_h323,$(MENUSELECT_CHANNELS)),)
-- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
-+ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS)
+- $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(ASTLDFLAGS)
else
-- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
-+ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS)
+- $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a db1-ast/libdb1.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
++ $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(ASTLINK) $(AST_EMBED_LDFLAGS) $(_ASTLDFLAGS) $(H323LDFLAGS) $(OBJS) editline/libedit.a $(AST_EMBED_LDSCRIPTS) buildinfo.o $(AST_LIBS) $(AST_EMBED_LIBS) $(H323LDLIBS) $(ASTLDFLAGS)
endif
clean::
diff --git a/net/asterisk14/files/patch-suppress_log_dups.diff b/net/asterisk14/files/patch-suppress_log_dups.diff
new file mode 100644
index 000000000000..115b69f21ca1
--- /dev/null
+++ b/net/asterisk14/files/patch-suppress_log_dups.diff
@@ -0,0 +1,270 @@
+Index: main/logger.c
+===================================================================
+--- main/logger.c (revision 188505)
++++ main/logger.c (working copy)
+@@ -140,6 +140,17 @@
+ AST_THREADSTORAGE(log_buf, log_buf_init);
+ #define LOG_BUF_INIT_SIZE 128
+
++/*
++ * Storage for previous log message to prevent log storms
++ */
++static int stored_log_level;
++static int stored_log_dup_count = 0;
++static char *stored_log_msg = NULL;
++static const char *stored_log_file;
++static int stored_log_line;
++static const char *stored_log_function;
++static ast_mutex_t stored_log_msg_lock;
++
+ static int make_components(char *s, int lineno)
+ {
+ char *w;
+@@ -591,6 +602,8 @@
+ char tmp[256];
+ int res = 0;
+
++ ast_mutex_init(&stored_log_msg_lock);
++
+ /* auto rotate if sig SIGXFSZ comes a-knockin */
+ (void) signal(SIGXFSZ,(void *) handle_SIGXFSZ);
+
+@@ -655,14 +668,14 @@
+ return;
+ }
+
+-static void __attribute__((format(printf, 5, 0))) ast_log_vsyslog(int level, const char *file, int line, const char *function, const char *fmt, va_list args)
++static void ast_log_syslog(int level, const char *file, int line, const char *function, const char *msg)
+ {
+ char buf[BUFSIZ];
+ char *s;
+
+ if (level >= SYSLOG_NLEVELS) {
+ /* we are locked here, so cannot ast_log() */
+- fprintf(stderr, "ast_log_vsyslog called with bogus level: %d\n", level);
++ fprintf(stderr, "ast_log_syslog called with bogus level: %d\n", level);
+ return;
+ }
+ if (level == __LOG_VERBOSE) {
+@@ -676,27 +689,20 @@
+ levels[level], (long)GETTID(), file, line, function);
+ }
+ s = buf + strlen(buf);
+- vsnprintf(s, sizeof(buf) - strlen(buf), fmt, args);
++ snprintf(s, sizeof(buf) - strlen(buf), "%s", msg);
+ term_strip(s, s, strlen(s) + 1);
+ syslog(syslog_level_map[level], "%s", buf);
+ }
+
+-/*!
+- * \brief send log messages to syslog and/or the console
+- */
+-void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++static void __ast_log(int level, const char *file, int line, const char *function, char *msg, int msglen)
+ {
+ struct logchannel *chan;
+- struct ast_dynamic_str *buf;
+ time_t t;
+ struct tm tm;
+ char date[256];
++ char buf[2048];
++ int res;
+
+- va_list ap;
+-
+- if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
+- return;
+-
+ if (AST_LIST_EMPTY(&logchannels))
+ {
+ /*
+@@ -704,35 +710,12 @@
+ * so just log to stdout
+ */
+ if (level != __LOG_VERBOSE) {
+- int res;
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_filter_escapes(buf->str);
+- fputs(buf->str, stdout);
+- }
++ term_filter_escapes(msg);
++ fputs(msg, stdout);
+ }
+ return;
+ }
+
+- /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
+- are non-zero; LOG_DEBUG messages can still be displayed if option_debug
+- is zero, if option_verbose is non-zero (this allows for 'level zero'
+- LOG_DEBUG messages to be displayed, if the logmask on any channel
+- allows it)
+- */
+- if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
+- return;
+-
+- /* Ignore anything that never gets logged anywhere */
+- if (!(global_logmask & (1 << level)))
+- return;
+-
+- /* Ignore anything other than the currently debugged file if there is one */
+- if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
+- return;
+-
+ time(&t);
+ ast_localtime(&t, &tm, NULL);
+ strftime(date, sizeof(date), dateformat, &tm);
+@@ -740,13 +723,8 @@
+ AST_LIST_LOCK(&logchannels);
+
+ if (logfiles.event_log && level == __LOG_EVENT) {
+- va_start(ap, fmt);
+-
+- fprintf(eventlog, "%s asterisk[%ld]: ", date, (long)getpid());
+- vfprintf(eventlog, fmt, ap);
++ fprintf(eventlog, "%s asterisk[%ld]: %s", date, (long)getpid(), msg);
+ fflush(eventlog);
+-
+- va_end(ap);
+ AST_LIST_UNLOCK(&logchannels);
+ return;
+ }
+@@ -756,18 +734,15 @@
+ break;
+ /* Check syslog channels */
+ if (chan->type == LOGTYPE_SYSLOG && (chan->logmask & (1 << level))) {
+- va_start(ap, fmt);
+- ast_log_vsyslog(level, file, line, function, fmt, ap);
+- va_end(ap);
++ ast_log_syslog(level, file, line, function, msg);
+ /* Console channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->type == LOGTYPE_CONSOLE)) {
+ char linestr[128];
+ char tmp1[80], tmp2[80], tmp3[80], tmp4[80];
+
+ if (level != __LOG_VERBOSE) {
+- int res;
+ sprintf(linestr, "%d", line);
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld]: %s:%s %s: ",
+ date,
+ term_color(tmp1, levels[level], colors[level], 0, sizeof(tmp1)),
+@@ -776,23 +751,17 @@
+ term_color(tmp3, linestr, COLOR_BRWHITE, 0, sizeof(tmp3)),
+ term_color(tmp4, function, COLOR_BRWHITE, 0, sizeof(tmp4)));
+ /*filter to the console!*/
+- term_filter_escapes(buf->str);
+- ast_console_puts_mutable(buf->str);
+-
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED)
+- ast_console_puts_mutable(buf->str);
++ term_filter_escapes(buf);
++ ast_console_puts_mutable(buf);
++ ast_console_puts_mutable(msg);
+ }
+ /* File channels */
+ } else if ((chan->logmask & (1 << level)) && (chan->fileptr)) {
+- int res;
+- ast_dynamic_str_thread_set(&buf, BUFSIZ, &log_buf,
++ snprintf(buf, sizeof(buf),
+ "[%s] %s[%ld] %s: ",
+ date, levels[level], (long)GETTID(), file);
+- res = fprintf(chan->fileptr, "%s", buf->str);
+- if (res <= 0 && !ast_strlen_zero(buf->str)) { /* Error, no characters printed */
++ res = fprintf(chan->fileptr, "%s", buf);
++ if (res <= 0 && !ast_strlen_zero(buf)) { /* Error, no characters printed */
+ fprintf(stderr,"**** Asterisk Logging Error: ***********\n");
+ if (errno == ENOMEM || errno == ENOSPC) {
+ fprintf(stderr, "Asterisk logging error: Out of disk space, can't log to log file %s\n", chan->filename);
+@@ -801,16 +770,10 @@
+ manager_event(EVENT_FLAG_SYSTEM, "LogChannel", "Channel: %s\r\nEnabled: No\r\nReason: %d - %s\r\n", chan->filename, errno, strerror(errno));
+ chan->disabled = 1;
+ } else {
+- int res;
+ /* No error message, continue printing */
+- va_start(ap, fmt);
+- res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
+- va_end(ap);
+- if (res != AST_DYNSTR_BUILD_FAILED) {
+- term_strip(buf->str, buf->str, buf->len);
+- fputs(buf->str, chan->fileptr);
+- fflush(chan->fileptr);
+- }
++ term_strip(msg, msg, msglen);
++ fputs(msg, chan->fileptr);
++ fflush(chan->fileptr);
+ }
+ }
+ }
+@@ -825,6 +788,65 @@
+ }
+ }
+
++/*!
++ * \brief send log messages to syslog and/or the console
++ */
++void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...)
++{
++ struct ast_dynamic_str *buf;
++ int res;
++ va_list ap;
++
++ if (!(buf = ast_dynamic_str_thread_get(&log_buf, LOG_BUF_INIT_SIZE)))
++ return;
++
++ va_start(ap, fmt);
++ res = ast_dynamic_str_thread_set_va(&buf, BUFSIZ, &log_buf, fmt, ap);
++ va_end(ap);
++ if (res == AST_DYNSTR_BUILD_FAILED)
++ return;
++
++ /* don't display LOG_DEBUG messages unless option_verbose _or_ option_debug
++ are non-zero; LOG_DEBUG messages can still be displayed if option_debug
++ is zero, if option_verbose is non-zero (this allows for 'level zero'
++ LOG_DEBUG messages to be displayed, if the logmask on any channel
++ allows it)
++ */
++ if (!option_verbose && !option_debug && (level == __LOG_DEBUG))
++ return;
++
++ /* Ignore anything that never gets logged anywhere */
++ if (!(global_logmask & (1 << level)))
++ return;
++
++ /* Ignore anything other than the currently debugged file if there is one */
++ if ((level == __LOG_DEBUG) && !ast_strlen_zero(debug_filename) && strcasecmp(debug_filename, file))
++ return;
++
++ ast_mutex_lock(&stored_log_msg_lock);
++ if (stored_log_msg == NULL || stored_log_level != level || strcmp(buf->str, stored_log_msg) != 0) {
++ if (stored_log_dup_count > 0) {
++ char buf2[1024];
++
++ snprintf(buf2, sizeof(buf2), "Last message repeated %d times\n", stored_log_dup_count);
++ __ast_log(stored_log_level, stored_log_file, stored_log_line, stored_log_function, buf2, strlen(buf2));
++ }
++ if (stored_log_msg != NULL)
++ ast_free(stored_log_msg);
++ stored_log_msg = ast_strdup(buf->str);
++ stored_log_level = level;
++ stored_log_dup_count = 0;
++ stored_log_file = file;
++ stored_log_line = line;
++ stored_log_function = function;
++ __ast_log(level, file, line, function, buf->str, buf->len);
++ }
++ else
++ ++stored_log_dup_count;
++
++ ast_mutex_unlock(&stored_log_msg_lock);
++}
++
+ void ast_backtrace(void)
+ {
+ #ifdef linux
diff --git a/net/asterisk14/files/rtp_force_dtmf-codecnego.diff b/net/asterisk14/files/rtp_force_dtmf-codecnego.diff
index 723bd8703c06..a670364ba603 100644
--- a/net/asterisk14/files/rtp_force_dtmf-codecnego.diff
+++ b/net/asterisk14/files/rtp_force_dtmf-codecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-03-12 17:37:00.000000000 +0200
-+++ channels/chan_sip.c 2008-03-12 18:17:33.000000000 +0200
-@@ -554,6 +554,9 @@
+--- channels/chan_sip.c.orig 2009-11-20 17:56:30.000000000 +0200
++++ channels/chan_sip.c 2009-11-20 17:59:43.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,37 +10,37 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -4983,6 +4986,8 @@
- int codec_index = 0;
- int codec_pt_order[256];
+@@ -5329,6 +5332,7 @@
+ int x;
+ int codec_index = 0;
+ int codec_pt_order[256];
++ int dtmf_present = 0;
-+ int dtmf_present = 0;
+ /* Host information */
+ struct ast_hostent audiohp;
+@@ -5600,12 +5604,21 @@
+ for (x = 0; x < codec_index; ++x) {
+ struct rtpPayloadType pt;
+ pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
++ if (pt.code == AST_RTP_DTMF)
++ dtmf_present = 1;
+ if (!pt.isAstFormat && !pt.code && p->vrtp)
+ pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
+ if (pt.isAstFormat)
+ ast_codec_pref_append(&p->formats, pt.code);
+ }
+ ast_codec_pref_remove2(&p->formats, ~p->usercapability);
++ if (!dtmf_present && global_force_dtmf_relay) {
++ newnoncodeccapability |= AST_RTP_DTMF;
++ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
++ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
++ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
++ }
+
- if (!p->rtp) {
- ast_log(LOG_ERROR, "Got SDP but have no RTP session allocated.\n");
- return -1;
-@@ -5408,12 +5413,20 @@
- for (x = 0; x < codec_index; ++x) {
- struct rtpPayloadType pt;
- pt = ast_rtp_lookup_pt(p->rtp, codec_pt_order[x]);
-+ if (pt.code == AST_RTP_DTMF)
-+ dtmf_present = 1;
- if (!pt.isAstFormat && !pt.code && p->vrtp)
- pt = ast_rtp_lookup_pt(p->vrtp, codec_pt_order[x]);
- if (pt.isAstFormat)
- ast_codec_pref_append(&p->formats, pt.code);
- }
- ast_codec_pref_remove2(&p->formats, ~p->usercapability);
-+ if (!dtmf_present && global_force_dtmf_relay) {
-+ newnoncodeccapability |= AST_RTP_DTMF;
-+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ codec_pt_order[codec_index++] = global_force_dtmf_relay_pt;
-+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
-+ }
-
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
-@@ -16845,6 +16858,9 @@
+@@ -18369,6 +18382,9 @@
global_matchexterniplocally = FALSE;
@@ -50,7 +50,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -16901,6 +16917,18 @@
+@@ -18431,6 +18447,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -67,7 +67,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-04-25 08:53:52.000000000 -0700
+++ configs/sip.conf.sample 2008-06-10 00:45:37.000000000 -0700
diff --git a/net/asterisk14/files/rtp_force_dtmf-nocodecnego.diff b/net/asterisk14/files/rtp_force_dtmf-nocodecnego.diff
index 9b1d521fa0e3..9dcb7d8b134f 100644
--- a/net/asterisk14/files/rtp_force_dtmf-nocodecnego.diff
+++ b/net/asterisk14/files/rtp_force_dtmf-nocodecnego.diff
@@ -1,6 +1,6 @@
---- channels/chan_sip.c.orig 2008-09-09 00:10:10.000000000 +0300
-+++ channels/chan_sip.c 2008-12-12 17:02:05.000000000 +0200
-@@ -557,6 +557,9 @@
+--- channels/chan_sip.c.orig 2009-11-23 17:28:47.000000000 +0200
++++ channels/chan_sip.c 2009-11-23 17:29:29.000000000 +0200
+@@ -565,6 +565,9 @@
static unsigned int global_tos_sip; /*!< IP type of service for SIP packets */
static unsigned int global_tos_audio; /*!< IP type of service for audio RTP packets */
static unsigned int global_tos_video; /*!< IP type of service for video RTP packets */
@@ -10,21 +10,20 @@
static int compactheaders; /*!< send compact sip headers */
static int recordhistory; /*!< Record SIP history. Off by default */
static int dumphistory; /*!< Dump history to verbose before destroying SIP dialog */
-@@ -5504,6 +5507,13 @@
-
+@@ -5593,6 +5596,12 @@
+
/* Now gather all of the codecs that we are asked for: */
ast_rtp_get_current_formats(newaudiortp, &peercapability, &peernoncodeccapability);
+ /* Add telephone-event */
+ if (global_force_dtmf_relay && !(peernoncodeccapability & AST_RTP_DTMF)) {
+ ast_rtp_set_m_type(newaudiortp, global_force_dtmf_relay_pt);
-+ found_rtpmap_codecs[last_rtpmap_codec++] = global_force_dtmf_relay_pt;
+ ast_rtp_set_rtpmap_type(newaudiortp, global_force_dtmf_relay_pt, "audio", "telephone-event", 0);
+ peernoncodeccapability |= AST_RTP_DTMF;
+ }
ast_rtp_get_current_formats(newvideortp, &vpeercapability, &vpeernoncodeccapability);
newjointcapability = p->capability & (peercapability | vpeercapability);
-@@ -17440,6 +17450,9 @@
+@@ -18366,6 +18375,9 @@
global_matchexterniplocally = FALSE;
@@ -34,7 +33,7 @@
/* Copy the default jb config over global_jbconf */
memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf));
-@@ -17496,6 +17509,18 @@
+@@ -18428,6 +18440,18 @@
}
} else if (!strcasecmp(v->name, "vmexten")) {
ast_copy_string(default_vmexten, v->value, sizeof(default_vmexten));
@@ -51,7 +50,7 @@
+ } else
+ ast_log(LOG_WARNING, "RTP forced DTMF relay payload type is %d\n", global_force_dtmf_relay_pt);
} else if (!strcasecmp(v->name, "rtptimeout")) {
- if ((sscanf(v->value, "%d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
+ if ((sscanf(v->value, "%30d", &global_rtptimeout) != 1) || (global_rtptimeout < 0)) {
ast_log(LOG_WARNING, "'%s' is not a valid RTP hold time at line %d. Using default.\n", v->value, v->lineno);
--- configs/sip.conf.sample.orig 2008-08-16 01:33:42.000000000 +0300
+++ configs/sip.conf.sample 2008-12-12 17:03:11.000000000 +0200
diff --git a/net/asterisk14/pkg-plist b/net/asterisk14/pkg-plist
index 465dbb095d9d..fa747b6e8a6e 100644
--- a/net/asterisk14/pkg-plist
+++ b/net/asterisk14/pkg-plist
@@ -435,23 +435,22 @@ share/asterisk/agi-bin/agi-test.agi
share/asterisk/agi-bin/eagi-sphinx-test
share/asterisk/agi-bin/eagi-test
share/asterisk/agi-bin/jukebox.agi
-share/asterisk/firmware/iax/iaxy.bin
share/asterisk/images/asterisk-intro.jpg
share/asterisk/keys/freeworlddialup.pub
share/asterisk/keys/iaxtel.pub
-share/asterisk/moh/.asterisk-moh-freeplay-wav
-share/asterisk/moh/CHANGES-asterisk-moh-opsound-2.01
-share/asterisk/moh/CREDITS-asterisk-moh-opsound-2.01
-share/asterisk/moh/LICENSE-asterisk-moh-opsound-2.01
+share/asterisk/moh/.asterisk-moh-opsound-wav
+share/asterisk/moh/CHANGES-asterisk-moh-opsound-wav
+share/asterisk/moh/CREDITS-asterisk-moh-opsound-wav
+share/asterisk/moh/LICENSE-asterisk-moh-opsound-wav
share/asterisk/moh/macroform-cold_day.wav
share/asterisk/moh/macroform-robot_dity.wav
share/asterisk/moh/macroform-the_simplicity.wav
share/asterisk/moh/manolo_camp-morning_coffee.wav
share/asterisk/moh/reno_project-system.wav
-share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.15
-share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.15
-share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.15
-share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.15
+share/asterisk/sounds/.asterisk-core-sounds-en-gsm-1.4.17
+share/asterisk/sounds/CHANGES-asterisk-core-en-1.4.17
+share/asterisk/sounds/CREDITS-asterisk-core-en-1.4.17
+share/asterisk/sounds/LICENSE-asterisk-core-en-1.4.17
share/asterisk/sounds/agent-alreadyon.gsm
share/asterisk/sounds/agent-incorrect.gsm
share/asterisk/sounds/agent-loggedoff.gsm
@@ -842,6 +841,7 @@ share/asterisk/sounds/vm-opts.gsm
share/asterisk/sounds/vm-opts-full.gsm
share/asterisk/sounds/vm-passchanged.gsm
share/asterisk/sounds/vm-password.gsm
+share/asterisk/sounds/vm-pls-try-again.gsm
share/asterisk/sounds/vm-press.gsm
share/asterisk/sounds/vm-prev.gsm
share/asterisk/sounds/vm-reachoper.gsm