<p>Joshua Colp <strong>submitted</strong> this change.</p><p><a href="https://gerrit.asterisk.org/c/asterisk/+/18505">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Kevin Harwell: Looks good to me, but someone else must approve
  George Joseph: Looks good to me, approved
  Joshua Colp: Approved for Submit

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">GCC12: Fixes for 16+<br><br>Most issues were in stringfields and had to do with comparing<br>a pointer to an constant/interned string with NULL.  Since the<br>string was a constant, a pointer to it could never be NULL so<br>the comparison was always "true".  gcc now complains about that.<br><br>There were also a few issues where determining if there was<br>enough space for a memcpy or s(n)printf which were fixed<br>by defining some of the involved variables as "volatile".<br><br>There were also a few other miscellaneous fixes.<br><br>ASTERISK-30044<br><br>Change-Id: Ia081ca1bcfb329df6487c4660aaf1944309eb570<br>---<br>M addons/Makefile<br>M apps/app_festival.c<br>M channels/chan_sip.c<br>M channels/sig_analog.c<br>M funcs/func_scramble.c<br>M include/asterisk/stringfields.h<br>M include/asterisk/strings.h<br>M main/pbx.c<br>M main/stun.c<br>M res/res_config_pgsql.c<br>M res/res_tonedetect.c<br>M tests/test_vector.c<br>12 files changed, 74 insertions(+), 46 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/addons/Makefile b/addons/Makefile</span><br><span>index 866d34b..c41ffdc 100644</span><br><span>--- a/addons/Makefile</span><br><span>+++ b/addons/Makefile</span><br><span>@@ -64,6 +64,10 @@</span><br><span> $(call MOD_ADD_C,chan_ooh323,$(H323SOURCE))</span><br><span> </span><br><span> ifneq ($(wildcard mp3/Makefile),)</span><br><span style="color: hsl(120, 100%, 40%);">+# At the current time, the fate of mp3 is in flux so it didn't make sense to</span><br><span style="color: hsl(120, 100%, 40%);">+# add configure/makeopts processing for array-bounds since this is the only</span><br><span style="color: hsl(120, 100%, 40%);">+# source file that needs that warning suppressed.</span><br><span style="color: hsl(120, 100%, 40%);">+mp3/layer3.o: _ASTCFLAGS+=-Wno-array-bounds</span><br><span> $(call MOD_ADD_C,format_mp3,mp3/common.c mp3/dct64_i386.c mp3/decode_ntom.c mp3/layer3.c mp3/tabinit.c mp3/interface.c)</span><br><span> </span><br><span> .PHONY: check_mp3</span><br><span>diff --git a/apps/app_festival.c b/apps/app_festival.c</span><br><span>index d5cea27..754bad3 100644</span><br><span>--- a/apps/app_festival.c</span><br><span>+++ b/apps/app_festival.c</span><br><span>@@ -434,7 +434,7 @@</span><br><span>    }</span><br><span>    readcache = 0;</span><br><span>       writecache = 0;</span><br><span style="color: hsl(0, 100%, 40%);">- if (strlen(cachedir) + strlen(MD5Hex) + 1 <= MAXFESTLEN && (usecache == -1)) {</span><br><span style="color: hsl(120, 100%, 40%);">+     if (strlen(cachedir) + sizeof(MD5Hex) + 1 <= MAXFESTLEN && (usecache == -1)) {</span><br><span>            snprintf(cachefile, sizeof(cachefile), "%s/%s", cachedir, MD5Hex);</span><br><span>                 fdesc = open(cachefile, O_RDWR);</span><br><span>             if (fdesc == -1) {</span><br><span>diff --git a/channels/chan_sip.c b/channels/chan_sip.c</span><br><span>index 6cc8fbb..a291886 100644</span><br><span>--- a/channels/chan_sip.c</span><br><span>+++ b/channels/chan_sip.c</span><br><span>@@ -35410,8 +35410,8 @@</span><br><span>                        ast_test_status_update(test, "Unexpected result: %d != %d\n", expected_res, res); \</span><br><span>                        return AST_TEST_FAIL;                           \</span><br><span>            }                                                       \</span><br><span style="color: hsl(0, 100%, 40%);">-               if ((expected_start) != start) {                        \</span><br><span style="color: hsl(0, 100%, 40%);">-                       const char *e = expected_start ? expected_start : "(null)"; \</span><br><span style="color: hsl(120, 100%, 40%);">+               if ((void *)(expected_start) != (void *)start) {                        \</span><br><span style="color: hsl(120, 100%, 40%);">+                     const char *e = ((void *)expected_start != (void *)NULL) ? expected_start : "(null)"; \</span><br><span>                    const char *a = start ? start : "(null)";     \</span><br><span>                    ast_test_status_update(test, "Unexpected start: %s != %s\n", e, a); \</span><br><span>                      return AST_TEST_FAIL;                           \</span><br><span>diff --git a/channels/sig_analog.c b/channels/sig_analog.c</span><br><span>index 64f1114..ea507fe 100644</span><br><span>--- a/channels/sig_analog.c</span><br><span>+++ b/channels/sig_analog.c</span><br><span>@@ -1033,6 +1033,10 @@</span><br><span>                          ast_log(LOG_WARNING, "Number '%s' is shorter than stripmsd (%d)\n", c, p->stripmsd);</span><br><span>                            c = NULL;</span><br><span>                    }</span><br><span style="color: hsl(120, 100%, 40%);">+                     if (c && (strlen(c) > sizeof(p->dop.dialstr) - 3 /* "Tw\0" */)) {</span><br><span style="color: hsl(120, 100%, 40%);">+                             ast_log(LOG_WARNING, "Number '%s' is longer than %d bytes\n", c, (int)sizeof(p->dop.dialstr) - 2);</span><br><span style="color: hsl(120, 100%, 40%);">+                               c = NULL;</span><br><span style="color: hsl(120, 100%, 40%);">+                     }</span><br><span>                    if (c) {</span><br><span>                             p->dop.op = ANALOG_DIAL_OP_REPLACE;</span><br><span>                               snprintf(p->dop.dialstr, sizeof(p->dop.dialstr), "Tw%s", c);</span><br><span>diff --git a/funcs/func_scramble.c b/funcs/func_scramble.c</span><br><span>index 9eb407d..c38a062 100644</span><br><span>--- a/funcs/func_scramble.c</span><br><span>+++ b/funcs/func_scramble.c</span><br><span>@@ -122,7 +122,7 @@</span><br><span> </span><br><span>      if (frame->frametype == AST_FRAME_VOICE) { /* only invert voice frequencies */</span><br><span>            /* Based on direction of frame, and confirm it is applicable */</span><br><span style="color: hsl(0, 100%, 40%);">-         if (!(direction == AST_AUDIOHOOK_DIRECTION_READ ? &ni->rx : &ni->tx)) {</span><br><span style="color: hsl(120, 100%, 40%);">+         if (!(direction == AST_AUDIOHOOK_DIRECTION_READ ? ni->rx : ni->tx)) {</span><br><span>                  return 0;</span><br><span>            }</span><br><span>            /* Scramble the sample now */</span><br><span>diff --git a/include/asterisk/stringfields.h b/include/asterisk/stringfields.h</span><br><span>index e2e72a9..8edc8d6 100644</span><br><span>--- a/include/asterisk/stringfields.h</span><br><span>+++ b/include/asterisk/stringfields.h</span><br><span>@@ -350,10 +350,11 @@</span><br><span> </span><br><span>   \return 0 on success, non-zero on failure</span><br><span> */</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> #define ast_string_field_init(x, size) \</span><br><span> ({ \</span><br><span>        int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __res__ = __ast_string_field_init(&(x)->__field_mgr, &(x)->__field_mgr_pool, size, __FILE__, __LINE__, __PRETTY_FUNCTION__); \</span><br><span>         } \</span><br><span>  __res__ ; \</span><br><span>@@ -368,7 +369,7 @@</span><br><span> #define ast_string_field_free_memory(x)     \</span><br><span> ({ \</span><br><span>   int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __res__ = __ast_string_field_free_memory(&(x)->__field_mgr, &(x)->__field_mgr_pool, \</span><br><span>                  AST_STRINGFIELD_DESTROY, __FILE__, __LINE__, __PRETTY_FUNCTION__); \</span><br><span>         } \</span><br><span>@@ -395,7 +396,7 @@</span><br><span> #define ast_string_field_init_extended(x, field) \</span><br><span> ({ \</span><br><span>      int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               ast_string_field *non_const = (ast_string_field *)&(x)->field; \</span><br><span>              *non_const = __ast_string_field_empty; \</span><br><span>             __res__ = AST_VECTOR_APPEND(&(x)->__field_mgr.string_fields, non_const); \</span><br><span>@@ -470,7 +471,7 @@</span><br><span> #define ast_string_field_ptr_set(x, ptr, data) \</span><br><span> ({ \</span><br><span>  int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __res__ = ast_string_field_ptr_set_by_fields((x)->__field_mgr_pool, (x)->__field_mgr, ptr, data); \</span><br><span>    } \</span><br><span>  __res__; \</span><br><span>@@ -478,26 +479,28 @@</span><br><span> </span><br><span> #define __ast_string_field_ptr_set_by_fields(field_mgr_pool, field_mgr, ptr, data, file, lineno, func) \</span><br><span> ({                                                                                             \</span><br><span style="color: hsl(0, 100%, 40%);">-    int __res__ = 0;                                                                           \</span><br><span style="color: hsl(0, 100%, 40%);">-    const char *__d__ = (data);                                                                \</span><br><span style="color: hsl(0, 100%, 40%);">-    size_t __dlen__ = (__d__) ? strlen(__d__) + 1 : 1;                                         \</span><br><span style="color: hsl(0, 100%, 40%);">-    ast_string_field *__p__ = (ast_string_field *) (ptr);                                      \</span><br><span style="color: hsl(0, 100%, 40%);">-    ast_string_field target = *__p__;                                                          \</span><br><span style="color: hsl(0, 100%, 40%);">-    if (__dlen__ == 1) {                                                                       \</span><br><span style="color: hsl(0, 100%, 40%);">-        __ast_string_field_release_active(field_mgr_pool, *__p__);                             \</span><br><span style="color: hsl(0, 100%, 40%);">-        *__p__ = __ast_string_field_empty;                                                     \</span><br><span style="color: hsl(0, 100%, 40%);">-    } else if ((__dlen__ <= AST_STRING_FIELD_ALLOCATION(*__p__)) ||                            \</span><br><span style="color: hsl(0, 100%, 40%);">-           (!__ast_string_field_ptr_grow(&field_mgr, &field_mgr_pool, __dlen__, __p__)) ||     \</span><br><span style="color: hsl(0, 100%, 40%);">-           (target = __ast_string_field_alloc_space(&field_mgr, &field_mgr_pool, __dlen__, file, lineno, func))) { \</span><br><span style="color: hsl(0, 100%, 40%);">-        if (target != *__p__) {                                                                \</span><br><span style="color: hsl(0, 100%, 40%);">-            __ast_string_field_release_active(field_mgr_pool, *__p__);                         \</span><br><span style="color: hsl(0, 100%, 40%);">-            *__p__ = target;                                                                   \</span><br><span style="color: hsl(0, 100%, 40%);">-        }                                                                                      \</span><br><span style="color: hsl(0, 100%, 40%);">-        memcpy(* (void **) __p__, __d__, __dlen__);                                            \</span><br><span style="color: hsl(0, 100%, 40%);">-    } else {                                                                                   \</span><br><span style="color: hsl(0, 100%, 40%);">-        __res__ = -1;                                                                          \</span><br><span style="color: hsl(0, 100%, 40%);">-    }                                                                                          \</span><br><span style="color: hsl(0, 100%, 40%);">-    __res__;                                                                                   \</span><br><span style="color: hsl(120, 100%, 40%);">+ int __res__ = 0;                                                                           \</span><br><span style="color: hsl(120, 100%, 40%);">+  const char *__d__ = (data);                                                                \</span><br><span style="color: hsl(120, 100%, 40%);">+  ast_string_field *__p__ = (ast_string_field *) (ptr);                                      \</span><br><span style="color: hsl(120, 100%, 40%);">+  ast_string_field target = *__p__;                                                          \</span><br><span style="color: hsl(120, 100%, 40%);">+  if (__d__ == NULL || *__d__ == '\0') {                                                     \</span><br><span style="color: hsl(120, 100%, 40%);">+          __ast_string_field_release_active(field_mgr_pool, *__p__);                             \</span><br><span style="color: hsl(120, 100%, 40%);">+              *__p__ = __ast_string_field_empty;                                                     \</span><br><span style="color: hsl(120, 100%, 40%);">+      } else {                                                                                   \</span><br><span style="color: hsl(120, 100%, 40%);">+          size_t __dlen__ = strlen(__d__) + 1;                                                   \</span><br><span style="color: hsl(120, 100%, 40%);">+              if ((__dlen__ <= AST_STRING_FIELD_ALLOCATION(*__p__)) ||                               \</span><br><span style="color: hsl(120, 100%, 40%);">+                   (!__ast_string_field_ptr_grow(&field_mgr, &field_mgr_pool, __dlen__, __p__)) ||    \</span><br><span style="color: hsl(120, 100%, 40%);">+                  (target = __ast_string_field_alloc_space(&field_mgr, &field_mgr_pool, __dlen__, file, lineno, func))) { \</span><br><span style="color: hsl(120, 100%, 40%);">+                     if (target != *__p__) {                                                            \</span><br><span style="color: hsl(120, 100%, 40%);">+                          __ast_string_field_release_active(field_mgr_pool, *__p__);                     \</span><br><span style="color: hsl(120, 100%, 40%);">+                              *__p__ = target;                                                               \</span><br><span style="color: hsl(120, 100%, 40%);">+                      }                                                                                  \</span><br><span style="color: hsl(120, 100%, 40%);">+                  memcpy(* (void **) __p__, __d__, __dlen__);                                        \</span><br><span style="color: hsl(120, 100%, 40%);">+          } else {                                                                               \</span><br><span style="color: hsl(120, 100%, 40%);">+                      __res__ = -1;                                                                      \</span><br><span style="color: hsl(120, 100%, 40%);">+          }                                                                                      \</span><br><span style="color: hsl(120, 100%, 40%);">+      }                                                                                          \</span><br><span style="color: hsl(120, 100%, 40%);">+  __res__;                                                                                   \</span><br><span> })</span><br><span> </span><br><span> #define ast_string_field_ptr_set_by_fields(field_mgr_pool, field_mgr, ptr, data) \</span><br><span>@@ -514,7 +517,7 @@</span><br><span> #define ast_string_field_set(x, field, data) \</span><br><span> ({ \</span><br><span>         int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __res__ = ast_string_field_ptr_set(x, &(x)->field, data); \</span><br><span>   } \</span><br><span>  __res__; \</span><br><span>@@ -531,7 +534,7 @@</span><br><span> #define ast_string_field_ptr_build(x, ptr, fmt, args...) \</span><br><span> ({ \</span><br><span>       int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __ast_string_field_ptr_build(__FILE__, __LINE__, __PRETTY_FUNCTION__, \</span><br><span>                      &(x)->__field_mgr, &(x)->__field_mgr_pool, (ast_string_field *) ptr, fmt, args); \</span><br><span>             __res__ = 0; \</span><br><span>@@ -550,7 +553,7 @@</span><br><span> #define ast_string_field_build(x, field, fmt, args...) \</span><br><span> ({ \</span><br><span>     int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __ast_string_field_ptr_build(__FILE__, __LINE__, __PRETTY_FUNCTION__, \</span><br><span>                      &(x)->__field_mgr, &(x)->__field_mgr_pool, (ast_string_field *) &(x)->field, fmt, args); \</span><br><span>              __res__ = 0; \</span><br><span>@@ -569,7 +572,7 @@</span><br><span> #define ast_string_field_ptr_build_va(x, ptr, fmt, args) \</span><br><span> ({ \</span><br><span>   int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __ast_string_field_ptr_build_va(&(x)->__field_mgr, &(x)->__field_mgr_pool, (ast_string_field *) ptr, fmt, args, \</span><br><span>                      __FILE__, __LINE__, __PRETTY_FUNCTION__); \</span><br><span>          __res__ = 0; \</span><br><span>@@ -588,7 +591,7 @@</span><br><span> #define ast_string_field_build_va(x, field, fmt, args) \</span><br><span> ({ \</span><br><span>     int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(x)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+        if (((void *)(x)) != (void *)NULL) { \</span><br><span>               __ast_string_field_ptr_build_va(&(x)->__field_mgr, &(x)->__field_mgr_pool, (ast_string_field *) &(x)->field, fmt, args, \</span><br><span>                       __FILE__, __LINE__, __PRETTY_FUNCTION__); \</span><br><span>          __res__ = 0; \</span><br><span>@@ -607,7 +610,7 @@</span><br><span> #define ast_string_fields_cmp(instance1, instance2) \</span><br><span> ({ \</span><br><span>        int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(instance1)) != NULL && ((void *)(instance2)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+       if (((void *)(instance1)) != (void *)NULL && ((void *)(instance2)) != (void *)NULL) { \</span><br><span>              __res__ = __ast_string_fields_cmp(&(instance1)->__field_mgr.string_fields, \</span><br><span>                  &(instance2)->__field_mgr.string_fields); \</span><br><span>   } \</span><br><span>@@ -627,7 +630,7 @@</span><br><span> #define ast_string_fields_copy(copy, orig) \</span><br><span> ({ \</span><br><span>    int __res__ = -1; \</span><br><span style="color: hsl(0, 100%, 40%);">-     if (((void *)(copy)) != NULL && ((void *)(orig)) != NULL) { \</span><br><span style="color: hsl(120, 100%, 40%);">+ if (((void *)(copy)) != (void *)NULL && ((void *)(orig)) != (void *)NULL) { \</span><br><span>                __res__ = __ast_string_fields_copy(((copy)->__field_mgr_pool), \</span><br><span>                  (struct ast_string_field_mgr *)&((copy)->__field_mgr), \</span><br><span>                      (struct ast_string_field_mgr *)&((orig)->__field_mgr), \</span><br><span>diff --git a/include/asterisk/strings.h b/include/asterisk/strings.h</span><br><span>index 59dece8..325491a 100644</span><br><span>--- a/include/asterisk/strings.h</span><br><span>+++ b/include/asterisk/strings.h</span><br><span>@@ -390,11 +390,13 @@</span><br><span> AST_INLINE_API(</span><br><span> void ast_copy_string(char *dst, const char *src, size_t size),</span><br><span> {</span><br><span style="color: hsl(0, 100%, 40%);">-  while (*src && size) {</span><br><span style="color: hsl(0, 100%, 40%);">-          *dst++ = *src++;</span><br><span style="color: hsl(0, 100%, 40%);">-                size--;</span><br><span style="color: hsl(120, 100%, 40%);">+       volatile size_t sz = size;</span><br><span style="color: hsl(120, 100%, 40%);">+    volatile char *sp = (char *)src;</span><br><span style="color: hsl(120, 100%, 40%);">+      while (*sp && sz) {</span><br><span style="color: hsl(120, 100%, 40%);">+           *dst++ = *sp++;</span><br><span style="color: hsl(120, 100%, 40%);">+               sz--;</span><br><span>        }</span><br><span style="color: hsl(0, 100%, 40%);">-       if (__builtin_expect(!size, 0))</span><br><span style="color: hsl(120, 100%, 40%);">+       if (__builtin_expect(!sz, 0))</span><br><span>                dst--;</span><br><span>       *dst = '\0';</span><br><span> }</span><br><span>diff --git a/main/pbx.c b/main/pbx.c</span><br><span>index 986e3ce..e6667f8 100644</span><br><span>--- a/main/pbx.c</span><br><span>+++ b/main/pbx.c</span><br><span>@@ -1654,6 +1654,7 @@</span><br><span> #undef INC_DST_OVERFLOW_CHECK</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+#define MAX_EXTENBUF_SIZE 512</span><br><span> static struct match_char *add_exten_to_pattern_tree(struct ast_context *con, struct ast_exten *e1, int findonly)</span><br><span> {</span><br><span>     struct match_char *m1 = NULL;</span><br><span>@@ -1664,11 +1665,13 @@</span><br><span>      int pattern = 0;</span><br><span>     int idx_cur;</span><br><span>         int idx_next;</span><br><span style="color: hsl(0, 100%, 40%);">-   char extenbuf[512];</span><br><span style="color: hsl(120, 100%, 40%);">+   char extenbuf[MAX_EXTENBUF_SIZE];</span><br><span style="color: hsl(120, 100%, 40%);">+     volatile size_t required_space = strlen(e1->exten) + 1;</span><br><span>   struct pattern_node pat_node[2];</span><br><span> </span><br><span>         if (e1->matchcid) {</span><br><span style="color: hsl(0, 100%, 40%);">-          if (sizeof(extenbuf) < strlen(e1->exten) + strlen(e1->cidmatch) + 2) {</span><br><span style="color: hsl(120, 100%, 40%);">+               required_space += (strlen(e1->cidmatch) + 2 /* '/' + NULL */);</span><br><span style="color: hsl(120, 100%, 40%);">+             if (required_space > MAX_EXTENBUF_SIZE) {</span><br><span>                         ast_log(LOG_ERROR,</span><br><span>                           "The pattern %s/%s is too big to deal with: it will be ignored! Disaster!\n",</span><br><span>                              e1->exten, e1->cidmatch);</span><br><span>@@ -1676,7 +1679,13 @@</span><br><span>             }</span><br><span>            sprintf(extenbuf, "%s/%s", e1->exten, e1->cidmatch);/* Safe.  We just checked. */</span><br><span>    } else {</span><br><span style="color: hsl(0, 100%, 40%);">-                ast_copy_string(extenbuf, e1->exten, sizeof(extenbuf));</span><br><span style="color: hsl(120, 100%, 40%);">+            if (required_space > MAX_EXTENBUF_SIZE) {</span><br><span style="color: hsl(120, 100%, 40%);">+                  ast_log(LOG_ERROR,</span><br><span style="color: hsl(120, 100%, 40%);">+                            "The pattern %s/%s is too big to deal with: it will be ignored! Disaster!\n",</span><br><span style="color: hsl(120, 100%, 40%);">+                               e1->exten, e1->cidmatch);</span><br><span style="color: hsl(120, 100%, 40%);">+                       return NULL;</span><br><span style="color: hsl(120, 100%, 40%);">+          }</span><br><span style="color: hsl(120, 100%, 40%);">+             ast_copy_string(extenbuf, e1->exten, required_space);</span><br><span>     }</span><br><span> </span><br><span> #ifdef NEED_DEBUG</span><br><span>diff --git a/main/stun.c b/main/stun.c</span><br><span>index 8007f3a..06e6d9f 100644</span><br><span>--- a/main/stun.c</span><br><span>+++ b/main/stun.c</span><br><span>@@ -370,7 +370,13 @@</span><br><span>                                       st.username ? st.username : "<none>");</span><br><span>                   if (st.username) {</span><br><span>                           append_attr_string(&attr, STUN_USERNAME, st.username, &resplen, &respleft);</span><br><span style="color: hsl(0, 100%, 40%);">-                         snprintf(combined, sizeof(combined), "%16s%16s", st.username + 16, st.username);</span><br><span style="color: hsl(120, 100%, 40%);">+                            /*</span><br><span style="color: hsl(120, 100%, 40%);">+                             * For Google Voice, the stun username is made up of the local</span><br><span style="color: hsl(120, 100%, 40%);">+                                 * and remote usernames, each being fixed at 16 bytes.  We have</span><br><span style="color: hsl(120, 100%, 40%);">+                                * to swap the two at this point.</span><br><span style="color: hsl(120, 100%, 40%);">+                              */</span><br><span style="color: hsl(120, 100%, 40%);">+                           snprintf(combined, 17, "%16s", st.username + 16);</span><br><span style="color: hsl(120, 100%, 40%);">+                           snprintf(combined + 16, 17, "%16s", st.username);</span><br><span>                  } else {</span><br><span>                             combined[0] = '\0';</span><br><span>                  }</span><br><span>diff --git a/res/res_config_pgsql.c b/res/res_config_pgsql.c</span><br><span>index aeec11f..a79f82a 100644</span><br><span>--- a/res/res_config_pgsql.c</span><br><span>+++ b/res/res_config_pgsql.c</span><br><span>@@ -1288,7 +1288,7 @@</span><br><span>                               res = -1;</span><br><span>                    } else {</span><br><span>                             struct ast_str *sql = ast_str_create(100);</span><br><span style="color: hsl(0, 100%, 40%);">-                              char fieldtype[10];</span><br><span style="color: hsl(120, 100%, 40%);">+                           char fieldtype[20];</span><br><span>                          PGresult *result;</span><br><span> </span><br><span>                                if (requirements == RQ_CREATECHAR || type == RQ_CHAR) {</span><br><span>diff --git a/res/res_tonedetect.c b/res/res_tonedetect.c</span><br><span>index 33682c7..929afdb 100644</span><br><span>--- a/res/res_tonedetect.c</span><br><span>+++ b/res/res_tonedetect.c</span><br><span>@@ -353,7 +353,7 @@</span><br><span>           return 0;</span><br><span>    }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-   if (!(direction == AST_AUDIOHOOK_DIRECTION_READ ? &di->rx : &di->tx)) {</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!(direction == AST_AUDIOHOOK_DIRECTION_READ ? di->rx : di->tx)) {</span><br><span>          return 0;</span><br><span>    }</span><br><span> </span><br><span>diff --git a/tests/test_vector.c b/tests/test_vector.c</span><br><span>index 2dfcc60..5f6f0a5 100644</span><br><span>--- a/tests/test_vector.c</span><br><span>+++ b/tests/test_vector.c</span><br><span>@@ -48,7 +48,7 @@</span><br><span> }</span><br><span> </span><br><span> #define STRING_CMP(a, b) ({ \</span><br><span style="color: hsl(0, 100%, 40%);">-    ((a) == NULL || (b) == NULL) ? -1 : (strcmp((a), (b)) == 0); \</span><br><span style="color: hsl(120, 100%, 40%);">+        ((void *)(a) == (void *)NULL || (void *)(b) == (void *)NULL) ? -1 : (strcmp((a), (b)) == 0); \</span><br><span> })</span><br><span> </span><br><span> AST_TEST_DEFINE(basic_ops)</span><br><span></span><br></pre><div style="white-space:pre-wrap"></div><p>To view, visit <a href="https://gerrit.asterisk.org/c/asterisk/+/18505">change 18505</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/c/asterisk/+/18505"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: certified/18.9 </div>
<div style="display:none"> Gerrit-Change-Id: Ia081ca1bcfb329df6487c4660aaf1944309eb570 </div>
<div style="display:none"> Gerrit-Change-Number: 18505 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Friendly Automation </div>
<div style="display:none"> Gerrit-Reviewer: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Gerrit-Reviewer: Kevin Harwell <kharwell@digium.com> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>