grpc 1.51.0-x86_64-linux → 1.52.0-x86_64-linux

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of grpc might be problematic. Click here for more details.

Files changed (2604) hide show
  1. checksums.yaml +4 -4
  2. data/grpc_c.32-msvcrt.ruby +0 -0
  3. data/grpc_c.64-msvcrt.ruby +0 -0
  4. data/grpc_c.64-ucrt.ruby +0 -0
  5. data/src/ruby/ext/grpc/{ext-export-truffleruby.clang → ext-export-truffleruby-with-ruby-abi-version.clang} +0 -0
  6. data/src/ruby/ext/grpc/{ext-export-truffleruby.gcc → ext-export-truffleruby-with-ruby-abi-version.gcc} +0 -0
  7. data/src/ruby/ext/grpc/ext-export-with-ruby-abi-version.clang +2 -0
  8. data/src/ruby/ext/grpc/ext-export-with-ruby-abi-version.gcc +7 -0
  9. data/src/ruby/ext/grpc/ext-export.clang +0 -1
  10. data/src/ruby/ext/grpc/ext-export.gcc +1 -2
  11. data/src/ruby/ext/grpc/extconf.rb +47 -2
  12. data/src/ruby/ext/grpc/rb_call.c +1 -0
  13. data/src/ruby/ext/grpc/rb_channel.c +1 -0
  14. data/src/ruby/ext/grpc/rb_channel_args.c +1 -0
  15. data/src/ruby/ext/grpc/rb_compression_options.c +1 -1
  16. data/src/ruby/ext/grpc/rb_grpc.c +1 -0
  17. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +38 -36
  18. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +59 -56
  19. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  20. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  21. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  22. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  23. data/src/ruby/lib/grpc/{grpc_c.so → 3.2/grpc_c.so} +0 -0
  24. data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -0
  25. data/src/ruby/lib/grpc/version.rb +1 -1
  26. data/src/ruby/spec/client_server_spec.rb +20 -8
  27. metadata +25 -2597
  28. data/.yardopts +0 -1
  29. data/Makefile +0 -3258
  30. data/include/grpc/byte_buffer.h +0 -27
  31. data/include/grpc/byte_buffer_reader.h +0 -26
  32. data/include/grpc/census.h +0 -40
  33. data/include/grpc/compression.h +0 -75
  34. data/include/grpc/event_engine/README.md +0 -38
  35. data/include/grpc/event_engine/endpoint_config.h +0 -49
  36. data/include/grpc/event_engine/event_engine.h +0 -453
  37. data/include/grpc/event_engine/internal/memory_allocator_impl.h +0 -68
  38. data/include/grpc/event_engine/memory_allocator.h +0 -211
  39. data/include/grpc/event_engine/memory_request.h +0 -57
  40. data/include/grpc/event_engine/port.h +0 -39
  41. data/include/grpc/event_engine/slice.h +0 -286
  42. data/include/grpc/event_engine/slice_buffer.h +0 -135
  43. data/include/grpc/fork.h +0 -26
  44. data/include/grpc/grpc.h +0 -595
  45. data/include/grpc/grpc_cronet.h +0 -38
  46. data/include/grpc/grpc_posix.h +0 -63
  47. data/include/grpc/grpc_security.h +0 -1270
  48. data/include/grpc/grpc_security_constants.h +0 -152
  49. data/include/grpc/impl/codegen/README.md +0 -22
  50. data/include/grpc/impl/codegen/atm.h +0 -97
  51. data/include/grpc/impl/codegen/atm_gcc_atomic.h +0 -84
  52. data/include/grpc/impl/codegen/atm_gcc_sync.h +0 -85
  53. data/include/grpc/impl/codegen/atm_windows.h +0 -132
  54. data/include/grpc/impl/codegen/byte_buffer.h +0 -103
  55. data/include/grpc/impl/codegen/byte_buffer_reader.h +0 -44
  56. data/include/grpc/impl/codegen/compression_types.h +0 -109
  57. data/include/grpc/impl/codegen/connectivity_state.h +0 -47
  58. data/include/grpc/impl/codegen/fork.h +0 -50
  59. data/include/grpc/impl/codegen/gpr_slice.h +0 -71
  60. data/include/grpc/impl/codegen/gpr_types.h +0 -62
  61. data/include/grpc/impl/codegen/grpc_types.h +0 -814
  62. data/include/grpc/impl/codegen/log.h +0 -112
  63. data/include/grpc/impl/codegen/port_platform.h +0 -779
  64. data/include/grpc/impl/codegen/propagation_bits.h +0 -54
  65. data/include/grpc/impl/codegen/slice.h +0 -132
  66. data/include/grpc/impl/codegen/status.h +0 -156
  67. data/include/grpc/impl/codegen/sync.h +0 -68
  68. data/include/grpc/impl/codegen/sync_abseil.h +0 -38
  69. data/include/grpc/impl/codegen/sync_custom.h +0 -40
  70. data/include/grpc/impl/codegen/sync_generic.h +0 -51
  71. data/include/grpc/impl/codegen/sync_posix.h +0 -54
  72. data/include/grpc/impl/codegen/sync_windows.h +0 -42
  73. data/include/grpc/load_reporting.h +0 -48
  74. data/include/grpc/module.modulemap +0 -64
  75. data/include/grpc/slice.h +0 -161
  76. data/include/grpc/slice_buffer.h +0 -84
  77. data/include/grpc/status.h +0 -26
  78. data/include/grpc/support/alloc.h +0 -52
  79. data/include/grpc/support/atm.h +0 -26
  80. data/include/grpc/support/atm_gcc_atomic.h +0 -26
  81. data/include/grpc/support/atm_gcc_sync.h +0 -26
  82. data/include/grpc/support/atm_windows.h +0 -26
  83. data/include/grpc/support/cpu.h +0 -44
  84. data/include/grpc/support/log.h +0 -26
  85. data/include/grpc/support/log_windows.h +0 -38
  86. data/include/grpc/support/port_platform.h +0 -24
  87. data/include/grpc/support/string_util.h +0 -51
  88. data/include/grpc/support/sync.h +0 -282
  89. data/include/grpc/support/sync_abseil.h +0 -26
  90. data/include/grpc/support/sync_custom.h +0 -26
  91. data/include/grpc/support/sync_generic.h +0 -26
  92. data/include/grpc/support/sync_posix.h +0 -26
  93. data/include/grpc/support/sync_windows.h +0 -26
  94. data/include/grpc/support/thd_id.h +0 -44
  95. data/include/grpc/support/time.h +0 -92
  96. data/include/grpc/support/workaround_list.h +0 -31
  97. data/src/core/ext/filters/census/grpc_context.cc +0 -42
  98. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +0 -315
  99. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +0 -142
  100. data/src/core/ext/filters/channel_idle/idle_filter_state.cc +0 -96
  101. data/src/core/ext/filters/channel_idle/idle_filter_state.h +0 -68
  102. data/src/core/ext/filters/client_channel/backend_metric.cc +0 -84
  103. data/src/core/ext/filters/client_channel/backend_metric.h +0 -47
  104. data/src/core/ext/filters/client_channel/backup_poller.cc +0 -187
  105. data/src/core/ext/filters/client_channel/backup_poller.h +0 -40
  106. data/src/core/ext/filters/client_channel/channel_connectivity.cc +0 -244
  107. data/src/core/ext/filters/client_channel/client_channel.cc +0 -3188
  108. data/src/core/ext/filters/client_channel/client_channel.h +0 -626
  109. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +0 -92
  110. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -85
  111. data/src/core/ext/filters/client_channel/client_channel_factory.cc +0 -32
  112. data/src/core/ext/filters/client_channel/client_channel_factory.h +0 -46
  113. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +0 -42
  114. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +0 -153
  115. data/src/core/ext/filters/client_channel/client_channel_service_config.h +0 -111
  116. data/src/core/ext/filters/client_channel/config_selector.cc +0 -60
  117. data/src/core/ext/filters/client_channel/config_selector.h +0 -155
  118. data/src/core/ext/filters/client_channel/connector.h +0 -84
  119. data/src/core/ext/filters/client_channel/dynamic_filters.cc +0 -175
  120. data/src/core/ext/filters/client_channel/dynamic_filters.h +0 -108
  121. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +0 -65
  122. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +0 -63
  123. data/src/core/ext/filters/client_channel/health/health_check_client.cc +0 -175
  124. data/src/core/ext/filters/client_channel/health/health_check_client.h +0 -43
  125. data/src/core/ext/filters/client_channel/http_proxy.cc +0 -200
  126. data/src/core/ext/filters/client_channel/http_proxy.h +0 -52
  127. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +0 -100
  128. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +0 -103
  129. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +0 -49
  130. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +0 -325
  131. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +0 -89
  132. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +0 -150
  133. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +0 -30
  134. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +0 -1933
  135. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +0 -40
  136. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -88
  137. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -41
  138. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +0 -90
  139. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +0 -82
  140. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +0 -202
  141. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +0 -76
  142. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +0 -415
  143. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +0 -57
  144. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +0 -1152
  145. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +0 -94
  146. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +0 -543
  147. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +0 -957
  148. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +0 -889
  149. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +0 -47
  150. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +0 -2512
  151. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +0 -529
  152. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +0 -439
  153. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +0 -793
  154. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +0 -762
  155. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +0 -42
  156. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.h +0 -64
  157. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +0 -29
  158. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +0 -806
  159. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +0 -732
  160. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +0 -1214
  161. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +0 -364
  162. data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +0 -60
  163. data/src/core/ext/filters/client_channel/local_subchannel_pool.h +0 -59
  164. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +0 -149
  165. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +0 -868
  166. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +0 -91
  167. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +0 -115
  168. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +0 -882
  169. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +0 -1204
  170. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +0 -137
  171. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_posix.cc +0 -29
  172. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +0 -35
  173. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +0 -30
  174. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.h +0 -30
  175. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +0 -201
  176. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +0 -368
  177. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +0 -110
  178. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +0 -472
  179. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +0 -258
  180. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +0 -123
  181. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +0 -190
  182. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +0 -1147
  183. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +0 -30
  184. data/src/core/ext/filters/client_channel/retry_filter.cc +0 -2661
  185. data/src/core/ext/filters/client_channel/retry_filter.h +0 -31
  186. data/src/core/ext/filters/client_channel/retry_service_config.cc +0 -282
  187. data/src/core/ext/filters/client_channel/retry_service_config.h +0 -105
  188. data/src/core/ext/filters/client_channel/retry_throttle.cc +0 -141
  189. data/src/core/ext/filters/client_channel/retry_throttle.h +0 -92
  190. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +0 -174
  191. data/src/core/ext/filters/client_channel/subchannel.cc +0 -974
  192. data/src/core/ext/filters/client_channel/subchannel.h +0 -435
  193. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +0 -38
  194. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +0 -66
  195. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +0 -100
  196. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +0 -470
  197. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +0 -222
  198. data/src/core/ext/filters/deadline/deadline_filter.cc +0 -400
  199. data/src/core/ext/filters/deadline/deadline_filter.h +0 -93
  200. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +0 -279
  201. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +0 -71
  202. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +0 -118
  203. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +0 -112
  204. data/src/core/ext/filters/http/client/http_client_filter.cc +0 -159
  205. data/src/core/ext/filters/http/client/http_client_filter.h +0 -61
  206. data/src/core/ext/filters/http/client_authority_filter.cc +0 -90
  207. data/src/core/ext/filters/http/client_authority_filter.h +0 -56
  208. data/src/core/ext/filters/http/http_filters_plugin.cc +0 -97
  209. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +0 -332
  210. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +0 -52
  211. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +0 -322
  212. data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +0 -32
  213. data/src/core/ext/filters/http/server/http_server_filter.cc +0 -161
  214. data/src/core/ext/filters/http/server/http_server_filter.h +0 -63
  215. data/src/core/ext/filters/message_size/message_size_filter.cc +0 -373
  216. data/src/core/ext/filters/message_size/message_size_filter.h +0 -90
  217. data/src/core/ext/filters/rbac/rbac_filter.cc +0 -174
  218. data/src/core/ext/filters/rbac/rbac_filter.h +0 -84
  219. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +0 -819
  220. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +0 -86
  221. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +0 -62
  222. data/src/core/ext/filters/server_config_selector/server_config_selector.h +0 -85
  223. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +0 -160
  224. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +0 -33
  225. data/src/core/ext/transport/chttp2/alpn/alpn.cc +0 -45
  226. data/src/core/ext/transport/chttp2/alpn/alpn.h +0 -36
  227. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +0 -434
  228. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +0 -77
  229. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +0 -1094
  230. data/src/core/ext/transport/chttp2/server/chttp2_server.h +0 -47
  231. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +0 -252
  232. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +0 -58
  233. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +0 -232
  234. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +0 -42
  235. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +0 -2963
  236. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +0 -77
  237. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  238. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  239. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +0 -287
  240. data/src/core/ext/transport/chttp2/transport/decode_huff.h +0 -1018
  241. data/src/core/ext/transport/chttp2/transport/flow_control.cc +0 -442
  242. data/src/core/ext/transport/chttp2/transport/flow_control.h +0 -386
  243. data/src/core/ext/transport/chttp2/transport/frame.h +0 -43
  244. data/src/core/ext/transport/chttp2/transport/frame_data.cc +0 -156
  245. data/src/core/ext/transport/chttp2/transport/frame_data.h +0 -60
  246. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +0 -190
  247. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +0 -65
  248. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +0 -137
  249. data/src/core/ext/transport/chttp2/transport/frame_ping.h +0 -49
  250. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +0 -130
  251. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +0 -54
  252. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +0 -241
  253. data/src/core/ext/transport/chttp2/transport/frame_settings.h +0 -66
  254. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +0 -122
  255. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +0 -46
  256. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +0 -47
  257. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +0 -667
  258. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +0 -236
  259. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +0 -89
  260. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +0 -80
  261. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +0 -1382
  262. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +0 -142
  263. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +0 -247
  264. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +0 -137
  265. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +0 -62
  266. data/src/core/ext/transport/chttp2/transport/http2_settings.h +0 -60
  267. data/src/core/ext/transport/chttp2/transport/huffsyms.cc +0 -92
  268. data/src/core/ext/transport/chttp2/transport/huffsyms.h +0 -32
  269. data/src/core/ext/transport/chttp2/transport/internal.h +0 -803
  270. data/src/core/ext/transport/chttp2/transport/parsing.cc +0 -730
  271. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +0 -216
  272. data/src/core/ext/transport/chttp2/transport/stream_map.cc +0 -177
  273. data/src/core/ext/transport/chttp2/transport/stream_map.h +0 -68
  274. data/src/core/ext/transport/chttp2/transport/varint.cc +0 -61
  275. data/src/core/ext/transport/chttp2/transport/varint.h +0 -76
  276. data/src/core/ext/transport/chttp2/transport/writing.cc +0 -683
  277. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  278. data/src/core/ext/transport/inproc/inproc_transport.cc +0 -1274
  279. data/src/core/ext/transport/inproc/inproc_transport.h +0 -34
  280. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +0 -117
  281. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +0 -502
  282. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +0 -121
  283. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +0 -569
  284. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +0 -125
  285. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +0 -516
  286. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +0 -352
  287. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +0 -1768
  288. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +0 -56
  289. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +0 -159
  290. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +0 -64
  291. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +0 -189
  292. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +0 -46
  293. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +0 -128
  294. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +0 -43
  295. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +0 -106
  296. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +0 -43
  297. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +0 -101
  298. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +0 -106
  299. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +0 -613
  300. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +0 -48
  301. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +0 -107
  302. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +0 -60
  303. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +0 -81
  304. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +0 -53
  305. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +0 -103
  306. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +0 -270
  307. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +0 -1300
  308. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +0 -413
  309. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +0 -2251
  310. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +0 -95
  311. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +0 -394
  312. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +0 -544
  313. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +0 -3066
  314. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +0 -48
  315. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +0 -107
  316. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +0 -89
  317. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +0 -549
  318. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +0 -299
  319. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +0 -1437
  320. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +0 -145
  321. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +0 -664
  322. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +0 -49
  323. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +0 -120
  324. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +0 -421
  325. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +0 -1891
  326. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +0 -163
  327. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +0 -806
  328. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +0 -47
  329. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +0 -104
  330. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +0 -47
  331. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +0 -107
  332. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +0 -58
  333. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +0 -159
  334. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +0 -269
  335. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +0 -1329
  336. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +0 -220
  337. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +0 -1255
  338. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +0 -49
  339. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +0 -126
  340. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +0 -323
  341. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +0 -1759
  342. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +0 -40
  343. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +0 -88
  344. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +0 -60
  345. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +0 -177
  346. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +0 -47
  347. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +0 -148
  348. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +0 -56
  349. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +0 -182
  350. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +0 -48
  351. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +0 -122
  352. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +0 -106
  353. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +0 -360
  354. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +0 -144
  355. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +0 -647
  356. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +0 -129
  357. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +0 -588
  358. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +0 -46
  359. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +0 -98
  360. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +0 -189
  361. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +0 -1041
  362. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +0 -186
  363. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +0 -969
  364. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +0 -63
  365. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +0 -238
  366. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +0 -59
  367. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +0 -186
  368. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +0 -53
  369. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +0 -140
  370. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +0 -165
  371. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +0 -748
  372. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +0 -174
  373. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +0 -757
  374. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +0 -221
  375. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +0 -1094
  376. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +0 -86
  377. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +0 -402
  378. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +0 -1096
  379. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +0 -6440
  380. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +0 -79
  381. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +0 -267
  382. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +0 -241
  383. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +0 -1191
  384. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +0 -44
  385. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +0 -92
  386. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +0 -49
  387. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +0 -107
  388. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +0 -63
  389. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +0 -175
  390. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +0 -52
  391. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +0 -138
  392. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +0 -63
  393. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +0 -254
  394. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +0 -46
  395. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +0 -98
  396. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +0 -47
  397. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +0 -98
  398. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +0 -69
  399. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +0 -221
  400. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +0 -33
  401. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +0 -43
  402. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +0 -71
  403. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +0 -226
  404. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +0 -54
  405. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +0 -150
  406. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +0 -42
  407. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +0 -89
  408. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +0 -96
  409. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +0 -395
  410. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +0 -94
  411. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +0 -445
  412. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +0 -71
  413. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +0 -237
  414. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +0 -55
  415. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +0 -172
  416. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +0 -471
  417. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +0 -2731
  418. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +0 -52
  419. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +0 -168
  420. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +0 -46
  421. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +0 -98
  422. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +0 -28
  423. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +0 -38
  424. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +0 -177
  425. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +0 -932
  426. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +0 -88
  427. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +0 -320
  428. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +0 -191
  429. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +0 -1063
  430. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +0 -62
  431. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +0 -168
  432. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +0 -38
  433. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +0 -74
  434. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +0 -280
  435. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +0 -1375
  436. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +0 -68
  437. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +0 -218
  438. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +0 -138
  439. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +0 -651
  440. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +0 -48
  441. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +0 -116
  442. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +0 -76
  443. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +0 -265
  444. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +0 -74
  445. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +0 -230
  446. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +0 -62
  447. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +0 -196
  448. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +0 -49
  449. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +0 -121
  450. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +0 -48
  451. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +0 -117
  452. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +0 -47
  453. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +0 -104
  454. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +0 -80
  455. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +0 -246
  456. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +0 -67
  457. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +0 -226
  458. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +0 -60
  459. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +0 -178
  460. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +0 -78
  461. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +0 -306
  462. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +0 -107
  463. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +0 -457
  464. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +0 -107
  465. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +0 -439
  466. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +0 -66
  467. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +0 -213
  468. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +0 -26
  469. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +0 -39
  470. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +0 -42
  471. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +0 -143
  472. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +0 -54
  473. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +0 -147
  474. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +0 -66
  475. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +0 -208
  476. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +0 -63
  477. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +0 -202
  478. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +0 -26
  479. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +0 -41
  480. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +0 -43
  481. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +0 -101
  482. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +0 -51
  483. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +0 -131
  484. data/src/core/ext/upb-generated/google/api/annotations.upb.c +0 -40
  485. data/src/core/ext/upb-generated/google/api/annotations.upb.h +0 -53
  486. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +0 -271
  487. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +0 -1280
  488. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +0 -283
  489. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +0 -1386
  490. data/src/core/ext/upb-generated/google/api/http.upb.c +0 -81
  491. data/src/core/ext/upb-generated/google/api/http.upb.h +0 -343
  492. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +0 -46
  493. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +0 -115
  494. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +0 -40
  495. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +0 -92
  496. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +0 -578
  497. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +0 -3217
  498. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +0 -40
  499. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +0 -92
  500. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +0 -35
  501. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +0 -74
  502. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +0 -95
  503. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +0 -329
  504. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +0 -40
  505. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +0 -92
  506. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +0 -127
  507. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +0 -475
  508. data/src/core/ext/upb-generated/google/rpc/status.upb.c +0 -46
  509. data/src/core/ext/upb-generated/google/rpc/status.upb.h +0 -115
  510. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +0 -84
  511. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +0 -335
  512. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +0 -63
  513. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +0 -188
  514. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +0 -240
  515. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +0 -1173
  516. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +0 -57
  517. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +0 -182
  518. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +0 -50
  519. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +0 -139
  520. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +0 -161
  521. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +0 -705
  522. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +0 -70
  523. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +0 -216
  524. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +0 -175
  525. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +0 -792
  526. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +0 -110
  527. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +0 -290
  528. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +0 -55
  529. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +0 -112
  530. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +0 -38
  531. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +0 -46
  532. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +0 -54
  533. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +0 -119
  534. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +0 -53
  535. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +0 -103
  536. data/src/core/ext/upb-generated/validate/validate.upb.c +0 -560
  537. data/src/core/ext/upb-generated/validate/validate.upb.h +0 -4105
  538. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +0 -110
  539. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +0 -290
  540. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +0 -55
  541. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +0 -112
  542. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +0 -38
  543. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +0 -46
  544. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +0 -105
  545. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +0 -306
  546. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +0 -53
  547. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +0 -103
  548. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +0 -41
  549. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +0 -83
  550. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +0 -66
  551. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +0 -208
  552. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +0 -56
  553. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +0 -119
  554. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +0 -46
  555. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +0 -107
  556. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +0 -49
  557. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +0 -131
  558. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +0 -68
  559. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +0 -248
  560. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +0 -49
  561. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +0 -125
  562. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +0 -73
  563. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +0 -191
  564. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +0 -47
  565. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +0 -113
  566. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +0 -207
  567. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +0 -914
  568. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +0 -52
  569. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +0 -151
  570. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +0 -65
  571. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +0 -226
  572. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +0 -46
  573. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +0 -107
  574. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +0 -84
  575. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +0 -55
  576. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +0 -127
  577. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +0 -50
  578. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +0 -102
  579. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +0 -55
  580. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +0 -256
  581. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +0 -115
  582. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +0 -43
  583. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +0 -40
  584. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +0 -56
  585. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +0 -40
  586. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +0 -49
  587. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +0 -35
  588. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +0 -46
  589. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +0 -35
  590. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +0 -46
  591. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +0 -35
  592. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +0 -142
  593. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +0 -40
  594. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +0 -51
  595. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +0 -35
  596. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +0 -48
  597. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +0 -30
  598. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +0 -38
  599. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +0 -35
  600. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +0 -222
  601. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +0 -105
  602. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +0 -397
  603. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +0 -120
  604. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +0 -98
  605. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +0 -45
  606. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +0 -559
  607. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +0 -155
  608. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +0 -51
  609. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +0 -35
  610. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +0 -138
  611. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +0 -35
  612. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +0 -206
  613. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +0 -105
  614. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +0 -112
  615. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +0 -65
  616. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +0 -54
  617. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +0 -35
  618. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +0 -270
  619. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +0 -150
  620. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +0 -168
  621. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +0 -65
  622. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +0 -53
  623. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +0 -35
  624. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +0 -47
  625. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +0 -35
  626. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +0 -53
  627. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +0 -40
  628. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +0 -235
  629. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +0 -100
  630. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +0 -228
  631. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +0 -75
  632. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +0 -53
  633. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +0 -35
  634. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +0 -300
  635. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +0 -110
  636. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +0 -41
  637. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +0 -35
  638. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +0 -55
  639. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +0 -40
  640. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +0 -57
  641. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +0 -35
  642. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +0 -70
  643. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +0 -35
  644. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +0 -49
  645. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +0 -35
  646. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +0 -99
  647. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +0 -50
  648. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +0 -128
  649. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +0 -60
  650. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +0 -136
  651. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +0 -55
  652. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +0 -48
  653. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +0 -35
  654. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +0 -220
  655. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +0 -65
  656. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +0 -190
  657. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +0 -65
  658. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +0 -88
  659. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +0 -35
  660. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +0 -71
  661. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +0 -40
  662. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +0 -69
  663. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +0 -35
  664. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +0 -125
  665. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +0 -70
  666. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +0 -134
  667. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +0 -75
  668. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +0 -194
  669. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +0 -75
  670. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +0 -112
  671. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +0 -40
  672. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +0 -939
  673. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +0 -305
  674. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +0 -77
  675. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +0 -45
  676. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +0 -199
  677. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +0 -90
  678. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +0 -54
  679. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +0 -35
  680. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +0 -57
  681. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +0 -35
  682. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +0 -57
  683. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +0 -40
  684. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +0 -72
  685. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +0 -35
  686. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +0 -99
  687. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +0 -35
  688. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +0 -47
  689. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +0 -35
  690. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +0 -52
  691. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +0 -35
  692. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +0 -71
  693. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +0 -40
  694. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +0 -61
  695. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +0 -30
  696. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +0 -75
  697. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +0 -40
  698. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +0 -77
  699. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +0 -35
  700. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +0 -50
  701. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +0 -35
  702. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +0 -92
  703. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +0 -55
  704. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +0 -117
  705. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +0 -45
  706. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +0 -80
  707. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +0 -40
  708. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +0 -78
  709. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +0 -35
  710. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +0 -562
  711. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +0 -130
  712. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +0 -48
  713. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +0 -30
  714. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +0 -213
  715. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +0 -65
  716. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +0 -91
  717. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +0 -45
  718. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +0 -254
  719. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +0 -65
  720. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +0 -58
  721. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +0 -40
  722. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +0 -58
  723. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +0 -35
  724. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +0 -197
  725. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +0 -100
  726. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +0 -76
  727. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +0 -40
  728. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +0 -153
  729. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +0 -55
  730. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +0 -46
  731. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +0 -35
  732. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +0 -56
  733. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +0 -50
  734. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +0 -52
  735. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +0 -50
  736. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +0 -61
  737. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +0 -40
  738. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +0 -54
  739. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +0 -35
  740. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +0 -52
  741. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +0 -35
  742. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +0 -51
  743. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +0 -35
  744. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +0 -71
  745. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +0 -45
  746. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +0 -65
  747. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +0 -40
  748. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +0 -58
  749. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +0 -40
  750. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +0 -75
  751. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +0 -45
  752. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +0 -78
  753. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +0 -65
  754. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +0 -85
  755. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +0 -55
  756. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +0 -53
  757. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +0 -45
  758. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +0 -36
  759. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +0 -30
  760. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +0 -94
  761. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +0 -35
  762. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +0 -54
  763. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +0 -40
  764. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +0 -48
  765. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +0 -45
  766. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +0 -69
  767. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +0 -40
  768. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +0 -38
  769. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +0 -30
  770. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +0 -44
  771. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +0 -35
  772. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +0 -57
  773. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +0 -35
  774. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +0 -40
  775. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +0 -30
  776. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +0 -154
  777. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +0 -95
  778. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +0 -153
  779. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +0 -100
  780. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +0 -52
  781. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +0 -45
  782. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +0 -39
  783. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +0 -35
  784. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +0 -34
  785. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +0 -35
  786. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +0 -331
  787. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +0 -165
  788. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +0 -35
  789. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +0 -35
  790. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +0 -32
  791. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +0 -35
  792. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +0 -54
  793. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +0 -50
  794. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +0 -35
  795. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +0 -35
  796. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +0 -45
  797. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +0 -75
  798. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +0 -37
  799. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +0 -35
  800. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +0 -67
  801. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +0 -50
  802. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +0 -99
  803. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +0 -75
  804. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +0 -62
  805. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +0 -45
  806. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +0 -47
  807. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +0 -35
  808. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +0 -34
  809. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +0 -30
  810. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +0 -46
  811. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +0 -35
  812. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +0 -39
  813. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +0 -35
  814. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +0 -283
  815. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +0 -145
  816. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +0 -63
  817. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +0 -45
  818. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +0 -47
  819. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +0 -35
  820. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +0 -35
  821. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +0 -30
  822. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +0 -64
  823. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +0 -50
  824. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +0 -40
  825. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +0 -35
  826. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +0 -38
  827. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +0 -35
  828. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +0 -56
  829. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +0 -40
  830. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +0 -39
  831. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +0 -40
  832. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +0 -41
  833. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +0 -35
  834. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +0 -45
  835. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +0 -35
  836. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +0 -61
  837. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +0 -40
  838. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +0 -46
  839. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +0 -35
  840. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +0 -126
  841. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +0 -80
  842. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +0 -40
  843. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +0 -40
  844. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +0 -52
  845. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +0 -40
  846. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +0 -40
  847. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +0 -35
  848. data/src/core/ext/xds/certificate_provider_store.cc +0 -159
  849. data/src/core/ext/xds/certificate_provider_store.h +0 -138
  850. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +0 -150
  851. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +0 -77
  852. data/src/core/ext/xds/upb_utils.h +0 -45
  853. data/src/core/ext/xds/xds_api.cc +0 -646
  854. data/src/core/ext/xds/xds_api.h +0 -192
  855. data/src/core/ext/xds/xds_bootstrap.cc +0 -38
  856. data/src/core/ext/xds/xds_bootstrap.h +0 -88
  857. data/src/core/ext/xds/xds_bootstrap_grpc.cc +0 -361
  858. data/src/core/ext/xds/xds_bootstrap_grpc.h +0 -184
  859. data/src/core/ext/xds/xds_certificate_provider.cc +0 -416
  860. data/src/core/ext/xds/xds_certificate_provider.h +0 -183
  861. data/src/core/ext/xds/xds_channel_args.h +0 -32
  862. data/src/core/ext/xds/xds_channel_stack_modifier.cc +0 -119
  863. data/src/core/ext/xds/xds_channel_stack_modifier.h +0 -65
  864. data/src/core/ext/xds/xds_client.cc +0 -2032
  865. data/src/core/ext/xds/xds_client.h +0 -341
  866. data/src/core/ext/xds/xds_client_grpc.cc +0 -210
  867. data/src/core/ext/xds/xds_client_grpc.h +0 -79
  868. data/src/core/ext/xds/xds_client_stats.cc +0 -159
  869. data/src/core/ext/xds/xds_client_stats.h +0 -242
  870. data/src/core/ext/xds/xds_cluster.cc +0 -659
  871. data/src/core/ext/xds/xds_cluster.h +0 -116
  872. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +0 -152
  873. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +0 -92
  874. data/src/core/ext/xds/xds_common_types.cc +0 -501
  875. data/src/core/ext/xds/xds_common_types.h +0 -108
  876. data/src/core/ext/xds/xds_endpoint.cc +0 -468
  877. data/src/core/ext/xds/xds_endpoint.h +0 -139
  878. data/src/core/ext/xds/xds_http_fault_filter.cc +0 -235
  879. data/src/core/ext/xds/xds_http_fault_filter.h +0 -58
  880. data/src/core/ext/xds/xds_http_filters.cc +0 -116
  881. data/src/core/ext/xds/xds_http_filters.h +0 -181
  882. data/src/core/ext/xds/xds_http_rbac_filter.cc +0 -505
  883. data/src/core/ext/xds/xds_http_rbac_filter.h +0 -58
  884. data/src/core/ext/xds/xds_lb_policy_registry.cc +0 -243
  885. data/src/core/ext/xds/xds_lb_policy_registry.h +0 -71
  886. data/src/core/ext/xds/xds_listener.cc +0 -1144
  887. data/src/core/ext/xds/xds_listener.h +0 -224
  888. data/src/core/ext/xds/xds_resource_type.h +0 -104
  889. data/src/core/ext/xds/xds_resource_type_impl.h +0 -86
  890. data/src/core/ext/xds/xds_route_config.cc +0 -1166
  891. data/src/core/ext/xds/xds_route_config.h +0 -241
  892. data/src/core/ext/xds/xds_routing.cc +0 -264
  893. data/src/core/ext/xds/xds_routing.h +0 -106
  894. data/src/core/ext/xds/xds_server_config_fetcher.cc +0 -1375
  895. data/src/core/ext/xds/xds_transport.h +0 -86
  896. data/src/core/ext/xds/xds_transport_grpc.cc +0 -356
  897. data/src/core/ext/xds/xds_transport_grpc.h +0 -135
  898. data/src/core/lib/address_utils/parse_address.cc +0 -340
  899. data/src/core/lib/address_utils/parse_address.h +0 -86
  900. data/src/core/lib/address_utils/sockaddr_utils.cc +0 -443
  901. data/src/core/lib/address_utils/sockaddr_utils.h +0 -100
  902. data/src/core/lib/avl/avl.h +0 -482
  903. data/src/core/lib/backoff/backoff.cc +0 -47
  904. data/src/core/lib/backoff/backoff.h +0 -89
  905. data/src/core/lib/channel/call_finalization.h +0 -88
  906. data/src/core/lib/channel/call_tracer.h +0 -94
  907. data/src/core/lib/channel/channel_args.cc +0 -626
  908. data/src/core/lib/channel/channel_args.h +0 -544
  909. data/src/core/lib/channel/channel_args_preconditioning.cc +0 -43
  910. data/src/core/lib/channel/channel_args_preconditioning.h +0 -62
  911. data/src/core/lib/channel/channel_fwd.h +0 -26
  912. data/src/core/lib/channel/channel_stack.cc +0 -314
  913. data/src/core/lib/channel/channel_stack.h +0 -394
  914. data/src/core/lib/channel/channel_stack_builder.cc +0 -51
  915. data/src/core/lib/channel/channel_stack_builder.h +0 -120
  916. data/src/core/lib/channel/channel_stack_builder_impl.cc +0 -113
  917. data/src/core/lib/channel/channel_stack_builder_impl.h +0 -48
  918. data/src/core/lib/channel/channel_trace.cc +0 -183
  919. data/src/core/lib/channel/channel_trace.h +0 -138
  920. data/src/core/lib/channel/channelz.cc +0 -583
  921. data/src/core/lib/channel/channelz.h +0 -374
  922. data/src/core/lib/channel/channelz_registry.cc +0 -277
  923. data/src/core/lib/channel/channelz_registry.h +0 -100
  924. data/src/core/lib/channel/connected_channel.cc +0 -901
  925. data/src/core/lib/channel/connected_channel.h +0 -32
  926. data/src/core/lib/channel/context.h +0 -63
  927. data/src/core/lib/channel/promise_based_filter.cc +0 -2126
  928. data/src/core/lib/channel/promise_based_filter.h +0 -848
  929. data/src/core/lib/channel/status_util.cc +0 -138
  930. data/src/core/lib/channel/status_util.h +0 -74
  931. data/src/core/lib/compression/compression.cc +0 -96
  932. data/src/core/lib/compression/compression_internal.cc +0 -249
  933. data/src/core/lib/compression/compression_internal.h +0 -93
  934. data/src/core/lib/compression/message_compress.cc +0 -194
  935. data/src/core/lib/compression/message_compress.h +0 -39
  936. data/src/core/lib/config/core_configuration.cc +0 -111
  937. data/src/core/lib/config/core_configuration.h +0 -243
  938. data/src/core/lib/debug/event_log.cc +0 -88
  939. data/src/core/lib/debug/event_log.h +0 -81
  940. data/src/core/lib/debug/histogram_view.cc +0 -69
  941. data/src/core/lib/debug/histogram_view.h +0 -37
  942. data/src/core/lib/debug/stats.cc +0 -68
  943. data/src/core/lib/debug/stats.h +0 -64
  944. data/src/core/lib/debug/stats_data.cc +0 -341
  945. data/src/core/lib/debug/stats_data.h +0 -292
  946. data/src/core/lib/debug/trace.cc +0 -153
  947. data/src/core/lib/debug/trace.h +0 -133
  948. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +0 -40
  949. data/src/core/lib/event_engine/channel_args_endpoint_config.h +0 -49
  950. data/src/core/lib/event_engine/common_closures.h +0 -71
  951. data/src/core/lib/event_engine/default_event_engine.cc +0 -94
  952. data/src/core/lib/event_engine/default_event_engine.h +0 -49
  953. data/src/core/lib/event_engine/default_event_engine_factory.cc +0 -48
  954. data/src/core/lib/event_engine/default_event_engine_factory.h +0 -33
  955. data/src/core/lib/event_engine/executor/executor.h +0 -38
  956. data/src/core/lib/event_engine/forkable.cc +0 -101
  957. data/src/core/lib/event_engine/forkable.h +0 -61
  958. data/src/core/lib/event_engine/handle_containers.h +0 -67
  959. data/src/core/lib/event_engine/memory_allocator.cc +0 -74
  960. data/src/core/lib/event_engine/poller.h +0 -62
  961. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +0 -618
  962. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +0 -129
  963. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +0 -901
  964. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +0 -97
  965. data/src/core/lib/event_engine/posix_engine/event_poller.h +0 -111
  966. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +0 -74
  967. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +0 -33
  968. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +0 -77
  969. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +0 -179
  970. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +0 -267
  971. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +0 -73
  972. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +0 -1270
  973. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +0 -682
  974. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +0 -577
  975. data/src/core/lib/event_engine/posix_engine/posix_engine.h +0 -245
  976. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +0 -80
  977. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +0 -1081
  978. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +0 -361
  979. data/src/core/lib/event_engine/posix_engine/timer.cc +0 -311
  980. data/src/core/lib/event_engine/posix_engine/timer.h +0 -194
  981. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +0 -107
  982. data/src/core/lib/event_engine/posix_engine/timer_heap.h +0 -56
  983. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +0 -174
  984. data/src/core/lib/event_engine/posix_engine/timer_manager.h +0 -114
  985. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +0 -301
  986. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +0 -179
  987. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +0 -126
  988. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +0 -45
  989. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +0 -151
  990. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +0 -45
  991. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +0 -76
  992. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +0 -67
  993. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +0 -37
  994. data/src/core/lib/event_engine/resolved_address.cc +0 -41
  995. data/src/core/lib/event_engine/slice.cc +0 -103
  996. data/src/core/lib/event_engine/slice_buffer.cc +0 -50
  997. data/src/core/lib/event_engine/socket_notifier.h +0 -55
  998. data/src/core/lib/event_engine/thread_pool.cc +0 -276
  999. data/src/core/lib/event_engine/thread_pool.h +0 -137
  1000. data/src/core/lib/event_engine/time_util.cc +0 -30
  1001. data/src/core/lib/event_engine/time_util.h +0 -32
  1002. data/src/core/lib/event_engine/trace.cc +0 -18
  1003. data/src/core/lib/event_engine/trace.h +0 -30
  1004. data/src/core/lib/event_engine/utils.cc +0 -44
  1005. data/src/core/lib/event_engine/utils.h +0 -36
  1006. data/src/core/lib/event_engine/windows/iocp.cc +0 -155
  1007. data/src/core/lib/event_engine/windows/iocp.h +0 -69
  1008. data/src/core/lib/event_engine/windows/win_socket.cc +0 -196
  1009. data/src/core/lib/event_engine/windows/win_socket.h +0 -120
  1010. data/src/core/lib/event_engine/windows/windows_engine.cc +0 -165
  1011. data/src/core/lib/event_engine/windows/windows_engine.h +0 -124
  1012. data/src/core/lib/experiments/config.cc +0 -146
  1013. data/src/core/lib/experiments/config.h +0 -43
  1014. data/src/core/lib/experiments/experiments.cc +0 -86
  1015. data/src/core/lib/experiments/experiments.h +0 -63
  1016. data/src/core/lib/gpr/alloc.cc +0 -68
  1017. data/src/core/lib/gpr/alloc.h +0 -28
  1018. data/src/core/lib/gpr/atm.cc +0 -35
  1019. data/src/core/lib/gpr/cpu_iphone.cc +0 -44
  1020. data/src/core/lib/gpr/cpu_linux.cc +0 -86
  1021. data/src/core/lib/gpr/cpu_posix.cc +0 -83
  1022. data/src/core/lib/gpr/cpu_windows.cc +0 -33
  1023. data/src/core/lib/gpr/log.cc +0 -145
  1024. data/src/core/lib/gpr/log_android.cc +0 -77
  1025. data/src/core/lib/gpr/log_linux.cc +0 -113
  1026. data/src/core/lib/gpr/log_posix.cc +0 -110
  1027. data/src/core/lib/gpr/log_windows.cc +0 -115
  1028. data/src/core/lib/gpr/spinlock.h +0 -53
  1029. data/src/core/lib/gpr/string.cc +0 -343
  1030. data/src/core/lib/gpr/string.h +0 -112
  1031. data/src/core/lib/gpr/string_posix.cc +0 -72
  1032. data/src/core/lib/gpr/string_util_windows.cc +0 -55
  1033. data/src/core/lib/gpr/string_windows.cc +0 -69
  1034. data/src/core/lib/gpr/sync.cc +0 -124
  1035. data/src/core/lib/gpr/sync_abseil.cc +0 -100
  1036. data/src/core/lib/gpr/sync_posix.cc +0 -157
  1037. data/src/core/lib/gpr/sync_windows.cc +0 -120
  1038. data/src/core/lib/gpr/time.cc +0 -267
  1039. data/src/core/lib/gpr/time_posix.cc +0 -177
  1040. data/src/core/lib/gpr/time_precise.cc +0 -168
  1041. data/src/core/lib/gpr/time_precise.h +0 -70
  1042. data/src/core/lib/gpr/time_windows.cc +0 -102
  1043. data/src/core/lib/gpr/tmpfile.h +0 -32
  1044. data/src/core/lib/gpr/tmpfile_msys.cc +0 -58
  1045. data/src/core/lib/gpr/tmpfile_posix.cc +0 -70
  1046. data/src/core/lib/gpr/tmpfile_windows.cc +0 -67
  1047. data/src/core/lib/gpr/useful.h +0 -171
  1048. data/src/core/lib/gpr/wrap_memcpy.cc +0 -43
  1049. data/src/core/lib/gprpp/atomic_utils.h +0 -47
  1050. data/src/core/lib/gprpp/bitset.h +0 -201
  1051. data/src/core/lib/gprpp/chunked_vector.h +0 -257
  1052. data/src/core/lib/gprpp/construct_destruct.h +0 -40
  1053. data/src/core/lib/gprpp/cpp_impl_of.h +0 -49
  1054. data/src/core/lib/gprpp/debug_location.h +0 -87
  1055. data/src/core/lib/gprpp/dual_ref_counted.h +0 -327
  1056. data/src/core/lib/gprpp/env.h +0 -53
  1057. data/src/core/lib/gprpp/env_linux.cc +0 -80
  1058. data/src/core/lib/gprpp/env_posix.cc +0 -47
  1059. data/src/core/lib/gprpp/env_windows.cc +0 -56
  1060. data/src/core/lib/gprpp/examine_stack.cc +0 -43
  1061. data/src/core/lib/gprpp/examine_stack.h +0 -45
  1062. data/src/core/lib/gprpp/fork.cc +0 -233
  1063. data/src/core/lib/gprpp/fork.h +0 -95
  1064. data/src/core/lib/gprpp/global_config.h +0 -93
  1065. data/src/core/lib/gprpp/global_config_custom.h +0 -29
  1066. data/src/core/lib/gprpp/global_config_env.cc +0 -139
  1067. data/src/core/lib/gprpp/global_config_env.h +0 -133
  1068. data/src/core/lib/gprpp/global_config_generic.h +0 -40
  1069. data/src/core/lib/gprpp/host_port.cc +0 -114
  1070. data/src/core/lib/gprpp/host_port.h +0 -56
  1071. data/src/core/lib/gprpp/load_file.cc +0 -75
  1072. data/src/core/lib/gprpp/load_file.h +0 -33
  1073. data/src/core/lib/gprpp/manual_constructor.h +0 -146
  1074. data/src/core/lib/gprpp/match.h +0 -75
  1075. data/src/core/lib/gprpp/memory.h +0 -53
  1076. data/src/core/lib/gprpp/mpscq.cc +0 -108
  1077. data/src/core/lib/gprpp/mpscq.h +0 -99
  1078. data/src/core/lib/gprpp/no_destruct.h +0 -94
  1079. data/src/core/lib/gprpp/notification.h +0 -67
  1080. data/src/core/lib/gprpp/orphanable.h +0 -122
  1081. data/src/core/lib/gprpp/overload.h +0 -59
  1082. data/src/core/lib/gprpp/packed_table.h +0 -40
  1083. data/src/core/lib/gprpp/per_cpu.h +0 -46
  1084. data/src/core/lib/gprpp/ref_counted.h +0 -349
  1085. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -337
  1086. data/src/core/lib/gprpp/single_set_ptr.h +0 -87
  1087. data/src/core/lib/gprpp/sorted_pack.h +0 -98
  1088. data/src/core/lib/gprpp/stat.h +0 -36
  1089. data/src/core/lib/gprpp/stat_posix.cc +0 -55
  1090. data/src/core/lib/gprpp/stat_windows.cc +0 -49
  1091. data/src/core/lib/gprpp/status_helper.cc +0 -454
  1092. data/src/core/lib/gprpp/status_helper.h +0 -189
  1093. data/src/core/lib/gprpp/strerror.cc +0 -41
  1094. data/src/core/lib/gprpp/strerror.h +0 -29
  1095. data/src/core/lib/gprpp/sync.h +0 -200
  1096. data/src/core/lib/gprpp/table.h +0 -451
  1097. data/src/core/lib/gprpp/tchar.cc +0 -49
  1098. data/src/core/lib/gprpp/tchar.h +0 -33
  1099. data/src/core/lib/gprpp/thd.h +0 -171
  1100. data/src/core/lib/gprpp/thd_posix.cc +0 -211
  1101. data/src/core/lib/gprpp/thd_windows.cc +0 -172
  1102. data/src/core/lib/gprpp/time.cc +0 -234
  1103. data/src/core/lib/gprpp/time.h +0 -367
  1104. data/src/core/lib/gprpp/time_averaged_stats.cc +0 -60
  1105. data/src/core/lib/gprpp/time_averaged_stats.h +0 -79
  1106. data/src/core/lib/gprpp/time_util.cc +0 -81
  1107. data/src/core/lib/gprpp/time_util.h +0 -42
  1108. data/src/core/lib/gprpp/unique_type_name.h +0 -104
  1109. data/src/core/lib/gprpp/validation_errors.cc +0 -61
  1110. data/src/core/lib/gprpp/validation_errors.h +0 -127
  1111. data/src/core/lib/gprpp/work_serializer.cc +0 -247
  1112. data/src/core/lib/gprpp/work_serializer.h +0 -86
  1113. data/src/core/lib/handshaker/proxy_mapper.h +0 -53
  1114. data/src/core/lib/handshaker/proxy_mapper_registry.cc +0 -71
  1115. data/src/core/lib/handshaker/proxy_mapper_registry.h +0 -75
  1116. data/src/core/lib/http/format_request.cc +0 -137
  1117. data/src/core/lib/http/format_request.h +0 -38
  1118. data/src/core/lib/http/httpcli.cc +0 -393
  1119. data/src/core/lib/http/httpcli.h +0 -272
  1120. data/src/core/lib/http/httpcli_security_connector.cc +0 -213
  1121. data/src/core/lib/http/httpcli_ssl_credentials.h +0 -39
  1122. data/src/core/lib/http/parser.cc +0 -451
  1123. data/src/core/lib/http/parser.h +0 -130
  1124. data/src/core/lib/iomgr/block_annotate.h +0 -57
  1125. data/src/core/lib/iomgr/buffer_list.cc +0 -296
  1126. data/src/core/lib/iomgr/buffer_list.h +0 -179
  1127. data/src/core/lib/iomgr/call_combiner.cc +0 -258
  1128. data/src/core/lib/iomgr/call_combiner.h +0 -214
  1129. data/src/core/lib/iomgr/cfstream_handle.cc +0 -207
  1130. data/src/core/lib/iomgr/cfstream_handle.h +0 -90
  1131. data/src/core/lib/iomgr/closure.h +0 -310
  1132. data/src/core/lib/iomgr/combiner.cc +0 -330
  1133. data/src/core/lib/iomgr/combiner.h +0 -89
  1134. data/src/core/lib/iomgr/dualstack_socket_posix.cc +0 -48
  1135. data/src/core/lib/iomgr/dynamic_annotations.h +0 -67
  1136. data/src/core/lib/iomgr/endpoint.cc +0 -67
  1137. data/src/core/lib/iomgr/endpoint.h +0 -109
  1138. data/src/core/lib/iomgr/endpoint_cfstream.cc +0 -376
  1139. data/src/core/lib/iomgr/endpoint_cfstream.h +0 -49
  1140. data/src/core/lib/iomgr/endpoint_pair.h +0 -34
  1141. data/src/core/lib/iomgr/endpoint_pair_posix.cc +0 -81
  1142. data/src/core/lib/iomgr/endpoint_pair_windows.cc +0 -86
  1143. data/src/core/lib/iomgr/error.cc +0 -202
  1144. data/src/core/lib/iomgr/error.h +0 -169
  1145. data/src/core/lib/iomgr/error_cfstream.cc +0 -54
  1146. data/src/core/lib/iomgr/error_cfstream.h +0 -31
  1147. data/src/core/lib/iomgr/ev_apple.cc +0 -360
  1148. data/src/core/lib/iomgr/ev_apple.h +0 -43
  1149. data/src/core/lib/iomgr/ev_epoll1_linux.cc +0 -1368
  1150. data/src/core/lib/iomgr/ev_epoll1_linux.h +0 -31
  1151. data/src/core/lib/iomgr/ev_poll_posix.cc +0 -1444
  1152. data/src/core/lib/iomgr/ev_poll_posix.h +0 -29
  1153. data/src/core/lib/iomgr/ev_posix.cc +0 -375
  1154. data/src/core/lib/iomgr/ev_posix.h +0 -209
  1155. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  1156. data/src/core/lib/iomgr/exec_ctx.cc +0 -132
  1157. data/src/core/lib/iomgr/exec_ctx.h +0 -333
  1158. data/src/core/lib/iomgr/executor.cc +0 -450
  1159. data/src/core/lib/iomgr/executor.h +0 -119
  1160. data/src/core/lib/iomgr/fork_posix.cc +0 -120
  1161. data/src/core/lib/iomgr/fork_windows.cc +0 -41
  1162. data/src/core/lib/iomgr/gethostname.h +0 -26
  1163. data/src/core/lib/iomgr/gethostname_fallback.cc +0 -30
  1164. data/src/core/lib/iomgr/gethostname_host_name_max.cc +0 -40
  1165. data/src/core/lib/iomgr/gethostname_sysconf.cc +0 -40
  1166. data/src/core/lib/iomgr/grpc_if_nametoindex.h +0 -30
  1167. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +0 -42
  1168. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +0 -38
  1169. data/src/core/lib/iomgr/internal_errqueue.cc +0 -61
  1170. data/src/core/lib/iomgr/internal_errqueue.h +0 -186
  1171. data/src/core/lib/iomgr/iocp_windows.cc +0 -158
  1172. data/src/core/lib/iomgr/iocp_windows.h +0 -48
  1173. data/src/core/lib/iomgr/iomgr.cc +0 -200
  1174. data/src/core/lib/iomgr/iomgr.h +0 -60
  1175. data/src/core/lib/iomgr/iomgr_fwd.h +0 -26
  1176. data/src/core/lib/iomgr/iomgr_internal.cc +0 -53
  1177. data/src/core/lib/iomgr/iomgr_internal.h +0 -74
  1178. data/src/core/lib/iomgr/iomgr_posix.cc +0 -91
  1179. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +0 -202
  1180. data/src/core/lib/iomgr/iomgr_windows.cc +0 -106
  1181. data/src/core/lib/iomgr/load_file.cc +0 -77
  1182. data/src/core/lib/iomgr/load_file.h +0 -35
  1183. data/src/core/lib/iomgr/lockfree_event.cc +0 -261
  1184. data/src/core/lib/iomgr/lockfree_event.h +0 -72
  1185. data/src/core/lib/iomgr/nameser.h +0 -106
  1186. data/src/core/lib/iomgr/polling_entity.cc +0 -96
  1187. data/src/core/lib/iomgr/polling_entity.h +0 -74
  1188. data/src/core/lib/iomgr/pollset.cc +0 -56
  1189. data/src/core/lib/iomgr/pollset.h +0 -99
  1190. data/src/core/lib/iomgr/pollset_set.cc +0 -55
  1191. data/src/core/lib/iomgr/pollset_set.h +0 -53
  1192. data/src/core/lib/iomgr/pollset_set_windows.cc +0 -52
  1193. data/src/core/lib/iomgr/pollset_set_windows.h +0 -26
  1194. data/src/core/lib/iomgr/pollset_windows.cc +0 -243
  1195. data/src/core/lib/iomgr/pollset_windows.h +0 -70
  1196. data/src/core/lib/iomgr/port.h +0 -238
  1197. data/src/core/lib/iomgr/python_util.h +0 -47
  1198. data/src/core/lib/iomgr/resolve_address.cc +0 -49
  1199. data/src/core/lib/iomgr/resolve_address.h +0 -116
  1200. data/src/core/lib/iomgr/resolve_address_impl.h +0 -59
  1201. data/src/core/lib/iomgr/resolve_address_posix.cc +0 -204
  1202. data/src/core/lib/iomgr/resolve_address_posix.h +0 -63
  1203. data/src/core/lib/iomgr/resolve_address_windows.cc +0 -196
  1204. data/src/core/lib/iomgr/resolve_address_windows.h +0 -63
  1205. data/src/core/lib/iomgr/resolved_address.h +0 -39
  1206. data/src/core/lib/iomgr/sockaddr.h +0 -32
  1207. data/src/core/lib/iomgr/sockaddr_posix.h +0 -57
  1208. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +0 -63
  1209. data/src/core/lib/iomgr/sockaddr_windows.h +0 -57
  1210. data/src/core/lib/iomgr/socket_factory_posix.cc +0 -95
  1211. data/src/core/lib/iomgr/socket_factory_posix.h +0 -69
  1212. data/src/core/lib/iomgr/socket_mutator.cc +0 -97
  1213. data/src/core/lib/iomgr/socket_mutator.h +0 -84
  1214. data/src/core/lib/iomgr/socket_utils.h +0 -47
  1215. data/src/core/lib/iomgr/socket_utils_common_posix.cc +0 -478
  1216. data/src/core/lib/iomgr/socket_utils_linux.cc +0 -42
  1217. data/src/core/lib/iomgr/socket_utils_posix.cc +0 -141
  1218. data/src/core/lib/iomgr/socket_utils_posix.h +0 -255
  1219. data/src/core/lib/iomgr/socket_utils_windows.cc +0 -47
  1220. data/src/core/lib/iomgr/socket_windows.cc +0 -202
  1221. data/src/core/lib/iomgr/socket_windows.h +0 -125
  1222. data/src/core/lib/iomgr/tcp_client.cc +0 -40
  1223. data/src/core/lib/iomgr/tcp_client.h +0 -66
  1224. data/src/core/lib/iomgr/tcp_client_cfstream.cc +0 -207
  1225. data/src/core/lib/iomgr/tcp_client_posix.cc +0 -469
  1226. data/src/core/lib/iomgr/tcp_client_posix.h +0 -72
  1227. data/src/core/lib/iomgr/tcp_client_windows.cc +0 -239
  1228. data/src/core/lib/iomgr/tcp_posix.cc +0 -2059
  1229. data/src/core/lib/iomgr/tcp_posix.h +0 -67
  1230. data/src/core/lib/iomgr/tcp_server.cc +0 -78
  1231. data/src/core/lib/iomgr/tcp_server.h +0 -150
  1232. data/src/core/lib/iomgr/tcp_server_posix.cc +0 -653
  1233. data/src/core/lib/iomgr/tcp_server_utils_posix.h +0 -129
  1234. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +0 -224
  1235. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +0 -178
  1236. data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +0 -36
  1237. data/src/core/lib/iomgr/tcp_server_windows.cc +0 -565
  1238. data/src/core/lib/iomgr/tcp_windows.cc +0 -527
  1239. data/src/core/lib/iomgr/tcp_windows.h +0 -52
  1240. data/src/core/lib/iomgr/timer.cc +0 -46
  1241. data/src/core/lib/iomgr/timer.h +0 -136
  1242. data/src/core/lib/iomgr/timer_generic.cc +0 -729
  1243. data/src/core/lib/iomgr/timer_generic.h +0 -40
  1244. data/src/core/lib/iomgr/timer_heap.cc +0 -134
  1245. data/src/core/lib/iomgr/timer_heap.h +0 -43
  1246. data/src/core/lib/iomgr/timer_manager.cc +0 -363
  1247. data/src/core/lib/iomgr/timer_manager.h +0 -41
  1248. data/src/core/lib/iomgr/unix_sockets_posix.cc +0 -94
  1249. data/src/core/lib/iomgr/unix_sockets_posix.h +0 -46
  1250. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -53
  1251. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +0 -81
  1252. data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +0 -39
  1253. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +0 -101
  1254. data/src/core/lib/iomgr/wakeup_fd_pipe.h +0 -28
  1255. data/src/core/lib/iomgr/wakeup_fd_posix.cc +0 -73
  1256. data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -96
  1257. data/src/core/lib/json/json.h +0 -246
  1258. data/src/core/lib/json/json_args.h +0 -34
  1259. data/src/core/lib/json/json_channel_args.h +0 -42
  1260. data/src/core/lib/json/json_object_loader.cc +0 -207
  1261. data/src/core/lib/json/json_object_loader.h +0 -620
  1262. data/src/core/lib/json/json_reader.cc +0 -929
  1263. data/src/core/lib/json/json_util.cc +0 -106
  1264. data/src/core/lib/json/json_util.h +0 -163
  1265. data/src/core/lib/json/json_writer.cc +0 -340
  1266. data/src/core/lib/load_balancing/lb_policy.cc +0 -93
  1267. data/src/core/lib/load_balancing/lb_policy.h +0 -439
  1268. data/src/core/lib/load_balancing/lb_policy_factory.h +0 -49
  1269. data/src/core/lib/load_balancing/lb_policy_registry.cc +0 -141
  1270. data/src/core/lib/load_balancing/lb_policy_registry.h +0 -82
  1271. data/src/core/lib/load_balancing/subchannel_interface.h +0 -133
  1272. data/src/core/lib/matchers/matchers.cc +0 -329
  1273. data/src/core/lib/matchers/matchers.h +0 -162
  1274. data/src/core/lib/promise/activity.cc +0 -134
  1275. data/src/core/lib/promise/activity.h +0 -604
  1276. data/src/core/lib/promise/arena_promise.h +0 -230
  1277. data/src/core/lib/promise/context.h +0 -92
  1278. data/src/core/lib/promise/detail/basic_seq.h +0 -497
  1279. data/src/core/lib/promise/detail/promise_factory.h +0 -235
  1280. data/src/core/lib/promise/detail/promise_like.h +0 -85
  1281. data/src/core/lib/promise/detail/status.h +0 -78
  1282. data/src/core/lib/promise/detail/switch.h +0 -1455
  1283. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +0 -50
  1284. data/src/core/lib/promise/for_each.h +0 -129
  1285. data/src/core/lib/promise/intra_activity_waiter.h +0 -49
  1286. data/src/core/lib/promise/latch.h +0 -103
  1287. data/src/core/lib/promise/loop.h +0 -138
  1288. data/src/core/lib/promise/map.h +0 -87
  1289. data/src/core/lib/promise/map_pipe.h +0 -87
  1290. data/src/core/lib/promise/pipe.cc +0 -19
  1291. data/src/core/lib/promise/pipe.h +0 -505
  1292. data/src/core/lib/promise/poll.h +0 -79
  1293. data/src/core/lib/promise/promise.h +0 -96
  1294. data/src/core/lib/promise/race.h +0 -83
  1295. data/src/core/lib/promise/seq.h +0 -106
  1296. data/src/core/lib/promise/sleep.cc +0 -90
  1297. data/src/core/lib/promise/sleep.h +0 -84
  1298. data/src/core/lib/promise/try_concurrently.h +0 -341
  1299. data/src/core/lib/promise/try_seq.h +0 -174
  1300. data/src/core/lib/resolver/resolver.cc +0 -37
  1301. data/src/core/lib/resolver/resolver.h +0 -138
  1302. data/src/core/lib/resolver/resolver_factory.h +0 -77
  1303. data/src/core/lib/resolver/resolver_registry.cc +0 -149
  1304. data/src/core/lib/resolver/resolver_registry.h +0 -123
  1305. data/src/core/lib/resolver/server_address.cc +0 -181
  1306. data/src/core/lib/resolver/server_address.h +0 -145
  1307. data/src/core/lib/resource_quota/api.cc +0 -104
  1308. data/src/core/lib/resource_quota/api.h +0 -49
  1309. data/src/core/lib/resource_quota/arena.cc +0 -138
  1310. data/src/core/lib/resource_quota/arena.h +0 -252
  1311. data/src/core/lib/resource_quota/memory_quota.cc +0 -603
  1312. data/src/core/lib/resource_quota/memory_quota.h +0 -530
  1313. data/src/core/lib/resource_quota/periodic_update.cc +0 -78
  1314. data/src/core/lib/resource_quota/periodic_update.h +0 -71
  1315. data/src/core/lib/resource_quota/resource_quota.cc +0 -33
  1316. data/src/core/lib/resource_quota/resource_quota.h +0 -74
  1317. data/src/core/lib/resource_quota/thread_quota.cc +0 -45
  1318. data/src/core/lib/resource_quota/thread_quota.h +0 -61
  1319. data/src/core/lib/resource_quota/trace.cc +0 -19
  1320. data/src/core/lib/resource_quota/trace.h +0 -24
  1321. data/src/core/lib/security/authorization/authorization_engine.h +0 -44
  1322. data/src/core/lib/security/authorization/authorization_policy_provider.h +0 -47
  1323. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +0 -50
  1324. data/src/core/lib/security/authorization/evaluate_args.cc +0 -221
  1325. data/src/core/lib/security/authorization/evaluate_args.h +0 -95
  1326. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +0 -64
  1327. data/src/core/lib/security/authorization/grpc_authorization_engine.h +0 -69
  1328. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +0 -122
  1329. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +0 -61
  1330. data/src/core/lib/security/authorization/matchers.cc +0 -241
  1331. data/src/core/lib/security/authorization/matchers.h +0 -218
  1332. data/src/core/lib/security/authorization/rbac_policy.cc +0 -445
  1333. data/src/core/lib/security/authorization/rbac_policy.h +0 -178
  1334. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +0 -66
  1335. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +0 -60
  1336. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +0 -70
  1337. data/src/core/lib/security/context/security_context.cc +0 -330
  1338. data/src/core/lib/security/context/security_context.h +0 -181
  1339. data/src/core/lib/security/credentials/alts/alts_credentials.cc +0 -119
  1340. data/src/core/lib/security/credentials/alts/alts_credentials.h +0 -123
  1341. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +0 -72
  1342. data/src/core/lib/security/credentials/alts/check_gcp_environment.h +0 -57
  1343. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +0 -68
  1344. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +0 -33
  1345. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +0 -102
  1346. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +0 -125
  1347. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +0 -46
  1348. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.h +0 -75
  1349. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +0 -56
  1350. data/src/core/lib/security/credentials/call_creds_util.cc +0 -97
  1351. data/src/core/lib/security/credentials/call_creds_util.h +0 -43
  1352. data/src/core/lib/security/credentials/channel_creds_registry.h +0 -103
  1353. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +0 -80
  1354. data/src/core/lib/security/credentials/composite/composite_credentials.cc +0 -171
  1355. data/src/core/lib/security/credentials/composite/composite_credentials.h +0 -132
  1356. data/src/core/lib/security/credentials/credentials.cc +0 -159
  1357. data/src/core/lib/security/credentials/credentials.h +0 -298
  1358. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +0 -546
  1359. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +0 -100
  1360. data/src/core/lib/security/credentials/external/aws_request_signer.cc +0 -224
  1361. data/src/core/lib/security/credentials/external/aws_request_signer.h +0 -72
  1362. data/src/core/lib/security/credentials/external/external_account_credentials.cc +0 -561
  1363. data/src/core/lib/security/credentials/external/external_account_credentials.h +0 -129
  1364. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -138
  1365. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +0 -55
  1366. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +0 -242
  1367. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +0 -71
  1368. data/src/core/lib/security/credentials/fake/fake_credentials.cc +0 -113
  1369. data/src/core/lib/security/credentials/fake/fake_credentials.h +0 -96
  1370. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +0 -40
  1371. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +0 -503
  1372. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +0 -100
  1373. data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -83
  1374. data/src/core/lib/security/credentials/iam/iam_credentials.h +0 -65
  1375. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +0 -73
  1376. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +0 -61
  1377. data/src/core/lib/security/credentials/jwt/json_token.cc +0 -297
  1378. data/src/core/lib/security/credentials/jwt/json_token.h +0 -76
  1379. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +0 -183
  1380. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +0 -107
  1381. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +0 -957
  1382. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +0 -124
  1383. data/src/core/lib/security/credentials/local/local_credentials.cc +0 -71
  1384. data/src/core/lib/security/credentials/local/local_credentials.h +0 -77
  1385. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +0 -745
  1386. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +0 -220
  1387. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +0 -215
  1388. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +0 -125
  1389. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +0 -381
  1390. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -131
  1391. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +0 -340
  1392. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +0 -216
  1393. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +0 -472
  1394. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +0 -206
  1395. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +0 -241
  1396. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +0 -168
  1397. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +0 -122
  1398. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +0 -117
  1399. data/src/core/lib/security/credentials/tls/tls_credentials.cc +0 -150
  1400. data/src/core/lib/security/credentials/tls/tls_credentials.h +0 -71
  1401. data/src/core/lib/security/credentials/tls/tls_utils.cc +0 -127
  1402. data/src/core/lib/security/credentials/tls/tls_utils.h +0 -51
  1403. data/src/core/lib/security/credentials/xds/xds_credentials.cc +0 -236
  1404. data/src/core/lib/security/credentials/xds/xds_credentials.h +0 -114
  1405. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +0 -312
  1406. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +0 -79
  1407. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +0 -315
  1408. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -43
  1409. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +0 -120
  1410. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +0 -104
  1411. data/src/core/lib/security/security_connector/load_system_roots.h +0 -33
  1412. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +0 -35
  1413. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +0 -175
  1414. data/src/core/lib/security/security_connector/load_system_roots_supported.h +0 -46
  1415. data/src/core/lib/security/security_connector/local/local_security_connector.cc +0 -306
  1416. data/src/core/lib/security/security_connector/local/local_security_connector.h +0 -63
  1417. data/src/core/lib/security/security_connector/security_connector.cc +0 -127
  1418. data/src/core/lib/security/security_connector/security_connector.h +0 -201
  1419. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +0 -458
  1420. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +0 -83
  1421. data/src/core/lib/security/security_connector/ssl_utils.cc +0 -625
  1422. data/src/core/lib/security/security_connector/ssl_utils.h +0 -187
  1423. data/src/core/lib/security/security_connector/ssl_utils_config.cc +0 -32
  1424. data/src/core/lib/security/security_connector/ssl_utils_config.h +0 -30
  1425. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +0 -828
  1426. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +0 -286
  1427. data/src/core/lib/security/transport/auth_filters.h +0 -76
  1428. data/src/core/lib/security/transport/client_auth_filter.cc +0 -227
  1429. data/src/core/lib/security/transport/secure_endpoint.cc +0 -566
  1430. data/src/core/lib/security/transport/secure_endpoint.h +0 -43
  1431. data/src/core/lib/security/transport/security_handshaker.cc +0 -673
  1432. data/src/core/lib/security/transport/security_handshaker.h +0 -51
  1433. data/src/core/lib/security/transport/server_auth_filter.cc +0 -360
  1434. data/src/core/lib/security/transport/tsi_error.cc +0 -31
  1435. data/src/core/lib/security/transport/tsi_error.h +0 -30
  1436. data/src/core/lib/security/util/json_util.cc +0 -70
  1437. data/src/core/lib/security/util/json_util.h +0 -43
  1438. data/src/core/lib/service_config/service_config.h +0 -89
  1439. data/src/core/lib/service_config/service_config_call_data.h +0 -76
  1440. data/src/core/lib/service_config/service_config_impl.cc +0 -191
  1441. data/src/core/lib/service_config/service_config_impl.h +0 -125
  1442. data/src/core/lib/service_config/service_config_parser.cc +0 -81
  1443. data/src/core/lib/service_config/service_config_parser.h +0 -105
  1444. data/src/core/lib/slice/b64.cc +0 -239
  1445. data/src/core/lib/slice/b64.h +0 -52
  1446. data/src/core/lib/slice/percent_encoding.cc +0 -150
  1447. data/src/core/lib/slice/percent_encoding.h +0 -54
  1448. data/src/core/lib/slice/slice.cc +0 -502
  1449. data/src/core/lib/slice/slice.h +0 -402
  1450. data/src/core/lib/slice/slice_buffer.cc +0 -472
  1451. data/src/core/lib/slice/slice_buffer.h +0 -137
  1452. data/src/core/lib/slice/slice_internal.h +0 -97
  1453. data/src/core/lib/slice/slice_refcount.h +0 -60
  1454. data/src/core/lib/slice/slice_string_helpers.cc +0 -28
  1455. data/src/core/lib/slice/slice_string_helpers.h +0 -31
  1456. data/src/core/lib/surface/api_trace.cc +0 -25
  1457. data/src/core/lib/surface/api_trace.h +0 -53
  1458. data/src/core/lib/surface/builtins.cc +0 -54
  1459. data/src/core/lib/surface/builtins.h +0 -26
  1460. data/src/core/lib/surface/byte_buffer.cc +0 -97
  1461. data/src/core/lib/surface/byte_buffer_reader.cc +0 -101
  1462. data/src/core/lib/surface/call.cc +0 -3043
  1463. data/src/core/lib/surface/call.h +0 -179
  1464. data/src/core/lib/surface/call_details.cc +0 -41
  1465. data/src/core/lib/surface/call_log_batch.cc +0 -117
  1466. data/src/core/lib/surface/call_test_only.h +0 -46
  1467. data/src/core/lib/surface/call_trace.cc +0 -113
  1468. data/src/core/lib/surface/call_trace.h +0 -30
  1469. data/src/core/lib/surface/channel.cc +0 -437
  1470. data/src/core/lib/surface/channel.h +0 -214
  1471. data/src/core/lib/surface/channel_init.cc +0 -55
  1472. data/src/core/lib/surface/channel_init.h +0 -84
  1473. data/src/core/lib/surface/channel_ping.cc +0 -69
  1474. data/src/core/lib/surface/channel_stack_type.cc +0 -61
  1475. data/src/core/lib/surface/channel_stack_type.h +0 -47
  1476. data/src/core/lib/surface/completion_queue.cc +0 -1411
  1477. data/src/core/lib/surface/completion_queue.h +0 -100
  1478. data/src/core/lib/surface/completion_queue_factory.cc +0 -94
  1479. data/src/core/lib/surface/completion_queue_factory.h +0 -37
  1480. data/src/core/lib/surface/event_string.cc +0 -56
  1481. data/src/core/lib/surface/event_string.h +0 -31
  1482. data/src/core/lib/surface/init.cc +0 -229
  1483. data/src/core/lib/surface/init.h +0 -25
  1484. data/src/core/lib/surface/init_internally.cc +0 -24
  1485. data/src/core/lib/surface/init_internally.h +0 -36
  1486. data/src/core/lib/surface/lame_client.cc +0 -154
  1487. data/src/core/lib/surface/lame_client.h +0 -71
  1488. data/src/core/lib/surface/metadata_array.cc +0 -38
  1489. data/src/core/lib/surface/server.cc +0 -1555
  1490. data/src/core/lib/surface/server.h +0 -525
  1491. data/src/core/lib/surface/validate_metadata.cc +0 -122
  1492. data/src/core/lib/surface/validate_metadata.h +0 -48
  1493. data/src/core/lib/surface/version.cc +0 -28
  1494. data/src/core/lib/transport/bdp_estimator.cc +0 -86
  1495. data/src/core/lib/transport/bdp_estimator.h +0 -94
  1496. data/src/core/lib/transport/connectivity_state.cc +0 -189
  1497. data/src/core/lib/transport/connectivity_state.h +0 -144
  1498. data/src/core/lib/transport/error_utils.cc +0 -171
  1499. data/src/core/lib/transport/error_utils.h +0 -63
  1500. data/src/core/lib/transport/handshaker.cc +0 -225
  1501. data/src/core/lib/transport/handshaker.h +0 -167
  1502. data/src/core/lib/transport/handshaker_factory.h +0 -74
  1503. data/src/core/lib/transport/handshaker_registry.cc +0 -61
  1504. data/src/core/lib/transport/handshaker_registry.h +0 -69
  1505. data/src/core/lib/transport/http2_errors.h +0 -41
  1506. data/src/core/lib/transport/http_connect_handshaker.cc +0 -400
  1507. data/src/core/lib/transport/http_connect_handshaker.h +0 -42
  1508. data/src/core/lib/transport/metadata_batch.cc +0 -291
  1509. data/src/core/lib/transport/metadata_batch.h +0 -1326
  1510. data/src/core/lib/transport/parsed_metadata.cc +0 -35
  1511. data/src/core/lib/transport/parsed_metadata.h +0 -409
  1512. data/src/core/lib/transport/pid_controller.cc +0 -51
  1513. data/src/core/lib/transport/pid_controller.h +0 -116
  1514. data/src/core/lib/transport/status_conversion.cc +0 -92
  1515. data/src/core/lib/transport/status_conversion.h +0 -38
  1516. data/src/core/lib/transport/tcp_connect_handshaker.cc +0 -246
  1517. data/src/core/lib/transport/tcp_connect_handshaker.h +0 -39
  1518. data/src/core/lib/transport/timeout_encoding.cc +0 -284
  1519. data/src/core/lib/transport/timeout_encoding.h +0 -72
  1520. data/src/core/lib/transport/transport.cc +0 -285
  1521. data/src/core/lib/transport/transport.h +0 -590
  1522. data/src/core/lib/transport/transport_fwd.h +0 -20
  1523. data/src/core/lib/transport/transport_impl.h +0 -95
  1524. data/src/core/lib/transport/transport_op_string.cc +0 -147
  1525. data/src/core/lib/uri/uri_parser.cc +0 -373
  1526. data/src/core/lib/uri/uri_parser.h +0 -101
  1527. data/src/core/plugin_registry/grpc_plugin_registry.cc +0 -113
  1528. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +0 -61
  1529. data/src/core/tsi/alts/crypt/aes_gcm.cc +0 -690
  1530. data/src/core/tsi/alts/crypt/gsec.cc +0 -190
  1531. data/src/core/tsi/alts/crypt/gsec.h +0 -459
  1532. data/src/core/tsi/alts/frame_protector/alts_counter.cc +0 -118
  1533. data/src/core/tsi/alts/frame_protector/alts_counter.h +0 -98
  1534. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +0 -66
  1535. data/src/core/tsi/alts/frame_protector/alts_crypter.h +0 -255
  1536. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +0 -408
  1537. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +0 -55
  1538. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.cc +0 -114
  1539. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.h +0 -114
  1540. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +0 -105
  1541. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +0 -103
  1542. data/src/core/tsi/alts/frame_protector/frame_handler.cc +0 -219
  1543. data/src/core/tsi/alts/frame_protector/frame_handler.h +0 -236
  1544. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +0 -927
  1545. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +0 -160
  1546. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +0 -91
  1547. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +0 -73
  1548. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +0 -720
  1549. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +0 -104
  1550. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker_private.h +0 -89
  1551. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +0 -65
  1552. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +0 -53
  1553. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +0 -223
  1554. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +0 -171
  1555. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +0 -226
  1556. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +0 -54
  1557. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +0 -145
  1558. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +0 -49
  1559. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol.h +0 -91
  1560. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +0 -174
  1561. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.h +0 -99
  1562. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +0 -478
  1563. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +0 -199
  1564. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +0 -315
  1565. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +0 -57
  1566. data/src/core/tsi/fake_transport_security.cc +0 -844
  1567. data/src/core/tsi/fake_transport_security.h +0 -53
  1568. data/src/core/tsi/local_transport_security.cc +0 -174
  1569. data/src/core/tsi/local_transport_security.h +0 -47
  1570. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +0 -145
  1571. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +0 -81
  1572. data/src/core/tsi/ssl/session_cache/ssl_session.h +0 -71
  1573. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +0 -59
  1574. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +0 -179
  1575. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +0 -99
  1576. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +0 -81
  1577. data/src/core/tsi/ssl_transport_security.cc +0 -2441
  1578. data/src/core/tsi/ssl_transport_security.h +0 -405
  1579. data/src/core/tsi/ssl_types.h +0 -42
  1580. data/src/core/tsi/transport_security.cc +0 -396
  1581. data/src/core/tsi/transport_security.h +0 -143
  1582. data/src/core/tsi/transport_security_grpc.cc +0 -74
  1583. data/src/core/tsi/transport_security_grpc.h +0 -83
  1584. data/src/core/tsi/transport_security_interface.h +0 -521
  1585. data/third_party/abseil-cpp/absl/algorithm/algorithm.h +0 -159
  1586. data/third_party/abseil-cpp/absl/algorithm/container.h +0 -1774
  1587. data/third_party/abseil-cpp/absl/base/attributes.h +0 -762
  1588. data/third_party/abseil-cpp/absl/base/call_once.h +0 -219
  1589. data/third_party/abseil-cpp/absl/base/casts.h +0 -180
  1590. data/third_party/abseil-cpp/absl/base/config.h +0 -913
  1591. data/third_party/abseil-cpp/absl/base/const_init.h +0 -76
  1592. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -471
  1593. data/third_party/abseil-cpp/absl/base/internal/atomic_hook.h +0 -200
  1594. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +0 -77
  1595. data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +0 -159
  1596. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +0 -169
  1597. data/third_party/abseil-cpp/absl/base/internal/dynamic_annotations.h +0 -398
  1598. data/third_party/abseil-cpp/absl/base/internal/endian.h +0 -282
  1599. data/third_party/abseil-cpp/absl/base/internal/errno_saver.h +0 -43
  1600. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +0 -50
  1601. data/third_party/abseil-cpp/absl/base/internal/hide_ptr.h +0 -51
  1602. data/third_party/abseil-cpp/absl/base/internal/identity.h +0 -37
  1603. data/third_party/abseil-cpp/absl/base/internal/inline_variable.h +0 -107
  1604. data/third_party/abseil-cpp/absl/base/internal/invoke.h +0 -241
  1605. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +0 -620
  1606. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +0 -126
  1607. data/third_party/abseil-cpp/absl/base/internal/low_level_scheduling.h +0 -134
  1608. data/third_party/abseil-cpp/absl/base/internal/per_thread_tls.h +0 -52
  1609. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +0 -138
  1610. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +0 -249
  1611. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +0 -196
  1612. data/third_party/abseil-cpp/absl/base/internal/scheduling_mode.h +0 -58
  1613. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +0 -232
  1614. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +0 -256
  1615. data/third_party/abseil-cpp/absl/base/internal/spinlock_akaros.inc +0 -35
  1616. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +0 -71
  1617. data/third_party/abseil-cpp/absl/base/internal/spinlock_posix.inc +0 -46
  1618. data/third_party/abseil-cpp/absl/base/internal/spinlock_wait.cc +0 -81
  1619. data/third_party/abseil-cpp/absl/base/internal/spinlock_wait.h +0 -95
  1620. data/third_party/abseil-cpp/absl/base/internal/spinlock_win32.inc +0 -37
  1621. data/third_party/abseil-cpp/absl/base/internal/strerror.cc +0 -88
  1622. data/third_party/abseil-cpp/absl/base/internal/strerror.h +0 -39
  1623. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -507
  1624. data/third_party/abseil-cpp/absl/base/internal/sysinfo.h +0 -74
  1625. data/third_party/abseil-cpp/absl/base/internal/thread_annotations.h +0 -271
  1626. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +0 -156
  1627. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +0 -265
  1628. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.cc +0 -212
  1629. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.h +0 -75
  1630. data/third_party/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +0 -68
  1631. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +0 -82
  1632. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -153
  1633. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +0 -133
  1634. data/third_party/abseil-cpp/absl/base/log_severity.cc +0 -55
  1635. data/third_party/abseil-cpp/absl/base/log_severity.h +0 -172
  1636. data/third_party/abseil-cpp/absl/base/macros.h +0 -158
  1637. data/third_party/abseil-cpp/absl/base/optimization.h +0 -252
  1638. data/third_party/abseil-cpp/absl/base/options.h +0 -238
  1639. data/third_party/abseil-cpp/absl/base/policy_checks.h +0 -111
  1640. data/third_party/abseil-cpp/absl/base/port.h +0 -25
  1641. data/third_party/abseil-cpp/absl/base/thread_annotations.h +0 -335
  1642. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +0 -140
  1643. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +0 -100
  1644. data/third_party/abseil-cpp/absl/container/fixed_array.h +0 -529
  1645. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +0 -613
  1646. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +0 -510
  1647. data/third_party/abseil-cpp/absl/container/inlined_vector.h +0 -866
  1648. data/third_party/abseil-cpp/absl/container/internal/common.h +0 -207
  1649. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +0 -290
  1650. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +0 -442
  1651. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +0 -163
  1652. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +0 -208
  1653. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +0 -85
  1654. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +0 -238
  1655. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +0 -299
  1656. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +0 -31
  1657. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +0 -953
  1658. data/third_party/abseil-cpp/absl/container/internal/layout.h +0 -743
  1659. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +0 -198
  1660. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +0 -71
  1661. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +0 -2365
  1662. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +0 -96
  1663. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +0 -32
  1664. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +0 -1959
  1665. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +0 -71
  1666. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +0 -387
  1667. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +0 -139
  1668. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +0 -204
  1669. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +0 -139
  1670. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +0 -88
  1671. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +0 -110
  1672. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +0 -108
  1673. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +0 -258
  1674. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +0 -236
  1675. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +0 -24
  1676. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +0 -93
  1677. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +0 -369
  1678. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +0 -153
  1679. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +0 -204
  1680. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +0 -158
  1681. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +0 -142
  1682. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +0 -231
  1683. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +0 -43
  1684. data/third_party/abseil-cpp/absl/debugging/symbolize.h +0 -99
  1685. data/third_party/abseil-cpp/absl/debugging/symbolize_darwin.inc +0 -101
  1686. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +0 -1613
  1687. data/third_party/abseil-cpp/absl/debugging/symbolize_emscripten.inc +0 -72
  1688. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +0 -40
  1689. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +0 -81
  1690. data/third_party/abseil-cpp/absl/functional/any_invocable.h +0 -313
  1691. data/third_party/abseil-cpp/absl/functional/bind_front.h +0 -193
  1692. data/third_party/abseil-cpp/absl/functional/function_ref.h +0 -143
  1693. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +0 -857
  1694. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +0 -95
  1695. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +0 -106
  1696. data/third_party/abseil-cpp/absl/hash/hash.h +0 -421
  1697. data/third_party/abseil-cpp/absl/hash/internal/city.cc +0 -349
  1698. data/third_party/abseil-cpp/absl/hash/internal/city.h +0 -78
  1699. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +0 -69
  1700. data/third_party/abseil-cpp/absl/hash/internal/hash.h +0 -1291
  1701. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +0 -123
  1702. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +0 -50
  1703. data/third_party/abseil-cpp/absl/memory/memory.h +0 -699
  1704. data/third_party/abseil-cpp/absl/meta/type_traits.h +0 -797
  1705. data/third_party/abseil-cpp/absl/numeric/bits.h +0 -178
  1706. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -385
  1707. data/third_party/abseil-cpp/absl/numeric/int128.h +0 -1165
  1708. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +0 -296
  1709. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +0 -311
  1710. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +0 -358
  1711. data/third_party/abseil-cpp/absl/numeric/internal/representation.h +0 -55
  1712. data/third_party/abseil-cpp/absl/profiling/internal/exponential_biased.cc +0 -93
  1713. data/third_party/abseil-cpp/absl/profiling/internal/exponential_biased.h +0 -130
  1714. data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +0 -245
  1715. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +0 -200
  1716. data/third_party/abseil-cpp/absl/random/beta_distribution.h +0 -427
  1717. data/third_party/abseil-cpp/absl/random/discrete_distribution.cc +0 -98
  1718. data/third_party/abseil-cpp/absl/random/discrete_distribution.h +0 -247
  1719. data/third_party/abseil-cpp/absl/random/distributions.h +0 -452
  1720. data/third_party/abseil-cpp/absl/random/exponential_distribution.h +0 -165
  1721. data/third_party/abseil-cpp/absl/random/gaussian_distribution.cc +0 -104
  1722. data/third_party/abseil-cpp/absl/random/gaussian_distribution.h +0 -275
  1723. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +0 -95
  1724. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +0 -269
  1725. data/third_party/abseil-cpp/absl/random/internal/fastmath.h +0 -57
  1726. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +0 -144
  1727. data/third_party/abseil-cpp/absl/random/internal/iostream_state_saver.h +0 -245
  1728. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +0 -161
  1729. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +0 -308
  1730. data/third_party/abseil-cpp/absl/random/internal/platform.h +0 -171
  1731. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.cc +0 -253
  1732. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.h +0 -131
  1733. data/third_party/abseil-cpp/absl/random/internal/randen.cc +0 -91
  1734. data/third_party/abseil-cpp/absl/random/internal/randen.h +0 -96
  1735. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +0 -225
  1736. data/third_party/abseil-cpp/absl/random/internal/randen_detect.h +0 -33
  1737. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +0 -264
  1738. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.cc +0 -526
  1739. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.h +0 -50
  1740. data/third_party/abseil-cpp/absl/random/internal/randen_round_keys.cc +0 -462
  1741. data/third_party/abseil-cpp/absl/random/internal/randen_slow.cc +0 -471
  1742. data/third_party/abseil-cpp/absl/random/internal/randen_slow.h +0 -40
  1743. data/third_party/abseil-cpp/absl/random/internal/randen_traits.h +0 -88
  1744. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +0 -165
  1745. data/third_party/abseil-cpp/absl/random/internal/seed_material.cc +0 -267
  1746. data/third_party/abseil-cpp/absl/random/internal/seed_material.h +0 -104
  1747. data/third_party/abseil-cpp/absl/random/internal/traits.h +0 -149
  1748. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +0 -244
  1749. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +0 -96
  1750. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +0 -256
  1751. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +0 -261
  1752. data/third_party/abseil-cpp/absl/random/random.h +0 -189
  1753. data/third_party/abseil-cpp/absl/random/seed_gen_exception.cc +0 -46
  1754. data/third_party/abseil-cpp/absl/random/seed_gen_exception.h +0 -55
  1755. data/third_party/abseil-cpp/absl/random/seed_sequences.cc +0 -29
  1756. data/third_party/abseil-cpp/absl/random/seed_sequences.h +0 -111
  1757. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +0 -275
  1758. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +0 -202
  1759. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +0 -272
  1760. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +0 -86
  1761. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +0 -396
  1762. data/third_party/abseil-cpp/absl/status/status.cc +0 -616
  1763. data/third_party/abseil-cpp/absl/status/status.h +0 -892
  1764. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +0 -38
  1765. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +0 -51
  1766. data/third_party/abseil-cpp/absl/status/statusor.cc +0 -103
  1767. data/third_party/abseil-cpp/absl/status/statusor.h +0 -776
  1768. data/third_party/abseil-cpp/absl/strings/ascii.cc +0 -200
  1769. data/third_party/abseil-cpp/absl/strings/ascii.h +0 -242
  1770. data/third_party/abseil-cpp/absl/strings/charconv.cc +0 -984
  1771. data/third_party/abseil-cpp/absl/strings/charconv.h +0 -120
  1772. data/third_party/abseil-cpp/absl/strings/cord.cc +0 -1328
  1773. data/third_party/abseil-cpp/absl/strings/cord.h +0 -1642
  1774. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +0 -188
  1775. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +0 -44
  1776. data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +0 -30
  1777. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +0 -572
  1778. data/third_party/abseil-cpp/absl/strings/escaping.cc +0 -949
  1779. data/third_party/abseil-cpp/absl/strings/escaping.h +0 -164
  1780. data/third_party/abseil-cpp/absl/strings/internal/char_map.h +0 -156
  1781. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +0 -359
  1782. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +0 -423
  1783. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.cc +0 -504
  1784. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.h +0 -99
  1785. data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +0 -63
  1786. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -77
  1787. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +0 -655
  1788. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +0 -1228
  1789. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +0 -924
  1790. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +0 -187
  1791. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +0 -267
  1792. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +0 -69
  1793. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +0 -212
  1794. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +0 -62
  1795. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.h +0 -50
  1796. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +0 -54
  1797. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +0 -102
  1798. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +0 -187
  1799. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +0 -773
  1800. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +0 -607
  1801. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring_reader.h +0 -118
  1802. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +0 -96
  1803. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +0 -85
  1804. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +0 -139
  1805. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.h +0 -131
  1806. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +0 -418
  1807. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +0 -298
  1808. data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +0 -88
  1809. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_scope.h +0 -71
  1810. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +0 -123
  1811. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +0 -181
  1812. data/third_party/abseil-cpp/absl/strings/internal/escaping.h +0 -58
  1813. data/third_party/abseil-cpp/absl/strings/internal/memutil.cc +0 -112
  1814. data/third_party/abseil-cpp/absl/strings/internal/memutil.h +0 -148
  1815. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +0 -36
  1816. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.h +0 -89
  1817. data/third_party/abseil-cpp/absl/strings/internal/resize_uninitialized.h +0 -119
  1818. data/third_party/abseil-cpp/absl/strings/internal/stl_type_traits.h +0 -248
  1819. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +0 -488
  1820. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +0 -526
  1821. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +0 -258
  1822. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +0 -248
  1823. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +0 -338
  1824. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +0 -74
  1825. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +0 -448
  1826. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +0 -1423
  1827. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +0 -37
  1828. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.cc +0 -72
  1829. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +0 -97
  1830. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.cc +0 -339
  1831. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +0 -359
  1832. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +0 -317
  1833. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +0 -430
  1834. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +0 -72
  1835. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +0 -53
  1836. data/third_party/abseil-cpp/absl/strings/internal/utf8.h +0 -50
  1837. data/third_party/abseil-cpp/absl/strings/match.cc +0 -43
  1838. data/third_party/abseil-cpp/absl/strings/match.h +0 -100
  1839. data/third_party/abseil-cpp/absl/strings/numbers.cc +0 -1093
  1840. data/third_party/abseil-cpp/absl/strings/numbers.h +0 -303
  1841. data/third_party/abseil-cpp/absl/strings/str_cat.cc +0 -246
  1842. data/third_party/abseil-cpp/absl/strings/str_cat.h +0 -415
  1843. data/third_party/abseil-cpp/absl/strings/str_format.h +0 -812
  1844. data/third_party/abseil-cpp/absl/strings/str_join.h +0 -287
  1845. data/third_party/abseil-cpp/absl/strings/str_replace.cc +0 -82
  1846. data/third_party/abseil-cpp/absl/strings/str_replace.h +0 -219
  1847. data/third_party/abseil-cpp/absl/strings/str_split.cc +0 -139
  1848. data/third_party/abseil-cpp/absl/strings/str_split.h +0 -547
  1849. data/third_party/abseil-cpp/absl/strings/string_view.cc +0 -219
  1850. data/third_party/abseil-cpp/absl/strings/string_view.h +0 -711
  1851. data/third_party/abseil-cpp/absl/strings/strip.h +0 -93
  1852. data/third_party/abseil-cpp/absl/strings/substitute.cc +0 -172
  1853. data/third_party/abseil-cpp/absl/strings/substitute.h +0 -729
  1854. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +0 -52
  1855. data/third_party/abseil-cpp/absl/synchronization/barrier.h +0 -79
  1856. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +0 -67
  1857. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +0 -101
  1858. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +0 -143
  1859. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -56
  1860. data/third_party/abseil-cpp/absl/synchronization/internal/futex.h +0 -154
  1861. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +0 -698
  1862. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +0 -141
  1863. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +0 -156
  1864. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -102
  1865. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +0 -110
  1866. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -403
  1867. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +0 -161
  1868. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +0 -2786
  1869. data/third_party/abseil-cpp/absl/synchronization/mutex.h +0 -1090
  1870. data/third_party/abseil-cpp/absl/synchronization/notification.cc +0 -78
  1871. data/third_party/abseil-cpp/absl/synchronization/notification.h +0 -124
  1872. data/third_party/abseil-cpp/absl/time/civil_time.cc +0 -173
  1873. data/third_party/abseil-cpp/absl/time/civil_time.h +0 -538
  1874. data/third_party/abseil-cpp/absl/time/clock.cc +0 -585
  1875. data/third_party/abseil-cpp/absl/time/clock.h +0 -74
  1876. data/third_party/abseil-cpp/absl/time/duration.cc +0 -955
  1877. data/third_party/abseil-cpp/absl/time/format.cc +0 -160
  1878. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time.h +0 -332
  1879. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +0 -632
  1880. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +0 -459
  1881. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +0 -102
  1882. data/third_party/abseil-cpp/absl/time/internal/cctz/src/civil_time_detail.cc +0 -94
  1883. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +0 -140
  1884. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.h +0 -52
  1885. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +0 -1029
  1886. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +0 -45
  1887. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +0 -77
  1888. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +0 -113
  1889. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +0 -93
  1890. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +0 -1027
  1891. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +0 -137
  1892. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +0 -315
  1893. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +0 -55
  1894. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -236
  1895. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +0 -159
  1896. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +0 -132
  1897. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +0 -122
  1898. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +0 -115
  1899. data/third_party/abseil-cpp/absl/time/internal/get_current_time_chrono.inc +0 -31
  1900. data/third_party/abseil-cpp/absl/time/internal/get_current_time_posix.inc +0 -24
  1901. data/third_party/abseil-cpp/absl/time/time.cc +0 -500
  1902. data/third_party/abseil-cpp/absl/time/time.h +0 -1620
  1903. data/third_party/abseil-cpp/absl/types/bad_optional_access.cc +0 -48
  1904. data/third_party/abseil-cpp/absl/types/bad_optional_access.h +0 -78
  1905. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +0 -64
  1906. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +0 -82
  1907. data/third_party/abseil-cpp/absl/types/internal/optional.h +0 -404
  1908. data/third_party/abseil-cpp/absl/types/internal/span.h +0 -128
  1909. data/third_party/abseil-cpp/absl/types/internal/variant.h +0 -1646
  1910. data/third_party/abseil-cpp/absl/types/optional.h +0 -779
  1911. data/third_party/abseil-cpp/absl/types/span.h +0 -727
  1912. data/third_party/abseil-cpp/absl/types/variant.h +0 -866
  1913. data/third_party/abseil-cpp/absl/utility/utility.h +0 -350
  1914. data/third_party/address_sorting/address_sorting.c +0 -375
  1915. data/third_party/address_sorting/address_sorting_internal.h +0 -70
  1916. data/third_party/address_sorting/address_sorting_posix.c +0 -98
  1917. data/third_party/address_sorting/address_sorting_windows.c +0 -95
  1918. data/third_party/address_sorting/include/address_sorting/address_sorting.h +0 -115
  1919. data/third_party/boringssl-with-bazel/err_data.c +0 -1493
  1920. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +0 -284
  1921. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +0 -122
  1922. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -91
  1923. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +0 -87
  1924. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_enum.c +0 -195
  1925. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +0 -266
  1926. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +0 -88
  1927. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +0 -420
  1928. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +0 -298
  1929. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +0 -299
  1930. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +0 -77
  1931. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_print.c +0 -83
  1932. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +0 -650
  1933. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +0 -266
  1934. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +0 -212
  1935. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +0 -163
  1936. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +0 -264
  1937. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +0 -236
  1938. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -452
  1939. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +0 -80
  1940. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +0 -101
  1941. data/third_party/boringssl-with-bazel/src/crypto/asn1/charmap.h +0 -15
  1942. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +0 -102
  1943. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +0 -91
  1944. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +0 -224
  1945. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +0 -969
  1946. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +0 -710
  1947. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +0 -233
  1948. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +0 -332
  1949. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +0 -131
  1950. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +0 -281
  1951. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +0 -206
  1952. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +0 -482
  1953. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +0 -702
  1954. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +0 -324
  1955. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +0 -541
  1956. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -275
  1957. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +0 -311
  1958. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.c +0 -192
  1959. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +0 -111
  1960. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +0 -483
  1961. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -115
  1962. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +0 -192
  1963. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +0 -122
  1964. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +0 -156
  1965. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/bn_asn1.c +0 -57
  1966. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +0 -470
  1967. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +0 -172
  1968. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +0 -52
  1969. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +0 -266
  1970. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +0 -728
  1971. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +0 -711
  1972. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +0 -96
  1973. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +0 -155
  1974. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +0 -175
  1975. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +0 -45
  1976. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +0 -127
  1977. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +0 -152
  1978. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesccm.c +0 -447
  1979. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +0 -283
  1980. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +0 -891
  1981. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +0 -343
  1982. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +0 -85
  1983. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +0 -462
  1984. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +0 -87
  1985. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +0 -601
  1986. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +0 -226
  1987. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +0 -338
  1988. data/third_party/boringssl-with-bazel/src/crypto/cmac/cmac.c +0 -278
  1989. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +0 -821
  1990. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -127
  1991. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +0 -31
  1992. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-fuchsia.c +0 -55
  1993. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-linux.c +0 -62
  1994. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-win.c +0 -41
  1995. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.c +0 -229
  1996. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.h +0 -201
  1997. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm.c +0 -38
  1998. data/third_party/boringssl-with-bazel/src/crypto/cpu-intel.c +0 -291
  1999. data/third_party/boringssl-with-bazel/src/crypto/cpu-ppc64le.c +0 -38
  2000. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +0 -226
  2001. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +0 -2159
  2002. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +0 -7872
  2003. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +0 -146
  2004. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +0 -539
  2005. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +0 -160
  2006. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +0 -272
  2007. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -268
  2008. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +0 -967
  2009. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -390
  2010. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +0 -34
  2011. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +0 -559
  2012. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +0 -95
  2013. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +0 -385
  2014. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +0 -56
  2015. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +0 -124
  2016. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +0 -267
  2017. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.c +0 -99
  2018. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +0 -857
  2019. data/third_party/boringssl-with-bazel/src/crypto/err/internal.h +0 -58
  2020. data/third_party/boringssl-with-bazel/src/crypto/evp/digestsign.c +0 -231
  2021. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +0 -456
  2022. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +0 -547
  2023. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +0 -484
  2024. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +0 -269
  2025. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +0 -277
  2026. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +0 -286
  2027. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +0 -255
  2028. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +0 -104
  2029. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +0 -221
  2030. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +0 -648
  2031. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +0 -194
  2032. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +0 -110
  2033. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +0 -248
  2034. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +0 -146
  2035. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +0 -489
  2036. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +0 -211
  2037. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +0 -151
  2038. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +0 -261
  2039. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +0 -108
  2040. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c +0 -1282
  2041. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +0 -238
  2042. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c +0 -236
  2043. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +0 -122
  2044. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +0 -266
  2045. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.c +0 -316
  2046. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.c +0 -541
  2047. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +0 -438
  2048. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +0 -230
  2049. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c +0 -200
  2050. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +0 -236
  2051. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +0 -902
  2052. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +0 -87
  2053. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +0 -1288
  2054. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +0 -378
  2055. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +0 -326
  2056. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +0 -711
  2057. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +0 -715
  2058. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.c +0 -146
  2059. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +0 -502
  2060. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +0 -186
  2061. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +0 -749
  2062. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +0 -1064
  2063. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +0 -341
  2064. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +0 -226
  2065. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +0 -104
  2066. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c +0 -364
  2067. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +0 -498
  2068. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c +0 -284
  2069. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +0 -648
  2070. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +0 -1473
  2071. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_des.c +0 -237
  2072. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +0 -128
  2073. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +0 -89
  2074. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/des.c +0 -784
  2075. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/internal.h +0 -238
  2076. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +0 -217
  2077. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +0 -456
  2078. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +0 -282
  2079. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.c +0 -304
  2080. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +0 -112
  2081. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +0 -195
  2082. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +0 -1268
  2083. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +0 -472
  2084. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +0 -524
  2085. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +0 -100
  2086. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +0 -772
  2087. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +0 -328
  2088. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +0 -1180
  2089. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64-table.h +0 -9497
  2090. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64.c +0 -633
  2091. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64.h +0 -153
  2092. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +0 -740
  2093. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +0 -297
  2094. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +0 -175
  2095. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +0 -357
  2096. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +0 -270
  2097. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.c +0 -255
  2098. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +0 -270
  2099. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +0 -122
  2100. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +0 -338
  2101. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +0 -39
  2102. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +0 -32
  2103. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c +0 -228
  2104. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +0 -240
  2105. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/internal.h +0 -37
  2106. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c +0 -284
  2107. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +0 -178
  2108. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +0 -203
  2109. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +0 -201
  2110. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +0 -733
  2111. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +0 -304
  2112. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +0 -420
  2113. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +0 -97
  2114. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +0 -91
  2115. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c +0 -202
  2116. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +0 -137
  2117. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +0 -49
  2118. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/getrandom_fillin.h +0 -64
  2119. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +0 -184
  2120. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +0 -457
  2121. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +0 -401
  2122. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +0 -243
  2123. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +0 -131
  2124. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +0 -695
  2125. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +0 -935
  2126. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +0 -1416
  2127. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +0 -79
  2128. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +0 -874
  2129. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +0 -53
  2130. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1-altivec.c +0 -361
  2131. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +0 -357
  2132. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +0 -321
  2133. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +0 -508
  2134. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +0 -39
  2135. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +0 -165
  2136. data/third_party/boringssl-with-bazel/src/crypto/hkdf/hkdf.c +0 -112
  2137. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +0 -618
  2138. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +0 -2198
  2139. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +0 -68
  2140. data/third_party/boringssl-with-bazel/src/crypto/internal.h +0 -959
  2141. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +0 -253
  2142. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +0 -353
  2143. data/third_party/boringssl-with-bazel/src/crypto/mem.c +0 -410
  2144. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +0 -553
  2145. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +0 -11585
  2146. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.c +0 -122
  2147. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -252
  2148. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -358
  2149. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -769
  2150. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +0 -87
  2151. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -255
  2152. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -214
  2153. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -65
  2154. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -65
  2155. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +0 -58
  2156. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +0 -193
  2157. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -526
  2158. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +0 -137
  2159. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +0 -316
  2160. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +0 -530
  2161. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +0 -1383
  2162. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +0 -41
  2163. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +0 -321
  2164. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +0 -307
  2165. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +0 -860
  2166. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +0 -49
  2167. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +0 -257
  2168. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +0 -56
  2169. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +0 -46
  2170. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/fuchsia.c +0 -34
  2171. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +0 -34
  2172. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +0 -74
  2173. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +0 -73
  2174. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.c +0 -98
  2175. data/third_party/boringssl-with-bazel/src/crypto/refcount_c11.c +0 -67
  2176. data/third_party/boringssl-with-bazel/src/crypto/refcount_lock.c +0 -53
  2177. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_asn1.c +0 -324
  2178. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_print.c +0 -22
  2179. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +0 -82
  2180. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +0 -425
  2181. data/third_party/boringssl-with-bazel/src/crypto/thread.c +0 -110
  2182. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -59
  2183. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +0 -182
  2184. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +0 -260
  2185. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +0 -318
  2186. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +0 -1399
  2187. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +0 -858
  2188. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +0 -766
  2189. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +0 -96
  2190. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +0 -128
  2191. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +0 -118
  2192. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +0 -163
  2193. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +0 -826
  2194. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +0 -459
  2195. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +0 -277
  2196. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +0 -83
  2197. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +0 -404
  2198. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +0 -246
  2199. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +0 -400
  2200. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +0 -130
  2201. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +0 -246
  2202. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -365
  2203. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +0 -116
  2204. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +0 -90
  2205. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +0 -358
  2206. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +0 -461
  2207. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +0 -106
  2208. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +0 -103
  2209. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +0 -212
  2210. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -830
  2211. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +0 -199
  2212. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +0 -304
  2213. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +0 -240
  2214. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +0 -331
  2215. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +0 -204
  2216. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +0 -281
  2217. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +0 -2456
  2218. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +0 -651
  2219. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +0 -284
  2220. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +0 -388
  2221. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +0 -84
  2222. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +0 -137
  2223. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +0 -153
  2224. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -386
  2225. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +0 -98
  2226. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +0 -565
  2227. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +0 -77
  2228. data/third_party/boringssl-with-bazel/src/crypto/x509/x_info.c +0 -98
  2229. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +0 -544
  2230. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +0 -106
  2231. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +0 -217
  2232. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +0 -106
  2233. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +0 -94
  2234. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +0 -80
  2235. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +0 -71
  2236. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +0 -394
  2237. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +0 -201
  2238. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +0 -138
  2239. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +0 -289
  2240. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +0 -287
  2241. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +0 -132
  2242. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_lib.c +0 -155
  2243. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +0 -131
  2244. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_node.c +0 -189
  2245. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +0 -843
  2246. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +0 -226
  2247. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akeya.c +0 -72
  2248. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +0 -640
  2249. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bcons.c +0 -133
  2250. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +0 -144
  2251. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +0 -468
  2252. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +0 -500
  2253. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +0 -563
  2254. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +0 -106
  2255. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_extku.c +0 -148
  2256. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +0 -266
  2257. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ia5.c +0 -121
  2258. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +0 -218
  2259. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_int.c +0 -91
  2260. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +0 -379
  2261. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +0 -558
  2262. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ocsp.c +0 -68
  2263. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +0 -289
  2264. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcia.c +0 -57
  2265. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcons.c +0 -139
  2266. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pmaps.c +0 -154
  2267. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +0 -230
  2268. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +0 -929
  2269. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +0 -156
  2270. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +0 -1437
  2271. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +0 -480
  2272. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +0 -207
  2273. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +0 -240
  2274. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +0 -2039
  2275. data/third_party/boringssl-with-bazel/src/include/openssl/asn1_mac.h +0 -18
  2276. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +0 -718
  2277. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +0 -627
  2278. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +0 -198
  2279. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +0 -939
  2280. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +0 -62
  2281. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +0 -93
  2282. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +0 -1057
  2283. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +0 -137
  2284. data/third_party/boringssl-with-bazel/src/include/openssl/buffer.h +0 -18
  2285. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +0 -586
  2286. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +0 -96
  2287. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +0 -41
  2288. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +0 -673
  2289. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +0 -91
  2290. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +0 -183
  2291. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +0 -202
  2292. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +0 -169
  2293. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +0 -201
  2294. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +0 -183
  2295. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +0 -353
  2296. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +0 -348
  2297. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +0 -443
  2298. data/third_party/boringssl-with-bazel/src/include/openssl/dtls1.h +0 -16
  2299. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +0 -18
  2300. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +0 -442
  2301. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +0 -357
  2302. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +0 -118
  2303. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +0 -236
  2304. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +0 -109
  2305. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +0 -466
  2306. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +0 -1083
  2307. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +0 -99
  2308. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +0 -203
  2309. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +0 -68
  2310. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +0 -186
  2311. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +0 -350
  2312. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +0 -102
  2313. data/third_party/boringssl-with-bazel/src/include/openssl/is_boringssl.h +0 -16
  2314. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +0 -81
  2315. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +0 -108
  2316. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +0 -109
  2317. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +0 -184
  2318. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +0 -4259
  2319. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +0 -256
  2320. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +0 -18
  2321. data/third_party/boringssl-with-bazel/src/include/openssl/objects.h +0 -18
  2322. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +0 -70
  2323. data/third_party/boringssl-with-bazel/src/include/openssl/opensslv.h +0 -18
  2324. data/third_party/boringssl-with-bazel/src/include/openssl/ossl_typ.h +0 -18
  2325. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +0 -483
  2326. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs12.h +0 -18
  2327. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +0 -239
  2328. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +0 -282
  2329. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +0 -49
  2330. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +0 -108
  2331. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +0 -114
  2332. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +0 -96
  2333. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +0 -108
  2334. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +0 -855
  2335. data/third_party/boringssl-with-bazel/src/include/openssl/safestack.h +0 -16
  2336. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +0 -294
  2337. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +0 -37
  2338. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +0 -222
  2339. data/third_party/boringssl-with-bazel/src/include/openssl/srtp.h +0 -18
  2340. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +0 -5624
  2341. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +0 -333
  2342. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +0 -542
  2343. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +0 -191
  2344. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +0 -647
  2345. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +0 -310
  2346. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +0 -90
  2347. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +0 -2419
  2348. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +0 -18
  2349. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +0 -1021
  2350. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +0 -192
  2351. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +0 -835
  2352. data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +0 -268
  2353. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +0 -273
  2354. data/third_party/boringssl-with-bazel/src/ssl/d1_srtp.cc +0 -232
  2355. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +0 -200
  2356. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +0 -353
  2357. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +0 -1084
  2358. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +0 -4325
  2359. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +0 -986
  2360. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +0 -758
  2361. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +0 -1986
  2362. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +0 -1956
  2363. data/third_party/boringssl-with-bazel/src/ssl/internal.h +0 -3953
  2364. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +0 -730
  2365. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +0 -219
  2366. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +0 -453
  2367. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +0 -432
  2368. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +0 -896
  2369. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +0 -306
  2370. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +0 -1014
  2371. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +0 -1717
  2372. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +0 -585
  2373. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +0 -400
  2374. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +0 -3072
  2375. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +0 -837
  2376. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +0 -1342
  2377. data/third_party/boringssl-with-bazel/src/ssl/ssl_stat.cc +0 -233
  2378. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +0 -272
  2379. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +0 -402
  2380. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +0 -1363
  2381. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +0 -384
  2382. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +0 -733
  2383. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +0 -1122
  2384. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +0 -582
  2385. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +0 -1349
  2386. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +0 -319
  2387. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +0 -705
  2388. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +0 -981
  2389. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +0 -619
  2390. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +0 -3147
  2391. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +0 -1226
  2392. data/third_party/cares/ares_build.h +0 -223
  2393. data/third_party/cares/cares/include/ares.h +0 -742
  2394. data/third_party/cares/cares/include/ares_dns.h +0 -112
  2395. data/third_party/cares/cares/include/ares_rules.h +0 -125
  2396. data/third_party/cares/cares/include/ares_version.h +0 -24
  2397. data/third_party/cares/cares/src/lib/ares__close_sockets.c +0 -61
  2398. data/third_party/cares/cares/src/lib/ares__get_hostent.c +0 -260
  2399. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +0 -260
  2400. data/third_party/cares/cares/src/lib/ares__read_line.c +0 -73
  2401. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +0 -264
  2402. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +0 -499
  2403. data/third_party/cares/cares/src/lib/ares__timeval.c +0 -111
  2404. data/third_party/cares/cares/src/lib/ares_android.c +0 -444
  2405. data/third_party/cares/cares/src/lib/ares_android.h +0 -27
  2406. data/third_party/cares/cares/src/lib/ares_cancel.c +0 -63
  2407. data/third_party/cares/cares/src/lib/ares_create_query.c +0 -197
  2408. data/third_party/cares/cares/src/lib/ares_data.c +0 -240
  2409. data/third_party/cares/cares/src/lib/ares_data.h +0 -74
  2410. data/third_party/cares/cares/src/lib/ares_destroy.c +0 -113
  2411. data/third_party/cares/cares/src/lib/ares_expand_name.c +0 -300
  2412. data/third_party/cares/cares/src/lib/ares_expand_string.c +0 -67
  2413. data/third_party/cares/cares/src/lib/ares_fds.c +0 -59
  2414. data/third_party/cares/cares/src/lib/ares_free_hostent.c +0 -43
  2415. data/third_party/cares/cares/src/lib/ares_free_string.c +0 -25
  2416. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +0 -59
  2417. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +0 -772
  2418. data/third_party/cares/cares/src/lib/ares_getenv.c +0 -28
  2419. data/third_party/cares/cares/src/lib/ares_getenv.h +0 -26
  2420. data/third_party/cares/cares/src/lib/ares_gethostbyaddr.c +0 -287
  2421. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +0 -534
  2422. data/third_party/cares/cares/src/lib/ares_getnameinfo.c +0 -447
  2423. data/third_party/cares/cares/src/lib/ares_getsock.c +0 -66
  2424. data/third_party/cares/cares/src/lib/ares_inet_net_pton.h +0 -25
  2425. data/third_party/cares/cares/src/lib/ares_init.c +0 -2654
  2426. data/third_party/cares/cares/src/lib/ares_iphlpapi.h +0 -221
  2427. data/third_party/cares/cares/src/lib/ares_ipv6.h +0 -85
  2428. data/third_party/cares/cares/src/lib/ares_library_init.c +0 -200
  2429. data/third_party/cares/cares/src/lib/ares_library_init.h +0 -43
  2430. data/third_party/cares/cares/src/lib/ares_llist.c +0 -63
  2431. data/third_party/cares/cares/src/lib/ares_llist.h +0 -39
  2432. data/third_party/cares/cares/src/lib/ares_mkquery.c +0 -24
  2433. data/third_party/cares/cares/src/lib/ares_nameser.h +0 -482
  2434. data/third_party/cares/cares/src/lib/ares_nowarn.c +0 -260
  2435. data/third_party/cares/cares/src/lib/ares_nowarn.h +0 -61
  2436. data/third_party/cares/cares/src/lib/ares_options.c +0 -406
  2437. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +0 -209
  2438. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +0 -212
  2439. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +0 -199
  2440. data/third_party/cares/cares/src/lib/ares_parse_mx_reply.c +0 -164
  2441. data/third_party/cares/cares/src/lib/ares_parse_naptr_reply.c +0 -183
  2442. data/third_party/cares/cares/src/lib/ares_parse_ns_reply.c +0 -177
  2443. data/third_party/cares/cares/src/lib/ares_parse_ptr_reply.c +0 -228
  2444. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +0 -179
  2445. data/third_party/cares/cares/src/lib/ares_parse_srv_reply.c +0 -168
  2446. data/third_party/cares/cares/src/lib/ares_parse_txt_reply.c +0 -214
  2447. data/third_party/cares/cares/src/lib/ares_platform.c +0 -11042
  2448. data/third_party/cares/cares/src/lib/ares_platform.h +0 -43
  2449. data/third_party/cares/cares/src/lib/ares_private.h +0 -423
  2450. data/third_party/cares/cares/src/lib/ares_process.c +0 -1548
  2451. data/third_party/cares/cares/src/lib/ares_query.c +0 -180
  2452. data/third_party/cares/cares/src/lib/ares_search.c +0 -321
  2453. data/third_party/cares/cares/src/lib/ares_send.c +0 -131
  2454. data/third_party/cares/cares/src/lib/ares_setup.h +0 -220
  2455. data/third_party/cares/cares/src/lib/ares_strcasecmp.c +0 -66
  2456. data/third_party/cares/cares/src/lib/ares_strcasecmp.h +0 -30
  2457. data/third_party/cares/cares/src/lib/ares_strdup.c +0 -49
  2458. data/third_party/cares/cares/src/lib/ares_strdup.h +0 -24
  2459. data/third_party/cares/cares/src/lib/ares_strerror.c +0 -56
  2460. data/third_party/cares/cares/src/lib/ares_strsplit.c +0 -178
  2461. data/third_party/cares/cares/src/lib/ares_strsplit.h +0 -43
  2462. data/third_party/cares/cares/src/lib/ares_timeout.c +0 -88
  2463. data/third_party/cares/cares/src/lib/ares_version.c +0 -11
  2464. data/third_party/cares/cares/src/lib/ares_writev.c +0 -79
  2465. data/third_party/cares/cares/src/lib/ares_writev.h +0 -36
  2466. data/third_party/cares/cares/src/lib/bitncmp.c +0 -59
  2467. data/third_party/cares/cares/src/lib/bitncmp.h +0 -26
  2468. data/third_party/cares/cares/src/lib/config-dos.h +0 -115
  2469. data/third_party/cares/cares/src/lib/config-win32.h +0 -351
  2470. data/third_party/cares/cares/src/lib/inet_net_pton.c +0 -444
  2471. data/third_party/cares/cares/src/lib/inet_ntop.c +0 -201
  2472. data/third_party/cares/cares/src/lib/setup_once.h +0 -554
  2473. data/third_party/cares/cares/src/lib/windows_port.c +0 -22
  2474. data/third_party/cares/config_darwin/ares_config.h +0 -428
  2475. data/third_party/cares/config_freebsd/ares_config.h +0 -505
  2476. data/third_party/cares/config_linux/ares_config.h +0 -461
  2477. data/third_party/cares/config_openbsd/ares_config.h +0 -505
  2478. data/third_party/re2/re2/bitmap256.h +0 -117
  2479. data/third_party/re2/re2/bitstate.cc +0 -385
  2480. data/third_party/re2/re2/compile.cc +0 -1261
  2481. data/third_party/re2/re2/dfa.cc +0 -2118
  2482. data/third_party/re2/re2/filtered_re2.cc +0 -137
  2483. data/third_party/re2/re2/filtered_re2.h +0 -114
  2484. data/third_party/re2/re2/mimics_pcre.cc +0 -197
  2485. data/third_party/re2/re2/nfa.cc +0 -713
  2486. data/third_party/re2/re2/onepass.cc +0 -623
  2487. data/third_party/re2/re2/parse.cc +0 -2483
  2488. data/third_party/re2/re2/perl_groups.cc +0 -119
  2489. data/third_party/re2/re2/pod_array.h +0 -55
  2490. data/third_party/re2/re2/prefilter.cc +0 -711
  2491. data/third_party/re2/re2/prefilter.h +0 -108
  2492. data/third_party/re2/re2/prefilter_tree.cc +0 -407
  2493. data/third_party/re2/re2/prefilter_tree.h +0 -139
  2494. data/third_party/re2/re2/prog.cc +0 -1166
  2495. data/third_party/re2/re2/prog.h +0 -455
  2496. data/third_party/re2/re2/re2.cc +0 -1331
  2497. data/third_party/re2/re2/re2.h +0 -1017
  2498. data/third_party/re2/re2/regexp.cc +0 -987
  2499. data/third_party/re2/re2/regexp.h +0 -665
  2500. data/third_party/re2/re2/set.cc +0 -176
  2501. data/third_party/re2/re2/set.h +0 -85
  2502. data/third_party/re2/re2/simplify.cc +0 -665
  2503. data/third_party/re2/re2/sparse_array.h +0 -392
  2504. data/third_party/re2/re2/sparse_set.h +0 -264
  2505. data/third_party/re2/re2/stringpiece.cc +0 -65
  2506. data/third_party/re2/re2/stringpiece.h +0 -210
  2507. data/third_party/re2/re2/tostring.cc +0 -351
  2508. data/third_party/re2/re2/unicode_casefold.cc +0 -582
  2509. data/third_party/re2/re2/unicode_casefold.h +0 -78
  2510. data/third_party/re2/re2/unicode_groups.cc +0 -6269
  2511. data/third_party/re2/re2/unicode_groups.h +0 -67
  2512. data/third_party/re2/re2/walker-inl.h +0 -246
  2513. data/third_party/re2/util/benchmark.h +0 -156
  2514. data/third_party/re2/util/flags.h +0 -26
  2515. data/third_party/re2/util/logging.h +0 -109
  2516. data/third_party/re2/util/malloc_counter.h +0 -19
  2517. data/third_party/re2/util/mix.h +0 -41
  2518. data/third_party/re2/util/mutex.h +0 -148
  2519. data/third_party/re2/util/pcre.cc +0 -1025
  2520. data/third_party/re2/util/pcre.h +0 -681
  2521. data/third_party/re2/util/rune.cc +0 -260
  2522. data/third_party/re2/util/strutil.cc +0 -149
  2523. data/third_party/re2/util/strutil.h +0 -21
  2524. data/third_party/re2/util/test.h +0 -50
  2525. data/third_party/re2/util/utf.h +0 -44
  2526. data/third_party/re2/util/util.h +0 -42
  2527. data/third_party/upb/third_party/utf8_range/naive.c +0 -92
  2528. data/third_party/upb/third_party/utf8_range/range2-neon.c +0 -157
  2529. data/third_party/upb/third_party/utf8_range/range2-sse.c +0 -170
  2530. data/third_party/upb/third_party/utf8_range/utf8_range.h +0 -9
  2531. data/third_party/upb/upb/arena.c +0 -277
  2532. data/third_party/upb/upb/arena.h +0 -225
  2533. data/third_party/upb/upb/array.c +0 -114
  2534. data/third_party/upb/upb/array.h +0 -83
  2535. data/third_party/upb/upb/collections.h +0 -36
  2536. data/third_party/upb/upb/decode.c +0 -1221
  2537. data/third_party/upb/upb/decode.h +0 -95
  2538. data/third_party/upb/upb/decode_fast.c +0 -1055
  2539. data/third_party/upb/upb/decode_fast.h +0 -153
  2540. data/third_party/upb/upb/def.c +0 -3269
  2541. data/third_party/upb/upb/def.h +0 -416
  2542. data/third_party/upb/upb/def.hpp +0 -441
  2543. data/third_party/upb/upb/encode.c +0 -613
  2544. data/third_party/upb/upb/encode.h +0 -81
  2545. data/third_party/upb/upb/extension_registry.c +0 -93
  2546. data/third_party/upb/upb/extension_registry.h +0 -84
  2547. data/third_party/upb/upb/internal/decode.h +0 -211
  2548. data/third_party/upb/upb/internal/table.h +0 -385
  2549. data/third_party/upb/upb/internal/upb.h +0 -68
  2550. data/third_party/upb/upb/internal/vsnprintf_compat.h +0 -52
  2551. data/third_party/upb/upb/json_decode.c +0 -1512
  2552. data/third_party/upb/upb/json_decode.h +0 -47
  2553. data/third_party/upb/upb/json_encode.c +0 -780
  2554. data/third_party/upb/upb/json_encode.h +0 -65
  2555. data/third_party/upb/upb/map.c +0 -108
  2556. data/third_party/upb/upb/map.h +0 -117
  2557. data/third_party/upb/upb/message_value.h +0 -66
  2558. data/third_party/upb/upb/mini_table.c +0 -1147
  2559. data/third_party/upb/upb/mini_table.h +0 -189
  2560. data/third_party/upb/upb/mini_table.hpp +0 -112
  2561. data/third_party/upb/upb/msg.c +0 -368
  2562. data/third_party/upb/upb/msg.h +0 -71
  2563. data/third_party/upb/upb/msg_internal.h +0 -837
  2564. data/third_party/upb/upb/port_def.inc +0 -262
  2565. data/third_party/upb/upb/port_undef.inc +0 -63
  2566. data/third_party/upb/upb/reflection.c +0 -323
  2567. data/third_party/upb/upb/reflection.h +0 -110
  2568. data/third_party/upb/upb/reflection.hpp +0 -37
  2569. data/third_party/upb/upb/status.c +0 -86
  2570. data/third_party/upb/upb/status.h +0 -66
  2571. data/third_party/upb/upb/table.c +0 -926
  2572. data/third_party/upb/upb/table_internal.h +0 -36
  2573. data/third_party/upb/upb/text_encode.c +0 -473
  2574. data/third_party/upb/upb/text_encode.h +0 -64
  2575. data/third_party/upb/upb/upb.c +0 -76
  2576. data/third_party/upb/upb/upb.h +0 -184
  2577. data/third_party/upb/upb/upb.hpp +0 -115
  2578. data/third_party/xxhash/xxhash.h +0 -5580
  2579. data/third_party/zlib/adler32.c +0 -186
  2580. data/third_party/zlib/compress.c +0 -86
  2581. data/third_party/zlib/crc32.c +0 -1125
  2582. data/third_party/zlib/crc32.h +0 -9446
  2583. data/third_party/zlib/deflate.c +0 -2217
  2584. data/third_party/zlib/deflate.h +0 -346
  2585. data/third_party/zlib/gzclose.c +0 -25
  2586. data/third_party/zlib/gzguts.h +0 -219
  2587. data/third_party/zlib/gzlib.c +0 -639
  2588. data/third_party/zlib/gzread.c +0 -650
  2589. data/third_party/zlib/gzwrite.c +0 -677
  2590. data/third_party/zlib/infback.c +0 -644
  2591. data/third_party/zlib/inffast.c +0 -323
  2592. data/third_party/zlib/inffast.h +0 -11
  2593. data/third_party/zlib/inffixed.h +0 -94
  2594. data/third_party/zlib/inflate.c +0 -1595
  2595. data/third_party/zlib/inflate.h +0 -126
  2596. data/third_party/zlib/inftrees.c +0 -304
  2597. data/third_party/zlib/inftrees.h +0 -62
  2598. data/third_party/zlib/trees.c +0 -1181
  2599. data/third_party/zlib/trees.h +0 -128
  2600. data/third_party/zlib/uncompr.c +0 -93
  2601. data/third_party/zlib/zconf.h +0 -547
  2602. data/third_party/zlib/zlib.h +0 -1935
  2603. data/third_party/zlib/zutil.c +0 -327
  2604. data/third_party/zlib/zutil.h +0 -275
@@ -1,2661 +0,0 @@
1
- //
2
- // Copyright 2015 gRPC authors.
3
- //
4
- // Licensed under the Apache License, Version 2.0 (the "License");
5
- // you may not use this file except in compliance with the License.
6
- // You may obtain a copy of the License at
7
- //
8
- // http://www.apache.org/licenses/LICENSE-2.0
9
- //
10
- // Unless required by applicable law or agreed to in writing, software
11
- // distributed under the License is distributed on an "AS IS" BASIS,
12
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- // See the License for the specific language governing permissions and
14
- // limitations under the License.
15
- //
16
-
17
- #include <grpc/support/port_platform.h>
18
-
19
- #include "src/core/ext/filters/client_channel/retry_filter.h"
20
-
21
- #include <inttypes.h>
22
- #include <limits.h>
23
- #include <stddef.h>
24
-
25
- #include <memory>
26
- #include <new>
27
- #include <string>
28
- #include <utility>
29
-
30
- #include "absl/container/inlined_vector.h"
31
- #include "absl/status/status.h"
32
- #include "absl/status/statusor.h"
33
- #include "absl/strings/str_cat.h"
34
- #include "absl/strings/string_view.h"
35
- #include "absl/strings/strip.h"
36
- #include "absl/types/optional.h"
37
-
38
- #include <grpc/impl/codegen/grpc_types.h>
39
- #include <grpc/slice.h>
40
- #include <grpc/status.h>
41
- #include <grpc/support/atm.h>
42
- #include <grpc/support/log.h>
43
-
44
- #include "src/core/ext/filters/client_channel/client_channel.h"
45
- #include "src/core/ext/filters/client_channel/config_selector.h"
46
- #include "src/core/ext/filters/client_channel/retry_service_config.h"
47
- #include "src/core/ext/filters/client_channel/retry_throttle.h"
48
- #include "src/core/lib/backoff/backoff.h"
49
- #include "src/core/lib/channel/channel_args.h"
50
- #include "src/core/lib/channel/channel_stack.h"
51
- #include "src/core/lib/channel/context.h"
52
- #include "src/core/lib/channel/status_util.h"
53
- #include "src/core/lib/debug/trace.h"
54
- #include "src/core/lib/gpr/useful.h"
55
- #include "src/core/lib/gprpp/construct_destruct.h"
56
- #include "src/core/lib/gprpp/debug_location.h"
57
- #include "src/core/lib/gprpp/orphanable.h"
58
- #include "src/core/lib/gprpp/ref_counted.h"
59
- #include "src/core/lib/gprpp/ref_counted_ptr.h"
60
- #include "src/core/lib/gprpp/status_helper.h"
61
- #include "src/core/lib/gprpp/time.h"
62
- #include "src/core/lib/iomgr/call_combiner.h"
63
- #include "src/core/lib/iomgr/closure.h"
64
- #include "src/core/lib/iomgr/error.h"
65
- #include "src/core/lib/iomgr/exec_ctx.h"
66
- #include "src/core/lib/iomgr/polling_entity.h"
67
- #include "src/core/lib/iomgr/timer.h"
68
- #include "src/core/lib/resource_quota/arena.h"
69
- #include "src/core/lib/service_config/service_config.h"
70
- #include "src/core/lib/service_config/service_config_call_data.h"
71
- #include "src/core/lib/slice/slice.h"
72
- #include "src/core/lib/slice/slice_buffer.h"
73
- #include "src/core/lib/transport/error_utils.h"
74
- #include "src/core/lib/transport/metadata_batch.h"
75
- #include "src/core/lib/transport/transport.h"
76
- #include "src/core/lib/uri/uri_parser.h"
77
-
78
- //
79
- // Retry filter
80
- //
81
-
82
- // This filter is intended to be used in the DynamicFilter stack in the
83
- // client channel, which is situated between the name resolver and the
84
- // LB policy. Normally, the last filter in the DynamicFilter stack is
85
- // the DynamicTerminationFilter (see client_channel.cc), which creates a
86
- // LoadBalancedCall and delegates to it. However, when retries are
87
- // enabled, this filter is used instead of the DynamicTerminationFilter.
88
- //
89
- // In order to support retries, we act as a proxy for stream op batches.
90
- // When we get a batch from the surface, we add it to our list of pending
91
- // batches, and we then use those batches to construct separate "child"
92
- // batches to be started on an LB call. When the child batches return, we
93
- // then decide which pending batches have been completed and schedule their
94
- // callbacks accordingly. If a call attempt fails and we want to retry it,
95
- // we create a new LB call and start again, constructing new "child" batches
96
- // for the new LB call.
97
- //
98
- // Note that retries are committed when receiving data from the server
99
- // (except for Trailers-Only responses). However, there may be many
100
- // send ops started before receiving any data, so we may have already
101
- // completed some number of send ops (and returned the completions up to
102
- // the surface) by the time we realize that we need to retry. To deal
103
- // with this, we cache data for send ops, so that we can replay them on a
104
- // different LB call even after we have completed the original batches.
105
- //
106
- // The code is structured as follows:
107
- // - In CallData (in the parent channel), we maintain a list of pending
108
- // ops and cached data for send ops.
109
- // - There is a CallData::CallAttempt object for each retry attempt.
110
- // This object contains the LB call for that attempt and state to indicate
111
- // which ops from the CallData object have already been sent down to that
112
- // LB call.
113
- // - There is a CallData::CallAttempt::BatchData object for each "child"
114
- // batch sent on the LB call.
115
- //
116
- // When constructing the "child" batches, we compare the state in the
117
- // CallAttempt object against the state in the CallData object to see
118
- // which batches need to be sent on the LB call for a given attempt.
119
-
120
- // TODO(roth): In subsequent PRs:
121
- // - implement hedging
122
-
123
- // By default, we buffer 256 KiB per RPC for retries.
124
- // TODO(roth): Do we have any data to suggest a better value?
125
- #define DEFAULT_PER_RPC_RETRY_BUFFER_SIZE (256 << 10)
126
-
127
- // This value was picked arbitrarily. It can be changed if there is
128
- // any even moderately compelling reason to do so.
129
- #define RETRY_BACKOFF_JITTER 0.2
130
-
131
- namespace grpc_core {
132
-
133
- namespace {
134
-
135
- using internal::RetryGlobalConfig;
136
- using internal::RetryMethodConfig;
137
- using internal::RetryServiceConfigParser;
138
- using internal::ServerRetryThrottleData;
139
-
140
- TraceFlag grpc_retry_trace(false, "retry");
141
-
142
- //
143
- // RetryFilter
144
- //
145
-
146
- class RetryFilter {
147
- public:
148
- class CallData;
149
-
150
- static grpc_error_handle Init(grpc_channel_element* elem,
151
- grpc_channel_element_args* args) {
152
- GPR_ASSERT(args->is_last);
153
- GPR_ASSERT(elem->filter == &kRetryFilterVtable);
154
- grpc_error_handle error;
155
- new (elem->channel_data) RetryFilter(args->channel_args, &error);
156
- return error;
157
- }
158
-
159
- static void Destroy(grpc_channel_element* elem) {
160
- auto* chand = static_cast<RetryFilter*>(elem->channel_data);
161
- chand->~RetryFilter();
162
- }
163
-
164
- // Will never be called.
165
- static void StartTransportOp(grpc_channel_element* /*elem*/,
166
- grpc_transport_op* /*op*/) {}
167
- static void GetChannelInfo(grpc_channel_element* /*elem*/,
168
- const grpc_channel_info* /*info*/) {}
169
-
170
- private:
171
- static size_t GetMaxPerRpcRetryBufferSize(const grpc_channel_args* args) {
172
- return static_cast<size_t>(grpc_channel_args_find_integer(
173
- args, GRPC_ARG_PER_RPC_RETRY_BUFFER_SIZE,
174
- {DEFAULT_PER_RPC_RETRY_BUFFER_SIZE, 0, INT_MAX}));
175
- }
176
-
177
- RetryFilter(const grpc_channel_args* args, grpc_error_handle* error)
178
- : client_channel_(grpc_channel_args_find_pointer<ClientChannel>(
179
- args, GRPC_ARG_CLIENT_CHANNEL)),
180
- per_rpc_retry_buffer_size_(GetMaxPerRpcRetryBufferSize(args)),
181
- service_config_parser_index_(
182
- internal::RetryServiceConfigParser::ParserIndex()) {
183
- // Get retry throttling parameters from service config.
184
- auto* service_config = grpc_channel_args_find_pointer<ServiceConfig>(
185
- args, GRPC_ARG_SERVICE_CONFIG_OBJ);
186
- if (service_config == nullptr) return;
187
- const auto* config = static_cast<const RetryGlobalConfig*>(
188
- service_config->GetGlobalParsedConfig(
189
- RetryServiceConfigParser::ParserIndex()));
190
- if (config == nullptr) return;
191
- // Get server name from target URI.
192
- const char* server_uri =
193
- grpc_channel_args_find_string(args, GRPC_ARG_SERVER_URI);
194
- if (server_uri == nullptr) {
195
- *error = GRPC_ERROR_CREATE(
196
- "server URI channel arg missing or wrong type in client channel "
197
- "filter");
198
- return;
199
- }
200
- absl::StatusOr<URI> uri = URI::Parse(server_uri);
201
- if (!uri.ok() || uri->path().empty()) {
202
- *error =
203
- GRPC_ERROR_CREATE("could not extract server name from target URI");
204
- return;
205
- }
206
- std::string server_name(absl::StripPrefix(uri->path(), "/"));
207
- // Get throttling config for server_name.
208
- retry_throttle_data_ =
209
- internal::ServerRetryThrottleMap::Get()->GetDataForServer(
210
- server_name, config->max_milli_tokens(),
211
- config->milli_token_ratio());
212
- }
213
-
214
- const RetryMethodConfig* GetRetryPolicy(
215
- const grpc_call_context_element* context);
216
-
217
- ClientChannel* client_channel_;
218
- size_t per_rpc_retry_buffer_size_;
219
- RefCountedPtr<ServerRetryThrottleData> retry_throttle_data_;
220
- const size_t service_config_parser_index_;
221
- };
222
-
223
- //
224
- // RetryFilter::CallData
225
- //
226
-
227
- class RetryFilter::CallData {
228
- public:
229
- static grpc_error_handle Init(grpc_call_element* elem,
230
- const grpc_call_element_args* args);
231
- static void Destroy(grpc_call_element* elem,
232
- const grpc_call_final_info* /*final_info*/,
233
- grpc_closure* then_schedule_closure);
234
- static void StartTransportStreamOpBatch(
235
- grpc_call_element* elem, grpc_transport_stream_op_batch* batch);
236
- static void SetPollent(grpc_call_element* elem, grpc_polling_entity* pollent);
237
-
238
- private:
239
- class CallStackDestructionBarrier;
240
-
241
- // Pending batches stored in call data.
242
- struct PendingBatch {
243
- // The pending batch. If nullptr, this slot is empty.
244
- grpc_transport_stream_op_batch* batch = nullptr;
245
- // Indicates whether payload for send ops has been cached in CallData.
246
- bool send_ops_cached = false;
247
- };
248
-
249
- // State associated with each call attempt.
250
- class CallAttempt : public RefCounted<CallAttempt> {
251
- public:
252
- CallAttempt(CallData* calld, bool is_transparent_retry);
253
- ~CallAttempt() override;
254
-
255
- bool lb_call_committed() const { return lb_call_committed_; }
256
-
257
- // Constructs and starts whatever batches are needed on this call
258
- // attempt.
259
- void StartRetriableBatches();
260
-
261
- // Frees cached send ops that have already been completed after
262
- // committing the call.
263
- void FreeCachedSendOpDataAfterCommit();
264
-
265
- // Cancels the call attempt.
266
- void CancelFromSurface(grpc_transport_stream_op_batch* cancel_batch);
267
-
268
- private:
269
- // State used for starting a retryable batch on the call attempt's LB call.
270
- // This provides its own grpc_transport_stream_op_batch and other data
271
- // structures needed to populate the ops in the batch.
272
- // We allocate one struct on the arena for each attempt at starting a
273
- // batch on a given LB call.
274
- class BatchData
275
- : public RefCounted<BatchData, PolymorphicRefCount, kUnrefCallDtor> {
276
- public:
277
- BatchData(RefCountedPtr<CallAttempt> call_attempt, int refcount,
278
- bool set_on_complete);
279
- ~BatchData() override;
280
-
281
- grpc_transport_stream_op_batch* batch() { return &batch_; }
282
-
283
- // Adds retriable send_initial_metadata op.
284
- void AddRetriableSendInitialMetadataOp();
285
- // Adds retriable send_message op.
286
- void AddRetriableSendMessageOp();
287
- // Adds retriable send_trailing_metadata op.
288
- void AddRetriableSendTrailingMetadataOp();
289
- // Adds retriable recv_initial_metadata op.
290
- void AddRetriableRecvInitialMetadataOp();
291
- // Adds retriable recv_message op.
292
- void AddRetriableRecvMessageOp();
293
- // Adds retriable recv_trailing_metadata op.
294
- void AddRetriableRecvTrailingMetadataOp();
295
- // Adds cancel_stream op.
296
- void AddCancelStreamOp(grpc_error_handle error);
297
-
298
- private:
299
- // Frees cached send ops that were completed by the completed batch in
300
- // batch_data. Used when batches are completed after the call is
301
- // committed.
302
- void FreeCachedSendOpDataForCompletedBatch();
303
-
304
- // If there is a pending recv_initial_metadata op, adds a closure
305
- // to closures for recv_initial_metadata_ready.
306
- void MaybeAddClosureForRecvInitialMetadataCallback(
307
- grpc_error_handle error, CallCombinerClosureList* closures);
308
- // Intercepts recv_initial_metadata_ready callback for retries.
309
- // Commits the call and returns the initial metadata up the stack.
310
- static void RecvInitialMetadataReady(void* arg, grpc_error_handle error);
311
-
312
- // If there is a pending recv_message op, adds a closure to closures
313
- // for recv_message_ready.
314
- void MaybeAddClosureForRecvMessageCallback(
315
- grpc_error_handle error, CallCombinerClosureList* closures);
316
- // Intercepts recv_message_ready callback for retries.
317
- // Commits the call and returns the message up the stack.
318
- static void RecvMessageReady(void* arg, grpc_error_handle error);
319
-
320
- // If there is a pending recv_trailing_metadata op, adds a closure to
321
- // closures for recv_trailing_metadata_ready.
322
- void MaybeAddClosureForRecvTrailingMetadataReady(
323
- grpc_error_handle error, CallCombinerClosureList* closures);
324
- // Adds any necessary closures for deferred batch completion
325
- // callbacks to closures.
326
- void AddClosuresForDeferredCompletionCallbacks(
327
- CallCombinerClosureList* closures);
328
- // For any pending batch containing an op that has not yet been started,
329
- // adds the pending batch's completion closures to closures.
330
- void AddClosuresToFailUnstartedPendingBatches(
331
- grpc_error_handle error, CallCombinerClosureList* closures);
332
- // Runs necessary closures upon completion of a call attempt.
333
- void RunClosuresForCompletedCall(grpc_error_handle error);
334
- // Intercepts recv_trailing_metadata_ready callback for retries.
335
- // Commits the call and returns the trailing metadata up the stack.
336
- static void RecvTrailingMetadataReady(void* arg, grpc_error_handle error);
337
-
338
- // Adds the on_complete closure for the pending batch completed in
339
- // batch_data to closures.
340
- void AddClosuresForCompletedPendingBatch(
341
- grpc_error_handle error, CallCombinerClosureList* closures);
342
-
343
- // If there are any cached ops to replay or pending ops to start on the
344
- // LB call, adds them to closures.
345
- void AddClosuresForReplayOrPendingSendOps(
346
- CallCombinerClosureList* closures);
347
-
348
- // Callback used to intercept on_complete from LB calls.
349
- static void OnComplete(void* arg, grpc_error_handle error);
350
-
351
- // Callback used to handle on_complete for internally generated
352
- // cancel_stream op.
353
- static void OnCompleteForCancelOp(void* arg, grpc_error_handle error);
354
-
355
- // This DOES hold a ref, but it cannot be a RefCountedPtr<>, because
356
- // our dtor unrefs the owning call, which may delete the arena in
357
- // which we are allocated, which means that running the dtor of any
358
- // data members after that would cause a crash.
359
- CallAttempt* call_attempt_;
360
- // The batch to use in the LB call.
361
- // Its payload field points to CallAttempt::batch_payload_.
362
- grpc_transport_stream_op_batch batch_;
363
- // For intercepting on_complete.
364
- grpc_closure on_complete_;
365
- };
366
-
367
- class AttemptDispatchController
368
- : public ConfigSelector::CallDispatchController {
369
- public:
370
- explicit AttemptDispatchController(CallAttempt* call_attempt)
371
- : call_attempt_(call_attempt) {}
372
-
373
- // Will never be called.
374
- bool ShouldRetry() override { return false; }
375
-
376
- void Commit() override {
377
- call_attempt_->lb_call_committed_ = true;
378
- auto* calld = call_attempt_->calld_;
379
- if (calld->retry_committed_) {
380
- auto* service_config_call_data =
381
- static_cast<ClientChannelServiceConfigCallData*>(
382
- calld->call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA]
383
- .value);
384
- service_config_call_data->call_dispatch_controller()->Commit();
385
- }
386
- }
387
-
388
- private:
389
- CallAttempt* call_attempt_;
390
- };
391
-
392
- // Creates a BatchData object on the call's arena with the
393
- // specified refcount. If set_on_complete is true, the batch's
394
- // on_complete callback will be set to point to on_complete();
395
- // otherwise, the batch's on_complete callback will be null.
396
- BatchData* CreateBatch(int refcount, bool set_on_complete) {
397
- return calld_->arena_->New<BatchData>(Ref(DEBUG_LOCATION, "CreateBatch"),
398
- refcount, set_on_complete);
399
- }
400
-
401
- // If there are any cached send ops that need to be replayed on this
402
- // call attempt, creates and returns a new batch to replay those ops.
403
- // Otherwise, returns nullptr.
404
- BatchData* MaybeCreateBatchForReplay();
405
-
406
- // Adds a closure to closures that will execute batch in the call combiner.
407
- void AddClosureForBatch(grpc_transport_stream_op_batch* batch,
408
- const char* reason,
409
- CallCombinerClosureList* closures);
410
-
411
- // Helper function used to start a recv_trailing_metadata batch. This
412
- // is used in the case where a recv_initial_metadata or recv_message
413
- // op fails in a way that we know the call is over but when the application
414
- // has not yet started its own recv_trailing_metadata op.
415
- void AddBatchForInternalRecvTrailingMetadata(
416
- CallCombinerClosureList* closures);
417
-
418
- // Adds a batch to closures to cancel this call attempt, if
419
- // cancellation has not already been sent on the LB call.
420
- void MaybeAddBatchForCancelOp(grpc_error_handle error,
421
- CallCombinerClosureList* closures);
422
-
423
- // Adds batches for pending batches to closures.
424
- void AddBatchesForPendingBatches(CallCombinerClosureList* closures);
425
-
426
- // Adds whatever batches are needed on this attempt to closures.
427
- void AddRetriableBatches(CallCombinerClosureList* closures);
428
-
429
- // Returns true if any send op in the batch was not yet started on this
430
- // attempt.
431
- bool PendingBatchContainsUnstartedSendOps(PendingBatch* pending);
432
-
433
- // Returns true if there are cached send ops to replay.
434
- bool HaveSendOpsToReplay();
435
-
436
- // If our retry state is no longer needed, switch to fast path by moving
437
- // our LB call into calld_->committed_call_ and having calld_ drop
438
- // its ref to us.
439
- void MaybeSwitchToFastPath();
440
-
441
- // Returns true if the call should be retried.
442
- bool ShouldRetry(absl::optional<grpc_status_code> status,
443
- absl::optional<Duration> server_pushback_ms);
444
-
445
- // Abandons the call attempt. Unrefs any deferred batches.
446
- void Abandon();
447
-
448
- static void OnPerAttemptRecvTimer(void* arg, grpc_error_handle error);
449
- static void OnPerAttemptRecvTimerLocked(void* arg, grpc_error_handle error);
450
- void MaybeCancelPerAttemptRecvTimer();
451
-
452
- CallData* calld_;
453
- AttemptDispatchController attempt_dispatch_controller_;
454
- OrphanablePtr<ClientChannel::LoadBalancedCall> lb_call_;
455
- bool lb_call_committed_ = false;
456
-
457
- grpc_timer per_attempt_recv_timer_;
458
- grpc_closure on_per_attempt_recv_timer_;
459
- bool per_attempt_recv_timer_pending_ = false;
460
-
461
- // BatchData.batch.payload points to this.
462
- grpc_transport_stream_op_batch_payload batch_payload_;
463
- // For send_initial_metadata.
464
- grpc_metadata_batch send_initial_metadata_{calld_->arena_};
465
- // For send_trailing_metadata.
466
- grpc_metadata_batch send_trailing_metadata_{calld_->arena_};
467
- // For intercepting recv_initial_metadata.
468
- grpc_metadata_batch recv_initial_metadata_{calld_->arena_};
469
- grpc_closure recv_initial_metadata_ready_;
470
- bool trailing_metadata_available_ = false;
471
- // For intercepting recv_message.
472
- grpc_closure recv_message_ready_;
473
- absl::optional<SliceBuffer> recv_message_;
474
- uint32_t recv_message_flags_;
475
- // For intercepting recv_trailing_metadata.
476
- grpc_metadata_batch recv_trailing_metadata_{calld_->arena_};
477
- grpc_transport_stream_stats collect_stats_;
478
- grpc_closure recv_trailing_metadata_ready_;
479
- // These fields indicate which ops have been started and completed on
480
- // this call attempt.
481
- size_t started_send_message_count_ = 0;
482
- size_t completed_send_message_count_ = 0;
483
- size_t started_recv_message_count_ = 0;
484
- size_t completed_recv_message_count_ = 0;
485
- bool started_send_initial_metadata_ : 1;
486
- bool completed_send_initial_metadata_ : 1;
487
- bool started_send_trailing_metadata_ : 1;
488
- bool completed_send_trailing_metadata_ : 1;
489
- bool started_recv_initial_metadata_ : 1;
490
- bool completed_recv_initial_metadata_ : 1;
491
- bool started_recv_trailing_metadata_ : 1;
492
- bool completed_recv_trailing_metadata_ : 1;
493
- bool sent_cancel_stream_ : 1;
494
- // State for callback processing.
495
- RefCountedPtr<BatchData> recv_initial_metadata_ready_deferred_batch_;
496
- grpc_error_handle recv_initial_metadata_error_;
497
- RefCountedPtr<BatchData> recv_message_ready_deferred_batch_;
498
- grpc_error_handle recv_message_error_;
499
- struct OnCompleteDeferredBatch {
500
- OnCompleteDeferredBatch(RefCountedPtr<BatchData> batch,
501
- grpc_error_handle error)
502
- : batch(std::move(batch)), error(error) {}
503
- RefCountedPtr<BatchData> batch;
504
- grpc_error_handle error;
505
- };
506
- // There cannot be more than 3 pending send op batches at a time.
507
- absl::InlinedVector<OnCompleteDeferredBatch, 3>
508
- on_complete_deferred_batches_;
509
- RefCountedPtr<BatchData> recv_trailing_metadata_internal_batch_;
510
- grpc_error_handle recv_trailing_metadata_error_;
511
- bool seen_recv_trailing_metadata_from_surface_ : 1;
512
- // NOTE: Do not move this next to the metadata bitfields above. That would
513
- // save space but will also result in a data race because compiler
514
- // will generate a 2 byte store which overwrites the meta-data
515
- // fields upon setting this field.
516
- bool abandoned_ : 1;
517
- };
518
-
519
- CallData(RetryFilter* chand, const grpc_call_element_args& args);
520
- ~CallData();
521
-
522
- void StartTransportStreamOpBatch(grpc_transport_stream_op_batch* batch);
523
-
524
- // Returns the index into pending_batches_ to be used for batch.
525
- static size_t GetBatchIndex(grpc_transport_stream_op_batch* batch);
526
- PendingBatch* PendingBatchesAdd(grpc_transport_stream_op_batch* batch);
527
- void PendingBatchClear(PendingBatch* pending);
528
- void MaybeClearPendingBatch(PendingBatch* pending);
529
- static void FailPendingBatchInCallCombiner(void* arg,
530
- grpc_error_handle error);
531
- // Fails all pending batches. Does NOT yield call combiner.
532
- void PendingBatchesFail(grpc_error_handle error);
533
- // Returns a pointer to the first pending batch for which predicate(batch)
534
- // returns true, or null if not found.
535
- template <typename Predicate>
536
- PendingBatch* PendingBatchFind(const char* log_message, Predicate predicate);
537
-
538
- // Caches data for send ops so that it can be retried later, if not
539
- // already cached.
540
- void MaybeCacheSendOpsForBatch(PendingBatch* pending);
541
- void FreeCachedSendInitialMetadata();
542
- // Frees cached send_message at index idx.
543
- void FreeCachedSendMessage(size_t idx);
544
- void FreeCachedSendTrailingMetadata();
545
- void FreeAllCachedSendOpData();
546
-
547
- // Commits the call so that no further retry attempts will be performed.
548
- void RetryCommit(CallAttempt* call_attempt);
549
-
550
- // Starts a timer to retry after appropriate back-off.
551
- // If server_pushback is nullopt, retry_backoff_ is used.
552
- void StartRetryTimer(absl::optional<Duration> server_pushback);
553
-
554
- static void OnRetryTimer(void* arg, grpc_error_handle error);
555
- static void OnRetryTimerLocked(void* arg, grpc_error_handle error);
556
-
557
- // Adds a closure to closures to start a transparent retry.
558
- void AddClosureToStartTransparentRetry(CallCombinerClosureList* closures);
559
- static void StartTransparentRetry(void* arg, grpc_error_handle error);
560
-
561
- OrphanablePtr<ClientChannel::LoadBalancedCall> CreateLoadBalancedCall(
562
- ConfigSelector::CallDispatchController* call_dispatch_controller,
563
- bool is_transparent_retry);
564
-
565
- void CreateCallAttempt(bool is_transparent_retry);
566
-
567
- RetryFilter* chand_;
568
- grpc_polling_entity* pollent_;
569
- RefCountedPtr<ServerRetryThrottleData> retry_throttle_data_;
570
- const RetryMethodConfig* retry_policy_ = nullptr;
571
- BackOff retry_backoff_;
572
-
573
- grpc_slice path_; // Request path.
574
- Timestamp deadline_;
575
- Arena* arena_;
576
- grpc_call_stack* owning_call_;
577
- CallCombiner* call_combiner_;
578
- grpc_call_context_element* call_context_;
579
-
580
- grpc_error_handle cancelled_from_surface_;
581
-
582
- RefCountedPtr<CallStackDestructionBarrier> call_stack_destruction_barrier_;
583
-
584
- // TODO(roth): As part of implementing hedging, we will need to maintain a
585
- // list of all pending attempts, so that we can cancel them all if the call
586
- // gets cancelled.
587
- RefCountedPtr<CallAttempt> call_attempt_;
588
-
589
- // LB call used when we've committed to a call attempt and the retry
590
- // state for that attempt is no longer needed. This provides a fast
591
- // path for long-running streaming calls that minimizes overhead.
592
- OrphanablePtr<ClientChannel::LoadBalancedCall> committed_call_;
593
-
594
- // When are are not yet fully committed to a particular call (i.e.,
595
- // either we might still retry or we have committed to the call but
596
- // there are still some cached ops to be replayed on the call),
597
- // batches received from above will be added to this list, and they
598
- // will not be removed until we have invoked their completion callbacks.
599
- size_t bytes_buffered_for_retry_ = 0;
600
- PendingBatch pending_batches_[MAX_PENDING_BATCHES];
601
- bool pending_send_initial_metadata_ : 1;
602
- bool pending_send_message_ : 1;
603
- bool pending_send_trailing_metadata_ : 1;
604
-
605
- // Retry state.
606
- bool retry_committed_ : 1;
607
- bool retry_timer_pending_ : 1;
608
- bool retry_codepath_started_ : 1;
609
- bool sent_transparent_retry_not_seen_by_server_ : 1;
610
- int num_attempts_completed_ = 0;
611
- grpc_timer retry_timer_;
612
- grpc_closure retry_closure_;
613
-
614
- // Cached data for retrying send ops.
615
- // send_initial_metadata
616
- bool seen_send_initial_metadata_ = false;
617
- grpc_metadata_batch send_initial_metadata_{arena_};
618
- // TODO(roth): As part of implementing hedging, we'll probably need to
619
- // have the LB call set a value in CallAttempt and then propagate it
620
- // from CallAttempt to the parent call when we commit. Otherwise, we
621
- // may leave this with a value for a peer other than the one we
622
- // actually commit to. Alternatively, maybe see if there's a way to
623
- // change the surface API such that the peer isn't available until
624
- // after initial metadata is received? (Could even change the
625
- // transport API to return this with the recv_initial_metadata op.)
626
- gpr_atm* peer_string_;
627
- // send_message
628
- // When we get a send_message op, we replace the original byte stream
629
- // with a CachingByteStream that caches the slices to a local buffer for
630
- // use in retries.
631
- // Note: We inline the cache for the first 3 send_message ops and use
632
- // dynamic allocation after that. This number was essentially picked
633
- // at random; it could be changed in the future to tune performance.
634
- struct CachedSendMessage {
635
- SliceBuffer* slices;
636
- uint32_t flags;
637
- };
638
- absl::InlinedVector<CachedSendMessage, 3> send_messages_;
639
- // send_trailing_metadata
640
- bool seen_send_trailing_metadata_ = false;
641
- grpc_metadata_batch send_trailing_metadata_{arena_};
642
- };
643
-
644
- //
645
- // RetryFilter::CallData::CallStackDestructionBarrier
646
- //
647
-
648
- // A class to track the existence of LoadBalancedCall call stacks that
649
- // we've created. We wait until all such call stacks have been
650
- // destroyed before we return the on_call_stack_destruction closure up
651
- // to the surface.
652
- //
653
- // The parent RetryFilter::CallData object holds a ref to this object.
654
- // When it is destroyed, it will store the on_call_stack_destruction
655
- // closure from the surface in this object and then release its ref.
656
- // We also take a ref to this object for each LB call we create, and
657
- // those refs are not released until the LB call stack is destroyed.
658
- // When this object is destroyed, it will invoke the
659
- // on_call_stack_destruction closure from the surface.
660
- class RetryFilter::CallData::CallStackDestructionBarrier
661
- : public RefCounted<CallStackDestructionBarrier, PolymorphicRefCount,
662
- kUnrefCallDtor> {
663
- public:
664
- CallStackDestructionBarrier() {}
665
-
666
- ~CallStackDestructionBarrier() override {
667
- // TODO(yashkt) : This can potentially be a Closure::Run
668
- ExecCtx::Run(DEBUG_LOCATION, on_call_stack_destruction_, absl::OkStatus());
669
- }
670
-
671
- // Set the closure from the surface. This closure will be invoked
672
- // when this object is destroyed.
673
- void set_on_call_stack_destruction(grpc_closure* on_call_stack_destruction) {
674
- on_call_stack_destruction_ = on_call_stack_destruction;
675
- }
676
-
677
- // Invoked to get an on_call_stack_destruction closure for a new LB call.
678
- grpc_closure* MakeLbCallDestructionClosure(CallData* calld) {
679
- Ref().release(); // Ref held by callback.
680
- grpc_closure* on_lb_call_destruction_complete =
681
- calld->arena_->New<grpc_closure>();
682
- GRPC_CLOSURE_INIT(on_lb_call_destruction_complete,
683
- OnLbCallDestructionComplete, this, nullptr);
684
- return on_lb_call_destruction_complete;
685
- }
686
-
687
- private:
688
- static void OnLbCallDestructionComplete(void* arg,
689
- grpc_error_handle /*error*/) {
690
- auto* self = static_cast<CallStackDestructionBarrier*>(arg);
691
- self->Unref();
692
- }
693
-
694
- grpc_closure* on_call_stack_destruction_ = nullptr;
695
- };
696
-
697
- //
698
- // RetryFilter::CallData::CallAttempt
699
- //
700
-
701
- RetryFilter::CallData::CallAttempt::CallAttempt(CallData* calld,
702
- bool is_transparent_retry)
703
- : RefCounted(GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) ? "CallAttempt"
704
- : nullptr),
705
- calld_(calld),
706
- attempt_dispatch_controller_(this),
707
- batch_payload_(calld->call_context_),
708
- started_send_initial_metadata_(false),
709
- completed_send_initial_metadata_(false),
710
- started_send_trailing_metadata_(false),
711
- completed_send_trailing_metadata_(false),
712
- started_recv_initial_metadata_(false),
713
- completed_recv_initial_metadata_(false),
714
- started_recv_trailing_metadata_(false),
715
- completed_recv_trailing_metadata_(false),
716
- sent_cancel_stream_(false),
717
- seen_recv_trailing_metadata_from_surface_(false),
718
- abandoned_(false) {
719
- lb_call_ = calld->CreateLoadBalancedCall(&attempt_dispatch_controller_,
720
- is_transparent_retry);
721
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
722
- gpr_log(GPR_INFO,
723
- "chand=%p calld=%p attempt=%p: created attempt, lb_call=%p",
724
- calld->chand_, calld, this, lb_call_.get());
725
- }
726
- // If per_attempt_recv_timeout is set, start a timer.
727
- if (calld->retry_policy_ != nullptr &&
728
- calld->retry_policy_->per_attempt_recv_timeout().has_value()) {
729
- Timestamp per_attempt_recv_deadline =
730
- Timestamp::Now() + *calld->retry_policy_->per_attempt_recv_timeout();
731
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
732
- gpr_log(GPR_INFO,
733
- "chand=%p calld=%p attempt=%p: per-attempt timeout in %" PRId64
734
- " ms",
735
- calld->chand_, calld, this,
736
- calld->retry_policy_->per_attempt_recv_timeout()->millis());
737
- }
738
- // Schedule retry after computed delay.
739
- GRPC_CLOSURE_INIT(&on_per_attempt_recv_timer_, OnPerAttemptRecvTimer, this,
740
- nullptr);
741
- GRPC_CALL_STACK_REF(calld->owning_call_, "OnPerAttemptRecvTimer");
742
- Ref(DEBUG_LOCATION, "OnPerAttemptRecvTimer").release();
743
- per_attempt_recv_timer_pending_ = true;
744
- grpc_timer_init(&per_attempt_recv_timer_, per_attempt_recv_deadline,
745
- &on_per_attempt_recv_timer_);
746
- }
747
- }
748
-
749
- RetryFilter::CallData::CallAttempt::~CallAttempt() {
750
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
751
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: destroying call attempt",
752
- calld_->chand_, calld_, this);
753
- }
754
- }
755
-
756
- void RetryFilter::CallData::CallAttempt::FreeCachedSendOpDataAfterCommit() {
757
- // TODO(roth): When we implement hedging, this logic will need to get
758
- // a bit more complex, because there may be other (now abandoned) call
759
- // attempts still using this data. We may need to do some sort of
760
- // ref-counting instead.
761
- if (completed_send_initial_metadata_) {
762
- calld_->FreeCachedSendInitialMetadata();
763
- }
764
- for (size_t i = 0; i < completed_send_message_count_; ++i) {
765
- calld_->FreeCachedSendMessage(i);
766
- }
767
- if (completed_send_trailing_metadata_) {
768
- calld_->FreeCachedSendTrailingMetadata();
769
- }
770
- }
771
-
772
- bool RetryFilter::CallData::CallAttempt::PendingBatchContainsUnstartedSendOps(
773
- PendingBatch* pending) {
774
- if (pending->batch->on_complete == nullptr) return false;
775
- if (pending->batch->send_initial_metadata &&
776
- !started_send_initial_metadata_) {
777
- return true;
778
- }
779
- if (pending->batch->send_message &&
780
- started_send_message_count_ < calld_->send_messages_.size()) {
781
- return true;
782
- }
783
- if (pending->batch->send_trailing_metadata &&
784
- !started_send_trailing_metadata_) {
785
- return true;
786
- }
787
- return false;
788
- }
789
-
790
- bool RetryFilter::CallData::CallAttempt::HaveSendOpsToReplay() {
791
- // We don't check send_initial_metadata here, because that op will always
792
- // be started as soon as it is received from the surface, so it will
793
- // never need to be started at this point.
794
- return started_send_message_count_ < calld_->send_messages_.size() ||
795
- (calld_->seen_send_trailing_metadata_ &&
796
- !started_send_trailing_metadata_);
797
- }
798
-
799
- void RetryFilter::CallData::CallAttempt::MaybeSwitchToFastPath() {
800
- // If we're not yet committed, we can't switch yet.
801
- // TODO(roth): As part of implementing hedging, this logic needs to
802
- // check that *this* call attempt is the one that we've committed to.
803
- // Might need to replace abandoned_ with an enum indicating whether we're
804
- // in flight, abandoned, or the winning call attempt.
805
- if (!calld_->retry_committed_) return;
806
- // If we've already switched to fast path, there's nothing to do here.
807
- if (calld_->committed_call_ != nullptr) return;
808
- // If the perAttemptRecvTimeout timer is pending, we can't switch yet.
809
- if (per_attempt_recv_timer_pending_) return;
810
- // If there are still send ops to replay, we can't switch yet.
811
- if (HaveSendOpsToReplay()) return;
812
- // If we started an internal batch for recv_trailing_metadata but have not
813
- // yet seen that op from the surface, we can't switch yet.
814
- if (recv_trailing_metadata_internal_batch_ != nullptr) return;
815
- // Switch to fast path.
816
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
817
- gpr_log(GPR_INFO,
818
- "chand=%p calld=%p attempt=%p: retry state no longer needed; "
819
- "moving LB call to parent and unreffing the call attempt",
820
- calld_->chand_, calld_, this);
821
- }
822
- calld_->committed_call_ = std::move(lb_call_);
823
- calld_->call_attempt_.reset(DEBUG_LOCATION, "MaybeSwitchToFastPath");
824
- }
825
-
826
- // If there are any cached send ops that need to be replayed on the
827
- // current call attempt, creates and returns a new batch to replay those ops.
828
- // Otherwise, returns nullptr.
829
- RetryFilter::CallData::CallAttempt::BatchData*
830
- RetryFilter::CallData::CallAttempt::MaybeCreateBatchForReplay() {
831
- BatchData* replay_batch_data = nullptr;
832
- // send_initial_metadata.
833
- if (calld_->seen_send_initial_metadata_ && !started_send_initial_metadata_ &&
834
- !calld_->pending_send_initial_metadata_) {
835
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
836
- gpr_log(GPR_INFO,
837
- "chand=%p calld=%p attempt=%p: replaying previously completed "
838
- "send_initial_metadata op",
839
- calld_->chand_, calld_, this);
840
- }
841
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
842
- replay_batch_data->AddRetriableSendInitialMetadataOp();
843
- }
844
- // send_message.
845
- // Note that we can only have one send_message op in flight at a time.
846
- if (started_send_message_count_ < calld_->send_messages_.size() &&
847
- started_send_message_count_ == completed_send_message_count_ &&
848
- !calld_->pending_send_message_) {
849
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
850
- gpr_log(GPR_INFO,
851
- "chand=%p calld=%p attempt=%p: replaying previously completed "
852
- "send_message op",
853
- calld_->chand_, calld_, this);
854
- }
855
- if (replay_batch_data == nullptr) {
856
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
857
- }
858
- replay_batch_data->AddRetriableSendMessageOp();
859
- }
860
- // send_trailing_metadata.
861
- // Note that we only add this op if we have no more send_message ops
862
- // to start, since we can't send down any more send_message ops after
863
- // send_trailing_metadata.
864
- if (calld_->seen_send_trailing_metadata_ &&
865
- started_send_message_count_ == calld_->send_messages_.size() &&
866
- !started_send_trailing_metadata_ &&
867
- !calld_->pending_send_trailing_metadata_) {
868
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
869
- gpr_log(GPR_INFO,
870
- "chand=%p calld=%p attempt=%p: replaying previously completed "
871
- "send_trailing_metadata op",
872
- calld_->chand_, calld_, this);
873
- }
874
- if (replay_batch_data == nullptr) {
875
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
876
- }
877
- replay_batch_data->AddRetriableSendTrailingMetadataOp();
878
- }
879
- return replay_batch_data;
880
- }
881
-
882
- namespace {
883
-
884
- void StartBatchInCallCombiner(void* arg, grpc_error_handle /*ignored*/) {
885
- grpc_transport_stream_op_batch* batch =
886
- static_cast<grpc_transport_stream_op_batch*>(arg);
887
- auto* lb_call = static_cast<ClientChannel::LoadBalancedCall*>(
888
- batch->handler_private.extra_arg);
889
- // Note: This will release the call combiner.
890
- lb_call->StartTransportStreamOpBatch(batch);
891
- }
892
-
893
- } // namespace
894
-
895
- void RetryFilter::CallData::CallAttempt::AddClosureForBatch(
896
- grpc_transport_stream_op_batch* batch, const char* reason,
897
- CallCombinerClosureList* closures) {
898
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
899
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: adding batch (%s): %s",
900
- calld_->chand_, calld_, this, reason,
901
- grpc_transport_stream_op_batch_string(batch).c_str());
902
- }
903
- batch->handler_private.extra_arg = lb_call_.get();
904
- GRPC_CLOSURE_INIT(&batch->handler_private.closure, StartBatchInCallCombiner,
905
- batch, grpc_schedule_on_exec_ctx);
906
- closures->Add(&batch->handler_private.closure, absl::OkStatus(), reason);
907
- }
908
-
909
- void RetryFilter::CallData::CallAttempt::
910
- AddBatchForInternalRecvTrailingMetadata(CallCombinerClosureList* closures) {
911
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
912
- gpr_log(GPR_INFO,
913
- "chand=%p calld=%p attempt=%p: call failed but "
914
- "recv_trailing_metadata not started; starting it internally",
915
- calld_->chand_, calld_, this);
916
- }
917
- // Create batch_data with 2 refs, since this batch will be unreffed twice:
918
- // once for the recv_trailing_metadata_ready callback when the batch
919
- // completes, and again when we actually get a recv_trailing_metadata
920
- // op from the surface.
921
- BatchData* batch_data = CreateBatch(2, false /* set_on_complete */);
922
- batch_data->AddRetriableRecvTrailingMetadataOp();
923
- recv_trailing_metadata_internal_batch_.reset(batch_data);
924
- AddClosureForBatch(batch_data->batch(),
925
- "starting internal recv_trailing_metadata", closures);
926
- }
927
-
928
- void RetryFilter::CallData::CallAttempt::MaybeAddBatchForCancelOp(
929
- grpc_error_handle error, CallCombinerClosureList* closures) {
930
- if (sent_cancel_stream_) {
931
- return;
932
- }
933
- sent_cancel_stream_ = true;
934
- BatchData* cancel_batch_data = CreateBatch(1, /*set_on_complete=*/true);
935
- cancel_batch_data->AddCancelStreamOp(error);
936
- AddClosureForBatch(cancel_batch_data->batch(),
937
- "start cancellation batch on call attempt", closures);
938
- }
939
-
940
- void RetryFilter::CallData::CallAttempt::AddBatchesForPendingBatches(
941
- CallCombinerClosureList* closures) {
942
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld_->pending_batches_); ++i) {
943
- PendingBatch* pending = &calld_->pending_batches_[i];
944
- grpc_transport_stream_op_batch* batch = pending->batch;
945
- if (batch == nullptr) continue;
946
- bool has_send_ops = false;
947
- // Skip any batch that either (a) has already been started on this
948
- // call attempt or (b) we can't start yet because we're still
949
- // replaying send ops that need to be completed first.
950
- // TODO(roth): Note that if any one op in the batch can't be sent
951
- // yet due to ops that we're replaying, we don't start any of the ops
952
- // in the batch. This is probably okay, but it could conceivably
953
- // lead to increased latency in some cases -- e.g., we could delay
954
- // starting a recv op due to it being in the same batch with a send
955
- // op. If/when we revamp the callback protocol in
956
- // transport_stream_op_batch, we may be able to fix this.
957
- if (batch->send_initial_metadata) {
958
- if (started_send_initial_metadata_) continue;
959
- has_send_ops = true;
960
- }
961
- if (batch->send_message) {
962
- // Cases where we can't start this send_message op:
963
- // - We are currently replaying a previous cached send_message op.
964
- // - We have already replayed all send_message ops, including this
965
- // one. (This can happen if a send_message op is in the same
966
- // batch as a recv op, the send_message op has already completed
967
- // but the recv op hasn't, and then a subsequent batch with another
968
- // recv op is started from the surface.)
969
- if (completed_send_message_count_ < started_send_message_count_ ||
970
- completed_send_message_count_ ==
971
- (calld_->send_messages_.size() + !pending->send_ops_cached)) {
972
- continue;
973
- }
974
- has_send_ops = true;
975
- }
976
- // Note that we only start send_trailing_metadata if we have no more
977
- // send_message ops to start, since we can't send down any more
978
- // send_message ops after send_trailing_metadata.
979
- if (batch->send_trailing_metadata) {
980
- if (started_send_message_count_ + batch->send_message <
981
- calld_->send_messages_.size() ||
982
- started_send_trailing_metadata_) {
983
- continue;
984
- }
985
- has_send_ops = true;
986
- }
987
- int num_callbacks = has_send_ops; // All send ops share one callback.
988
- if (batch->recv_initial_metadata) {
989
- if (started_recv_initial_metadata_) continue;
990
- ++num_callbacks;
991
- }
992
- if (batch->recv_message) {
993
- // Skip if the op is already in flight, or if it has already completed
994
- // but the completion has not yet been sent to the surface.
995
- if (completed_recv_message_count_ < started_recv_message_count_ ||
996
- recv_message_ready_deferred_batch_ != nullptr) {
997
- continue;
998
- }
999
- ++num_callbacks;
1000
- }
1001
- if (batch->recv_trailing_metadata) {
1002
- if (started_recv_trailing_metadata_) {
1003
- seen_recv_trailing_metadata_from_surface_ = true;
1004
- // If we previously completed a recv_trailing_metadata op
1005
- // initiated by AddBatchForInternalRecvTrailingMetadata(), use the
1006
- // result of that instead of trying to re-start this op.
1007
- if (GPR_UNLIKELY(recv_trailing_metadata_internal_batch_ != nullptr)) {
1008
- // If the batch completed, then trigger the completion callback
1009
- // directly, so that we return the previously returned results to
1010
- // the application. Otherwise, just unref the internally started
1011
- // batch, since we'll propagate the completion when it completes.
1012
- if (completed_recv_trailing_metadata_) {
1013
- closures->Add(
1014
- &recv_trailing_metadata_ready_, recv_trailing_metadata_error_,
1015
- "re-executing recv_trailing_metadata_ready to propagate "
1016
- "internally triggered result");
1017
- // Ref will be released by callback.
1018
- recv_trailing_metadata_internal_batch_.release();
1019
- } else {
1020
- recv_trailing_metadata_internal_batch_.reset(
1021
- DEBUG_LOCATION,
1022
- "internally started recv_trailing_metadata batch pending and "
1023
- "recv_trailing_metadata started from surface");
1024
- }
1025
- recv_trailing_metadata_error_ = absl::OkStatus();
1026
- }
1027
- // We don't want the fact that we've already started this op internally
1028
- // to prevent us from adding a batch that may contain other ops.
1029
- // Instead, we'll just skip adding this op below.
1030
- if (num_callbacks == 0) continue;
1031
- } else {
1032
- ++num_callbacks;
1033
- }
1034
- }
1035
- // If we're already committed and the following conditions are met,
1036
- // just send the batch down as-is:
1037
- // - The batch contains no cached send ops. (If it does, we need
1038
- // the logic below to use the cached payloads.)
1039
- // - The batch does not contain recv_trailing_metadata when we have
1040
- // already started an internal recv_trailing_metadata batch. (If
1041
- // we've already started an internal recv_trailing_metadata batch,
1042
- // then we need the logic below to send all ops in the batch
1043
- // *except* the recv_trailing_metadata op.)
1044
- if (calld_->retry_committed_ && !pending->send_ops_cached &&
1045
- (!batch->recv_trailing_metadata || !started_recv_trailing_metadata_)) {
1046
- AddClosureForBatch(
1047
- batch,
1048
- "start non-replayable pending batch on call attempt after commit",
1049
- closures);
1050
- calld_->PendingBatchClear(pending);
1051
- continue;
1052
- }
1053
- // Create batch with the right number of callbacks.
1054
- BatchData* batch_data =
1055
- CreateBatch(num_callbacks, has_send_ops /* set_on_complete */);
1056
- // Cache send ops if needed.
1057
- calld_->MaybeCacheSendOpsForBatch(pending);
1058
- // send_initial_metadata.
1059
- if (batch->send_initial_metadata) {
1060
- batch_data->AddRetriableSendInitialMetadataOp();
1061
- }
1062
- // send_message.
1063
- if (batch->send_message) {
1064
- batch_data->AddRetriableSendMessageOp();
1065
- }
1066
- // send_trailing_metadata.
1067
- if (batch->send_trailing_metadata) {
1068
- batch_data->AddRetriableSendTrailingMetadataOp();
1069
- }
1070
- // recv_initial_metadata.
1071
- if (batch->recv_initial_metadata) {
1072
- batch_data->AddRetriableRecvInitialMetadataOp();
1073
- }
1074
- // recv_message.
1075
- if (batch->recv_message) {
1076
- batch_data->AddRetriableRecvMessageOp();
1077
- }
1078
- // recv_trailing_metadata.
1079
- if (batch->recv_trailing_metadata && !started_recv_trailing_metadata_) {
1080
- batch_data->AddRetriableRecvTrailingMetadataOp();
1081
- }
1082
- AddClosureForBatch(batch_data->batch(),
1083
- "start replayable pending batch on call attempt",
1084
- closures);
1085
- }
1086
- }
1087
-
1088
- void RetryFilter::CallData::CallAttempt::AddRetriableBatches(
1089
- CallCombinerClosureList* closures) {
1090
- // Replay previously-returned send_* ops if needed.
1091
- BatchData* replay_batch_data = MaybeCreateBatchForReplay();
1092
- if (replay_batch_data != nullptr) {
1093
- AddClosureForBatch(replay_batch_data->batch(),
1094
- "start replay batch on call attempt", closures);
1095
- }
1096
- // Now add pending batches.
1097
- AddBatchesForPendingBatches(closures);
1098
- }
1099
-
1100
- void RetryFilter::CallData::CallAttempt::StartRetriableBatches() {
1101
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1102
- gpr_log(GPR_INFO,
1103
- "chand=%p calld=%p attempt=%p: constructing retriable batches",
1104
- calld_->chand_, calld_, this);
1105
- }
1106
- // Construct list of closures to execute, one for each pending batch.
1107
- CallCombinerClosureList closures;
1108
- AddRetriableBatches(&closures);
1109
- // Note: This will yield the call combiner.
1110
- // Start batches on LB call.
1111
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1112
- gpr_log(GPR_INFO,
1113
- "chand=%p calld=%p attempt=%p: starting %" PRIuPTR
1114
- " retriable batches on lb_call=%p",
1115
- calld_->chand_, calld_, this, closures.size(), lb_call_.get());
1116
- }
1117
- closures.RunClosures(calld_->call_combiner_);
1118
- }
1119
-
1120
- void RetryFilter::CallData::CallAttempt::CancelFromSurface(
1121
- grpc_transport_stream_op_batch* cancel_batch) {
1122
- MaybeCancelPerAttemptRecvTimer();
1123
- Abandon();
1124
- // Propagate cancellation to LB call.
1125
- lb_call_->StartTransportStreamOpBatch(cancel_batch);
1126
- }
1127
-
1128
- bool RetryFilter::CallData::CallAttempt::ShouldRetry(
1129
- absl::optional<grpc_status_code> status,
1130
- absl::optional<Duration> server_pushback) {
1131
- // If no retry policy, don't retry.
1132
- if (calld_->retry_policy_ == nullptr) return false;
1133
- // Check status.
1134
- if (status.has_value()) {
1135
- if (GPR_LIKELY(*status == GRPC_STATUS_OK)) {
1136
- if (calld_->retry_throttle_data_ != nullptr) {
1137
- calld_->retry_throttle_data_->RecordSuccess();
1138
- }
1139
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1140
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: call succeeded",
1141
- calld_->chand_, calld_, this);
1142
- }
1143
- return false;
1144
- }
1145
- // Status is not OK. Check whether the status is retryable.
1146
- if (!calld_->retry_policy_->retryable_status_codes().Contains(*status)) {
1147
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1148
- gpr_log(GPR_INFO,
1149
- "chand=%p calld=%p attempt=%p: status %s not configured as "
1150
- "retryable",
1151
- calld_->chand_, calld_, this,
1152
- grpc_status_code_to_string(*status));
1153
- }
1154
- return false;
1155
- }
1156
- }
1157
- // Record the failure and check whether retries are throttled.
1158
- // Note that it's important for this check to come after the status
1159
- // code check above, since we should only record failures whose statuses
1160
- // match the configured retryable status codes, so that we don't count
1161
- // things like failures due to malformed requests (INVALID_ARGUMENT).
1162
- // Conversely, it's important for this to come before the remaining
1163
- // checks, so that we don't fail to record failures due to other factors.
1164
- if (calld_->retry_throttle_data_ != nullptr &&
1165
- !calld_->retry_throttle_data_->RecordFailure()) {
1166
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1167
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: retries throttled",
1168
- calld_->chand_, calld_, this);
1169
- }
1170
- return false;
1171
- }
1172
- // Check whether the call is committed.
1173
- if (calld_->retry_committed_) {
1174
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1175
- gpr_log(GPR_INFO,
1176
- "chand=%p calld=%p attempt=%p: retries already committed",
1177
- calld_->chand_, calld_, this);
1178
- }
1179
- return false;
1180
- }
1181
- // Check whether we have retries remaining.
1182
- ++calld_->num_attempts_completed_;
1183
- if (calld_->num_attempts_completed_ >=
1184
- calld_->retry_policy_->max_attempts()) {
1185
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1186
- gpr_log(
1187
- GPR_INFO, "chand=%p calld=%p attempt=%p: exceeded %d retry attempts",
1188
- calld_->chand_, calld_, this, calld_->retry_policy_->max_attempts());
1189
- }
1190
- return false;
1191
- }
1192
- // Check server push-back.
1193
- if (server_pushback.has_value()) {
1194
- if (*server_pushback < Duration::Zero()) {
1195
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1196
- gpr_log(GPR_INFO,
1197
- "chand=%p calld=%p attempt=%p: not retrying due to server "
1198
- "push-back",
1199
- calld_->chand_, calld_, this);
1200
- }
1201
- return false;
1202
- } else {
1203
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1204
- gpr_log(
1205
- GPR_INFO,
1206
- "chand=%p calld=%p attempt=%p: server push-back: retry in %" PRIu64
1207
- " ms",
1208
- calld_->chand_, calld_, this, server_pushback->millis());
1209
- }
1210
- }
1211
- }
1212
- // Check with call dispatch controller.
1213
- auto* service_config_call_data =
1214
- static_cast<ClientChannelServiceConfigCallData*>(
1215
- calld_->call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
1216
- if (!service_config_call_data->call_dispatch_controller()->ShouldRetry()) {
1217
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1218
- gpr_log(
1219
- GPR_INFO,
1220
- "chand=%p calld=%p attempt=%p: call dispatch controller denied retry",
1221
- calld_->chand_, calld_, this);
1222
- }
1223
- return false;
1224
- }
1225
- // We should retry.
1226
- return true;
1227
- }
1228
-
1229
- void RetryFilter::CallData::CallAttempt::Abandon() {
1230
- abandoned_ = true;
1231
- // Unref batches for deferred completion callbacks that will now never
1232
- // be invoked.
1233
- if (started_recv_trailing_metadata_ &&
1234
- !seen_recv_trailing_metadata_from_surface_) {
1235
- recv_trailing_metadata_internal_batch_.reset(
1236
- DEBUG_LOCATION,
1237
- "unref internal recv_trailing_metadata_ready batch; attempt abandoned");
1238
- }
1239
- recv_trailing_metadata_error_ = absl::OkStatus();
1240
- recv_initial_metadata_ready_deferred_batch_.reset(
1241
- DEBUG_LOCATION,
1242
- "unref deferred recv_initial_metadata_ready batch; attempt abandoned");
1243
- recv_initial_metadata_error_ = absl::OkStatus();
1244
- recv_message_ready_deferred_batch_.reset(
1245
- DEBUG_LOCATION,
1246
- "unref deferred recv_message_ready batch; attempt abandoned");
1247
- recv_message_error_ = absl::OkStatus();
1248
- for (auto& on_complete_deferred_batch : on_complete_deferred_batches_) {
1249
- on_complete_deferred_batch.batch.reset(
1250
- DEBUG_LOCATION, "unref deferred on_complete batch; attempt abandoned");
1251
- }
1252
- on_complete_deferred_batches_.clear();
1253
- }
1254
-
1255
- void RetryFilter::CallData::CallAttempt::OnPerAttemptRecvTimer(
1256
- void* arg, grpc_error_handle error) {
1257
- auto* call_attempt = static_cast<CallAttempt*>(arg);
1258
- GRPC_CLOSURE_INIT(&call_attempt->on_per_attempt_recv_timer_,
1259
- OnPerAttemptRecvTimerLocked, call_attempt, nullptr);
1260
- GRPC_CALL_COMBINER_START(call_attempt->calld_->call_combiner_,
1261
- &call_attempt->on_per_attempt_recv_timer_, error,
1262
- "per-attempt timer fired");
1263
- }
1264
-
1265
- void RetryFilter::CallData::CallAttempt::OnPerAttemptRecvTimerLocked(
1266
- void* arg, grpc_error_handle error) {
1267
- auto* call_attempt = static_cast<CallAttempt*>(arg);
1268
- auto* calld = call_attempt->calld_;
1269
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1270
- gpr_log(GPR_INFO,
1271
- "chand=%p calld=%p attempt=%p: perAttemptRecvTimeout timer fired: "
1272
- "error=%s, per_attempt_recv_timer_pending_=%d",
1273
- calld->chand_, calld, call_attempt, StatusToString(error).c_str(),
1274
- call_attempt->per_attempt_recv_timer_pending_);
1275
- }
1276
- CallCombinerClosureList closures;
1277
- if (error.ok() && call_attempt->per_attempt_recv_timer_pending_) {
1278
- call_attempt->per_attempt_recv_timer_pending_ = false;
1279
- // Cancel this attempt.
1280
- // TODO(roth): When implementing hedging, we should not cancel the
1281
- // current attempt.
1282
- call_attempt->MaybeAddBatchForCancelOp(
1283
- grpc_error_set_int(
1284
- GRPC_ERROR_CREATE("retry perAttemptRecvTimeout exceeded"),
1285
- StatusIntProperty::kRpcStatus, GRPC_STATUS_CANCELLED),
1286
- &closures);
1287
- // Check whether we should retry.
1288
- if (call_attempt->ShouldRetry(/*status=*/absl::nullopt,
1289
- /*server_pushback_ms=*/absl::nullopt)) {
1290
- // Mark current attempt as abandoned.
1291
- call_attempt->Abandon();
1292
- // We are retrying. Start backoff timer.
1293
- calld->StartRetryTimer(/*server_pushback=*/absl::nullopt);
1294
- } else {
1295
- // Not retrying, so commit the call.
1296
- calld->RetryCommit(call_attempt);
1297
- // If retry state is no longer needed, switch to fast path for
1298
- // subsequent batches.
1299
- call_attempt->MaybeSwitchToFastPath();
1300
- }
1301
- }
1302
- closures.RunClosures(calld->call_combiner_);
1303
- call_attempt->Unref(DEBUG_LOCATION, "OnPerAttemptRecvTimer");
1304
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnPerAttemptRecvTimer");
1305
- }
1306
-
1307
- void RetryFilter::CallData::CallAttempt::MaybeCancelPerAttemptRecvTimer() {
1308
- if (per_attempt_recv_timer_pending_) {
1309
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1310
- gpr_log(GPR_INFO,
1311
- "chand=%p calld=%p attempt=%p: cancelling "
1312
- "perAttemptRecvTimeout timer",
1313
- calld_->chand_, calld_, this);
1314
- }
1315
- per_attempt_recv_timer_pending_ = false;
1316
- grpc_timer_cancel(&per_attempt_recv_timer_);
1317
- }
1318
- }
1319
-
1320
- //
1321
- // RetryFilter::CallData::CallAttempt::BatchData
1322
- //
1323
-
1324
- RetryFilter::CallData::CallAttempt::BatchData::BatchData(
1325
- RefCountedPtr<CallAttempt> attempt, int refcount, bool set_on_complete)
1326
- : RefCounted(
1327
- GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) ? "BatchData" : nullptr,
1328
- refcount),
1329
- call_attempt_(attempt.release()) {
1330
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1331
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: creating batch %p",
1332
- call_attempt_->calld_->chand_, call_attempt_->calld_, call_attempt_,
1333
- this);
1334
- }
1335
- // We hold a ref to the call stack for every batch sent on a call attempt.
1336
- // This is because some batches on the call attempt may not complete
1337
- // until after all of the batches are completed at the surface (because
1338
- // each batch that is pending at the surface holds a ref). This
1339
- // can happen for replayed send ops, and it can happen for
1340
- // recv_initial_metadata and recv_message ops on a call attempt that has
1341
- // been abandoned.
1342
- GRPC_CALL_STACK_REF(call_attempt_->calld_->owning_call_, "Retry BatchData");
1343
- batch_.payload = &call_attempt_->batch_payload_;
1344
- if (set_on_complete) {
1345
- GRPC_CLOSURE_INIT(&on_complete_, OnComplete, this, nullptr);
1346
- batch_.on_complete = &on_complete_;
1347
- }
1348
- }
1349
-
1350
- RetryFilter::CallData::CallAttempt::BatchData::~BatchData() {
1351
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1352
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: destroying batch %p",
1353
- call_attempt_->calld_->chand_, call_attempt_->calld_, call_attempt_,
1354
- this);
1355
- }
1356
- CallAttempt* call_attempt = std::exchange(call_attempt_, nullptr);
1357
- GRPC_CALL_STACK_UNREF(call_attempt->calld_->owning_call_, "Retry BatchData");
1358
- call_attempt->Unref(DEBUG_LOCATION, "~BatchData");
1359
- }
1360
-
1361
- void RetryFilter::CallData::CallAttempt::BatchData::
1362
- FreeCachedSendOpDataForCompletedBatch() {
1363
- auto* calld = call_attempt_->calld_;
1364
- // TODO(roth): When we implement hedging, this logic will need to get
1365
- // a bit more complex, because there may be other (now abandoned) call
1366
- // attempts still using this data. We may need to do some sort of
1367
- // ref-counting instead.
1368
- if (batch_.send_initial_metadata) {
1369
- calld->FreeCachedSendInitialMetadata();
1370
- }
1371
- if (batch_.send_message) {
1372
- calld->FreeCachedSendMessage(call_attempt_->completed_send_message_count_ -
1373
- 1);
1374
- }
1375
- if (batch_.send_trailing_metadata) {
1376
- calld->FreeCachedSendTrailingMetadata();
1377
- }
1378
- }
1379
-
1380
- //
1381
- // recv_initial_metadata callback handling
1382
- //
1383
-
1384
- void RetryFilter::CallData::CallAttempt::BatchData::
1385
- MaybeAddClosureForRecvInitialMetadataCallback(
1386
- grpc_error_handle error, CallCombinerClosureList* closures) {
1387
- // Find pending batch.
1388
- PendingBatch* pending = call_attempt_->calld_->PendingBatchFind(
1389
- "invoking recv_initial_metadata_ready for",
1390
- [](grpc_transport_stream_op_batch* batch) {
1391
- return batch->recv_initial_metadata &&
1392
- batch->payload->recv_initial_metadata
1393
- .recv_initial_metadata_ready != nullptr;
1394
- });
1395
- if (pending == nullptr) {
1396
- return;
1397
- }
1398
- // Return metadata.
1399
- *pending->batch->payload->recv_initial_metadata.recv_initial_metadata =
1400
- std::move(call_attempt_->recv_initial_metadata_);
1401
- // Propagate trailing_metadata_available.
1402
- *pending->batch->payload->recv_initial_metadata.trailing_metadata_available =
1403
- call_attempt_->trailing_metadata_available_;
1404
- // Update bookkeeping.
1405
- // Note: Need to do this before invoking the callback, since invoking
1406
- // the callback will result in yielding the call combiner.
1407
- grpc_closure* recv_initial_metadata_ready =
1408
- pending->batch->payload->recv_initial_metadata
1409
- .recv_initial_metadata_ready;
1410
- pending->batch->payload->recv_initial_metadata.recv_initial_metadata_ready =
1411
- nullptr;
1412
- call_attempt_->calld_->MaybeClearPendingBatch(pending);
1413
- // Add callback to closures.
1414
- closures->Add(recv_initial_metadata_ready, error,
1415
- "recv_initial_metadata_ready for pending batch");
1416
- }
1417
-
1418
- void RetryFilter::CallData::CallAttempt::BatchData::RecvInitialMetadataReady(
1419
- void* arg, grpc_error_handle error) {
1420
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1421
- CallAttempt* call_attempt = batch_data->call_attempt_;
1422
- CallData* calld = call_attempt->calld_;
1423
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1424
- gpr_log(GPR_INFO,
1425
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1426
- "got recv_initial_metadata_ready, error=%s",
1427
- calld->chand_, calld, call_attempt, batch_data.get(),
1428
- StatusToString(error).c_str());
1429
- }
1430
- call_attempt->completed_recv_initial_metadata_ = true;
1431
- // If this attempt has been abandoned, then we're not going to use the
1432
- // result of this recv_initial_metadata op, so do nothing.
1433
- if (call_attempt->abandoned_) {
1434
- GRPC_CALL_COMBINER_STOP(
1435
- calld->call_combiner_,
1436
- "recv_initial_metadata_ready for abandoned attempt");
1437
- return;
1438
- }
1439
- // Cancel per-attempt recv timer, if any.
1440
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1441
- // If we're not committed, check the response to see if we need to commit.
1442
- if (!calld->retry_committed_) {
1443
- // If we got an error or a Trailers-Only response and have not yet gotten
1444
- // the recv_trailing_metadata_ready callback, then defer propagating this
1445
- // callback back to the surface. We can evaluate whether to retry when
1446
- // recv_trailing_metadata comes back.
1447
- if (GPR_UNLIKELY(
1448
- (call_attempt->trailing_metadata_available_ || !error.ok()) &&
1449
- !call_attempt->completed_recv_trailing_metadata_)) {
1450
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1451
- gpr_log(GPR_INFO,
1452
- "chand=%p calld=%p attempt=%p: deferring "
1453
- "recv_initial_metadata_ready (Trailers-Only)",
1454
- calld->chand_, calld, call_attempt);
1455
- }
1456
- call_attempt->recv_initial_metadata_ready_deferred_batch_ =
1457
- std::move(batch_data);
1458
- call_attempt->recv_initial_metadata_error_ = error;
1459
- CallCombinerClosureList closures;
1460
- if (!error.ok()) {
1461
- call_attempt->MaybeAddBatchForCancelOp(error, &closures);
1462
- }
1463
- if (!call_attempt->started_recv_trailing_metadata_) {
1464
- // recv_trailing_metadata not yet started by application; start it
1465
- // ourselves to get status.
1466
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1467
- }
1468
- closures.RunClosures(calld->call_combiner_);
1469
- return;
1470
- }
1471
- // Received valid initial metadata, so commit the call.
1472
- calld->RetryCommit(call_attempt);
1473
- // If retry state is no longer needed, switch to fast path for
1474
- // subsequent batches.
1475
- call_attempt->MaybeSwitchToFastPath();
1476
- }
1477
- // Invoke the callback to return the result to the surface.
1478
- CallCombinerClosureList closures;
1479
- batch_data->MaybeAddClosureForRecvInitialMetadataCallback(error, &closures);
1480
- closures.RunClosures(calld->call_combiner_);
1481
- }
1482
-
1483
- //
1484
- // recv_message callback handling
1485
- //
1486
-
1487
- void RetryFilter::CallData::CallAttempt::BatchData::
1488
- MaybeAddClosureForRecvMessageCallback(grpc_error_handle error,
1489
- CallCombinerClosureList* closures) {
1490
- // Find pending op.
1491
- PendingBatch* pending = call_attempt_->calld_->PendingBatchFind(
1492
- "invoking recv_message_ready for",
1493
- [](grpc_transport_stream_op_batch* batch) {
1494
- return batch->recv_message &&
1495
- batch->payload->recv_message.recv_message_ready != nullptr;
1496
- });
1497
- if (pending == nullptr) {
1498
- return;
1499
- }
1500
- // Return payload.
1501
- *pending->batch->payload->recv_message.recv_message =
1502
- std::move(call_attempt_->recv_message_);
1503
- *pending->batch->payload->recv_message.flags =
1504
- call_attempt_->recv_message_flags_;
1505
- // Update bookkeeping.
1506
- // Note: Need to do this before invoking the callback, since invoking
1507
- // the callback will result in yielding the call combiner.
1508
- grpc_closure* recv_message_ready =
1509
- pending->batch->payload->recv_message.recv_message_ready;
1510
- pending->batch->payload->recv_message.recv_message_ready = nullptr;
1511
- call_attempt_->calld_->MaybeClearPendingBatch(pending);
1512
- // Add callback to closures.
1513
- closures->Add(recv_message_ready, error,
1514
- "recv_message_ready for pending batch");
1515
- }
1516
-
1517
- void RetryFilter::CallData::CallAttempt::BatchData::RecvMessageReady(
1518
- void* arg, grpc_error_handle error) {
1519
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1520
- CallAttempt* call_attempt = batch_data->call_attempt_;
1521
- CallData* calld = call_attempt->calld_;
1522
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1523
- gpr_log(GPR_INFO,
1524
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1525
- "got recv_message_ready, error=%s",
1526
- calld->chand_, calld, call_attempt, batch_data.get(),
1527
- StatusToString(error).c_str());
1528
- }
1529
- ++call_attempt->completed_recv_message_count_;
1530
- // If this attempt has been abandoned, then we're not going to use the
1531
- // result of this recv_message op, so do nothing.
1532
- if (call_attempt->abandoned_) {
1533
- // The transport will not invoke recv_trailing_metadata_ready until the byte
1534
- // stream for any recv_message op is orphaned, so we do that here to ensure
1535
- // that any pending recv_trailing_metadata op can complete.
1536
- call_attempt->recv_message_.reset();
1537
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
1538
- "recv_message_ready for abandoned attempt");
1539
- return;
1540
- }
1541
- // Cancel per-attempt recv timer, if any.
1542
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1543
- // If we're not committed, check the response to see if we need to commit.
1544
- if (!calld->retry_committed_) {
1545
- // If we got an error or the payload was nullptr and we have not yet gotten
1546
- // the recv_trailing_metadata_ready callback, then defer propagating this
1547
- // callback back to the surface. We can evaluate whether to retry when
1548
- // recv_trailing_metadata comes back.
1549
- if (GPR_UNLIKELY(
1550
- (!call_attempt->recv_message_.has_value() || !error.ok()) &&
1551
- !call_attempt->completed_recv_trailing_metadata_)) {
1552
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1553
- gpr_log(GPR_INFO,
1554
- "chand=%p calld=%p attempt=%p: deferring recv_message_ready "
1555
- "(nullptr message and recv_trailing_metadata pending)",
1556
- calld->chand_, calld, call_attempt);
1557
- }
1558
- call_attempt->recv_message_ready_deferred_batch_ = std::move(batch_data);
1559
- call_attempt->recv_message_error_ = error;
1560
- CallCombinerClosureList closures;
1561
- if (!error.ok()) {
1562
- call_attempt->MaybeAddBatchForCancelOp(error, &closures);
1563
- }
1564
- if (!call_attempt->started_recv_trailing_metadata_) {
1565
- // recv_trailing_metadata not yet started by application; start it
1566
- // ourselves to get status.
1567
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1568
- }
1569
- closures.RunClosures(calld->call_combiner_);
1570
- return;
1571
- }
1572
- // Received a valid message, so commit the call.
1573
- calld->RetryCommit(call_attempt);
1574
- // If retry state is no longer needed, switch to fast path for
1575
- // subsequent batches.
1576
- call_attempt->MaybeSwitchToFastPath();
1577
- }
1578
- // Invoke the callback to return the result to the surface.
1579
- CallCombinerClosureList closures;
1580
- batch_data->MaybeAddClosureForRecvMessageCallback(error, &closures);
1581
- closures.RunClosures(calld->call_combiner_);
1582
- }
1583
-
1584
- //
1585
- // recv_trailing_metadata handling
1586
- //
1587
-
1588
- namespace {
1589
-
1590
- // Sets *status, *server_pushback, and *is_lb_drop based on md_batch
1591
- // and error.
1592
- void GetCallStatus(
1593
- Timestamp deadline, grpc_metadata_batch* md_batch, grpc_error_handle error,
1594
- grpc_status_code* status, absl::optional<Duration>* server_pushback,
1595
- bool* is_lb_drop,
1596
- absl::optional<GrpcStreamNetworkState::ValueType>* stream_network_state) {
1597
- if (!error.ok()) {
1598
- grpc_error_get_status(error, deadline, status, nullptr, nullptr, nullptr);
1599
- intptr_t value = 0;
1600
- if (grpc_error_get_int(error, StatusIntProperty::kLbPolicyDrop, &value) &&
1601
- value != 0) {
1602
- *is_lb_drop = true;
1603
- }
1604
- } else {
1605
- *status = *md_batch->get(GrpcStatusMetadata());
1606
- }
1607
- *server_pushback = md_batch->get(GrpcRetryPushbackMsMetadata());
1608
- *stream_network_state = md_batch->get(GrpcStreamNetworkState());
1609
- }
1610
-
1611
- } // namespace
1612
-
1613
- void RetryFilter::CallData::CallAttempt::BatchData::
1614
- MaybeAddClosureForRecvTrailingMetadataReady(
1615
- grpc_error_handle error, CallCombinerClosureList* closures) {
1616
- auto* calld = call_attempt_->calld_;
1617
- // Find pending batch.
1618
- PendingBatch* pending = calld->PendingBatchFind(
1619
- "invoking recv_trailing_metadata_ready for",
1620
- [](grpc_transport_stream_op_batch* batch) {
1621
- return batch->recv_trailing_metadata &&
1622
- batch->payload->recv_trailing_metadata
1623
- .recv_trailing_metadata_ready != nullptr;
1624
- });
1625
- // If we generated the recv_trailing_metadata op internally via
1626
- // AddBatchForInternalRecvTrailingMetadata(), then there will be no
1627
- // pending batch.
1628
- if (pending == nullptr) {
1629
- call_attempt_->recv_trailing_metadata_error_ = error;
1630
- return;
1631
- }
1632
- // Copy transport stats to be delivered up to the surface.
1633
- grpc_transport_move_stats(
1634
- &call_attempt_->collect_stats_,
1635
- pending->batch->payload->recv_trailing_metadata.collect_stats);
1636
- // Return metadata.
1637
- *pending->batch->payload->recv_trailing_metadata.recv_trailing_metadata =
1638
- std::move(call_attempt_->recv_trailing_metadata_);
1639
- // Add closure.
1640
- closures->Add(pending->batch->payload->recv_trailing_metadata
1641
- .recv_trailing_metadata_ready,
1642
- error, "recv_trailing_metadata_ready for pending batch");
1643
- // Update bookkeeping.
1644
- pending->batch->payload->recv_trailing_metadata.recv_trailing_metadata_ready =
1645
- nullptr;
1646
- calld->MaybeClearPendingBatch(pending);
1647
- }
1648
-
1649
- void RetryFilter::CallData::CallAttempt::BatchData::
1650
- AddClosuresForDeferredCompletionCallbacks(
1651
- CallCombinerClosureList* closures) {
1652
- // Add closure for deferred recv_initial_metadata_ready.
1653
- if (GPR_UNLIKELY(call_attempt_->recv_initial_metadata_ready_deferred_batch_ !=
1654
- nullptr)) {
1655
- MaybeAddClosureForRecvInitialMetadataCallback(
1656
- call_attempt_->recv_initial_metadata_error_, closures);
1657
- call_attempt_->recv_initial_metadata_ready_deferred_batch_.reset(
1658
- DEBUG_LOCATION, "resuming deferred recv_initial_metadata_ready");
1659
- call_attempt_->recv_initial_metadata_error_ = absl::OkStatus();
1660
- }
1661
- // Add closure for deferred recv_message_ready.
1662
- if (GPR_UNLIKELY(call_attempt_->recv_message_ready_deferred_batch_ !=
1663
- nullptr)) {
1664
- MaybeAddClosureForRecvMessageCallback(call_attempt_->recv_message_error_,
1665
- closures);
1666
- call_attempt_->recv_message_ready_deferred_batch_.reset(
1667
- DEBUG_LOCATION, "resuming deferred recv_message_ready");
1668
- call_attempt_->recv_message_error_ = absl::OkStatus();
1669
- }
1670
- // Add closures for deferred on_complete callbacks.
1671
- for (auto& on_complete_deferred_batch :
1672
- call_attempt_->on_complete_deferred_batches_) {
1673
- closures->Add(&on_complete_deferred_batch.batch->on_complete_,
1674
- on_complete_deferred_batch.error, "resuming on_complete");
1675
- on_complete_deferred_batch.batch.release();
1676
- }
1677
- call_attempt_->on_complete_deferred_batches_.clear();
1678
- }
1679
-
1680
- void RetryFilter::CallData::CallAttempt::BatchData::
1681
- AddClosuresToFailUnstartedPendingBatches(
1682
- grpc_error_handle error, CallCombinerClosureList* closures) {
1683
- auto* calld = call_attempt_->calld_;
1684
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld->pending_batches_); ++i) {
1685
- PendingBatch* pending = &calld->pending_batches_[i];
1686
- if (pending->batch == nullptr) continue;
1687
- if (call_attempt_->PendingBatchContainsUnstartedSendOps(pending)) {
1688
- closures->Add(pending->batch->on_complete, error,
1689
- "failing on_complete for pending batch");
1690
- pending->batch->on_complete = nullptr;
1691
- calld->MaybeClearPendingBatch(pending);
1692
- }
1693
- }
1694
- }
1695
-
1696
- void RetryFilter::CallData::CallAttempt::BatchData::RunClosuresForCompletedCall(
1697
- grpc_error_handle error) {
1698
- // Construct list of closures to execute.
1699
- CallCombinerClosureList closures;
1700
- // First, add closure for recv_trailing_metadata_ready.
1701
- MaybeAddClosureForRecvTrailingMetadataReady(error, &closures);
1702
- // If there are deferred batch completion callbacks, add them to closures.
1703
- AddClosuresForDeferredCompletionCallbacks(&closures);
1704
- // Add closures to fail any pending batches that have not yet been started.
1705
- AddClosuresToFailUnstartedPendingBatches(error, &closures);
1706
- // Schedule all of the closures identified above.
1707
- // Note: This will release the call combiner.
1708
- closures.RunClosures(call_attempt_->calld_->call_combiner_);
1709
- }
1710
-
1711
- void RetryFilter::CallData::CallAttempt::BatchData::RecvTrailingMetadataReady(
1712
- void* arg, grpc_error_handle error) {
1713
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1714
- CallAttempt* call_attempt = batch_data->call_attempt_;
1715
- CallData* calld = call_attempt->calld_;
1716
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1717
- gpr_log(GPR_INFO,
1718
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1719
- "got recv_trailing_metadata_ready, error=%s",
1720
- calld->chand_, calld, call_attempt, batch_data.get(),
1721
- StatusToString(error).c_str());
1722
- }
1723
- call_attempt->completed_recv_trailing_metadata_ = true;
1724
- // If this attempt has been abandoned, then we're not going to use the
1725
- // result of this recv_trailing_metadata op, so do nothing.
1726
- if (call_attempt->abandoned_) {
1727
- GRPC_CALL_COMBINER_STOP(
1728
- calld->call_combiner_,
1729
- "recv_trailing_metadata_ready for abandoned attempt");
1730
- return;
1731
- }
1732
- // Cancel per-attempt recv timer, if any.
1733
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1734
- // Get the call's status and check for server pushback metadata.
1735
- grpc_status_code status = GRPC_STATUS_OK;
1736
- absl::optional<Duration> server_pushback;
1737
- bool is_lb_drop = false;
1738
- absl::optional<GrpcStreamNetworkState::ValueType> stream_network_state;
1739
- grpc_metadata_batch* md_batch =
1740
- batch_data->batch_.payload->recv_trailing_metadata.recv_trailing_metadata;
1741
- GetCallStatus(calld->deadline_, md_batch, error, &status, &server_pushback,
1742
- &is_lb_drop, &stream_network_state);
1743
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1744
- gpr_log(GPR_INFO,
1745
- "chand=%p calld=%p attempt=%p: call finished, status=%s "
1746
- "server_pushback=%s is_lb_drop=%d stream_network_state=%s",
1747
- calld->chand_, calld, call_attempt,
1748
- grpc_status_code_to_string(status),
1749
- server_pushback.has_value() ? server_pushback->ToString().c_str()
1750
- : "N/A",
1751
- is_lb_drop,
1752
- stream_network_state.has_value()
1753
- ? absl::StrCat(*stream_network_state).c_str()
1754
- : "N/A");
1755
- }
1756
- // Check if we should retry.
1757
- if (!is_lb_drop) { // Never retry on LB drops.
1758
- enum { kNoRetry, kTransparentRetry, kConfigurableRetry } retry = kNoRetry;
1759
- // Handle transparent retries.
1760
- if (stream_network_state.has_value() && !calld->retry_committed_) {
1761
- // If not sent on wire, then always retry.
1762
- // If sent on wire but not seen by server, retry exactly once.
1763
- if (*stream_network_state == GrpcStreamNetworkState::kNotSentOnWire) {
1764
- retry = kTransparentRetry;
1765
- } else if (*stream_network_state ==
1766
- GrpcStreamNetworkState::kNotSeenByServer &&
1767
- !calld->sent_transparent_retry_not_seen_by_server_) {
1768
- calld->sent_transparent_retry_not_seen_by_server_ = true;
1769
- retry = kTransparentRetry;
1770
- }
1771
- }
1772
- // If not transparently retrying, check for configurable retry.
1773
- if (retry == kNoRetry &&
1774
- call_attempt->ShouldRetry(status, server_pushback)) {
1775
- retry = kConfigurableRetry;
1776
- }
1777
- // If we're retrying, do so.
1778
- if (retry != kNoRetry) {
1779
- CallCombinerClosureList closures;
1780
- // Cancel call attempt.
1781
- call_attempt->MaybeAddBatchForCancelOp(
1782
- error.ok() ? grpc_error_set_int(
1783
- GRPC_ERROR_CREATE("call attempt failed"),
1784
- StatusIntProperty::kRpcStatus, GRPC_STATUS_CANCELLED)
1785
- : error,
1786
- &closures);
1787
- // For transparent retries, add a closure to immediately start a new
1788
- // call attempt.
1789
- // For configurable retries, start retry timer.
1790
- if (retry == kTransparentRetry) {
1791
- calld->AddClosureToStartTransparentRetry(&closures);
1792
- } else {
1793
- calld->StartRetryTimer(server_pushback);
1794
- }
1795
- // Record that this attempt has been abandoned.
1796
- call_attempt->Abandon();
1797
- // Yields call combiner.
1798
- closures.RunClosures(calld->call_combiner_);
1799
- return;
1800
- }
1801
- }
1802
- // Not retrying, so commit the call.
1803
- calld->RetryCommit(call_attempt);
1804
- // If retry state is no longer needed, switch to fast path for
1805
- // subsequent batches.
1806
- call_attempt->MaybeSwitchToFastPath();
1807
- // Run any necessary closures.
1808
- batch_data->RunClosuresForCompletedCall(error);
1809
- }
1810
-
1811
- //
1812
- // on_complete callback handling
1813
- //
1814
-
1815
- void RetryFilter::CallData::CallAttempt::BatchData::
1816
- AddClosuresForCompletedPendingBatch(grpc_error_handle error,
1817
- CallCombinerClosureList* closures) {
1818
- auto* calld = call_attempt_->calld_;
1819
- PendingBatch* pending = calld->PendingBatchFind(
1820
- "completed", [this](grpc_transport_stream_op_batch* batch) {
1821
- // Match the pending batch with the same set of send ops as the
1822
- // batch we've just completed.
1823
- return batch->on_complete != nullptr &&
1824
- batch_.send_initial_metadata == batch->send_initial_metadata &&
1825
- batch_.send_message == batch->send_message &&
1826
- batch_.send_trailing_metadata == batch->send_trailing_metadata;
1827
- });
1828
- // If batch_data is a replay batch, then there will be no pending
1829
- // batch to complete.
1830
- if (pending == nullptr) {
1831
- return;
1832
- }
1833
- // Propagate payload.
1834
- if (batch_.send_message) {
1835
- pending->batch->payload->send_message.stream_write_closed =
1836
- batch_.payload->send_message.stream_write_closed;
1837
- }
1838
- // Add closure.
1839
- closures->Add(pending->batch->on_complete, error,
1840
- "on_complete for pending batch");
1841
- pending->batch->on_complete = nullptr;
1842
- calld->MaybeClearPendingBatch(pending);
1843
- }
1844
-
1845
- void RetryFilter::CallData::CallAttempt::BatchData::
1846
- AddClosuresForReplayOrPendingSendOps(CallCombinerClosureList* closures) {
1847
- auto* calld = call_attempt_->calld_;
1848
- bool have_pending_send_ops = call_attempt_->HaveSendOpsToReplay();
1849
- // We don't check send_initial_metadata here, because that op will always
1850
- // be started as soon as it is received from the surface, so it will
1851
- // never need to be started at this point.
1852
- if (!have_pending_send_ops) {
1853
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld->pending_batches_); ++i) {
1854
- PendingBatch* pending = &calld->pending_batches_[i];
1855
- grpc_transport_stream_op_batch* batch = pending->batch;
1856
- if (batch == nullptr || pending->send_ops_cached) continue;
1857
- if (batch->send_message || batch->send_trailing_metadata) {
1858
- have_pending_send_ops = true;
1859
- break;
1860
- }
1861
- }
1862
- }
1863
- if (have_pending_send_ops) {
1864
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1865
- gpr_log(GPR_INFO,
1866
- "chand=%p calld=%p attempt=%p: starting next batch for pending "
1867
- "send op(s)",
1868
- calld->chand_, calld, call_attempt_);
1869
- }
1870
- call_attempt_->AddRetriableBatches(closures);
1871
- }
1872
- }
1873
-
1874
- void RetryFilter::CallData::CallAttempt::BatchData::OnComplete(
1875
- void* arg, grpc_error_handle error) {
1876
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1877
- CallAttempt* call_attempt = batch_data->call_attempt_;
1878
- CallData* calld = call_attempt->calld_;
1879
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1880
- gpr_log(GPR_INFO,
1881
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1882
- "got on_complete, error=%s, batch=%s",
1883
- calld->chand_, calld, call_attempt, batch_data.get(),
1884
- StatusToString(error).c_str(),
1885
- grpc_transport_stream_op_batch_string(&batch_data->batch_).c_str());
1886
- }
1887
- // If this attempt has been abandoned, then we're not going to propagate
1888
- // the completion of this batch, so do nothing.
1889
- if (call_attempt->abandoned_) {
1890
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
1891
- "on_complete for abandoned attempt");
1892
- return;
1893
- }
1894
- // If we got an error and have not yet gotten the
1895
- // recv_trailing_metadata_ready callback, then defer propagating this
1896
- // callback back to the surface. We can evaluate whether to retry when
1897
- // recv_trailing_metadata comes back.
1898
- if (GPR_UNLIKELY(!calld->retry_committed_ && !error.ok() &&
1899
- !call_attempt->completed_recv_trailing_metadata_)) {
1900
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1901
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: deferring on_complete",
1902
- calld->chand_, calld, call_attempt);
1903
- }
1904
- call_attempt->on_complete_deferred_batches_.emplace_back(
1905
- std::move(batch_data), error);
1906
- CallCombinerClosureList closures;
1907
- call_attempt->MaybeAddBatchForCancelOp(error, &closures);
1908
- if (!call_attempt->started_recv_trailing_metadata_) {
1909
- // recv_trailing_metadata not yet started by application; start it
1910
- // ourselves to get status.
1911
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1912
- }
1913
- closures.RunClosures(calld->call_combiner_);
1914
- return;
1915
- }
1916
- // Update bookkeeping in call_attempt.
1917
- if (batch_data->batch_.send_initial_metadata) {
1918
- call_attempt->completed_send_initial_metadata_ = true;
1919
- }
1920
- if (batch_data->batch_.send_message) {
1921
- ++call_attempt->completed_send_message_count_;
1922
- }
1923
- if (batch_data->batch_.send_trailing_metadata) {
1924
- call_attempt->completed_send_trailing_metadata_ = true;
1925
- }
1926
- // If the call is committed, free cached data for send ops that we've just
1927
- // completed.
1928
- if (calld->retry_committed_) {
1929
- batch_data->FreeCachedSendOpDataForCompletedBatch();
1930
- }
1931
- // Construct list of closures to execute.
1932
- CallCombinerClosureList closures;
1933
- // Add closure for the completed pending batch, if any.
1934
- batch_data->AddClosuresForCompletedPendingBatch(error, &closures);
1935
- // If needed, add a callback to start any replay or pending send ops on
1936
- // the LB call.
1937
- if (!call_attempt->completed_recv_trailing_metadata_) {
1938
- batch_data->AddClosuresForReplayOrPendingSendOps(&closures);
1939
- }
1940
- // If retry state is no longer needed (i.e., we're committed and there
1941
- // are no more send ops to replay), switch to fast path for subsequent
1942
- // batches.
1943
- call_attempt->MaybeSwitchToFastPath();
1944
- // Schedule all of the closures identified above.
1945
- // Note: This yields the call combiner.
1946
- closures.RunClosures(calld->call_combiner_);
1947
- }
1948
-
1949
- void RetryFilter::CallData::CallAttempt::BatchData::OnCompleteForCancelOp(
1950
- void* arg, grpc_error_handle error) {
1951
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1952
- CallAttempt* call_attempt = batch_data->call_attempt_;
1953
- CallData* calld = call_attempt->calld_;
1954
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1955
- gpr_log(GPR_INFO,
1956
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1957
- "got on_complete for cancel_stream batch, error=%s, batch=%s",
1958
- calld->chand_, calld, call_attempt, batch_data.get(),
1959
- StatusToString(error).c_str(),
1960
- grpc_transport_stream_op_batch_string(&batch_data->batch_).c_str());
1961
- }
1962
- GRPC_CALL_COMBINER_STOP(
1963
- calld->call_combiner_,
1964
- "on_complete for internally generated cancel_stream op");
1965
- }
1966
-
1967
- //
1968
- // retriable batch construction
1969
- //
1970
-
1971
- void RetryFilter::CallData::CallAttempt::BatchData::
1972
- AddRetriableSendInitialMetadataOp() {
1973
- auto* calld = call_attempt_->calld_;
1974
- // We need to make a copy of the metadata batch for each attempt, since
1975
- // the filters in the subchannel stack may modify this batch, and we don't
1976
- // want those modifications to be passed forward to subsequent attempts.
1977
- //
1978
- // If we've already completed one or more attempts, add the
1979
- // grpc-retry-attempts header.
1980
- call_attempt_->send_initial_metadata_ = calld->send_initial_metadata_.Copy();
1981
- if (GPR_UNLIKELY(calld->num_attempts_completed_ > 0)) {
1982
- call_attempt_->send_initial_metadata_.Set(GrpcPreviousRpcAttemptsMetadata(),
1983
- calld->num_attempts_completed_);
1984
- } else {
1985
- call_attempt_->send_initial_metadata_.Remove(
1986
- GrpcPreviousRpcAttemptsMetadata());
1987
- }
1988
- call_attempt_->started_send_initial_metadata_ = true;
1989
- batch_.send_initial_metadata = true;
1990
- batch_.payload->send_initial_metadata.send_initial_metadata =
1991
- &call_attempt_->send_initial_metadata_;
1992
- batch_.payload->send_initial_metadata.peer_string = calld->peer_string_;
1993
- }
1994
-
1995
- void RetryFilter::CallData::CallAttempt::BatchData::
1996
- AddRetriableSendMessageOp() {
1997
- auto* calld = call_attempt_->calld_;
1998
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1999
- gpr_log(
2000
- GPR_INFO,
2001
- "chand=%p calld=%p attempt=%p: starting calld->send_messages[%" PRIuPTR
2002
- "]",
2003
- calld->chand_, calld, call_attempt_,
2004
- call_attempt_->started_send_message_count_);
2005
- }
2006
- CachedSendMessage cache =
2007
- calld->send_messages_[call_attempt_->started_send_message_count_];
2008
- ++call_attempt_->started_send_message_count_;
2009
- batch_.send_message = true;
2010
- batch_.payload->send_message.send_message = cache.slices;
2011
- batch_.payload->send_message.flags = cache.flags;
2012
- }
2013
-
2014
- void RetryFilter::CallData::CallAttempt::BatchData::
2015
- AddRetriableSendTrailingMetadataOp() {
2016
- auto* calld = call_attempt_->calld_;
2017
- // We need to make a copy of the metadata batch for each attempt, since
2018
- // the filters in the subchannel stack may modify this batch, and we don't
2019
- // want those modifications to be passed forward to subsequent attempts.
2020
- call_attempt_->send_trailing_metadata_ =
2021
- calld->send_trailing_metadata_.Copy();
2022
- call_attempt_->started_send_trailing_metadata_ = true;
2023
- batch_.send_trailing_metadata = true;
2024
- batch_.payload->send_trailing_metadata.send_trailing_metadata =
2025
- &call_attempt_->send_trailing_metadata_;
2026
- }
2027
-
2028
- void RetryFilter::CallData::CallAttempt::BatchData::
2029
- AddRetriableRecvInitialMetadataOp() {
2030
- call_attempt_->started_recv_initial_metadata_ = true;
2031
- batch_.recv_initial_metadata = true;
2032
- call_attempt_->recv_initial_metadata_.Clear();
2033
- batch_.payload->recv_initial_metadata.recv_initial_metadata =
2034
- &call_attempt_->recv_initial_metadata_;
2035
- batch_.payload->recv_initial_metadata.trailing_metadata_available =
2036
- &call_attempt_->trailing_metadata_available_;
2037
- GRPC_CLOSURE_INIT(&call_attempt_->recv_initial_metadata_ready_,
2038
- RecvInitialMetadataReady, this, grpc_schedule_on_exec_ctx);
2039
- batch_.payload->recv_initial_metadata.recv_initial_metadata_ready =
2040
- &call_attempt_->recv_initial_metadata_ready_;
2041
- }
2042
-
2043
- void RetryFilter::CallData::CallAttempt::BatchData::
2044
- AddRetriableRecvMessageOp() {
2045
- ++call_attempt_->started_recv_message_count_;
2046
- batch_.recv_message = true;
2047
- batch_.payload->recv_message.recv_message = &call_attempt_->recv_message_;
2048
- batch_.payload->recv_message.flags = &call_attempt_->recv_message_flags_;
2049
- batch_.payload->recv_message.call_failed_before_recv_message = nullptr;
2050
- GRPC_CLOSURE_INIT(&call_attempt_->recv_message_ready_, RecvMessageReady, this,
2051
- grpc_schedule_on_exec_ctx);
2052
- batch_.payload->recv_message.recv_message_ready =
2053
- &call_attempt_->recv_message_ready_;
2054
- }
2055
-
2056
- void RetryFilter::CallData::CallAttempt::BatchData::
2057
- AddRetriableRecvTrailingMetadataOp() {
2058
- call_attempt_->started_recv_trailing_metadata_ = true;
2059
- batch_.recv_trailing_metadata = true;
2060
- call_attempt_->recv_trailing_metadata_.Clear();
2061
- batch_.payload->recv_trailing_metadata.recv_trailing_metadata =
2062
- &call_attempt_->recv_trailing_metadata_;
2063
- batch_.payload->recv_trailing_metadata.collect_stats =
2064
- &call_attempt_->collect_stats_;
2065
- GRPC_CLOSURE_INIT(&call_attempt_->recv_trailing_metadata_ready_,
2066
- RecvTrailingMetadataReady, this, grpc_schedule_on_exec_ctx);
2067
- batch_.payload->recv_trailing_metadata.recv_trailing_metadata_ready =
2068
- &call_attempt_->recv_trailing_metadata_ready_;
2069
- }
2070
-
2071
- void RetryFilter::CallData::CallAttempt::BatchData::AddCancelStreamOp(
2072
- grpc_error_handle error) {
2073
- batch_.cancel_stream = true;
2074
- batch_.payload->cancel_stream.cancel_error = error;
2075
- // Override on_complete callback.
2076
- GRPC_CLOSURE_INIT(&on_complete_, OnCompleteForCancelOp, this, nullptr);
2077
- }
2078
-
2079
- //
2080
- // CallData vtable functions
2081
- //
2082
-
2083
- grpc_error_handle RetryFilter::CallData::Init(
2084
- grpc_call_element* elem, const grpc_call_element_args* args) {
2085
- auto* chand = static_cast<RetryFilter*>(elem->channel_data);
2086
- new (elem->call_data) CallData(chand, *args);
2087
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2088
- gpr_log(GPR_INFO, "chand=%p calld=%p: created call", chand,
2089
- elem->call_data);
2090
- }
2091
- return absl::OkStatus();
2092
- }
2093
-
2094
- void RetryFilter::CallData::Destroy(grpc_call_element* elem,
2095
- const grpc_call_final_info* /*final_info*/,
2096
- grpc_closure* then_schedule_closure) {
2097
- auto* calld = static_cast<CallData*>(elem->call_data);
2098
- // Save our ref to the CallStackDestructionBarrier until after our
2099
- // dtor is invoked.
2100
- RefCountedPtr<CallStackDestructionBarrier> call_stack_destruction_barrier =
2101
- std::move(calld->call_stack_destruction_barrier_);
2102
- calld->~CallData();
2103
- // Now set the callback in the CallStackDestructionBarrier object,
2104
- // right before we release our ref to it (implicitly upon returning).
2105
- // The callback will be invoked when the CallStackDestructionBarrier
2106
- // is destroyed.
2107
- call_stack_destruction_barrier->set_on_call_stack_destruction(
2108
- then_schedule_closure);
2109
- }
2110
-
2111
- void RetryFilter::CallData::StartTransportStreamOpBatch(
2112
- grpc_call_element* elem, grpc_transport_stream_op_batch* batch) {
2113
- auto* calld = static_cast<CallData*>(elem->call_data);
2114
- calld->StartTransportStreamOpBatch(batch);
2115
- }
2116
-
2117
- void RetryFilter::CallData::SetPollent(grpc_call_element* elem,
2118
- grpc_polling_entity* pollent) {
2119
- auto* calld = static_cast<CallData*>(elem->call_data);
2120
- calld->pollent_ = pollent;
2121
- }
2122
-
2123
- //
2124
- // CallData implementation
2125
- //
2126
-
2127
- const RetryMethodConfig* RetryFilter::GetRetryPolicy(
2128
- const grpc_call_context_element* context) {
2129
- if (context == nullptr) return nullptr;
2130
- auto* svc_cfg_call_data = static_cast<ServiceConfigCallData*>(
2131
- context[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2132
- if (svc_cfg_call_data == nullptr) return nullptr;
2133
- return static_cast<const RetryMethodConfig*>(
2134
- svc_cfg_call_data->GetMethodParsedConfig(service_config_parser_index_));
2135
- }
2136
-
2137
- RetryFilter::CallData::CallData(RetryFilter* chand,
2138
- const grpc_call_element_args& args)
2139
- : chand_(chand),
2140
- retry_throttle_data_(chand->retry_throttle_data_),
2141
- retry_policy_(chand->GetRetryPolicy(args.context)),
2142
- retry_backoff_(
2143
- BackOff::Options()
2144
- .set_initial_backoff(retry_policy_ == nullptr
2145
- ? Duration::Zero()
2146
- : retry_policy_->initial_backoff())
2147
- .set_multiplier(retry_policy_ == nullptr
2148
- ? 0
2149
- : retry_policy_->backoff_multiplier())
2150
- .set_jitter(RETRY_BACKOFF_JITTER)
2151
- .set_max_backoff(retry_policy_ == nullptr
2152
- ? Duration::Zero()
2153
- : retry_policy_->max_backoff())),
2154
- path_(CSliceRef(args.path)),
2155
- deadline_(args.deadline),
2156
- arena_(args.arena),
2157
- owning_call_(args.call_stack),
2158
- call_combiner_(args.call_combiner),
2159
- call_context_(args.context),
2160
- call_stack_destruction_barrier_(
2161
- arena_->New<CallStackDestructionBarrier>()),
2162
- pending_send_initial_metadata_(false),
2163
- pending_send_message_(false),
2164
- pending_send_trailing_metadata_(false),
2165
- retry_committed_(false),
2166
- retry_timer_pending_(false),
2167
- retry_codepath_started_(false),
2168
- sent_transparent_retry_not_seen_by_server_(false) {}
2169
-
2170
- RetryFilter::CallData::~CallData() {
2171
- FreeAllCachedSendOpData();
2172
- CSliceUnref(path_);
2173
- // Make sure there are no remaining pending batches.
2174
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2175
- GPR_ASSERT(pending_batches_[i].batch == nullptr);
2176
- }
2177
- }
2178
-
2179
- void RetryFilter::CallData::StartTransportStreamOpBatch(
2180
- grpc_transport_stream_op_batch* batch) {
2181
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) &&
2182
- !GRPC_TRACE_FLAG_ENABLED(grpc_trace_channel)) {
2183
- gpr_log(GPR_INFO, "chand=%p calld=%p: batch started from surface: %s",
2184
- chand_, this, grpc_transport_stream_op_batch_string(batch).c_str());
2185
- }
2186
- // If we have an LB call, delegate to the LB call.
2187
- if (committed_call_ != nullptr) {
2188
- // Note: This will release the call combiner.
2189
- committed_call_->StartTransportStreamOpBatch(batch);
2190
- return;
2191
- }
2192
- // If we were previously cancelled from the surface, fail this
2193
- // batch immediately.
2194
- if (!cancelled_from_surface_.ok()) {
2195
- // Note: This will release the call combiner.
2196
- grpc_transport_stream_op_batch_finish_with_failure(
2197
- batch, cancelled_from_surface_, call_combiner_);
2198
- return;
2199
- }
2200
- // Handle cancellation.
2201
- if (GPR_UNLIKELY(batch->cancel_stream)) {
2202
- // Save cancel_error in case subsequent batches are started.
2203
- cancelled_from_surface_ = batch->payload->cancel_stream.cancel_error;
2204
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2205
- gpr_log(GPR_INFO, "chand=%p calld=%p: cancelled from surface: %s", chand_,
2206
- this, StatusToString(cancelled_from_surface_).c_str());
2207
- }
2208
- // Fail any pending batches.
2209
- PendingBatchesFail(cancelled_from_surface_);
2210
- // If we have a current call attempt, commit the call, then send
2211
- // the cancellation down to that attempt. When the call fails, it
2212
- // will not be retried, because we have committed it here.
2213
- if (call_attempt_ != nullptr) {
2214
- RetryCommit(call_attempt_.get());
2215
- // TODO(roth): When implementing hedging, this will get more
2216
- // complex, because instead of just passing the batch down to a
2217
- // single call attempt, we'll need to cancel multiple call
2218
- // attempts and wait for the cancellation on_complete from each call
2219
- // attempt before we propagate the on_complete from this batch
2220
- // back to the surface.
2221
- // Note: This will release the call combiner.
2222
- call_attempt_->CancelFromSurface(batch);
2223
- return;
2224
- }
2225
- // Cancel retry timer if needed.
2226
- if (retry_timer_pending_) {
2227
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2228
- gpr_log(GPR_INFO, "chand=%p calld=%p: cancelling retry timer", chand_,
2229
- this);
2230
- }
2231
- retry_timer_pending_ = false; // Lame timer callback.
2232
- grpc_timer_cancel(&retry_timer_);
2233
- FreeAllCachedSendOpData();
2234
- }
2235
- // We have no call attempt, so there's nowhere to send the cancellation
2236
- // batch. Return it back to the surface immediately.
2237
- // Note: This will release the call combiner.
2238
- grpc_transport_stream_op_batch_finish_with_failure(
2239
- batch, cancelled_from_surface_, call_combiner_);
2240
- return;
2241
- }
2242
- // Add the batch to the pending list.
2243
- PendingBatch* pending = PendingBatchesAdd(batch);
2244
- // If the timer is pending, yield the call combiner and wait for it to
2245
- // run, since we don't want to start another call attempt until it does.
2246
- if (retry_timer_pending_) {
2247
- GRPC_CALL_COMBINER_STOP(call_combiner_,
2248
- "added pending batch while retry timer pending");
2249
- return;
2250
- }
2251
- // If we do not yet have a call attempt, create one.
2252
- if (call_attempt_ == nullptr) {
2253
- // If this is the first batch and retries are already committed
2254
- // (e.g., if this batch put the call above the buffer size limit), then
2255
- // immediately create an LB call and delegate the batch to it. This
2256
- // avoids the overhead of unnecessarily allocating a CallAttempt
2257
- // object or caching any of the send op data.
2258
- // Note that we would ideally like to do this also on subsequent
2259
- // attempts (e.g., if a batch puts the call above the buffer size
2260
- // limit since the last attempt was complete), but in practice that's
2261
- // not really worthwhile, because we will almost always have cached and
2262
- // completed at least the send_initial_metadata op on the previous
2263
- // attempt, which means that we'd need special logic to replay the
2264
- // batch anyway, which is exactly what the CallAttempt object provides.
2265
- // We also skip this optimization if perAttemptRecvTimeout is set in the
2266
- // retry policy, because we need the code in CallAttempt to handle
2267
- // the associated timer.
2268
- if (!retry_codepath_started_ && retry_committed_ &&
2269
- (retry_policy_ == nullptr ||
2270
- !retry_policy_->per_attempt_recv_timeout().has_value())) {
2271
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2272
- gpr_log(GPR_INFO,
2273
- "chand=%p calld=%p: retry committed before first attempt; "
2274
- "creating LB call",
2275
- chand_, this);
2276
- }
2277
- PendingBatchClear(pending);
2278
- auto* service_config_call_data =
2279
- static_cast<ClientChannelServiceConfigCallData*>(
2280
- call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2281
- committed_call_ = CreateLoadBalancedCall(
2282
- service_config_call_data->call_dispatch_controller(),
2283
- /*is_transparent_retry=*/false);
2284
- committed_call_->StartTransportStreamOpBatch(batch);
2285
- return;
2286
- }
2287
- // Otherwise, create a call attempt.
2288
- // The attempt will automatically start any necessary replays or
2289
- // pending batches.
2290
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2291
- gpr_log(GPR_INFO, "chand=%p calld=%p: creating call attempt", chand_,
2292
- this);
2293
- }
2294
- retry_codepath_started_ = true;
2295
- CreateCallAttempt(/*is_transparent_retry=*/false);
2296
- return;
2297
- }
2298
- // Send batches to call attempt.
2299
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2300
- gpr_log(GPR_INFO, "chand=%p calld=%p: starting batch on attempt=%p", chand_,
2301
- this, call_attempt_.get());
2302
- }
2303
- call_attempt_->StartRetriableBatches();
2304
- }
2305
-
2306
- OrphanablePtr<ClientChannel::LoadBalancedCall>
2307
- RetryFilter::CallData::CreateLoadBalancedCall(
2308
- ConfigSelector::CallDispatchController* call_dispatch_controller,
2309
- bool is_transparent_retry) {
2310
- grpc_call_element_args args = {owning_call_, nullptr, call_context_,
2311
- path_, /*start_time=*/0, deadline_,
2312
- arena_, call_combiner_};
2313
- return chand_->client_channel_->CreateLoadBalancedCall(
2314
- args, pollent_,
2315
- // This callback holds a ref to the CallStackDestructionBarrier
2316
- // object until the LB call is destroyed.
2317
- call_stack_destruction_barrier_->MakeLbCallDestructionClosure(this),
2318
- call_dispatch_controller, is_transparent_retry);
2319
- }
2320
-
2321
- void RetryFilter::CallData::CreateCallAttempt(bool is_transparent_retry) {
2322
- call_attempt_ = MakeRefCounted<CallAttempt>(this, is_transparent_retry);
2323
- call_attempt_->StartRetriableBatches();
2324
- }
2325
-
2326
- //
2327
- // send op data caching
2328
- //
2329
-
2330
- void RetryFilter::CallData::MaybeCacheSendOpsForBatch(PendingBatch* pending) {
2331
- if (pending->send_ops_cached) return;
2332
- pending->send_ops_cached = true;
2333
- grpc_transport_stream_op_batch* batch = pending->batch;
2334
- // Save a copy of metadata for send_initial_metadata ops.
2335
- if (batch->send_initial_metadata) {
2336
- seen_send_initial_metadata_ = true;
2337
- grpc_metadata_batch* send_initial_metadata =
2338
- batch->payload->send_initial_metadata.send_initial_metadata;
2339
- send_initial_metadata_ = send_initial_metadata->Copy();
2340
- peer_string_ = batch->payload->send_initial_metadata.peer_string;
2341
- }
2342
- // Set up cache for send_message ops.
2343
- if (batch->send_message) {
2344
- SliceBuffer* cache = arena_->New<SliceBuffer>(std::move(
2345
- *std::exchange(batch->payload->send_message.send_message, nullptr)));
2346
- send_messages_.push_back({cache, batch->payload->send_message.flags});
2347
- }
2348
- // Save metadata batch for send_trailing_metadata ops.
2349
- if (batch->send_trailing_metadata) {
2350
- seen_send_trailing_metadata_ = true;
2351
- grpc_metadata_batch* send_trailing_metadata =
2352
- batch->payload->send_trailing_metadata.send_trailing_metadata;
2353
- send_trailing_metadata_ = send_trailing_metadata->Copy();
2354
- }
2355
- }
2356
-
2357
- void RetryFilter::CallData::FreeCachedSendInitialMetadata() {
2358
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2359
- gpr_log(GPR_INFO, "chand=%p calld=%p: destroying send_initial_metadata",
2360
- chand_, this);
2361
- }
2362
- send_initial_metadata_.Clear();
2363
- }
2364
-
2365
- void RetryFilter::CallData::FreeCachedSendMessage(size_t idx) {
2366
- if (send_messages_[idx].slices != nullptr) {
2367
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2368
- gpr_log(GPR_INFO,
2369
- "chand=%p calld=%p: destroying send_messages[%" PRIuPTR "]",
2370
- chand_, this, idx);
2371
- }
2372
- Destruct(std::exchange(send_messages_[idx].slices, nullptr));
2373
- }
2374
- }
2375
-
2376
- void RetryFilter::CallData::FreeCachedSendTrailingMetadata() {
2377
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2378
- gpr_log(GPR_INFO, "chand=%p calld=%p: destroying send_trailing_metadata",
2379
- chand_, this);
2380
- }
2381
- send_trailing_metadata_.Clear();
2382
- }
2383
-
2384
- void RetryFilter::CallData::FreeAllCachedSendOpData() {
2385
- if (seen_send_initial_metadata_) {
2386
- FreeCachedSendInitialMetadata();
2387
- }
2388
- for (size_t i = 0; i < send_messages_.size(); ++i) {
2389
- FreeCachedSendMessage(i);
2390
- }
2391
- if (seen_send_trailing_metadata_) {
2392
- FreeCachedSendTrailingMetadata();
2393
- }
2394
- }
2395
-
2396
- //
2397
- // pending_batches management
2398
- //
2399
-
2400
- size_t RetryFilter::CallData::GetBatchIndex(
2401
- grpc_transport_stream_op_batch* batch) {
2402
- if (batch->send_initial_metadata) return 0;
2403
- if (batch->send_message) return 1;
2404
- if (batch->send_trailing_metadata) return 2;
2405
- if (batch->recv_initial_metadata) return 3;
2406
- if (batch->recv_message) return 4;
2407
- if (batch->recv_trailing_metadata) return 5;
2408
- GPR_UNREACHABLE_CODE(return (size_t)-1);
2409
- }
2410
-
2411
- // This is called via the call combiner, so access to calld is synchronized.
2412
- RetryFilter::CallData::PendingBatch* RetryFilter::CallData::PendingBatchesAdd(
2413
- grpc_transport_stream_op_batch* batch) {
2414
- const size_t idx = GetBatchIndex(batch);
2415
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2416
- gpr_log(GPR_INFO,
2417
- "chand=%p calld=%p: adding pending batch at index %" PRIuPTR,
2418
- chand_, this, idx);
2419
- }
2420
- PendingBatch* pending = &pending_batches_[idx];
2421
- GPR_ASSERT(pending->batch == nullptr);
2422
- pending->batch = batch;
2423
- pending->send_ops_cached = false;
2424
- // Update state in calld about pending batches.
2425
- // Also check if the batch takes us over the retry buffer limit.
2426
- // Note: We don't check the size of trailing metadata here, because
2427
- // gRPC clients do not send trailing metadata.
2428
- if (batch->send_initial_metadata) {
2429
- pending_send_initial_metadata_ = true;
2430
- bytes_buffered_for_retry_ += batch->payload->send_initial_metadata
2431
- .send_initial_metadata->TransportSize();
2432
- }
2433
- if (batch->send_message) {
2434
- pending_send_message_ = true;
2435
- bytes_buffered_for_retry_ +=
2436
- batch->payload->send_message.send_message->Length();
2437
- }
2438
- if (batch->send_trailing_metadata) {
2439
- pending_send_trailing_metadata_ = true;
2440
- }
2441
- // TODO(roth): When we implement hedging, if there are currently attempts
2442
- // in flight, we will need to pick the one on which the max number of send
2443
- // ops have already been sent, and we commit to that attempt.
2444
- if (GPR_UNLIKELY(bytes_buffered_for_retry_ >
2445
- chand_->per_rpc_retry_buffer_size_)) {
2446
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2447
- gpr_log(GPR_INFO,
2448
- "chand=%p calld=%p: exceeded retry buffer size, committing",
2449
- chand_, this);
2450
- }
2451
- RetryCommit(call_attempt_.get());
2452
- }
2453
- return pending;
2454
- }
2455
-
2456
- void RetryFilter::CallData::PendingBatchClear(PendingBatch* pending) {
2457
- if (pending->batch->send_initial_metadata) {
2458
- pending_send_initial_metadata_ = false;
2459
- }
2460
- if (pending->batch->send_message) {
2461
- pending_send_message_ = false;
2462
- }
2463
- if (pending->batch->send_trailing_metadata) {
2464
- pending_send_trailing_metadata_ = false;
2465
- }
2466
- pending->batch = nullptr;
2467
- }
2468
-
2469
- void RetryFilter::CallData::MaybeClearPendingBatch(PendingBatch* pending) {
2470
- grpc_transport_stream_op_batch* batch = pending->batch;
2471
- // We clear the pending batch if all of its callbacks have been
2472
- // scheduled and reset to nullptr.
2473
- if (batch->on_complete == nullptr &&
2474
- (!batch->recv_initial_metadata ||
2475
- batch->payload->recv_initial_metadata.recv_initial_metadata_ready ==
2476
- nullptr) &&
2477
- (!batch->recv_message ||
2478
- batch->payload->recv_message.recv_message_ready == nullptr) &&
2479
- (!batch->recv_trailing_metadata ||
2480
- batch->payload->recv_trailing_metadata.recv_trailing_metadata_ready ==
2481
- nullptr)) {
2482
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2483
- gpr_log(GPR_INFO, "chand=%p calld=%p: clearing pending batch", chand_,
2484
- this);
2485
- }
2486
- PendingBatchClear(pending);
2487
- }
2488
- }
2489
-
2490
- // This is called via the call combiner, so access to calld is synchronized.
2491
- void RetryFilter::CallData::FailPendingBatchInCallCombiner(
2492
- void* arg, grpc_error_handle error) {
2493
- grpc_transport_stream_op_batch* batch =
2494
- static_cast<grpc_transport_stream_op_batch*>(arg);
2495
- CallData* call = static_cast<CallData*>(batch->handler_private.extra_arg);
2496
- // Note: This will release the call combiner.
2497
- grpc_transport_stream_op_batch_finish_with_failure(batch, error,
2498
- call->call_combiner_);
2499
- }
2500
-
2501
- // This is called via the call combiner, so access to calld is synchronized.
2502
- void RetryFilter::CallData::PendingBatchesFail(grpc_error_handle error) {
2503
- GPR_ASSERT(!error.ok());
2504
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2505
- size_t num_batches = 0;
2506
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2507
- if (pending_batches_[i].batch != nullptr) ++num_batches;
2508
- }
2509
- gpr_log(GPR_INFO,
2510
- "chand=%p calld=%p: failing %" PRIuPTR " pending batches: %s",
2511
- chand_, this, num_batches, StatusToString(error).c_str());
2512
- }
2513
- CallCombinerClosureList closures;
2514
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2515
- PendingBatch* pending = &pending_batches_[i];
2516
- grpc_transport_stream_op_batch* batch = pending->batch;
2517
- if (batch != nullptr) {
2518
- batch->handler_private.extra_arg = this;
2519
- GRPC_CLOSURE_INIT(&batch->handler_private.closure,
2520
- FailPendingBatchInCallCombiner, batch,
2521
- grpc_schedule_on_exec_ctx);
2522
- closures.Add(&batch->handler_private.closure, error,
2523
- "PendingBatchesFail");
2524
- PendingBatchClear(pending);
2525
- }
2526
- }
2527
- closures.RunClosuresWithoutYielding(call_combiner_);
2528
- }
2529
-
2530
- template <typename Predicate>
2531
- RetryFilter::CallData::PendingBatch* RetryFilter::CallData::PendingBatchFind(
2532
- const char* log_message, Predicate predicate) {
2533
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2534
- PendingBatch* pending = &pending_batches_[i];
2535
- grpc_transport_stream_op_batch* batch = pending->batch;
2536
- if (batch != nullptr && predicate(batch)) {
2537
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2538
- gpr_log(GPR_INFO,
2539
- "chand=%p calld=%p: %s pending batch at index %" PRIuPTR,
2540
- chand_, this, log_message, i);
2541
- }
2542
- return pending;
2543
- }
2544
- }
2545
- return nullptr;
2546
- }
2547
-
2548
- //
2549
- // retry code
2550
- //
2551
-
2552
- void RetryFilter::CallData::RetryCommit(CallAttempt* call_attempt) {
2553
- if (retry_committed_) return;
2554
- retry_committed_ = true;
2555
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2556
- gpr_log(GPR_INFO, "chand=%p calld=%p: committing retries", chand_, this);
2557
- }
2558
- if (call_attempt != nullptr) {
2559
- // If the call attempt's LB call has been committed, inform the call
2560
- // dispatch controller that the call has been committed.
2561
- // Note: If call_attempt is null, this is happening before the first
2562
- // retry attempt is started, in which case we'll just pass the real
2563
- // call dispatch controller down into the LB call, and it won't be
2564
- // our problem anymore.
2565
- if (call_attempt->lb_call_committed()) {
2566
- auto* service_config_call_data =
2567
- static_cast<ClientChannelServiceConfigCallData*>(
2568
- call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2569
- service_config_call_data->call_dispatch_controller()->Commit();
2570
- }
2571
- // Free cached send ops.
2572
- call_attempt->FreeCachedSendOpDataAfterCommit();
2573
- }
2574
- }
2575
-
2576
- void RetryFilter::CallData::StartRetryTimer(
2577
- absl::optional<Duration> server_pushback) {
2578
- // Reset call attempt.
2579
- call_attempt_.reset(DEBUG_LOCATION, "StartRetryTimer");
2580
- // Compute backoff delay.
2581
- Timestamp next_attempt_time;
2582
- if (server_pushback.has_value()) {
2583
- GPR_ASSERT(*server_pushback >= Duration::Zero());
2584
- next_attempt_time = Timestamp::Now() + *server_pushback;
2585
- retry_backoff_.Reset();
2586
- } else {
2587
- next_attempt_time = retry_backoff_.NextAttemptTime();
2588
- }
2589
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2590
- gpr_log(GPR_INFO,
2591
- "chand=%p calld=%p: retrying failed call in %" PRId64 " ms", chand_,
2592
- this, (next_attempt_time - Timestamp::Now()).millis());
2593
- }
2594
- // Schedule retry after computed delay.
2595
- GRPC_CLOSURE_INIT(&retry_closure_, OnRetryTimer, this, nullptr);
2596
- GRPC_CALL_STACK_REF(owning_call_, "OnRetryTimer");
2597
- retry_timer_pending_ = true;
2598
- grpc_timer_init(&retry_timer_, next_attempt_time, &retry_closure_);
2599
- }
2600
-
2601
- void RetryFilter::CallData::OnRetryTimer(void* arg, grpc_error_handle error) {
2602
- auto* calld = static_cast<CallData*>(arg);
2603
- GRPC_CLOSURE_INIT(&calld->retry_closure_, OnRetryTimerLocked, calld, nullptr);
2604
- GRPC_CALL_COMBINER_START(calld->call_combiner_, &calld->retry_closure_, error,
2605
- "retry timer fired");
2606
- }
2607
-
2608
- void RetryFilter::CallData::OnRetryTimerLocked(void* arg,
2609
- grpc_error_handle error) {
2610
- auto* calld = static_cast<CallData*>(arg);
2611
- if (error.ok() && calld->retry_timer_pending_) {
2612
- calld->retry_timer_pending_ = false;
2613
- calld->CreateCallAttempt(/*is_transparent_retry=*/false);
2614
- } else {
2615
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_, "retry timer cancelled");
2616
- }
2617
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnRetryTimer");
2618
- }
2619
-
2620
- void RetryFilter::CallData::AddClosureToStartTransparentRetry(
2621
- CallCombinerClosureList* closures) {
2622
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2623
- gpr_log(GPR_INFO, "chand=%p calld=%p: scheduling transparent retry", chand_,
2624
- this);
2625
- }
2626
- GRPC_CALL_STACK_REF(owning_call_, "OnRetryTimer");
2627
- GRPC_CLOSURE_INIT(&retry_closure_, StartTransparentRetry, this, nullptr);
2628
- closures->Add(&retry_closure_, absl::OkStatus(), "start transparent retry");
2629
- }
2630
-
2631
- void RetryFilter::CallData::StartTransparentRetry(void* arg,
2632
- grpc_error_handle /*error*/) {
2633
- auto* calld = static_cast<CallData*>(arg);
2634
- if (calld->cancelled_from_surface_.ok()) {
2635
- calld->CreateCallAttempt(/*is_transparent_retry=*/true);
2636
- } else {
2637
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
2638
- "call cancelled before transparent retry");
2639
- }
2640
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnRetryTimer");
2641
- }
2642
-
2643
- } // namespace
2644
-
2645
- const grpc_channel_filter kRetryFilterVtable = {
2646
- RetryFilter::CallData::StartTransportStreamOpBatch,
2647
- nullptr,
2648
- RetryFilter::StartTransportOp,
2649
- sizeof(RetryFilter::CallData),
2650
- RetryFilter::CallData::Init,
2651
- RetryFilter::CallData::SetPollent,
2652
- RetryFilter::CallData::Destroy,
2653
- sizeof(RetryFilter),
2654
- RetryFilter::Init,
2655
- grpc_channel_stack_no_post_init,
2656
- RetryFilter::Destroy,
2657
- RetryFilter::GetChannelInfo,
2658
- "retry_filter",
2659
- };
2660
-
2661
- } // namespace grpc_core