grpc 1.64.3 → 1.65.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (632) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +57 -58
  3. data/include/grpc/event_engine/event_engine.h +13 -6
  4. data/include/grpc/impl/channel_arg_names.h +7 -3
  5. data/include/grpc/module.modulemap +1 -0
  6. data/include/grpc/passive_listener.h +62 -0
  7. data/include/grpc/support/log.h +7 -17
  8. data/include/grpc/support/port_platform.h +3 -0
  9. data/src/core/channelz/channel_trace.cc +1 -1
  10. data/src/core/channelz/channel_trace.h +1 -1
  11. data/src/core/channelz/channelz.cc +3 -3
  12. data/src/core/channelz/channelz.h +7 -7
  13. data/src/core/channelz/channelz_registry.cc +4 -3
  14. data/src/core/client_channel/backup_poller.cc +4 -5
  15. data/src/core/client_channel/client_channel.cc +1324 -0
  16. data/src/core/client_channel/client_channel.h +243 -0
  17. data/src/core/client_channel/client_channel_filter.cc +266 -709
  18. data/src/core/client_channel/client_channel_filter.h +11 -64
  19. data/src/core/client_channel/client_channel_internal.h +16 -5
  20. data/src/core/client_channel/client_channel_plugin.cc +1 -14
  21. data/src/core/client_channel/client_channel_service_config.h +3 -3
  22. data/src/core/client_channel/config_selector.cc +1 -1
  23. data/src/core/client_channel/config_selector.h +1 -1
  24. data/src/core/client_channel/dynamic_filters.cc +3 -3
  25. data/src/core/client_channel/dynamic_filters.h +1 -3
  26. data/src/core/client_channel/load_balanced_call_destination.cc +336 -0
  27. data/src/core/client_channel/load_balanced_call_destination.h +49 -0
  28. data/src/core/client_channel/retry_filter.cc +2 -9
  29. data/src/core/client_channel/retry_filter.h +2 -7
  30. data/src/core/client_channel/retry_filter_legacy_call_data.cc +65 -72
  31. data/src/core/client_channel/retry_filter_legacy_call_data.h +0 -2
  32. data/src/core/client_channel/retry_service_config.cc +4 -5
  33. data/src/core/client_channel/retry_service_config.h +3 -3
  34. data/src/core/client_channel/subchannel.cc +220 -112
  35. data/src/core/client_channel/subchannel.h +31 -18
  36. data/src/core/client_channel/subchannel_pool_interface.cc +0 -2
  37. data/src/core/client_channel/subchannel_pool_interface.h +2 -4
  38. data/src/core/client_channel/subchannel_stream_client.cc +36 -49
  39. data/src/core/client_channel/subchannel_stream_client.h +2 -4
  40. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +7 -10
  41. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +1 -0
  42. data/src/core/ext/filters/backend_metrics/backend_metric_provider.h +7 -0
  43. data/src/core/ext/filters/census/grpc_context.cc +2 -4
  44. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +8 -15
  45. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +2 -0
  46. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +3 -7
  47. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +1 -0
  48. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +3 -3
  49. data/src/core/ext/filters/http/client/http_client_filter.cc +1 -0
  50. data/src/core/ext/filters/http/client/http_client_filter.h +1 -0
  51. data/src/core/ext/filters/http/client_authority_filter.cc +1 -0
  52. data/src/core/ext/filters/http/client_authority_filter.h +1 -0
  53. data/src/core/ext/filters/http/message_compress/compression_filter.cc +10 -15
  54. data/src/core/ext/filters/http/message_compress/compression_filter.h +2 -0
  55. data/src/core/ext/filters/http/server/http_server_filter.cc +2 -2
  56. data/src/core/ext/filters/http/server/http_server_filter.h +1 -0
  57. data/src/core/ext/filters/message_size/message_size_filter.cc +6 -9
  58. data/src/core/ext/filters/message_size/message_size_filter.h +6 -6
  59. data/src/core/ext/filters/rbac/rbac_filter.cc +2 -5
  60. data/src/core/ext/filters/rbac/rbac_filter.h +1 -0
  61. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +2 -2
  62. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +1 -1
  63. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +2 -6
  64. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +1 -0
  65. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +3 -3
  66. data/src/core/ext/transport/chttp2/alpn/alpn.cc +1 -1
  67. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +8 -25
  68. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +0 -5
  69. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +223 -148
  70. data/src/core/ext/transport/chttp2/server/chttp2_server.h +33 -0
  71. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +131 -107
  72. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +8 -8
  73. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +1 -1
  74. data/src/core/ext/transport/chttp2/transport/flow_control.cc +2 -4
  75. data/src/core/ext/transport/chttp2/transport/flow_control.h +0 -2
  76. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -6
  77. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +1 -2
  78. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +9 -5
  79. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +5 -4
  80. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +9 -2
  81. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +32 -43
  82. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +1 -3
  83. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +3 -8
  84. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +1 -1
  85. data/src/core/ext/transport/chttp2/transport/http2_settings.h +1 -1
  86. data/src/core/ext/transport/chttp2/transport/internal.h +29 -19
  87. data/src/core/ext/transport/chttp2/transport/parsing.cc +15 -25
  88. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +0 -2
  89. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +0 -2
  90. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +29 -13
  91. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +5 -4
  92. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +3 -5
  93. data/src/core/ext/transport/chttp2/transport/writing.cc +24 -25
  94. data/src/core/ext/transport/inproc/inproc_transport.cc +56 -32
  95. data/src/core/ext/transport/inproc/inproc_transport.h +1 -3
  96. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +13 -15
  97. data/src/core/ext/transport/inproc/legacy_inproc_transport.h +0 -2
  98. data/src/core/handshaker/handshaker.cc +6 -14
  99. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +9 -17
  100. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +3 -2
  101. data/src/core/handshaker/security/secure_endpoint.cc +38 -32
  102. data/src/core/handshaker/security/secure_endpoint.h +0 -2
  103. data/src/core/handshaker/security/security_handshaker.cc +25 -37
  104. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +2 -1
  105. data/src/core/lib/address_utils/parse_address.cc +27 -39
  106. data/src/core/lib/address_utils/sockaddr_utils.cc +5 -6
  107. data/src/core/lib/avl/avl.h +1 -1
  108. data/src/core/lib/channel/channel_args.cc +13 -17
  109. data/src/core/lib/channel/channel_args.h +19 -8
  110. data/src/core/lib/channel/channel_stack.cc +5 -63
  111. data/src/core/lib/channel/channel_stack.h +13 -37
  112. data/src/core/lib/channel/channel_stack_builder.h +0 -5
  113. data/src/core/lib/channel/channel_stack_builder_impl.cc +0 -142
  114. data/src/core/lib/channel/channel_stack_builder_impl.h +0 -2
  115. data/src/core/lib/channel/connected_channel.cc +37 -676
  116. data/src/core/lib/channel/promise_based_filter.cc +41 -47
  117. data/src/core/lib/channel/promise_based_filter.h +124 -477
  118. data/src/core/lib/channel/status_util.cc +1 -1
  119. data/src/core/lib/compression/compression.cc +1 -1
  120. data/src/core/lib/compression/message_compress.cc +6 -6
  121. data/src/core/lib/config/config_vars.cc +3 -8
  122. data/src/core/lib/config/config_vars.h +1 -5
  123. data/src/core/lib/debug/event_log.h +1 -1
  124. data/src/core/lib/debug/trace.cc +43 -59
  125. data/src/core/lib/debug/trace.h +2 -97
  126. data/src/core/lib/debug/trace_flags.cc +255 -0
  127. data/src/core/lib/debug/trace_flags.h +133 -0
  128. data/src/core/lib/debug/trace_impl.h +115 -0
  129. data/src/core/lib/event_engine/ares_resolver.cc +5 -7
  130. data/src/core/lib/event_engine/ares_resolver.h +1 -3
  131. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +1 -1
  132. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +17 -22
  133. data/src/core/lib/event_engine/event_engine.cc +29 -4
  134. data/src/core/lib/event_engine/extensions/supports_fd.h +7 -0
  135. data/src/core/lib/event_engine/extensions/tcp_trace.h +43 -0
  136. data/src/core/lib/event_engine/forkable.cc +4 -5
  137. data/src/core/lib/event_engine/forkable.h +0 -11
  138. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +10 -11
  139. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +4 -3
  140. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +1 -1
  141. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +19 -33
  142. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +3 -2
  143. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +24 -7
  144. data/src/core/lib/event_engine/posix_engine/posix_engine.h +2 -0
  145. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +14 -16
  146. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +18 -22
  147. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +13 -17
  148. data/src/core/lib/event_engine/posix_engine/timer.cc +1 -1
  149. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +4 -6
  150. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +2 -1
  151. data/src/core/lib/event_engine/shim.cc +1 -1
  152. data/src/core/lib/event_engine/tcp_socket_utils.cc +6 -8
  153. data/src/core/lib/event_engine/thread_local.h +1 -1
  154. data/src/core/lib/event_engine/thread_pool/thread_count.h +1 -1
  155. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +19 -21
  156. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +3 -6
  157. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +14 -13
  158. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +4 -3
  159. data/src/core/lib/event_engine/trace.h +6 -17
  160. data/src/core/lib/event_engine/windows/iocp.h +1 -1
  161. data/src/core/lib/event_engine/windows/win_socket.cc +23 -17
  162. data/src/core/lib/event_engine/windows/win_socket.h +4 -5
  163. data/src/core/lib/event_engine/windows/windows_endpoint.cc +6 -9
  164. data/src/core/lib/event_engine/windows/windows_engine.cc +201 -87
  165. data/src/core/lib/event_engine/windows/windows_engine.h +136 -25
  166. data/src/core/lib/event_engine/windows/windows_listener.cc +12 -23
  167. data/src/core/lib/experiments/experiments.cc +35 -151
  168. data/src/core/lib/experiments/experiments.h +12 -45
  169. data/src/core/lib/gprpp/bitset.h +1 -1
  170. data/src/core/lib/gprpp/crash.cc +2 -3
  171. data/src/core/lib/gprpp/dual_ref_counted.h +45 -33
  172. data/src/core/lib/gprpp/dump_args.cc +54 -0
  173. data/src/core/lib/gprpp/dump_args.h +69 -0
  174. data/src/core/lib/gprpp/glob.cc +70 -0
  175. data/src/core/lib/gprpp/glob.h +29 -0
  176. data/src/core/lib/gprpp/per_cpu.cc +1 -1
  177. data/src/core/lib/gprpp/posix/stat.cc +3 -4
  178. data/src/core/lib/gprpp/posix/thd.cc +8 -9
  179. data/src/core/lib/gprpp/ref_counted.h +30 -22
  180. data/src/core/lib/gprpp/single_set_ptr.h +5 -3
  181. data/src/core/lib/gprpp/status_helper.cc +11 -30
  182. data/src/core/lib/gprpp/status_helper.h +3 -31
  183. data/src/core/lib/gprpp/time.cc +3 -4
  184. data/src/core/lib/gprpp/time.h +3 -2
  185. data/src/core/lib/gprpp/unique_type_name.h +1 -1
  186. data/src/core/lib/gprpp/validation_errors.cc +10 -1
  187. data/src/core/lib/gprpp/validation_errors.h +11 -0
  188. data/src/core/lib/gprpp/windows/stat.cc +3 -4
  189. data/src/core/lib/gprpp/windows/thd.cc +3 -2
  190. data/src/core/lib/gprpp/work_serializer.cc +48 -57
  191. data/src/core/lib/iomgr/buffer_list.cc +4 -2
  192. data/src/core/lib/iomgr/call_combiner.cc +18 -27
  193. data/src/core/lib/iomgr/call_combiner.h +1 -3
  194. data/src/core/lib/iomgr/cfstream_handle.cc +4 -6
  195. data/src/core/lib/iomgr/closure.h +2 -4
  196. data/src/core/lib/iomgr/combiner.cc +6 -8
  197. data/src/core/lib/iomgr/combiner.h +0 -2
  198. data/src/core/lib/iomgr/endpoint.cc +0 -6
  199. data/src/core/lib/iomgr/endpoint.h +0 -2
  200. data/src/core/lib/iomgr/endpoint_cfstream.cc +19 -41
  201. data/src/core/lib/iomgr/endpoint_pair_posix.cc +1 -1
  202. data/src/core/lib/iomgr/endpoint_pair_windows.cc +5 -6
  203. data/src/core/lib/iomgr/error.cc +13 -21
  204. data/src/core/lib/iomgr/error.h +1 -1
  205. data/src/core/lib/iomgr/ev_apple.cc +3 -5
  206. data/src/core/lib/iomgr/ev_epoll1_linux.cc +43 -42
  207. data/src/core/lib/iomgr/ev_poll_posix.cc +38 -29
  208. data/src/core/lib/iomgr/ev_posix.cc +8 -9
  209. data/src/core/lib/iomgr/ev_posix.h +10 -7
  210. data/src/core/lib/iomgr/event_engine_shims/closure.cc +2 -2
  211. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +14 -28
  212. data/src/core/lib/iomgr/exec_ctx.cc +2 -2
  213. data/src/core/lib/iomgr/exec_ctx.h +1 -1
  214. data/src/core/lib/iomgr/executor.cc +6 -15
  215. data/src/core/lib/iomgr/executor.h +1 -1
  216. data/src/core/lib/iomgr/fork_posix.cc +8 -10
  217. data/src/core/lib/iomgr/fork_windows.cc +3 -1
  218. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -3
  219. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +3 -5
  220. data/src/core/lib/iomgr/internal_errqueue.cc +4 -2
  221. data/src/core/lib/iomgr/iocp_windows.cc +4 -3
  222. data/src/core/lib/iomgr/iomgr.cc +13 -17
  223. data/src/core/lib/iomgr/lockfree_event.cc +3 -5
  224. data/src/core/lib/iomgr/pollset.h +0 -2
  225. data/src/core/lib/iomgr/pollset_windows.cc +0 -2
  226. data/src/core/lib/iomgr/resolve_address_posix.cc +7 -14
  227. data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
  228. data/src/core/lib/iomgr/socket_factory_posix.cc +1 -1
  229. data/src/core/lib/iomgr/socket_mutator.cc +1 -1
  230. data/src/core/lib/iomgr/socket_utils_common_posix.cc +11 -17
  231. data/src/core/lib/iomgr/socket_windows.cc +4 -6
  232. data/src/core/lib/iomgr/tcp_client_cfstream.cc +3 -5
  233. data/src/core/lib/iomgr/tcp_client_posix.cc +9 -15
  234. data/src/core/lib/iomgr/tcp_client_windows.cc +2 -4
  235. data/src/core/lib/iomgr/tcp_posix.cc +57 -84
  236. data/src/core/lib/iomgr/tcp_posix.h +0 -2
  237. data/src/core/lib/iomgr/tcp_server_posix.cc +3 -3
  238. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +4 -6
  239. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +7 -7
  240. data/src/core/lib/iomgr/tcp_server_windows.cc +10 -16
  241. data/src/core/lib/iomgr/tcp_windows.cc +25 -41
  242. data/src/core/lib/iomgr/timer_generic.cc +17 -20
  243. data/src/core/lib/iomgr/timer_heap.cc +1 -1
  244. data/src/core/lib/iomgr/timer_manager.cc +17 -30
  245. data/src/core/lib/iomgr/unix_sockets_posix.cc +1 -1
  246. data/src/core/lib/iomgr/vsock.cc +1 -1
  247. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +3 -3
  248. data/src/core/lib/promise/activity.h +27 -4
  249. data/src/core/lib/promise/cancel_callback.h +24 -0
  250. data/src/core/lib/promise/context.h +11 -0
  251. data/src/core/lib/promise/detail/basic_seq.h +1 -2
  252. data/src/core/lib/promise/detail/join_state.h +354 -398
  253. data/src/core/lib/promise/detail/promise_like.h +6 -5
  254. data/src/core/lib/promise/detail/seq_state.h +1178 -1178
  255. data/src/core/lib/promise/for_each.h +6 -6
  256. data/src/core/lib/promise/interceptor_list.h +6 -7
  257. data/src/core/lib/promise/latch.h +9 -9
  258. data/src/core/lib/promise/map.h +17 -0
  259. data/src/core/lib/promise/observable.h +182 -0
  260. data/src/core/lib/promise/party.cc +7 -8
  261. data/src/core/lib/promise/party.h +10 -8
  262. data/src/core/lib/promise/pipe.h +16 -35
  263. data/src/core/lib/promise/promise.h +1 -0
  264. data/src/core/lib/promise/status_flag.h +2 -0
  265. data/src/core/lib/resource_quota/arena.cc +56 -79
  266. data/src/core/lib/resource_quota/arena.h +118 -209
  267. data/src/core/lib/resource_quota/memory_quota.cc +12 -13
  268. data/src/core/lib/resource_quota/memory_quota.h +2 -3
  269. data/src/core/lib/resource_quota/periodic_update.cc +1 -1
  270. data/src/core/lib/resource_quota/resource_quota.h +1 -1
  271. data/src/core/lib/security/authorization/authorization_policy_provider.h +1 -1
  272. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +1 -1
  273. data/src/core/lib/security/authorization/evaluate_args.cc +6 -8
  274. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +5 -6
  275. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +1 -0
  276. data/src/core/lib/security/authorization/matchers.cc +3 -3
  277. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +2 -2
  278. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +2 -3
  279. data/src/core/lib/security/context/security_context.cc +12 -13
  280. data/src/core/lib/security/context/security_context.h +31 -8
  281. data/src/core/lib/security/credentials/alts/alts_credentials.h +1 -1
  282. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +3 -1
  283. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +2 -3
  284. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +5 -5
  285. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +3 -3
  286. data/src/core/lib/security/credentials/call_creds_util.cc +2 -1
  287. data/src/core/lib/security/credentials/channel_creds_registry.h +2 -2
  288. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +5 -3
  289. data/src/core/lib/security/credentials/composite/composite_credentials.h +1 -1
  290. data/src/core/lib/security/credentials/credentials.cc +6 -6
  291. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +4 -4
  292. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +2 -2
  293. data/src/core/lib/security/credentials/external/external_account_credentials.cc +9 -11
  294. data/src/core/lib/security/credentials/external/external_account_credentials.h +3 -3
  295. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +2 -2
  296. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +4 -4
  297. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +1 -1
  298. data/src/core/lib/security/credentials/fake/fake_credentials.h +1 -1
  299. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +3 -3
  300. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +11 -11
  301. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +1 -1
  302. data/src/core/lib/security/credentials/iam/iam_credentials.h +1 -1
  303. data/src/core/lib/security/credentials/jwt/json_token.cc +14 -15
  304. data/src/core/lib/security/credentials/jwt/json_token.h +1 -1
  305. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +6 -5
  306. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +1 -1
  307. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +50 -54
  308. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +1 -1
  309. data/src/core/lib/security/credentials/local/local_credentials.h +1 -1
  310. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +12 -11
  311. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +4 -4
  312. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +6 -7
  313. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +1 -3
  314. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +15 -21
  315. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +1 -1
  316. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +21 -30
  317. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +1 -1
  318. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +1 -1
  319. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -4
  320. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +3 -5
  321. data/src/core/lib/security/credentials/tls/tls_credentials.cc +14 -16
  322. data/src/core/lib/security/credentials/tls/tls_utils.cc +4 -4
  323. data/src/core/lib/security/credentials/xds/xds_credentials.cc +1 -1
  324. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +13 -16
  325. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +15 -12
  326. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +6 -6
  327. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +1 -1
  328. data/src/core/lib/security/security_connector/local/local_security_connector.cc +8 -12
  329. data/src/core/lib/security/security_connector/security_connector.cc +1 -4
  330. data/src/core/lib/security/security_connector/security_connector.h +1 -3
  331. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +17 -19
  332. data/src/core/lib/security/security_connector/ssl_utils.cc +19 -21
  333. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +29 -40
  334. data/src/core/lib/security/transport/auth_filters.h +1 -0
  335. data/src/core/lib/security/transport/client_auth_filter.cc +7 -13
  336. data/src/core/lib/security/transport/server_auth_filter.cc +3 -8
  337. data/src/core/lib/security/util/json_util.h +1 -1
  338. data/src/core/lib/slice/slice.h +1 -1
  339. data/src/core/lib/slice/slice_refcount.h +2 -4
  340. data/src/core/lib/slice/slice_string_helpers.cc +1 -1
  341. data/src/core/lib/surface/api_trace.h +1 -3
  342. data/src/core/lib/surface/call.cc +64 -3738
  343. data/src/core/lib/surface/call.h +41 -143
  344. data/src/core/lib/surface/call_log_batch.cc +1 -1
  345. data/src/core/lib/surface/call_utils.cc +276 -0
  346. data/src/core/lib/surface/call_utils.h +449 -0
  347. data/src/core/lib/surface/channel.cc +8 -3
  348. data/src/core/lib/surface/channel.h +10 -7
  349. data/src/core/lib/surface/channel_create.cc +14 -6
  350. data/src/core/lib/surface/channel_create.h +3 -2
  351. data/src/core/lib/surface/channel_init.cc +21 -77
  352. data/src/core/lib/surface/channel_init.h +19 -97
  353. data/src/core/lib/surface/client_call.cc +419 -0
  354. data/src/core/lib/surface/client_call.h +180 -0
  355. data/src/core/lib/surface/completion_queue.cc +28 -33
  356. data/src/core/lib/surface/completion_queue.h +0 -8
  357. data/src/core/lib/surface/filter_stack_call.cc +1157 -0
  358. data/src/core/lib/surface/filter_stack_call.h +369 -0
  359. data/src/core/lib/surface/init.cc +7 -6
  360. data/src/core/lib/surface/lame_client.cc +1 -1
  361. data/src/core/lib/surface/legacy_channel.cc +40 -27
  362. data/src/core/lib/surface/legacy_channel.h +9 -18
  363. data/src/core/lib/surface/server_call.cc +222 -0
  364. data/src/core/lib/surface/server_call.h +167 -0
  365. data/src/core/lib/surface/version.cc +2 -2
  366. data/src/core/lib/transport/bdp_estimator.cc +3 -5
  367. data/src/core/lib/transport/bdp_estimator.h +2 -4
  368. data/src/core/lib/transport/call_arena_allocator.h +9 -7
  369. data/src/core/lib/transport/call_destination.h +76 -0
  370. data/src/core/lib/transport/call_filters.cc +28 -10
  371. data/src/core/lib/transport/call_filters.h +128 -22
  372. data/src/core/lib/transport/call_spine.cc +5 -6
  373. data/src/core/lib/transport/call_spine.h +159 -334
  374. data/src/core/lib/transport/connectivity_state.cc +8 -10
  375. data/src/core/lib/transport/connectivity_state.h +0 -2
  376. data/src/core/lib/transport/interception_chain.cc +155 -0
  377. data/src/core/lib/transport/interception_chain.h +236 -0
  378. data/src/core/lib/transport/metadata_batch.h +10 -1
  379. data/src/core/lib/transport/metadata_info.h +1 -1
  380. data/src/core/lib/transport/transport.cc +3 -6
  381. data/src/core/lib/transport/transport.h +43 -40
  382. data/src/core/load_balancing/child_policy_handler.cc +8 -8
  383. data/src/core/load_balancing/endpoint_list.cc +5 -5
  384. data/src/core/load_balancing/endpoint_list.h +1 -1
  385. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +1 -0
  386. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +1 -0
  387. data/src/core/load_balancing/grpclb/grpclb.cc +25 -29
  388. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +1 -1
  389. data/src/core/load_balancing/grpclb/load_balancer_api.cc +3 -4
  390. data/src/core/load_balancing/health_check_client.cc +10 -13
  391. data/src/core/load_balancing/lb_policy.cc +5 -8
  392. data/src/core/load_balancing/lb_policy.h +19 -3
  393. data/src/core/load_balancing/lb_policy_factory.h +1 -1
  394. data/src/core/load_balancing/lb_policy_registry.cc +2 -3
  395. data/src/core/load_balancing/lb_policy_registry.h +1 -1
  396. data/src/core/load_balancing/oob_backend_metric.cc +2 -4
  397. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +33 -35
  398. data/src/core/load_balancing/outlier_detection/outlier_detection.h +3 -3
  399. data/src/core/load_balancing/pick_first/pick_first.cc +65 -65
  400. data/src/core/load_balancing/priority/priority.cc +26 -28
  401. data/src/core/load_balancing/ring_hash/ring_hash.cc +11 -13
  402. data/src/core/load_balancing/ring_hash/ring_hash.h +3 -3
  403. data/src/core/load_balancing/rls/rls.cc +82 -82
  404. data/src/core/load_balancing/round_robin/round_robin.cc +17 -20
  405. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +54 -43
  406. data/src/core/load_balancing/weighted_target/weighted_target.cc +21 -24
  407. data/src/core/load_balancing/xds/cds.cc +14 -16
  408. data/src/core/load_balancing/xds/xds_cluster_impl.cc +16 -18
  409. data/src/core/load_balancing/xds/xds_cluster_manager.cc +15 -17
  410. data/src/core/load_balancing/xds/xds_override_host.cc +40 -41
  411. data/src/core/load_balancing/xds/xds_override_host.h +3 -3
  412. data/src/core/load_balancing/xds/xds_wrr_locality.cc +10 -12
  413. data/src/core/plugin_registry/grpc_plugin_registry.cc +5 -1
  414. data/src/core/resolver/binder/binder_resolver.cc +3 -2
  415. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +3 -2
  416. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +1 -1
  417. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +7 -14
  418. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +1 -5
  419. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  420. data/src/core/resolver/dns/dns_resolver_plugin.cc +6 -5
  421. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +4 -9
  422. data/src/core/resolver/dns/event_engine/service_config_helper.cc +5 -5
  423. data/src/core/resolver/dns/native/dns_resolver.cc +8 -9
  424. data/src/core/resolver/endpoint_addresses.cc +1 -1
  425. data/src/core/resolver/fake/fake_resolver.cc +1 -1
  426. data/src/core/resolver/fake/fake_resolver.h +1 -1
  427. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +13 -14
  428. data/src/core/resolver/polling_resolver.cc +30 -35
  429. data/src/core/resolver/resolver.cc +2 -6
  430. data/src/core/resolver/resolver.h +0 -2
  431. data/src/core/resolver/resolver_registry.cc +6 -8
  432. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +3 -3
  433. data/src/core/resolver/xds/xds_dependency_manager.cc +22 -23
  434. data/src/core/resolver/xds/xds_resolver.cc +13 -15
  435. data/src/core/server/server.cc +269 -389
  436. data/src/core/server/server.h +37 -19
  437. data/src/core/server/server_call_tracer_filter.cc +7 -14
  438. data/src/core/server/server_config_selector.h +1 -1
  439. data/src/core/server/server_config_selector_filter.cc +3 -3
  440. data/src/core/server/server_interface.h +2 -0
  441. data/src/core/server/xds_channel_stack_modifier.cc +1 -1
  442. data/src/core/server/xds_channel_stack_modifier.h +1 -1
  443. data/src/core/server/xds_server_config_fetcher.cc +1 -4
  444. data/src/core/service_config/service_config.h +1 -1
  445. data/src/core/service_config/service_config_call_data.h +13 -11
  446. data/src/core/service_config/service_config_channel_arg_filter.cc +6 -4
  447. data/src/core/service_config/service_config_impl.cc +5 -5
  448. data/src/core/service_config/service_config_impl.h +1 -1
  449. data/src/core/service_config/service_config_parser.cc +3 -6
  450. data/src/core/service_config/service_config_parser.h +1 -1
  451. data/src/core/{lib/channel → telemetry}/call_tracer.cc +20 -30
  452. data/src/core/{lib/channel → telemetry}/call_tracer.h +32 -9
  453. data/src/core/{lib/debug → telemetry}/histogram_view.cc +1 -1
  454. data/src/core/{lib/debug → telemetry}/histogram_view.h +3 -3
  455. data/src/core/telemetry/metrics.cc +178 -0
  456. data/src/core/telemetry/metrics.h +562 -0
  457. data/src/core/{lib/debug → telemetry}/stats.cc +1 -1
  458. data/src/core/{lib/debug → telemetry}/stats.h +5 -5
  459. data/src/core/{lib/debug → telemetry}/stats_data.cc +1 -1
  460. data/src/core/{lib/debug → telemetry}/stats_data.h +4 -4
  461. data/src/core/{lib/channel → telemetry}/tcp_tracer.h +3 -3
  462. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +12 -13
  463. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +25 -27
  464. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +32 -33
  465. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -1
  466. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -1
  467. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +5 -4
  468. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +5 -3
  469. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +1 -1
  470. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +4 -3
  471. data/src/core/tsi/fake_transport_security.cc +14 -17
  472. data/src/core/tsi/local_transport_security.cc +6 -5
  473. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +4 -4
  474. data/src/core/tsi/ssl_transport_security.cc +76 -81
  475. data/src/core/tsi/ssl_transport_security_utils.cc +74 -18
  476. data/src/core/tsi/ssl_transport_security_utils.h +11 -0
  477. data/src/core/tsi/transport_security.cc +0 -4
  478. data/src/core/tsi/transport_security.h +0 -2
  479. data/src/core/tsi/transport_security_interface.h +0 -4
  480. data/src/core/{lib/gpr → util}/alloc.h +3 -3
  481. data/src/core/{lib/gpr → util}/android/log.cc +0 -19
  482. data/src/core/{lib/gpr → util}/atm.cc +1 -1
  483. data/src/core/{ext/gcp/metadata_query.cc → util/gcp_metadata_query.cc} +25 -26
  484. data/src/core/{ext/gcp/metadata_query.h → util/gcp_metadata_query.h} +11 -11
  485. data/src/core/{lib/http → util/http_client}/format_request.cc +4 -3
  486. data/src/core/{lib/http → util/http_client}/format_request.h +6 -5
  487. data/src/core/{lib/http → util/http_client}/httpcli.cc +9 -10
  488. data/src/core/{lib/http → util/http_client}/httpcli.h +6 -5
  489. data/src/core/{lib/http → util/http_client}/httpcli_security_connector.cc +9 -9
  490. data/src/core/{lib/http → util/http_client}/httpcli_ssl_credentials.h +5 -4
  491. data/src/core/{lib/http → util/http_client}/parser.cc +4 -5
  492. data/src/core/{lib/http → util/http_client}/parser.h +5 -6
  493. data/src/core/{lib → util}/json/json.h +5 -4
  494. data/src/core/{lib → util}/json/json_args.h +5 -5
  495. data/src/core/{lib → util}/json/json_channel_args.h +6 -6
  496. data/src/core/{lib → util}/json/json_object_loader.cc +3 -2
  497. data/src/core/{lib → util}/json/json_object_loader.h +7 -7
  498. data/src/core/{lib → util}/json/json_reader.cc +3 -2
  499. data/src/core/{lib → util}/json/json_reader.h +6 -6
  500. data/src/core/{lib → util}/json/json_util.cc +4 -4
  501. data/src/core/{lib → util}/json/json_util.h +6 -6
  502. data/src/core/{lib → util}/json/json_writer.cc +3 -3
  503. data/src/core/{lib → util}/json/json_writer.h +6 -6
  504. data/src/core/{lib/gpr → util}/linux/log.cc +0 -45
  505. data/src/core/util/log.cc +165 -0
  506. data/src/core/{lib/gpr → util}/msys/tmpfile.cc +2 -2
  507. data/src/core/{lib/gpr → util}/posix/cpu.cc +1 -1
  508. data/src/core/{lib/gpr → util}/posix/log.cc +0 -42
  509. data/src/core/{lib/gpr → util}/posix/time.cc +1 -1
  510. data/src/core/{lib/gpr → util}/posix/tmpfile.cc +2 -2
  511. data/src/core/{lib/gpr → util}/spinlock.h +3 -3
  512. data/src/core/{lib/gpr → util}/string.cc +2 -2
  513. data/src/core/{lib/gpr → util}/string.h +3 -3
  514. data/src/core/{lib/gpr → util}/time_precise.cc +1 -1
  515. data/src/core/{lib/gpr → util}/time_precise.h +3 -3
  516. data/src/core/{lib/gpr → util}/tmpfile.h +3 -3
  517. data/src/core/{lib/gpr → util}/useful.h +3 -3
  518. data/src/core/{lib/gpr → util}/windows/log.cc +1 -44
  519. data/src/core/{lib/gpr → util}/windows/string.cc +1 -1
  520. data/src/core/{lib/gpr → util}/windows/string_util.cc +1 -1
  521. data/src/core/{lib/gpr → util}/windows/time.cc +1 -1
  522. data/src/core/{lib/gpr → util}/windows/tmpfile.cc +1 -1
  523. data/src/core/xds/grpc/certificate_provider_store.cc +3 -3
  524. data/src/core/xds/grpc/certificate_provider_store.h +4 -4
  525. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +3 -3
  526. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +3 -3
  527. data/src/core/xds/grpc/xds_audit_logger_registry.h +1 -1
  528. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +5 -5
  529. data/src/core/xds/grpc/xds_bootstrap_grpc.h +3 -3
  530. data/src/core/xds/grpc/xds_certificate_provider.h +1 -1
  531. data/src/core/xds/grpc/xds_client_grpc.cc +27 -23
  532. data/src/core/xds/grpc/xds_client_grpc.h +2 -2
  533. data/src/core/xds/grpc/xds_cluster.cc +4 -5
  534. data/src/core/xds/grpc/xds_cluster.h +1 -1
  535. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +2 -2
  536. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +1 -1
  537. data/src/core/xds/grpc/xds_common_types.cc +1 -1
  538. data/src/core/xds/grpc/xds_common_types.h +1 -1
  539. data/src/core/xds/grpc/xds_endpoint.cc +4 -5
  540. data/src/core/xds/grpc/xds_http_fault_filter.cc +2 -2
  541. data/src/core/xds/grpc/xds_http_filters.h +2 -2
  542. data/src/core/xds/grpc/xds_http_rbac_filter.cc +3 -3
  543. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +2 -2
  544. data/src/core/xds/grpc/xds_lb_policy_registry.h +1 -1
  545. data/src/core/xds/grpc/xds_listener.cc +4 -6
  546. data/src/core/xds/grpc/xds_route_config.cc +7 -8
  547. data/src/core/xds/grpc/xds_transport_grpc.cc +2 -2
  548. data/src/core/xds/grpc/xds_transport_grpc.h +1 -1
  549. data/src/core/xds/xds_client/xds_api.cc +5 -9
  550. data/src/core/xds/xds_client/xds_bootstrap.cc +1 -1
  551. data/src/core/xds/xds_client/xds_bootstrap.h +1 -1
  552. data/src/core/xds/xds_client/xds_client.cc +39 -45
  553. data/src/core/xds/xds_client/xds_client.h +0 -3
  554. data/src/core/xds/xds_client/xds_client_stats.cc +6 -6
  555. data/src/core/xds/xds_client/xds_client_stats.h +2 -2
  556. data/src/ruby/bin/math_pb.rb +1 -22
  557. data/src/ruby/ext/grpc/rb_call.c +8 -1
  558. data/src/ruby/ext/grpc/rb_completion_queue.c +15 -32
  559. data/src/ruby/ext/grpc/rb_completion_queue.h +7 -1
  560. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +2 -2
  561. data/src/ruby/ext/grpc/rb_server.c +39 -22
  562. data/src/ruby/lib/grpc/version.rb +1 -1
  563. data/src/ruby/pb/grpc/health/v1/health_pb.rb +1 -22
  564. data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +5 -5
  565. data/src/ruby/pb/grpc/testing/metrics_pb.rb +10 -19
  566. data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +5 -5
  567. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +1 -22
  568. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +1 -22
  569. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +1 -22
  570. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +4 -0
  571. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +12 -12
  572. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +66 -41
  573. data/third_party/boringssl-with-bazel/src/crypto/dilithium/dilithium.c +1497 -0
  574. data/third_party/boringssl-with-bazel/src/crypto/dilithium/internal.h +58 -0
  575. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +10 -3
  576. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -2
  577. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +2 -0
  578. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +5 -0
  579. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +45 -1
  580. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +33 -23
  581. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +3 -6
  582. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +9 -4
  583. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +6 -0
  584. data/third_party/boringssl-with-bazel/src/crypto/internal.h +7 -0
  585. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +0 -4
  586. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +49 -16
  587. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -10
  588. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +7 -17
  589. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +8 -6
  590. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +3 -0
  591. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +125 -0
  592. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +0 -23
  593. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +1 -1
  594. data/third_party/boringssl-with-bazel/src/ssl/internal.h +4 -10
  595. metadata +103 -93
  596. data/src/core/ext/transport/chttp2/transport/http_trace.cc +0 -19
  597. data/src/core/ext/transport/chttp2/transport/http_trace.h +0 -24
  598. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  599. data/src/core/handshaker/security/tsi_error.cc +0 -31
  600. data/src/core/handshaker/security/tsi_error.h +0 -30
  601. data/src/core/lib/channel/channel_stack_trace.cc +0 -19
  602. data/src/core/lib/channel/channel_stack_trace.h +0 -24
  603. data/src/core/lib/channel/context.h +0 -105
  604. data/src/core/lib/channel/metrics.cc +0 -334
  605. data/src/core/lib/channel/metrics.h +0 -365
  606. data/src/core/lib/event_engine/trace.cc +0 -25
  607. data/src/core/lib/gpr/log.cc +0 -166
  608. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  609. data/src/core/lib/promise/trace.cc +0 -20
  610. data/src/core/lib/promise/trace.h +0 -24
  611. data/src/core/lib/resource_quota/trace.cc +0 -19
  612. data/src/core/lib/resource_quota/trace.h +0 -24
  613. data/src/core/lib/slice/slice_refcount.cc +0 -20
  614. data/src/core/lib/surface/api_trace.cc +0 -25
  615. data/src/core/lib/surface/call_trace.h +0 -24
  616. data/src/core/lib/surface/wait_for_cq_end_op.cc +0 -75
  617. data/src/core/lib/surface/wait_for_cq_end_op.h +0 -72
  618. data/src/core/lib/transport/batch_builder.cc +0 -172
  619. data/src/core/lib/transport/batch_builder.h +0 -474
  620. data/src/core/resolver/xds/xds_resolver_trace.cc +0 -25
  621. data/src/core/resolver/xds/xds_resolver_trace.h +0 -30
  622. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -122
  623. /data/src/core/{lib/gpr → util}/alloc.cc +0 -0
  624. /data/src/core/{lib/gpr → util}/iphone/cpu.cc +0 -0
  625. /data/src/core/{lib/gpr → util}/linux/cpu.cc +0 -0
  626. /data/src/core/{lib/gpr → util}/posix/string.cc +0 -0
  627. /data/src/core/{lib/gpr → util}/posix/sync.cc +0 -0
  628. /data/src/core/{lib/gpr → util}/sync.cc +0 -0
  629. /data/src/core/{lib/gpr → util}/sync_abseil.cc +0 -0
  630. /data/src/core/{lib/gpr → util}/time.cc +0 -0
  631. /data/src/core/{lib/gpr → util}/windows/cpu.cc +0 -0
  632. /data/src/core/{lib/gpr → util}/windows/sync.cc +0 -0
@@ -19,6 +19,7 @@
19
19
 
20
20
  #include "absl/functional/any_invocable.h"
21
21
  #include "absl/log/check.h"
22
+ #include "absl/log/log.h"
22
23
  #include "absl/status/status.h"
23
24
  #include "absl/status/statusor.h"
24
25
  #include "absl/strings/string_view.h"
@@ -37,7 +38,6 @@
37
38
  #include "src/core/lib/event_engine/shim.h"
38
39
  #include "src/core/lib/event_engine/tcp_socket_utils.h"
39
40
  #include "src/core/lib/event_engine/trace.h"
40
- #include "src/core/lib/gpr/string.h"
41
41
  #include "src/core/lib/gprpp/construct_destruct.h"
42
42
  #include "src/core/lib/gprpp/debug_location.h"
43
43
  #include "src/core/lib/gprpp/sync.h"
@@ -49,8 +49,7 @@
49
49
  #include "src/core/lib/iomgr/port.h"
50
50
  #include "src/core/lib/slice/slice_string_helpers.h"
51
51
  #include "src/core/lib/transport/error_utils.h"
52
-
53
- extern grpc_core::TraceFlag grpc_tcp_trace;
52
+ #include "src/core/util/string.h"
54
53
 
55
54
  namespace grpc_event_engine {
56
55
  namespace experimental {
@@ -120,15 +119,15 @@ class EventEngineEndpointWrapper {
120
119
  grpc_slice_buffer_move_into(read_buffer->c_slice_buffer(),
121
120
  pending_read_buffer_);
122
121
  read_buffer->~SliceBuffer();
123
- if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
122
+ if (GRPC_TRACE_FLAG_ENABLED(tcp)) {
124
123
  size_t i;
125
124
  gpr_log(GPR_INFO, "TCP: %p READ error=%s", eeep_->wrapper,
126
125
  status.ToString().c_str());
127
- if (gpr_should_log(GPR_LOG_SEVERITY_DEBUG)) {
126
+ if (ABSL_VLOG_IS_ON(2)) {
128
127
  for (i = 0; i < pending_read_buffer_->count; i++) {
129
128
  char* dump = grpc_dump_slice(pending_read_buffer_->slices[i],
130
129
  GPR_DUMP_HEX | GPR_DUMP_ASCII);
131
- gpr_log(GPR_DEBUG, "READ DATA: %s", dump);
130
+ VLOG(2) << "READ DATA: " << dump;
132
131
  gpr_free(dump);
133
132
  }
134
133
  }
@@ -151,15 +150,15 @@ class EventEngineEndpointWrapper {
151
150
  bool Write(grpc_closure* write_cb, grpc_slice_buffer* slices,
152
151
  const EventEngine::Endpoint::WriteArgs* args) {
153
152
  Ref();
154
- if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
153
+ if (GRPC_TRACE_FLAG_ENABLED(tcp)) {
155
154
  size_t i;
156
155
  gpr_log(GPR_INFO, "TCP: %p WRITE (peer=%s)", this,
157
156
  std::string(PeerAddress()).c_str());
158
- if (gpr_should_log(GPR_LOG_SEVERITY_DEBUG)) {
157
+ if (ABSL_VLOG_IS_ON(2)) {
159
158
  for (i = 0; i < slices->count; i++) {
160
159
  char* dump =
161
160
  grpc_dump_slice(slices->slices[i], GPR_DUMP_HEX | GPR_DUMP_ASCII);
162
- gpr_log(GPR_DEBUG, "WRITE DATA: %s", dump);
161
+ VLOG(2) << "WRITE DATA: " << dump;
163
162
  gpr_free(dump);
164
163
  }
165
164
  }
@@ -178,7 +177,7 @@ class EventEngineEndpointWrapper {
178
177
  void FinishPendingWrite(absl::Status status) {
179
178
  auto* write_buffer = reinterpret_cast<SliceBuffer*>(&eeep_->write_buffer);
180
179
  write_buffer->~SliceBuffer();
181
- if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
180
+ if (GRPC_TRACE_FLAG_ENABLED(tcp)) {
182
181
  gpr_log(GPR_INFO, "TCP: %p WRITE (peer=%s) error=%s", this,
183
182
  std::string(PeerAddress()).c_str(), status.ToString().c_str());
184
183
  }
@@ -345,29 +344,17 @@ void EndpointAddToPollsetSet(grpc_endpoint* /* ep */,
345
344
  grpc_pollset_set* /* pollset */) {}
346
345
  void EndpointDeleteFromPollsetSet(grpc_endpoint* /* ep */,
347
346
  grpc_pollset_set* /* pollset */) {}
348
- /// After shutdown, all endpoint operations except destroy are no-op,
349
- /// and will return some kind of sane default (empty strings, nullptrs, etc).
350
- /// It is the caller's responsibility to ensure that calls to EndpointShutdown
351
- /// are synchronized.
352
- void EndpointShutdown(grpc_endpoint* ep, grpc_error_handle why) {
353
- auto* eeep =
354
- reinterpret_cast<EventEngineEndpointWrapper::grpc_event_engine_endpoint*>(
355
- ep);
356
- if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
357
- gpr_log(GPR_INFO, "TCP Endpoint %p shutdown why=%s", eeep->wrapper,
358
- why.ToString().c_str());
359
- }
360
- GRPC_EVENT_ENGINE_TRACE("EventEngine::Endpoint %p Shutdown:%s", eeep->wrapper,
361
- why.ToString().c_str());
362
- eeep->wrapper->TriggerShutdown(nullptr);
363
- }
364
347
 
365
- // Attempts to free the underlying data structures.
348
+ /// Attempts to free the underlying data structures.
349
+ /// After destruction, no new endpoint operations may be started.
350
+ /// It is the caller's responsibility to ensure that calls to EndpointDestroy
351
+ /// are synchronized.
366
352
  void EndpointDestroy(grpc_endpoint* ep) {
367
353
  auto* eeep =
368
354
  reinterpret_cast<EventEngineEndpointWrapper::grpc_event_engine_endpoint*>(
369
355
  ep);
370
356
  GRPC_EVENT_ENGINE_TRACE("EventEngine::Endpoint %p Destroy", eeep->wrapper);
357
+ eeep->wrapper->TriggerShutdown(nullptr);
371
358
  eeep->wrapper->Unref();
372
359
  }
373
360
 
@@ -405,7 +392,6 @@ grpc_endpoint_vtable grpc_event_engine_endpoint_vtable = {
405
392
  EndpointAddToPollset,
406
393
  EndpointAddToPollsetSet,
407
394
  EndpointDeleteFromPollsetSet,
408
- EndpointShutdown,
409
395
  EndpointDestroy,
410
396
  EndpointGetPeerAddress,
411
397
  EndpointGetLocalAddress,
@@ -32,7 +32,7 @@
32
32
  static void exec_ctx_run(grpc_closure* closure) {
33
33
  #ifndef NDEBUG
34
34
  closure->scheduled = false;
35
- if (grpc_trace_closure.enabled()) {
35
+ if (GRPC_TRACE_FLAG_ENABLED(closure)) {
36
36
  gpr_log(GPR_DEBUG, "running closure %p: created [%s:%d]: %s [%s:%d]",
37
37
  closure, closure->file_created, closure->line_created,
38
38
  closure->run ? "run" : "scheduled", closure->file_initiated,
@@ -44,7 +44,7 @@ static void exec_ctx_run(grpc_closure* closure) {
44
44
  closure->error_data.error = 0;
45
45
  closure->cb(closure->cb_arg, std::move(error));
46
46
  #ifndef NDEBUG
47
- if (grpc_trace_closure.enabled()) {
47
+ if (GRPC_TRACE_FLAG_ENABLED(closure)) {
48
48
  gpr_log(GPR_DEBUG, "closure %p finished", closure);
49
49
  }
50
50
  #endif
@@ -36,12 +36,12 @@
36
36
  #include <grpc/support/log.h>
37
37
  #include <grpc/support/time.h>
38
38
 
39
- #include "src/core/lib/gpr/time_precise.h"
40
39
  #include "src/core/lib/gprpp/crash.h"
41
40
  #include "src/core/lib/gprpp/debug_location.h"
42
41
  #include "src/core/lib/gprpp/fork.h"
43
42
  #include "src/core/lib/gprpp/time.h"
44
43
  #include "src/core/lib/iomgr/closure.h"
44
+ #include "src/core/util/time_precise.h"
45
45
 
46
46
  #if !defined(_WIN32) || !defined(_DLL)
47
47
  #define EXEC_CTX exec_ctx_
@@ -28,28 +28,21 @@
28
28
  #include <grpc/support/port_platform.h>
29
29
  #include <grpc/support/sync.h>
30
30
 
31
- #include "src/core/lib/gpr/useful.h"
32
31
  #include "src/core/lib/gprpp/crash.h"
33
32
  #include "src/core/lib/gprpp/memory.h"
34
33
  #include "src/core/lib/iomgr/exec_ctx.h"
35
34
  #include "src/core/lib/iomgr/iomgr_internal.h"
35
+ #include "src/core/util/useful.h"
36
36
 
37
37
  #define MAX_DEPTH 2
38
38
 
39
39
  #define EXECUTOR_TRACE(format, ...) \
40
40
  do { \
41
- if (GRPC_TRACE_FLAG_ENABLED(executor_trace)) { \
41
+ if (GRPC_TRACE_FLAG_ENABLED(executor)) { \
42
42
  gpr_log(GPR_INFO, "EXECUTOR " format, __VA_ARGS__); \
43
43
  } \
44
44
  } while (0)
45
45
 
46
- #define EXECUTOR_TRACE0(str) \
47
- do { \
48
- if (GRPC_TRACE_FLAG_ENABLED(executor_trace)) { \
49
- gpr_log(GPR_INFO, "EXECUTOR " str); \
50
- } \
51
- } while (0)
52
-
53
46
  namespace grpc_core {
54
47
  namespace {
55
48
 
@@ -87,8 +80,6 @@ const EnqueueFunc
87
80
 
88
81
  } // namespace
89
82
 
90
- TraceFlag executor_trace(false, "executor");
91
-
92
83
  Executor::Executor(const char* name) : name_(name) {
93
84
  adding_thread_lock_ = GPR_SPINLOCK_STATIC_INITIALIZER;
94
85
  gpr_atm_rel_store(&num_threads_, 0);
@@ -368,7 +359,7 @@ void Executor::Enqueue(grpc_closure* closure, grpc_error_handle error,
368
359
  // the grpc_init() and grpc_shutdown() code paths which are protected by a
369
360
  // global mutex. So it is okay to assume that these functions are thread-safe
370
361
  void Executor::InitAll() {
371
- EXECUTOR_TRACE0("Executor::InitAll() enter");
362
+ GRPC_TRACE_LOG(executor, INFO) << "Executor::InitAll() enter";
372
363
 
373
364
  // Return if Executor::InitAll() is already called earlier
374
365
  if (executors[static_cast<size_t>(ExecutorType::DEFAULT)] != nullptr) {
@@ -384,7 +375,7 @@ void Executor::InitAll() {
384
375
  executors[static_cast<size_t>(ExecutorType::DEFAULT)]->Init();
385
376
  executors[static_cast<size_t>(ExecutorType::RESOLVER)]->Init();
386
377
 
387
- EXECUTOR_TRACE0("Executor::InitAll() done");
378
+ GRPC_TRACE_LOG(executor, INFO) << "Executor::InitAll() done";
388
379
  }
389
380
 
390
381
  void Executor::Run(grpc_closure* closure, grpc_error_handle error,
@@ -394,7 +385,7 @@ void Executor::Run(grpc_closure* closure, grpc_error_handle error,
394
385
  }
395
386
 
396
387
  void Executor::ShutdownAll() {
397
- EXECUTOR_TRACE0("Executor::ShutdownAll() enter");
388
+ GRPC_TRACE_LOG(executor, INFO) << "Executor::ShutdownAll() enter";
398
389
 
399
390
  // Return if Executor:SshutdownAll() is already called earlier
400
391
  if (executors[static_cast<size_t>(ExecutorType::DEFAULT)] == nullptr) {
@@ -422,7 +413,7 @@ void Executor::ShutdownAll() {
422
413
  executors[static_cast<size_t>(ExecutorType::DEFAULT)] = nullptr;
423
414
  executors[static_cast<size_t>(ExecutorType::RESOLVER)] = nullptr;
424
415
 
425
- EXECUTOR_TRACE0("Executor::ShutdownAll() done");
416
+ GRPC_TRACE_LOG(executor, INFO) << "Executor::ShutdownAll() done";
426
417
  }
427
418
 
428
419
  bool Executor::IsThreaded(ExecutorType executor_type) {
@@ -21,9 +21,9 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
- #include "src/core/lib/gpr/spinlock.h"
25
24
  #include "src/core/lib/gprpp/thd.h"
26
25
  #include "src/core/lib/iomgr/closure.h"
26
+ #include "src/core/util/spinlock.h"
27
27
 
28
28
  namespace grpc_core {
29
29
 
@@ -28,9 +28,10 @@
28
28
 
29
29
  #include <string.h>
30
30
 
31
+ #include "absl/log/log.h"
32
+
31
33
  #include <grpc/fork.h>
32
34
  #include <grpc/grpc.h>
33
- #include <grpc/support/log.h>
34
35
 
35
36
  #include "src/core/lib/gprpp/crash.h"
36
37
  #include "src/core/lib/gprpp/fork.h"
@@ -60,24 +61,21 @@ void grpc_prefork() {
60
61
  }
61
62
  grpc_core::ExecCtx exec_ctx;
62
63
  if (!grpc_core::Fork::Enabled()) {
63
- gpr_log(GPR_ERROR,
64
- "Fork support not enabled; try running with the "
65
- "environment variable GRPC_ENABLE_FORK_SUPPORT=1");
64
+ LOG(ERROR) << "Fork support not enabled; try running with the "
65
+ "environment variable GRPC_ENABLE_FORK_SUPPORT=1";
66
66
  return;
67
67
  }
68
68
  const char* poll_strategy_name = grpc_get_poll_strategy_name();
69
69
  if (poll_strategy_name == nullptr ||
70
70
  (strcmp(poll_strategy_name, "epoll1") != 0 &&
71
71
  strcmp(poll_strategy_name, "poll") != 0)) {
72
- gpr_log(GPR_INFO,
73
- "Fork support is only compatible with the epoll1 and poll polling "
74
- "strategies");
72
+ LOG(INFO) << "Fork support is only compatible with the epoll1 and poll "
73
+ "polling strategies";
75
74
  return;
76
75
  }
77
76
  if (!grpc_core::Fork::BlockExecCtx()) {
78
- gpr_log(GPR_INFO,
79
- "Other threads are currently calling into gRPC, skipping fork() "
80
- "handlers");
77
+ LOG(INFO) << "Other threads are currently calling into gRPC, skipping "
78
+ "fork() handlers";
81
79
  return;
82
80
  }
83
81
  grpc_timer_manager_set_threading(false);
@@ -22,6 +22,8 @@
22
22
 
23
23
  #ifndef GRPC_POSIX_FORK
24
24
 
25
+ #include "absl/log/log.h"
26
+
25
27
  #include <grpc/fork.h>
26
28
  #include <grpc/support/log.h>
27
29
 
@@ -30,7 +32,7 @@
30
32
  // AROUND VERY SPECIFIC USE CASES.
31
33
  //
32
34
 
33
- void grpc_prefork() { gpr_log(GPR_ERROR, "Forking not supported on Windows"); }
35
+ void grpc_prefork() { LOG(ERROR) << "Forking not supported on Windows"; }
34
36
 
35
37
  void grpc_postfork_parent() {}
36
38
 
@@ -25,7 +25,7 @@
25
25
  #include <errno.h>
26
26
  #include <net/if.h>
27
27
 
28
- #include <grpc/support/log.h>
28
+ #include "absl/log/log.h"
29
29
 
30
30
  #include "src/core/lib/gprpp/crash.h"
31
31
  #include "src/core/lib/iomgr/grpc_if_nametoindex.h"
@@ -33,8 +33,7 @@
33
33
  uint32_t grpc_if_nametoindex(char* name) {
34
34
  uint32_t out = if_nametoindex(name);
35
35
  if (out == 0) {
36
- gpr_log(GPR_DEBUG, "if_nametoindex failed for name %s. errno %d", name,
37
- errno);
36
+ VLOG(2) << "if_nametoindex failed for name " << name << ". errno " << errno;
38
37
  }
39
38
  return out;
40
39
  }
@@ -22,16 +22,14 @@
22
22
 
23
23
  #if GRPC_IF_NAMETOINDEX == 0 || !defined(GRPC_POSIX_SOCKET_IF_NAMETOINDEX)
24
24
 
25
- #include <grpc/support/log.h>
25
+ #include "absl/log/log.h"
26
26
 
27
27
  #include "src/core/lib/gprpp/crash.h"
28
28
  #include "src/core/lib/iomgr/grpc_if_nametoindex.h"
29
29
 
30
30
  uint32_t grpc_if_nametoindex(char* name) {
31
- gpr_log(GPR_DEBUG,
32
- "Not attempting to convert interface name %s to index for current "
33
- "platform.",
34
- name);
31
+ VLOG(2) << "Not attempting to convert interface name " << name
32
+ << " to index for current platform.";
35
33
  return 0;
36
34
  }
37
35
 
@@ -14,6 +14,8 @@
14
14
 
15
15
  #include "src/core/lib/iomgr/internal_errqueue.h"
16
16
 
17
+ #include "absl/log/log.h"
18
+
17
19
  #include <grpc/support/log.h>
18
20
  #include <grpc/support/port_platform.h>
19
21
 
@@ -37,7 +39,7 @@ bool KernelSupportsErrqueue() {
37
39
  // least 4.0.0
38
40
  struct utsname buffer;
39
41
  if (uname(&buffer) != 0) {
40
- gpr_log(GPR_ERROR, "uname: %s", StrError(errno).c_str());
42
+ LOG(ERROR) << "uname: " << StrError(errno);
41
43
  return false;
42
44
  }
43
45
  char* release = buffer.release;
@@ -48,7 +50,7 @@ bool KernelSupportsErrqueue() {
48
50
  if (strtol(release, nullptr, 10) >= 4) {
49
51
  return true;
50
52
  } else {
51
- gpr_log(GPR_DEBUG, "ERRQUEUE support not enabled");
53
+ VLOG(2) << "ERRQUEUE support not enabled";
52
54
  }
53
55
  #endif // GRPC_LINUX_ERRQUEUE
54
56
  return false;
@@ -27,19 +27,20 @@
27
27
  #include <limits>
28
28
 
29
29
  #include "absl/log/check.h"
30
+ #include "absl/log/log.h"
30
31
 
31
32
  #include <grpc/support/alloc.h>
32
33
  #include <grpc/support/log.h>
33
34
  #include <grpc/support/log_windows.h>
34
35
 
35
- #include "src/core/lib/debug/stats.h"
36
- #include "src/core/lib/debug/stats_data.h"
37
36
  #include "src/core/lib/gprpp/crash.h"
38
37
  #include "src/core/lib/gprpp/thd.h"
39
38
  #include "src/core/lib/iomgr/iocp_windows.h"
40
39
  #include "src/core/lib/iomgr/iomgr_internal.h"
41
40
  #include "src/core/lib/iomgr/socket_windows.h"
42
41
  #include "src/core/lib/iomgr/timer.h"
42
+ #include "src/core/telemetry/stats.h"
43
+ #include "src/core/telemetry/stats_data.h"
43
44
 
44
45
  static ULONG g_iocp_kick_token;
45
46
  static OVERLAPPED g_iocp_custom_overlap;
@@ -157,7 +158,7 @@ void grpc_iocp_add_socket(grpc_winsocket* socket) {
157
158
  (uintptr_t)socket, 0);
158
159
  if (!ret) {
159
160
  char* utf8_message = gpr_format_message(WSAGetLastError());
160
- gpr_log(GPR_ERROR, "Unable to add socket to iocp: %s", utf8_message);
161
+ LOG(ERROR) << "Unable to add socket to iocp: " << utf8_message;
161
162
  gpr_free(utf8_message);
162
163
  __debugbreak();
163
164
  abort();
@@ -22,15 +22,14 @@
22
22
  #include <stdlib.h>
23
23
  #include <string.h>
24
24
 
25
+ #include "absl/log/log.h"
26
+
25
27
  #include <grpc/support/alloc.h>
26
- #include <grpc/support/log.h>
27
28
  #include <grpc/support/port_platform.h>
28
29
  #include <grpc/support/string_util.h>
29
30
  #include <grpc/support/sync.h>
30
31
 
31
32
  #include "src/core/lib/config/config_vars.h"
32
- #include "src/core/lib/gpr/string.h"
33
- #include "src/core/lib/gpr/useful.h"
34
33
  #include "src/core/lib/gprpp/crash.h"
35
34
  #include "src/core/lib/gprpp/thd.h"
36
35
  #include "src/core/lib/iomgr/buffer_list.h"
@@ -40,6 +39,8 @@
40
39
  #include "src/core/lib/iomgr/iomgr_internal.h"
41
40
  #include "src/core/lib/iomgr/timer.h"
42
41
  #include "src/core/lib/iomgr/timer_manager.h"
42
+ #include "src/core/util/string.h"
43
+ #include "src/core/util/useful.h"
43
44
 
44
45
  static gpr_mu g_mu;
45
46
  static gpr_cv g_rcv;
@@ -82,7 +83,7 @@ size_t grpc_iomgr_count_objects_for_testing(void) {
82
83
  static void dump_objects(const char* kind) {
83
84
  grpc_iomgr_object* obj;
84
85
  for (obj = g_root_object.next; obj != &g_root_object; obj = obj->next) {
85
- gpr_log(GPR_DEBUG, "%s OBJECT: %s %p", kind, obj->name, obj);
86
+ VLOG(2) << kind << " OBJECT: " << obj->name << " " << obj;
86
87
  }
87
88
  }
88
89
 
@@ -102,9 +103,8 @@ void grpc_iomgr_shutdown() {
102
103
  gpr_time_sub(gpr_now(GPR_CLOCK_REALTIME), last_warning_time),
103
104
  gpr_time_from_seconds(1, GPR_TIMESPAN)) >= 0) {
104
105
  if (g_root_object.next != &g_root_object) {
105
- gpr_log(GPR_DEBUG,
106
- "Waiting for %" PRIuPTR " iomgr objects to be destroyed",
107
- count_objects());
106
+ VLOG(2) << "Waiting for " << count_objects()
107
+ << " iomgr objects to be destroyed";
108
108
  }
109
109
  last_warning_time = gpr_now(GPR_CLOCK_REALTIME);
110
110
  }
@@ -118,11 +118,9 @@ void grpc_iomgr_shutdown() {
118
118
  }
119
119
  if (g_root_object.next != &g_root_object) {
120
120
  if (grpc_iomgr_abort_on_leaks()) {
121
- gpr_log(GPR_DEBUG,
122
- "Failed to free %" PRIuPTR
123
- " iomgr objects before shutdown deadline: "
124
- "memory leaks are likely",
125
- count_objects());
121
+ VLOG(2) << "Failed to free " << count_objects()
122
+ << " iomgr objects before shutdown deadline: "
123
+ << "memory leaks are likely";
126
124
  dump_objects("LEAKED");
127
125
  abort();
128
126
  }
@@ -133,11 +131,9 @@ void grpc_iomgr_shutdown() {
133
131
  if (gpr_time_cmp(gpr_now(GPR_CLOCK_REALTIME), shutdown_deadline) >
134
132
  0) {
135
133
  if (g_root_object.next != &g_root_object) {
136
- gpr_log(GPR_DEBUG,
137
- "Failed to free %" PRIuPTR
138
- " iomgr objects before shutdown deadline: "
139
- "memory leaks are likely",
140
- count_objects());
134
+ VLOG(2) << "Failed to free " << count_objects()
135
+ << " iomgr objects before shutdown deadline: "
136
+ << "memory leaks are likely";
141
137
  dump_objects("LEAKED");
142
138
  }
143
139
  break;
@@ -27,8 +27,6 @@
27
27
  #include "src/core/lib/gprpp/crash.h"
28
28
  #include "src/core/lib/iomgr/exec_ctx.h"
29
29
 
30
- extern grpc_core::DebugOnlyTraceFlag grpc_polling_trace;
31
-
32
30
  // 'state' holds the to call when the fd is readable or writable respectively.
33
31
  // It can contain one of the following values:
34
32
  // kClosureReady : The fd has an I/O event of interest but there is no
@@ -97,7 +95,7 @@ void LockfreeEvent::NotifyOn(grpc_closure* closure) {
97
95
  // sure that the shutdown error has been initialized properly before us
98
96
  // referencing it.
99
97
  gpr_atm curr = gpr_atm_acq_load(&state_);
100
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
98
+ if (GRPC_TRACE_FLAG_ENABLED(polling)) {
101
99
  gpr_log(GPR_DEBUG,
102
100
  "LockfreeEvent::NotifyOn: %p curr=%" PRIxPTR " closure=%p", this,
103
101
  curr, closure);
@@ -166,7 +164,7 @@ bool LockfreeEvent::SetShutdown(grpc_error_handle shutdown_error) {
166
164
 
167
165
  while (true) {
168
166
  gpr_atm curr = gpr_atm_no_barrier_load(&state_);
169
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
167
+ if (GRPC_TRACE_FLAG_ENABLED(polling)) {
170
168
  gpr_log(GPR_DEBUG,
171
169
  "LockfreeEvent::SetShutdown: %p curr=%" PRIxPTR " err=%s",
172
170
  &state_, curr, StatusToString(shutdown_error).c_str());
@@ -216,7 +214,7 @@ void LockfreeEvent::SetReady() {
216
214
  while (true) {
217
215
  gpr_atm curr = gpr_atm_no_barrier_load(&state_);
218
216
 
219
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
217
+ if (GRPC_TRACE_FLAG_ENABLED(polling)) {
220
218
  gpr_log(GPR_DEBUG, "LockfreeEvent::SetReady: %p curr=%" PRIxPTR, &state_,
221
219
  curr);
222
220
  }
@@ -26,8 +26,6 @@
26
26
  #include "src/core/lib/iomgr/exec_ctx.h"
27
27
  #include "src/core/lib/iomgr/iomgr_fwd.h"
28
28
 
29
- extern grpc_core::DebugOnlyTraceFlag grpc_trace_fd_refcount;
30
-
31
29
  // A grpc_pollset is a set of file descriptors that a higher level item is
32
30
  // interested in. For example:
33
31
  // - a server will typically keep a pollset containing all connected channels,
@@ -33,8 +33,6 @@
33
33
 
34
34
  #define GRPC_POLLSET_KICK_BROADCAST ((grpc_pollset_worker*)1)
35
35
 
36
- grpc_core::DebugOnlyTraceFlag grpc_trace_fd_refcount(false, "fd_refcount");
37
-
38
36
  gpr_mu grpc_polling_mu;
39
37
  static grpc_pollset_worker* g_active_poller;
40
38
  static grpc_pollset_worker g_global_root_worker;
@@ -30,8 +30,6 @@
30
30
  #include <grpc/support/time.h>
31
31
 
32
32
  #include "src/core/lib/event_engine/default_event_engine.h"
33
- #include "src/core/lib/gpr/string.h"
34
- #include "src/core/lib/gpr/useful.h"
35
33
  #include "src/core/lib/gprpp/crash.h"
36
34
  #include "src/core/lib/gprpp/host_port.h"
37
35
  #include "src/core/lib/gprpp/thd.h"
@@ -44,6 +42,8 @@
44
42
  #include "src/core/lib/iomgr/sockaddr.h"
45
43
  #include "src/core/lib/iomgr/unix_sockets_posix.h"
46
44
  #include "src/core/lib/transport/error_utils.h"
45
+ #include "src/core/util/string.h"
46
+ #include "src/core/util/useful.h"
47
47
 
48
48
  namespace grpc_core {
49
49
  namespace {
@@ -106,14 +106,13 @@ NativeDNSResolver::LookupHostnameBlocking(absl::string_view name,
106
106
  // parse name, splitting it into host and port parts
107
107
  SplitHostPort(name, &host, &port);
108
108
  if (host.empty()) {
109
- err = grpc_error_set_str(GRPC_ERROR_CREATE("unparseable host:port"),
110
- StatusStrProperty::kTargetAddress, name);
109
+ err =
110
+ GRPC_ERROR_CREATE(absl::StrCat("unparseable host:port \"", name, "\""));
111
111
  goto done;
112
112
  }
113
113
  if (port.empty()) {
114
114
  if (default_port.empty()) {
115
- err = grpc_error_set_str(GRPC_ERROR_CREATE("no port in name"),
116
- StatusStrProperty::kTargetAddress, name);
115
+ err = GRPC_ERROR_CREATE(absl::StrCat("no port in name \"", name, "\""));
117
116
  goto done;
118
117
  }
119
118
  port = std::string(default_port);
@@ -139,14 +138,8 @@ NativeDNSResolver::LookupHostnameBlocking(absl::string_view name,
139
138
  }
140
139
  }
141
140
  if (s != 0) {
142
- err = grpc_error_set_str(
143
- grpc_error_set_str(
144
- grpc_error_set_str(
145
- grpc_error_set_int(GRPC_ERROR_CREATE(gai_strerror(s)),
146
- StatusIntProperty::kErrorNo, s),
147
- StatusStrProperty::kOsError, gai_strerror(s)),
148
- StatusStrProperty::kSyscall, "getaddrinfo"),
149
- StatusStrProperty::kTargetAddress, name);
141
+ err = absl::UnknownError(absl::StrCat(
142
+ "getaddrinfo(\"", name, "\"): ", gai_strerror(s), " (", s, ")"));
150
143
  goto done;
151
144
  }
152
145
  // Success path: fill in addrs
@@ -35,7 +35,6 @@
35
35
 
36
36
  #include "src/core/lib/address_utils/sockaddr_utils.h"
37
37
  #include "src/core/lib/event_engine/default_event_engine.h"
38
- #include "src/core/lib/gpr/string.h"
39
38
  #include "src/core/lib/gprpp/crash.h"
40
39
  #include "src/core/lib/gprpp/host_port.h"
41
40
  #include "src/core/lib/gprpp/thd.h"
@@ -47,6 +46,7 @@
47
46
  #include "src/core/lib/iomgr/resolve_address_windows.h"
48
47
  #include "src/core/lib/iomgr/sockaddr.h"
49
48
  #include "src/core/lib/transport/error_utils.h"
49
+ #include "src/core/util/string.h"
50
50
 
51
51
  namespace grpc_core {
52
52
  namespace {
@@ -26,8 +26,8 @@
26
26
  #include <grpc/support/sync.h>
27
27
 
28
28
  #include "src/core/lib/channel/channel_args.h"
29
- #include "src/core/lib/gpr/useful.h"
30
29
  #include "src/core/lib/iomgr/socket_factory_posix.h"
30
+ #include "src/core/util/useful.h"
31
31
 
32
32
  void grpc_socket_factory_init(grpc_socket_factory* factory,
33
33
  const grpc_socket_factory_vtable* vtable) {
@@ -24,8 +24,8 @@
24
24
  #include <grpc/support/sync.h>
25
25
 
26
26
  #include "src/core/lib/channel/channel_args.h"
27
- #include "src/core/lib/gpr/useful.h"
28
27
  #include "src/core/lib/gprpp/crash.h"
28
+ #include "src/core/util/useful.h"
29
29
 
30
30
  void grpc_socket_mutator_init(grpc_socket_mutator* mutator,
31
31
  const grpc_socket_mutator_vtable* vtable) {