summaryrefslogtreecommitdiff
path: root/poll
diff options
context:
space:
mode:
authortrawick <trawick@13f79535-47bb-0310-9956-ffa450edef68>2009-11-14 03:02:29 +0000
committertrawick <trawick@13f79535-47bb-0310-9956-ffa450edef68>2009-11-14 03:02:29 +0000
commit71fd364c9d549c09e5006ff34f0d4361a9e41d1f (patch)
tree27afd14cab711ef7cca7d720b2efd13c6be89596 /poll
parent5c96751da8118f991efde977266c0a2187cfc83f (diff)
downloadlibapr-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.c24
-rw-r--r--poll/unix/pollset.c34
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;
}