diff options
author | trawick <trawick@13f79535-47bb-0310-9956-ffa450edef68> | 2009-11-14 03:02:29 +0000 |
---|---|---|
committer | trawick <trawick@13f79535-47bb-0310-9956-ffa450edef68> | 2009-11-14 03:02:29 +0000 |
commit | 71fd364c9d549c09e5006ff34f0d4361a9e41d1f (patch) | |
tree | 27afd14cab711ef7cca7d720b2efd13c6be89596 /poll | |
parent | 5c96751da8118f991efde977266c0a2187cfc83f (diff) | |
download | libapr-71fd364c9d549c09e5006ff34f0d4361a9e41d1f.tar.gz |
merge r834029 from trunk:
apr_pollset_create_ex(), apr_pollcb_create_ex():
simplify logic to update the caller's pollcb/pollset ptr,
fixing a apr_pollcb_create_ex() crash in one of the
fall-back paths which was reported by Neil Conway
git-svn-id: http://svn.apache.org/repos/asf/apr/apr/branches/1.4.x@836105 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'poll')
-rw-r--r-- | poll/unix/pollcb.c | 24 | ||||
-rw-r--r-- | poll/unix/pollset.c | 34 |
2 files changed, 30 insertions, 28 deletions
diff --git a/poll/unix/pollcb.c b/poll/unix/pollcb.c index cd5266a7e..0af3e512c 100644 --- a/poll/unix/pollcb.c +++ b/poll/unix/pollcb.c @@ -72,21 +72,23 @@ static apr_pollcb_provider_t *pollcb_provider(apr_pollset_method_e method) return provider; } -APR_DECLARE(apr_status_t) apr_pollcb_create_ex(apr_pollcb_t **pollcb, +APR_DECLARE(apr_status_t) apr_pollcb_create_ex(apr_pollcb_t **ret_pollcb, apr_uint32_t size, apr_pool_t *p, apr_uint32_t flags, apr_pollset_method_e method) { apr_status_t rv; + apr_pollcb_t *pollcb; apr_pollcb_provider_t *provider = NULL; + *ret_pollcb = NULL; + if (method == APR_POLLSET_DEFAULT) method = pollset_default_method; while (provider == NULL) { provider = pollcb_provider(method); if (!provider) { - *pollcb = NULL; if ((flags & APR_POLLSET_NODEFAULT) == APR_POLLSET_NODEFAULT) return APR_ENOTIMPL; if (method == pollset_default_method) @@ -95,15 +97,14 @@ APR_DECLARE(apr_status_t) apr_pollcb_create_ex(apr_pollcb_t **pollcb, } } - *pollcb = apr_palloc(p, sizeof(**pollcb)); - (*pollcb)->nelts = 0; - (*pollcb)->nalloc = size; - (*pollcb)->pool = p; - (*pollcb)->provider = provider; + pollcb = apr_palloc(p, sizeof(*pollcb)); + pollcb->nelts = 0; + pollcb->nalloc = size; + pollcb->pool = p; + pollcb->provider = provider; - rv = (*provider->create)(*pollcb, size, p, flags); + rv = (*provider->create)(pollcb, size, p, flags); if (rv == APR_ENOTIMPL) { - *pollcb = NULL; if (method == pollset_default_method) { return rv; } @@ -117,13 +118,14 @@ APR_DECLARE(apr_status_t) apr_pollcb_create_ex(apr_pollcb_t **pollcb, if (!provider) { return APR_ENOTIMPL; } - rv = (*provider->create)(*pollcb, size, p, flags); + rv = (*provider->create)(pollcb, size, p, flags); if (rv != APR_SUCCESS) { return rv; } - (*pollcb)->provider = provider; + pollcb->provider = provider; } + *ret_pollcb = pollcb; return APR_SUCCESS; } diff --git a/poll/unix/pollset.c b/poll/unix/pollset.c index 6a3fa5dfe..049509f40 100644 --- a/poll/unix/pollset.c +++ b/poll/unix/pollset.c @@ -210,21 +210,23 @@ static apr_pollset_provider_t *pollset_provider(apr_pollset_method_e method) return provider; } -APR_DECLARE(apr_status_t) apr_pollset_create_ex(apr_pollset_t **pollset, +APR_DECLARE(apr_status_t) apr_pollset_create_ex(apr_pollset_t **ret_pollset, apr_uint32_t size, apr_pool_t *p, apr_uint32_t flags, apr_pollset_method_e method) { apr_status_t rv; + apr_pollset_t *pollset; apr_pollset_provider_t *provider = NULL; + *ret_pollset = NULL; + if (method == APR_POLLSET_DEFAULT) method = pollset_default_method; while (provider == NULL) { provider = pollset_provider(method); if (!provider) { - *pollset = NULL; if ((flags & APR_POLLSET_NODEFAULT) == APR_POLLSET_NODEFAULT) return APR_ENOTIMPL; if (method == pollset_default_method) @@ -237,41 +239,39 @@ APR_DECLARE(apr_status_t) apr_pollset_create_ex(apr_pollset_t **pollset, size++; } - *pollset = apr_palloc(p, sizeof(**pollset)); - (*pollset)->nelts = 0; - (*pollset)->nalloc = size; - (*pollset)->pool = p; - (*pollset)->flags = flags; - (*pollset)->provider = provider; + pollset = apr_palloc(p, sizeof(*pollset)); + pollset->nelts = 0; + pollset->nalloc = size; + pollset->pool = p; + pollset->flags = flags; + pollset->provider = provider; - rv = (*provider->create)(*pollset, size, p, flags); + rv = (*provider->create)(pollset, size, p, flags); if (rv == APR_ENOTIMPL) { if (method == pollset_default_method) { - *pollset = NULL; return rv; } provider = pollset_provider(pollset_default_method); if (!provider) { - *pollset = NULL; return APR_ENOTIMPL; } - rv = (*provider->create)(*pollset, size, p, flags); + rv = (*provider->create)(pollset, size, p, flags); if (rv != APR_SUCCESS) { - *pollset = NULL; return rv; } - (*pollset)->provider = provider; + pollset->provider = provider; } if (flags & APR_POLLSET_WAKEABLE) { /* Create wakeup pipe */ - if ((rv = create_wakeup_pipe(*pollset)) != APR_SUCCESS) { - *pollset = NULL; + if ((rv = create_wakeup_pipe(pollset)) != APR_SUCCESS) { return rv; } } if ((flags & APR_POLLSET_WAKEABLE) || provider->cleanup) - apr_pool_cleanup_register(p, *pollset, pollset_cleanup, + apr_pool_cleanup_register(p, pollset, pollset_cleanup, apr_pool_cleanup_null); + + *ret_pollset = pollset; return APR_SUCCESS; } |