[asterisk-bugs] [JIRA] (ASTERISK-19451) va_start/va_copy and va_end do not always match up
Matt Jordan (JIRA)
noreply at issues.asterisk.org
Sun Feb 24 17:21:18 CST 2013
[ https://issues.asterisk.org/jira/browse/ASTERISK-19451?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=203411#comment-203411 ]
Matt Jordan commented on ASTERISK-19451:
----------------------------------------
Patch attached for {{res_config_mysql.c}}.
It looks like it doesn't need to call va_end in all but a single case, since the configuration engine takes care of the calls for realtime providers.
Walter: does that look correct?
> va_start/va_copy and va_end do not always match up
> --------------------------------------------------
>
> Key: ASTERISK-19451
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-19451
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: General
> Affects Versions: SVN
> Reporter: Walter Doekes
> Severity: Minor
> Attachments: ASTERISK-19451-1.8.diff
>
>
> {noformat}
> va_end()
> Each invocation of va_start() must be matched by a corresponding invo‐
> cation of va_end() in the same function. After the call va_end(ap)
> the variable ap is undefined. Multiple traversals of the list, each
> bracketed by va_start() and va_end() are possible. va_end() may be a
> macro or a function.
> {noformat}
> and
> {quote}[...] on systems where arguments are passed in registers, it may be necessary for va_start() to allocate memory, store the arguments there, and also an indication of which argument is next, so that va_arg() can step through the list. Now va_end() can free the allocated memory again.{quote}
> This is not always done right:
> - there is a va_end too many in main/utils.c
> - there are a couple too few in res/res_config_odbc.c and then lots of va_copy's aren't closed on early failure-return
> - res/res_config_pgsql.c and res/res_config_curl.c have lots of va_ends but does not start/copy any (they shouldn't va_end, the callers of ast_load_realtime_helper handle both va_start/va_end)
> And possibly a few more.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the asterisk-bugs
mailing list