mirror of https://github.com/grpc/grpc.git
commit
ff60024eaf
908 changed files with 8757 additions and 5096 deletions
@ -0,0 +1,71 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
#include "src/core/iomgr/closure.h" |
||||
|
||||
void grpc_closure_init(grpc_closure *closure, grpc_iomgr_cb_func cb, |
||||
void *cb_arg) { |
||||
closure->cb = cb; |
||||
closure->cb_arg = cb_arg; |
||||
closure->next = NULL; |
||||
} |
||||
|
||||
void grpc_closure_list_add(grpc_closure_list *closure_list, |
||||
grpc_closure *closure, int success) { |
||||
if (closure == NULL) return; |
||||
closure->next = NULL; |
||||
closure->success = success; |
||||
if (closure_list->head == NULL) { |
||||
closure_list->head = closure; |
||||
} else { |
||||
closure_list->tail->next = closure; |
||||
} |
||||
closure_list->tail = closure; |
||||
} |
||||
|
||||
int grpc_closure_list_empty(grpc_closure_list closure_list) { |
||||
return closure_list.head == NULL; |
||||
} |
||||
|
||||
void grpc_closure_list_move(grpc_closure_list *src, grpc_closure_list *dst) { |
||||
if (src->head == NULL) { |
||||
return; |
||||
} |
||||
if (dst->head == NULL) { |
||||
*dst = *src; |
||||
} else { |
||||
dst->tail->next = src->head; |
||||
dst->tail = src->tail; |
||||
} |
||||
src->head = src->tail = NULL; |
||||
} |
@ -0,0 +1,88 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
#ifndef GRPC_INTERNAL_CORE_IOMGR_CLOSURE_H |
||||
#define GRPC_INTERNAL_CORE_IOMGR_CLOSURE_H |
||||
|
||||
#include <stddef.h> |
||||
|
||||
struct grpc_closure; |
||||
typedef struct grpc_closure grpc_closure; |
||||
|
||||
/* forward declaration for exec_ctx.h */ |
||||
struct grpc_exec_ctx; |
||||
typedef struct grpc_exec_ctx grpc_exec_ctx; |
||||
|
||||
typedef struct grpc_closure_list { |
||||
grpc_closure *head; |
||||
grpc_closure *tail; |
||||
} grpc_closure_list; |
||||
|
||||
/** gRPC Callback definition.
|
||||
* |
||||
* \param arg Arbitrary input. |
||||
* \param success An indication on the state of the iomgr. On false, cleanup |
||||
* actions should be taken (eg, shutdown). */ |
||||
typedef void (*grpc_iomgr_cb_func)(grpc_exec_ctx *exec_ctx, void *arg, |
||||
int success); |
||||
|
||||
/** A closure over a grpc_iomgr_cb_func. */ |
||||
struct grpc_closure { |
||||
/** Bound callback. */ |
||||
grpc_iomgr_cb_func cb; |
||||
|
||||
/** Arguments to be passed to "cb". */ |
||||
void *cb_arg; |
||||
|
||||
/** Internal. A boolean indication to "cb" on the state of the iomgr.
|
||||
* For instance, closures created during a shutdown would have this field set |
||||
* to false. */ |
||||
int success; |
||||
|
||||
/**< Internal. Do not touch */ |
||||
struct grpc_closure *next; |
||||
}; |
||||
|
||||
/** Initializes \a closure with \a cb and \a cb_arg. */ |
||||
void grpc_closure_init(grpc_closure *closure, grpc_iomgr_cb_func cb, |
||||
void *cb_arg); |
||||
|
||||
#define GRPC_CLOSURE_LIST_INIT \ |
||||
{ NULL, NULL } |
||||
|
||||
void grpc_closure_list_add(grpc_closure_list *list, grpc_closure *closure, |
||||
int success); |
||||
void grpc_closure_list_move(grpc_closure_list *src, grpc_closure_list *dst); |
||||
int grpc_closure_list_empty(grpc_closure_list list); |
||||
|
||||
#endif /* GRPC_INTERNAL_CORE_IOMGR_CLOSURE_H */ |
@ -0,0 +1,62 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
#include "src/core/iomgr/exec_ctx.h" |
||||
|
||||
#include <grpc/support/log.h> |
||||
|
||||
void grpc_exec_ctx_flush(grpc_exec_ctx *exec_ctx) { |
||||
while (!grpc_closure_list_empty(exec_ctx->closure_list)) { |
||||
grpc_closure *c = exec_ctx->closure_list.head; |
||||
exec_ctx->closure_list.head = exec_ctx->closure_list.tail = NULL; |
||||
while (c != NULL) { |
||||
grpc_closure *next = c->next; |
||||
c->cb(exec_ctx, c->cb_arg, c->success); |
||||
c = next; |
||||
} |
||||
} |
||||
} |
||||
|
||||
void grpc_exec_ctx_finish(grpc_exec_ctx *exec_ctx) { |
||||
grpc_exec_ctx_flush(exec_ctx); |
||||
} |
||||
|
||||
void grpc_exec_ctx_enqueue(grpc_exec_ctx *exec_ctx, grpc_closure *closure, |
||||
int success) { |
||||
grpc_closure_list_add(&exec_ctx->closure_list, closure, success); |
||||
} |
||||
|
||||
void grpc_exec_ctx_enqueue_list(grpc_exec_ctx *exec_ctx, |
||||
grpc_closure_list *list) { |
||||
grpc_closure_list_move(list, &exec_ctx->closure_list); |
||||
} |
@ -0,0 +1,77 @@ |
||||
/*
|
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
#ifndef GRPC_INTERNAL_CORE_IOMGR_EXEC_CTX_H |
||||
#define GRPC_INTERNAL_CORE_IOMGR_EXEC_CTX_H |
||||
|
||||
#include "src/core/iomgr/closure.h" |
||||
|
||||
/** Execution context.
|
||||
* A bag of data that collects information along a callstack. |
||||
* Generally created at public API entry points, and passed down as |
||||
* pointer to child functions that manipulate it. |
||||
* |
||||
* Specific responsibilities (this may grow in the future): |
||||
* - track a list of work that needs to be delayed until the top of the |
||||
* call stack (this provides a convenient mechanism to run callbacks |
||||
* without worrying about locking issues) |
||||
* |
||||
* CONVENTIONS: |
||||
* Instance of this must ALWAYS be constructed on the stack, never |
||||
* heap allocated. Instances and pointers to them must always be called |
||||
* exec_ctx. Instances are always passed as the first argument |
||||
* to a function that takes it, and always as a pointer (grpc_exec_ctx |
||||
* is never copied). |
||||
*/ |
||||
struct grpc_exec_ctx { |
||||
grpc_closure_list closure_list; |
||||
}; |
||||
|
||||
#define GRPC_EXEC_CTX_INIT \ |
||||
{ GRPC_CLOSURE_LIST_INIT } |
||||
|
||||
/** Flush any work that has been enqueued onto this grpc_exec_ctx.
|
||||
* Caller must guarantee that no interfering locks are held. */ |
||||
void grpc_exec_ctx_flush(grpc_exec_ctx *exec_ctx); |
||||
/** Finish any pending work for a grpc_exec_ctx. Must be called before
|
||||
* the instance is destroyed, or work may be lost. */ |
||||
void grpc_exec_ctx_finish(grpc_exec_ctx *exec_ctx); |
||||
/** Add a closure to be executed at the next flush/finish point */ |
||||
void grpc_exec_ctx_enqueue(grpc_exec_ctx *exec_ctx, grpc_closure *closure, |
||||
int success); |
||||
/** Add a list of closures to be executed at the next flush/finish point.
|
||||
* Leaves \a list empty. */ |
||||
void grpc_exec_ctx_enqueue_list(grpc_exec_ctx *exec_ctx, |
||||
grpc_closure_list *list); |
||||
|
||||
#endif |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue