19 #ifndef GRPC_CORE_LIB_SURFACE_COMPLETION_QUEUE_H 20 #define GRPC_CORE_LIB_SURFACE_COMPLETION_QUEUE_H 55 const char* file,
int line);
57 const char* file,
int line);
58 #define GRPC_CQ_INTERNAL_REF(cc, reason) \ 59 grpc_cq_internal_ref(cc, reason, __FILE__, __LINE__) 60 #define GRPC_CQ_INTERNAL_UNREF(cc, reason) \ 61 grpc_cq_internal_unref(cc, reason, __FILE__, __LINE__) 65 #define GRPC_CQ_INTERNAL_REF(cc, reason) grpc_cq_internal_ref(cc) 66 #define GRPC_CQ_INTERNAL_UNREF(cc, reason) grpc_cq_internal_unref(cc) 83 bool internal =
false);
void(* done)(void *done_arg, struct grpc_cq_completion *c)
done callback - called when this queue element is no longer needed by the completion queue ...
Definition: completion_queue.h:47
grpc_pollset * grpc_cq_pollset(grpc_completion_queue *cc)
Definition: completion_queue.cc:1411
Definition: error_internal.h:39
struct grpc_cq_completion grpc_cq_completion
grpc_core::TraceFlag grpc_cq_pluck_trace
grpc_cq_completion_type grpc_get_cq_completion_type(grpc_completion_queue *cc)
Definition: completion_queue.cc:563
void grpc_cq_internal_ref(grpc_completion_queue *cc, const char *reason, const char *file, int line)
Definition: completion_queue.cc:576
Definition: completion_queue.h:39
void grpc_cq_end_op(grpc_completion_queue *cc, void *tag, grpc_error *error, void(*done)(void *done_arg, grpc_cq_completion *storage), void *done_arg, grpc_cq_completion *storage, bool internal=false)
Definition: completion_queue.cc:871
Definition: pollset_custom.cc:40
grpc_core::ManualConstructor< grpc_core::MultiProducerSingleConsumerQueue > node
Definition: completion_queue.h:41
void * done_arg
Definition: completion_queue.h:48
bool grpc_cq_begin_op(grpc_completion_queue *cc, void *tag)
Definition: completion_queue.cc:654
grpc_cq_completion_type
Specifies the type of APIs to use to pop events from the completion queue.
Definition: grpc_types.h:706
grpc_cq_polling_type
Completion queues internally MAY maintain a set of file descriptors in a structure called 'pollset'...
Definition: grpc_types.h:688
Definition: completion_queue.cc:321
uintptr_t next
next pointer; low bit is used to indicate success or not
Definition: completion_queue.h:50
void grpc_cq_global_init()
Definition: completion_queue.cc:425
grpc_core::TraceFlag grpc_trace_operation_failures
int grpc_get_cq_poll_num(grpc_completion_queue *cc)
Definition: completion_queue.cc:567
grpc_core::DebugOnlyTraceFlag grpc_trace_cq_refcount
grpc_core::DebugOnlyTraceFlag grpc_trace_pending_tags
EXPERIMENTAL: Specifies an interface class to be used as a tag for callback-based completion queues...
Definition: grpc_types.h:722
bool grpc_cq_can_listen(grpc_completion_queue *cc)
Definition: completion_queue.cc:1415
grpc_completion_queue * grpc_completion_queue_create_internal(grpc_cq_completion_type completion_type, grpc_cq_polling_type polling_type, grpc_experimental_completion_queue_functor *shutdown_callback)
Definition: completion_queue.cc:494
void grpc_cq_internal_unref(grpc_completion_queue *cc, const char *reason, const char *file, int line)
Definition: completion_queue.cc:593
void * tag
user supplied tag
Definition: completion_queue.h:44