34 #ifndef GRPC_INTERNAL_CORE_CLIENT_CONFIG_LB_POLICY_H
35 #define GRPC_INTERNAL_CORE_CLIENT_CONFIG_LB_POLICY_H
78 #ifdef GRPC_LB_POLICY_REFCOUNT_DEBUG
79 #define GRPC_LB_POLICY_REF(p, r) \
80 grpc_lb_policy_ref((p), __FILE__, __LINE__, (r))
81 #define GRPC_LB_POLICY_UNREF(p, r) \
82 grpc_lb_policy_unref((p), __FILE__, __LINE__, (r))
88 #define GRPC_LB_POLICY_REF(p, r) grpc_lb_policy_ref((p))
89 #define GRPC_LB_POLICY_UNREF(p, r) grpc_lb_policy_unref((p))
const grpc_lb_policy_vtable * vtable
Definition: lb_policy.h:48
grpc_connectivity_state
Connectivity state of a channel.
Definition: grpc.h:139
Definition: sync_generic.h:49
void grpc_lb_policy_exit_idle(grpc_lb_policy *policy)
Definition: lb_policy.c:81
grpc_connectivity_state grpc_lb_policy_check_connectivity(grpc_lb_policy *policy)
Definition: lb_policy.c:91
void(* pick)(grpc_lb_policy *policy, grpc_pollset *pollset, grpc_metadata_batch *initial_metadata, grpc_subchannel **target, grpc_iomgr_closure *on_complete)
implement grpc_lb_policy_pick
Definition: lb_policy.h:58
void(* broadcast)(grpc_lb_policy *policy, grpc_transport_op *op)
broadcast a transport op to all subchannels
Definition: lb_policy.h:66
Definition: pollset_posix.h:48
Definition: subchannel.c:77
void(* grpc_lb_completion)(void *cb_arg, grpc_subchannel *subchannel, grpc_status_code status, const char *errmsg)
Definition: lb_policy.h:44
void grpc_lb_policy_broadcast(grpc_lb_policy *policy, grpc_transport_op *op)
Definition: lb_policy.c:77
Definition: lb_policy.h:52
void grpc_lb_policy_shutdown(grpc_lb_policy *policy)
Start shutting down (fail any pending picks)
Definition: lb_policy.c:66
void(* destroy)(grpc_lb_policy *policy)
Definition: lb_policy.h:53
A closure over a grpc_iomgr_cb_func.
Definition: iomgr.h:45
gpr_refcount refs
Definition: lb_policy.h:49
void grpc_lb_policy_pick(grpc_lb_policy *policy, grpc_pollset *pollset, grpc_metadata_batch *initial_metadata, grpc_subchannel **target, grpc_iomgr_closure *on_complete)
Given initial metadata in initial_metadata, find an appropriate target for this rpc, and 'return' it by calling on_complete after setting target.
Definition: lb_policy.c:70
void(* shutdown)(grpc_lb_policy *policy)
Definition: lb_policy.h:55
void grpc_lb_policy_ref(grpc_lb_policy *policy)
Definition: lb_policy.c:48
void(* notify_on_state_change)(grpc_lb_policy *policy, grpc_connectivity_state *state, grpc_iomgr_closure *closure)
call notify when the connectivity state of a channel changes from *state.
Definition: lb_policy.h:73
grpc_status_code
Definition: status.h:41
void grpc_lb_policy_unref(grpc_lb_policy *policy)
Definition: lb_policy.c:59
void(* exit_idle)(grpc_lb_policy *policy)
try to enter a READY connectivity state
Definition: lb_policy.h:63
void grpc_lb_policy_notify_on_state_change(grpc_lb_policy *policy, grpc_connectivity_state *state, grpc_iomgr_closure *closure)
Definition: lb_policy.c:85
void grpc_lb_policy_init(grpc_lb_policy *policy, const grpc_lb_policy_vtable *vtable)
called by concrete implementations to initialize the base struct
Definition: lb_policy.c:36
Definition: lb_policy.h:47
Transport op: a set of operations to perform on a transport as a whole.
Definition: transport.h:90
grpc_connectivity_state(* check_connectivity)(grpc_lb_policy *policy)
check the current connectivity of the lb_policy
Definition: lb_policy.h:69