mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-01 22:58:50 -04:00
acp: improve debug of channel map
Increase the size of the channel_map debug printf buffer. Use a safer version of the snprintf that avoids buffer overruns. See #1781
This commit is contained in:
parent
efd8ac25e3
commit
86ca0f8466
3 changed files with 41 additions and 4 deletions
|
|
@ -29,7 +29,7 @@ extern "C" {
|
|||
|
||||
#define PA_CHANNELS_MAX 64
|
||||
|
||||
#define PA_CHANNEL_MAP_SNPRINT_MAX 336
|
||||
#define PA_CHANNEL_MAP_SNPRINT_MAX (PA_CHANNELS_MAX * 32)
|
||||
|
||||
typedef enum pa_channel_map_def {
|
||||
PA_CHANNEL_MAP_AIFF,
|
||||
|
|
|
|||
|
|
@ -280,7 +280,44 @@ static inline PA_PRINTF_FUNC(5, 6) void pa_log_level_meta(enum pa_log_level leve
|
|||
#define pa_strnull(s) ((s) ? (s) : "null")
|
||||
#define pa_startswith(s,pfx) (strstr(s, pfx) == s)
|
||||
|
||||
#define pa_snprintf snprintf
|
||||
PA_PRINTF_FUNC(3, 0)
|
||||
static inline size_t pa_vsnprintf(char *str, size_t size, const char *format, va_list ap)
|
||||
{
|
||||
int ret;
|
||||
|
||||
pa_assert(str);
|
||||
pa_assert(size > 0);
|
||||
pa_assert(format);
|
||||
|
||||
ret = vsnprintf(str, size, format, ap);
|
||||
|
||||
str[size-1] = 0;
|
||||
|
||||
if (ret < 0)
|
||||
return strlen(str);
|
||||
|
||||
if ((size_t) ret > size-1)
|
||||
return size-1;
|
||||
|
||||
return (size_t) ret;
|
||||
}
|
||||
|
||||
PA_PRINTF_FUNC(3, 4)
|
||||
static inline size_t pa_snprintf(char *str, size_t size, const char *format, ...)
|
||||
{
|
||||
size_t ret;
|
||||
va_list ap;
|
||||
|
||||
pa_assert(str);
|
||||
pa_assert(size > 0);
|
||||
pa_assert(format);
|
||||
|
||||
va_start(ap, format);
|
||||
ret = pa_vsnprintf(str, size, format, ap);
|
||||
va_end(ap);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
#define pa_xstrdup(s) ((s) != NULL ? strdup(s) : NULL)
|
||||
#define pa_xstrndup(s,n) ((s) != NULL ? strndup(s,n) : NULL)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue