grpc 1.53.0 → 1.59.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2080) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +729 -374
  3. data/include/grpc/event_engine/event_engine.h +55 -53
  4. data/include/grpc/event_engine/memory_allocator.h +2 -2
  5. data/include/grpc/grpc_audit_logging.h +96 -0
  6. data/include/grpc/grpc_security.h +23 -0
  7. data/include/grpc/impl/channel_arg_names.h +375 -0
  8. data/include/grpc/impl/grpc_types.h +1 -339
  9. data/include/grpc/module.modulemap +3 -0
  10. data/include/grpc/support/json.h +218 -0
  11. data/include/grpc/support/port_platform.h +107 -28
  12. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +18 -2
  13. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +24 -10
  14. data/src/core/ext/filters/client_channel/backend_metric.cc +10 -1
  15. data/src/core/ext/filters/client_channel/backup_poller.cc +2 -11
  16. data/src/core/ext/filters/client_channel/backup_poller.h +0 -3
  17. data/src/core/ext/filters/client_channel/channel_connectivity.cc +4 -4
  18. data/src/core/ext/filters/client_channel/client_channel.cc +1366 -947
  19. data/src/core/ext/filters/client_channel/client_channel.h +180 -168
  20. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +20 -19
  21. data/src/core/ext/filters/client_channel/client_channel_internal.h +77 -0
  22. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +15 -1
  23. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +2 -2
  24. data/src/core/ext/filters/client_channel/config_selector.h +13 -39
  25. data/src/core/ext/filters/client_channel/dynamic_filters.h +5 -3
  26. data/src/core/ext/filters/client_channel/{http_proxy.cc → http_proxy_mapper.cc} +42 -4
  27. data/src/core/ext/filters/client_channel/{http_proxy.h → http_proxy_mapper.h} +3 -3
  28. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +27 -53
  29. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +23 -9
  30. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +9 -1
  31. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +25 -35
  32. data/src/core/ext/filters/client_channel/lb_policy/endpoint_list.cc +188 -0
  33. data/src/core/ext/filters/client_channel/lb_policy/endpoint_list.h +214 -0
  34. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +120 -160
  35. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +2 -1
  36. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +5 -4
  37. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +4 -2
  38. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.cc +515 -0
  39. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.h +52 -0
  40. data/src/core/ext/filters/client_channel/lb_policy/health_check_client_internal.h +204 -0
  41. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +6 -9
  42. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric_internal.h +2 -0
  43. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +93 -106
  44. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +2 -2
  45. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +532 -191
  46. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.h +36 -0
  47. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +16 -45
  48. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +464 -498
  49. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +18 -1
  50. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +75 -145
  51. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +430 -40
  52. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +26 -23
  53. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/static_stride_scheduler.cc +76 -6
  54. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +951 -110
  55. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +30 -57
  56. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +73 -126
  57. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +8 -0
  58. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +43 -87
  59. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +25 -74
  60. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +117 -173
  61. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +83 -70
  62. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +28 -96
  63. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +47 -157
  64. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.h +30 -0
  65. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +102 -11
  66. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +107 -177
  67. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +58 -44
  68. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +4 -1
  69. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.cc +66 -0
  70. data/src/core/ext/filters/client_channel/resolver/dns/{dns_resolver_selection.h → dns_resolver_plugin.h} +10 -12
  71. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +586 -0
  72. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.h +35 -0
  73. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.cc +97 -0
  74. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.h +32 -0
  75. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +20 -37
  76. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.h +24 -0
  77. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +24 -6
  78. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +36 -2
  79. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +61 -207
  80. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +11 -6
  81. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +2 -2
  82. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +25 -13
  83. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +470 -313
  84. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +32 -1
  85. data/src/core/ext/filters/client_channel/retry_filter.cc +40 -2538
  86. data/src/core/ext/filters/client_channel/retry_filter.h +92 -1
  87. data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.cc +2052 -0
  88. data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.h +442 -0
  89. data/src/core/ext/filters/client_channel/retry_service_config.cc +10 -9
  90. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +40 -90
  91. data/src/core/ext/filters/client_channel/subchannel.cc +52 -203
  92. data/src/core/ext/filters/client_channel/subchannel.h +23 -48
  93. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +3 -0
  94. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +26 -27
  95. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +8 -5
  96. data/src/core/ext/filters/deadline/deadline_filter.cc +1 -1
  97. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +1 -1
  98. data/src/core/ext/filters/http/client/http_client_filter.cc +4 -3
  99. data/src/core/ext/filters/http/client_authority_filter.cc +1 -1
  100. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -12
  101. data/src/core/ext/filters/http/message_compress/compression_filter.cc +31 -14
  102. data/src/core/ext/filters/http/server/http_server_filter.cc +22 -18
  103. data/src/core/ext/filters/message_size/message_size_filter.cc +142 -224
  104. data/src/core/ext/filters/message_size/message_size_filter.h +48 -3
  105. data/src/core/ext/filters/rbac/rbac_filter.cc +40 -111
  106. data/src/core/ext/filters/rbac/rbac_filter.h +12 -30
  107. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +162 -72
  108. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +6 -8
  109. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +165 -88
  110. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +16 -7
  111. data/src/core/ext/gcp/metadata_query.cc +137 -0
  112. data/src/core/ext/gcp/metadata_query.h +87 -0
  113. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +1 -0
  114. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +84 -70
  115. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +12 -8
  116. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +5 -1
  117. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +1118 -882
  118. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +21 -0
  119. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +70 -0
  120. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +6569 -174
  121. data/src/core/ext/transport/chttp2/transport/decode_huff.h +2278 -441
  122. data/src/core/ext/transport/chttp2/transport/flow_control.cc +79 -119
  123. data/src/core/ext/transport/chttp2/transport/flow_control.h +29 -5
  124. data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -1
  125. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -1
  126. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +24 -25
  127. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -4
  128. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +10 -1
  129. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -1
  130. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +5 -2
  131. data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -1
  132. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -1
  133. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +119 -223
  134. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +296 -113
  135. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -0
  136. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +2 -0
  137. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +176 -0
  138. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +326 -0
  139. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +774 -488
  140. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +166 -14
  141. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +59 -42
  142. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +26 -4
  143. data/src/core/ext/transport/chttp2/transport/internal.h +211 -151
  144. data/src/core/ext/transport/chttp2/transport/{frame.h → legacy_frame.h} +3 -3
  145. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +44 -0
  146. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +67 -0
  147. data/src/core/ext/transport/chttp2/transport/parsing.cc +152 -33
  148. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +90 -0
  149. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +59 -0
  150. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +108 -0
  151. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +115 -0
  152. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +120 -0
  153. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +88 -0
  154. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +1 -1
  155. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +60 -0
  156. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +66 -0
  157. data/src/core/ext/transport/chttp2/transport/writing.cc +222 -142
  158. data/src/core/ext/transport/inproc/inproc_transport.cc +30 -14
  159. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +85 -52
  160. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +407 -182
  161. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +119 -60
  162. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +474 -225
  163. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +88 -55
  164. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +408 -189
  165. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +355 -210
  166. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1564 -729
  167. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +28 -17
  168. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +140 -51
  169. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +32 -21
  170. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +153 -63
  171. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +25 -14
  172. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +71 -39
  173. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +18 -11
  174. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +41 -27
  175. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +18 -11
  176. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +41 -27
  177. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +107 -62
  178. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +559 -245
  179. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +19 -12
  180. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +38 -31
  181. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +20 -19
  182. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +75 -30
  183. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +21 -16
  184. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +38 -31
  185. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +253 -147
  186. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +869 -405
  187. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +415 -262
  188. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1842 -888
  189. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +72 -41
  190. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +279 -149
  191. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +529 -334
  192. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +2009 -1131
  193. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +19 -12
  194. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +38 -31
  195. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +87 -52
  196. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +340 -233
  197. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +262 -165
  198. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +881 -477
  199. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +137 -80
  200. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +520 -275
  201. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +20 -13
  202. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +43 -37
  203. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +378 -221
  204. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1160 -611
  205. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +155 -92
  206. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +620 -293
  207. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +16 -11
  208. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +30 -27
  209. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +19 -12
  210. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +38 -31
  211. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +28 -17
  212. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +140 -51
  213. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +277 -167
  214. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +811 -441
  215. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +230 -137
  216. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +1157 -501
  217. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +20 -13
  218. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +53 -38
  219. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +367 -209
  220. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +1118 -636
  221. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +42 -11
  222. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +168 -19
  223. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +32 -19
  224. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +110 -56
  225. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +36 -21
  226. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +141 -65
  227. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +29 -18
  228. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +136 -66
  229. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +20 -13
  230. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +44 -38
  231. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +76 -43
  232. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +258 -128
  233. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +143 -88
  234. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +431 -242
  235. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +113 -62
  236. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +552 -228
  237. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +16 -11
  238. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +28 -27
  239. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +185 -109
  240. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +949 -422
  241. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +170 -95
  242. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +857 -375
  243. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +47 -25
  244. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +164 -101
  245. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +37 -18
  246. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +66 -56
  247. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +27 -15
  248. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +85 -46
  249. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +129 -74
  250. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +481 -249
  251. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +161 -84
  252. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +673 -241
  253. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +254 -129
  254. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +989 -398
  255. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +78 -49
  256. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +609 -202
  257. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +1281 -774
  258. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +5422 -2509
  259. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +47 -28
  260. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +157 -85
  261. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +226 -141
  262. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +731 -400
  263. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +18 -11
  264. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +41 -27
  265. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +19 -12
  266. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +38 -31
  267. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +30 -19
  268. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +62 -49
  269. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +25 -14
  270. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +103 -44
  271. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +44 -25
  272. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +252 -101
  273. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +19 -13
  274. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +38 -31
  275. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +16 -11
  276. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +28 -27
  277. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +40 -23
  278. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +101 -71
  279. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +5 -4
  280. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +14 -17
  281. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +41 -24
  282. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +103 -76
  283. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +28 -17
  284. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +88 -51
  285. data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.c +556 -0
  286. data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.h +2702 -0
  287. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +14 -9
  288. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +66 -24
  289. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +58 -37
  290. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +143 -109
  291. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +91 -43
  292. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +379 -168
  293. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +42 -25
  294. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +107 -81
  295. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +66 -22
  296. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +348 -83
  297. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.c +30 -19
  298. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +65 -51
  299. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +502 -296
  300. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +2259 -1055
  301. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.c +16 -11
  302. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +28 -27
  303. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +33 -19
  304. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +118 -68
  305. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.c +70 -45
  306. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +186 -139
  307. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.c +45 -0
  308. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +85 -0
  309. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +32 -19
  310. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +125 -68
  311. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +16 -11
  312. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +28 -27
  313. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +5 -4
  314. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +8 -11
  315. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +182 -96
  316. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +900 -361
  317. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +54 -33
  318. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +143 -102
  319. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +186 -111
  320. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +809 -420
  321. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +30 -19
  322. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +101 -53
  323. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +8 -7
  324. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +11 -15
  325. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +298 -177
  326. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +1277 -523
  327. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +40 -23
  328. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +181 -76
  329. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +128 -83
  330. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +503 -239
  331. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +20 -13
  332. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +48 -35
  333. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +37 -26
  334. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +117 -69
  335. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.c +19 -12
  336. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.h +40 -31
  337. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +58 -26
  338. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +123 -52
  339. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +35 -20
  340. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +126 -64
  341. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +20 -13
  342. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +84 -41
  343. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +19 -12
  344. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +43 -33
  345. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +16 -11
  346. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +30 -27
  347. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +44 -27
  348. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +94 -71
  349. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.c +11 -10
  350. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.h +17 -22
  351. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +38 -23
  352. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +154 -76
  353. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +29 -18
  354. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +106 -56
  355. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +44 -29
  356. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +132 -92
  357. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +63 -42
  358. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +192 -121
  359. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +78 -45
  360. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +201 -132
  361. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +32 -21
  362. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +66 -53
  363. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +5 -4
  364. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +5 -8
  365. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +14 -9
  366. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +21 -19
  367. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +26 -15
  368. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +47 -34
  369. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +41 -22
  370. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +83 -53
  371. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +33 -20
  372. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +84 -57
  373. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +5 -4
  374. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +5 -8
  375. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +18 -11
  376. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +41 -27
  377. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +21 -14
  378. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +54 -42
  379. data/src/core/ext/upb-generated/google/api/annotations.upb.c +12 -11
  380. data/src/core/ext/upb-generated/google/api/annotations.upb.h +22 -20
  381. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +253 -154
  382. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +927 -451
  383. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +297 -180
  384. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +939 -484
  385. data/src/core/ext/upb-generated/google/api/http.upb.c +66 -35
  386. data/src/core/ext/upb-generated/google/api/http.upb.h +277 -121
  387. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +20 -13
  388. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +88 -38
  389. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +17 -10
  390. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +31 -23
  391. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +1168 -419
  392. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +4431 -1412
  393. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +17 -10
  394. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +31 -23
  395. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +8 -7
  396. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +11 -15
  397. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +60 -39
  398. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +200 -103
  399. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +17 -10
  400. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +31 -23
  401. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +88 -51
  402. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +149 -107
  403. data/src/core/ext/upb-generated/google/rpc/status.upb.c +20 -13
  404. data/src/core/ext/upb-generated/google/rpc/status.upb.h +88 -38
  405. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +57 -34
  406. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +147 -93
  407. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +41 -24
  408. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +110 -60
  409. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +248 -145
  410. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +912 -416
  411. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +32 -19
  412. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +68 -51
  413. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +23 -14
  414. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +37 -30
  415. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +142 -81
  416. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +397 -217
  417. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +49 -26
  418. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +146 -62
  419. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +171 -102
  420. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +848 -299
  421. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +66 -49
  422. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +148 -105
  423. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +24 -17
  424. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +48 -35
  425. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +10 -9
  426. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +23 -14
  427. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +24 -17
  428. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +48 -35
  429. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +21 -16
  430. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +38 -31
  431. data/src/core/ext/upb-generated/validate/validate.upb.c +843 -455
  432. data/src/core/ext/upb-generated/validate/validate.upb.h +4340 -1909
  433. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +66 -49
  434. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +148 -105
  435. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +24 -17
  436. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +48 -35
  437. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +10 -9
  438. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +23 -14
  439. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +63 -44
  440. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +130 -92
  441. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +21 -16
  442. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +38 -31
  443. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +14 -9
  444. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +21 -19
  445. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.c +19 -12
  446. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.h +38 -31
  447. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +35 -22
  448. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +88 -63
  449. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +24 -17
  450. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +44 -29
  451. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +19 -12
  452. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +38 -31
  453. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +21 -14
  454. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +55 -43
  455. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +42 -25
  456. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +162 -80
  457. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +25 -14
  458. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +58 -39
  459. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +84 -31
  460. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +211 -59
  461. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +19 -12
  462. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +82 -35
  463. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.c +16 -11
  464. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.h +28 -27
  465. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.c +30 -19
  466. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.h +143 -55
  467. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.c +8 -7
  468. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.h +11 -15
  469. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.c +32 -21
  470. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.h +154 -64
  471. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +160 -101
  472. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +494 -294
  473. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.c +83 -52
  474. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.h +423 -165
  475. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +22 -15
  476. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +45 -37
  477. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +38 -23
  478. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +154 -76
  479. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.c +35 -22
  480. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.h +84 -66
  481. data/src/core/ext/upb-generated/xds/type/v3/range.upb.c +41 -22
  482. data/src/core/ext/upb-generated/xds/type/v3/range.upb.h +83 -53
  483. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +19 -12
  484. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +38 -31
  485. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +1 -1
  486. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +6 -5
  487. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +1 -1
  488. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +6 -5
  489. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +1 -1
  490. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +6 -5
  491. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +1 -1
  492. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +6 -5
  493. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +1 -1
  494. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +6 -5
  495. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +1 -1
  496. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +6 -5
  497. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +1 -1
  498. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +6 -5
  499. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +1 -1
  500. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +6 -5
  501. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +1 -1
  502. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +6 -5
  503. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +1 -1
  504. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +6 -5
  505. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +1 -1
  506. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +6 -5
  507. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +1 -1
  508. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +6 -5
  509. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +1 -1
  510. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +6 -5
  511. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +89 -77
  512. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +11 -5
  513. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +251 -248
  514. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +6 -5
  515. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +1 -1
  516. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +6 -5
  517. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +1 -1
  518. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +6 -5
  519. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +1 -1
  520. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +6 -5
  521. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +1 -1
  522. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +6 -5
  523. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +1 -1
  524. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +6 -5
  525. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +1 -1
  526. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +6 -5
  527. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +1 -1
  528. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +6 -5
  529. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +1 -1
  530. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +6 -5
  531. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +1 -1
  532. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +6 -5
  533. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +1 -1
  534. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +6 -5
  535. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +1 -1
  536. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +6 -5
  537. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +1 -1
  538. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +6 -5
  539. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +163 -161
  540. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +6 -5
  541. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +130 -119
  542. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +6 -5
  543. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +1 -1
  544. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +6 -5
  545. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +143 -134
  546. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +6 -5
  547. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +32 -16
  548. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +11 -5
  549. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +1 -1
  550. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +6 -5
  551. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +1 -1
  552. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +6 -5
  553. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +1 -1
  554. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +6 -5
  555. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +1 -1
  556. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +6 -5
  557. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +1 -1
  558. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +6 -5
  559. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +1 -1
  560. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +6 -5
  561. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +1 -1
  562. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +6 -5
  563. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +1 -1
  564. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +6 -5
  565. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +13 -10
  566. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +21 -5
  567. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +1 -1
  568. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +6 -5
  569. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +55 -46
  570. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +6 -5
  571. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +1 -1
  572. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +6 -5
  573. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +20 -13
  574. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +6 -5
  575. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +1 -1
  576. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +6 -5
  577. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +39 -31
  578. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +11 -5
  579. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +142 -120
  580. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +16 -5
  581. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +1 -1
  582. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +6 -5
  583. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +101 -98
  584. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +6 -5
  585. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +1 -1
  586. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +6 -5
  587. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +1 -1
  588. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +6 -5
  589. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +1 -1
  590. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +6 -5
  591. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +1 -1
  592. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +6 -5
  593. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +1 -1
  594. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +6 -5
  595. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +1 -1
  596. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +6 -5
  597. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +1 -1
  598. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +6 -5
  599. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +16 -19
  600. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +6 -5
  601. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +1 -1
  602. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +6 -5
  603. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +1 -1
  604. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +6 -5
  605. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +1 -1
  606. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +6 -5
  607. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +1 -1
  608. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +6 -5
  609. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +1 -1
  610. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +6 -5
  611. data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.c +402 -0
  612. data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.h +111 -0
  613. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +1 -1
  614. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +6 -5
  615. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +1 -1
  616. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +6 -5
  617. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +81 -75
  618. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +6 -5
  619. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +1 -1
  620. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +6 -5
  621. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +64 -48
  622. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +11 -5
  623. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +1 -1
  624. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +6 -5
  625. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +315 -282
  626. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +11 -5
  627. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +1 -1
  628. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +6 -5
  629. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +1 -1
  630. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +6 -5
  631. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +138 -136
  632. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +6 -5
  633. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +1 -1
  634. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +6 -5
  635. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +118 -118
  636. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +6 -5
  637. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +1 -1
  638. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +6 -5
  639. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +6 -6
  640. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +6 -5
  641. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +1 -1
  642. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +6 -5
  643. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +6 -6
  644. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +6 -5
  645. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +12 -13
  646. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +6 -5
  647. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +1 -1
  648. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +6 -5
  649. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +1 -1
  650. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +6 -5
  651. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.c +1 -1
  652. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.h +6 -5
  653. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +13 -10
  654. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +11 -5
  655. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +1 -1
  656. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +6 -5
  657. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +1 -1
  658. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +6 -5
  659. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +1 -1
  660. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +6 -5
  661. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +1 -1
  662. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +6 -5
  663. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +30 -30
  664. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +6 -5
  665. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.c +1 -1
  666. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.h +6 -5
  667. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +1 -1
  668. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +6 -5
  669. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +1 -1
  670. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +6 -5
  671. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +1 -1
  672. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +6 -5
  673. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +1 -1
  674. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +6 -5
  675. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +1 -1
  676. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +6 -5
  677. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +1 -1
  678. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +6 -5
  679. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +1 -1
  680. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +6 -5
  681. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +1 -1
  682. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +6 -5
  683. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +1 -1
  684. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +6 -5
  685. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +1 -1
  686. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +6 -5
  687. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +1 -1
  688. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +6 -5
  689. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +1 -1
  690. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +6 -5
  691. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +1 -1
  692. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +6 -5
  693. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +1 -1
  694. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +6 -5
  695. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +1 -1
  696. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +6 -5
  697. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +1 -1
  698. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +6 -5
  699. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +1 -1
  700. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +6 -5
  701. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +1 -1
  702. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +6 -5
  703. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +1 -1
  704. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +6 -5
  705. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +1 -1
  706. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +6 -5
  707. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +406 -273
  708. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +21 -5
  709. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +1 -1
  710. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +6 -5
  711. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +1 -1
  712. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +6 -5
  713. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +1 -1
  714. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +6 -5
  715. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +1 -1
  716. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +6 -5
  717. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +1 -1
  718. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +6 -5
  719. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +1 -1
  720. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +6 -5
  721. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +1 -1
  722. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +6 -5
  723. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +1 -1
  724. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +6 -5
  725. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +1 -1
  726. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +6 -5
  727. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +1 -1
  728. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +6 -5
  729. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +1 -1
  730. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +6 -5
  731. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +1 -1
  732. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +6 -5
  733. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +1 -1
  734. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +6 -5
  735. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +1 -1
  736. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +6 -5
  737. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +1 -1
  738. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +6 -5
  739. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +1 -1
  740. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +6 -5
  741. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +1 -1
  742. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +6 -5
  743. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +1 -1
  744. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +6 -5
  745. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +1 -1
  746. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +6 -5
  747. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +1 -1
  748. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +6 -5
  749. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.c +1 -1
  750. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.h +6 -5
  751. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +1 -1
  752. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +6 -5
  753. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +1 -1
  754. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +6 -5
  755. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +1 -1
  756. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +6 -5
  757. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +1 -1
  758. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +6 -5
  759. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +1 -1
  760. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +6 -5
  761. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +1 -1
  762. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +6 -5
  763. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.c +1 -1
  764. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.h +6 -5
  765. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.c +1 -1
  766. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.h +6 -5
  767. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  768. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  769. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.c +1 -1
  770. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.h +6 -5
  771. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +1 -1
  772. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +6 -5
  773. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.c +1 -1
  774. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.h +6 -5
  775. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +1 -1
  776. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +6 -5
  777. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +1 -1
  778. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +6 -5
  779. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.c +1 -1
  780. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.h +6 -5
  781. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.c +1 -1
  782. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.h +6 -5
  783. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +1 -1
  784. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +6 -5
  785. data/src/core/ext/xds/certificate_provider_store.cc +8 -13
  786. data/src/core/ext/xds/certificate_provider_store.h +1 -1
  787. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +30 -42
  788. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +14 -9
  789. data/src/core/ext/xds/upb_utils.h +1 -1
  790. data/src/core/ext/xds/xds_api.cc +41 -18
  791. data/src/core/ext/xds/xds_api.h +5 -4
  792. data/src/core/ext/xds/xds_audit_logger_registry.cc +122 -0
  793. data/src/core/ext/xds/xds_audit_logger_registry.h +68 -0
  794. data/src/core/ext/xds/xds_bootstrap.cc +3 -3
  795. data/src/core/ext/xds/xds_bootstrap_grpc.cc +65 -50
  796. data/src/core/ext/xds/xds_bootstrap_grpc.h +10 -13
  797. data/src/core/ext/xds/xds_channel_stack_modifier.cc +1 -2
  798. data/src/core/ext/xds/xds_client.cc +35 -16
  799. data/src/core/ext/xds/xds_client.h +3 -3
  800. data/src/core/ext/xds/xds_client_grpc.cc +12 -6
  801. data/src/core/ext/xds/xds_client_grpc.h +16 -2
  802. data/src/core/ext/xds/xds_client_stats.cc +29 -15
  803. data/src/core/ext/xds/xds_client_stats.h +34 -20
  804. data/src/core/ext/xds/xds_cluster.cc +100 -109
  805. data/src/core/ext/xds/xds_cluster.h +1 -6
  806. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +15 -11
  807. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +2 -2
  808. data/src/core/ext/xds/xds_common_types.cc +8 -5
  809. data/src/core/ext/xds/xds_endpoint.cc +26 -30
  810. data/src/core/ext/xds/xds_endpoint.h +10 -3
  811. data/src/core/ext/xds/xds_health_status.cc +0 -17
  812. data/src/core/ext/xds/xds_health_status.h +5 -25
  813. data/src/core/ext/xds/xds_http_fault_filter.cc +16 -14
  814. data/src/core/ext/xds/xds_http_fault_filter.h +1 -1
  815. data/src/core/ext/xds/xds_http_filters.cc +1 -4
  816. data/src/core/ext/xds/xds_http_filters.h +3 -2
  817. data/src/core/ext/xds/xds_http_rbac_filter.cc +153 -73
  818. data/src/core/ext/xds/xds_http_rbac_filter.h +1 -1
  819. data/src/core/ext/xds/xds_http_stateful_session_filter.cc +16 -16
  820. data/src/core/ext/xds/xds_http_stateful_session_filter.h +1 -1
  821. data/src/core/ext/xds/xds_lb_policy_registry.cc +72 -35
  822. data/src/core/ext/xds/xds_listener.cc +25 -18
  823. data/src/core/ext/xds/xds_listener.h +14 -4
  824. data/src/core/ext/xds/xds_resource_type.h +3 -9
  825. data/src/core/ext/xds/xds_resource_type_impl.h +9 -11
  826. data/src/core/ext/xds/xds_route_config.cc +62 -19
  827. data/src/core/ext/xds/xds_route_config.h +2 -2
  828. data/src/core/ext/xds/xds_server_config_fetcher.cc +53 -28
  829. data/src/core/ext/xds/xds_transport_grpc.cc +14 -3
  830. data/src/core/lib/address_utils/parse_address.cc +63 -1
  831. data/src/core/lib/address_utils/parse_address.h +8 -0
  832. data/src/core/lib/address_utils/sockaddr_utils.cc +46 -1
  833. data/src/core/lib/address_utils/sockaddr_utils.h +2 -2
  834. data/src/core/lib/avl/avl.h +15 -173
  835. data/src/core/lib/backoff/random_early_detection.cc +33 -0
  836. data/src/core/lib/backoff/random_early_detection.h +62 -0
  837. data/src/core/lib/channel/call_finalization.h +1 -1
  838. data/src/core/lib/channel/call_tracer.cc +346 -0
  839. data/src/core/lib/channel/call_tracer.h +140 -39
  840. data/src/core/lib/channel/channel_args.cc +120 -46
  841. data/src/core/lib/channel/channel_args.h +52 -4
  842. data/src/core/lib/channel/channel_trace.cc +16 -12
  843. data/src/core/lib/channel/channelz.cc +163 -135
  844. data/src/core/lib/channel/channelz.h +42 -35
  845. data/src/core/lib/channel/channelz_registry.cc +24 -20
  846. data/src/core/lib/channel/channelz_registry.h +4 -2
  847. data/src/core/lib/channel/connected_channel.cc +545 -1044
  848. data/src/core/lib/channel/context.h +8 -1
  849. data/src/core/lib/channel/promise_based_filter.cc +113 -51
  850. data/src/core/lib/channel/promise_based_filter.h +32 -14
  851. data/src/core/lib/channel/server_call_tracer_filter.cc +110 -0
  852. data/src/core/lib/compression/compression_internal.cc +8 -7
  853. data/src/core/lib/config/config_vars.cc +153 -0
  854. data/src/core/lib/config/config_vars.h +127 -0
  855. data/src/core/lib/config/config_vars_non_generated.cc +51 -0
  856. data/src/core/lib/config/core_configuration.cc +2 -1
  857. data/src/core/lib/config/core_configuration.h +5 -4
  858. data/src/core/lib/config/load_config.cc +79 -0
  859. data/src/core/lib/config/load_config.h +55 -0
  860. data/src/core/lib/debug/event_log.h +1 -1
  861. data/src/core/lib/debug/stats_data.cc +202 -35
  862. data/src/core/lib/debug/stats_data.h +103 -1
  863. data/src/core/lib/debug/trace.cc +35 -61
  864. data/src/core/lib/debug/trace.h +14 -9
  865. data/src/core/lib/event_engine/ares_resolver.cc +721 -0
  866. data/src/core/lib/event_engine/ares_resolver.h +150 -0
  867. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +221 -0
  868. data/src/core/lib/event_engine/cf_engine/cf_engine.h +89 -0
  869. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +357 -0
  870. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +149 -0
  871. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +82 -0
  872. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +241 -0
  873. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +120 -0
  874. data/src/core/lib/event_engine/default_event_engine.cc +13 -1
  875. data/src/core/lib/event_engine/default_event_engine_factory.cc +14 -2
  876. data/src/core/lib/event_engine/event_engine.cc +25 -2
  877. data/src/core/lib/event_engine/forkable.cc +62 -43
  878. data/src/core/lib/event_engine/forkable.h +15 -0
  879. data/src/core/lib/event_engine/grpc_polled_fd.h +73 -0
  880. data/src/core/lib/event_engine/handle_containers.h +5 -24
  881. data/src/core/lib/event_engine/memory_allocator_factory.h +47 -0
  882. data/src/core/lib/event_engine/nameser.h +102 -0
  883. data/src/core/lib/event_engine/poller.h +2 -2
  884. data/src/core/lib/event_engine/posix.h +4 -0
  885. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +5 -7
  886. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +29 -13
  887. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +10 -1
  888. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +3 -9
  889. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +197 -0
  890. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -18
  891. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +76 -29
  892. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +20 -9
  893. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +96 -52
  894. data/src/core/lib/event_engine/posix_engine/posix_engine.h +22 -14
  895. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +75 -33
  896. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +12 -8
  897. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +4 -2
  898. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +76 -21
  899. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +9 -3
  900. data/src/core/lib/event_engine/posix_engine/timer.h +10 -37
  901. data/src/core/lib/event_engine/posix_engine/timer_manager.h +1 -1
  902. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +2 -0
  903. data/src/core/lib/event_engine/resolved_address.cc +2 -1
  904. data/src/core/lib/event_engine/shim.cc +9 -1
  905. data/src/core/lib/event_engine/tcp_socket_utils.cc +67 -7
  906. data/src/core/lib/event_engine/tcp_socket_utils.h +3 -0
  907. data/src/core/lib/event_engine/thread_pool/thread_count.cc +58 -0
  908. data/src/core/lib/event_engine/thread_pool/thread_count.h +176 -0
  909. data/src/core/lib/event_engine/thread_pool/thread_pool.h +50 -0
  910. data/src/core/lib/event_engine/{executor/executor.h → thread_pool/thread_pool_factory.cc} +12 -15
  911. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +523 -0
  912. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +223 -0
  913. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +157 -0
  914. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +104 -0
  915. data/src/core/lib/event_engine/trace.cc +1 -0
  916. data/src/core/lib/event_engine/trace.h +6 -0
  917. data/src/core/lib/event_engine/windows/iocp.cc +4 -3
  918. data/src/core/lib/event_engine/windows/iocp.h +3 -3
  919. data/src/core/lib/event_engine/windows/win_socket.cc +6 -7
  920. data/src/core/lib/event_engine/windows/win_socket.h +4 -4
  921. data/src/core/lib/event_engine/windows/windows_endpoint.cc +153 -105
  922. data/src/core/lib/event_engine/windows/windows_endpoint.h +30 -10
  923. data/src/core/lib/event_engine/windows/windows_engine.cc +57 -33
  924. data/src/core/lib/event_engine/windows/windows_engine.h +16 -19
  925. data/src/core/lib/event_engine/windows/windows_listener.cc +370 -0
  926. data/src/core/lib/event_engine/windows/windows_listener.h +156 -0
  927. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +63 -0
  928. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +71 -0
  929. data/src/core/lib/event_engine/work_queue/work_queue.h +62 -0
  930. data/src/core/lib/experiments/config.cc +122 -38
  931. data/src/core/lib/experiments/config.h +33 -5
  932. data/src/core/lib/experiments/experiments.cc +680 -21
  933. data/src/core/lib/experiments/experiments.h +348 -25
  934. data/src/core/lib/gpr/log.cc +15 -28
  935. data/src/core/lib/gpr/log_internal.h +55 -0
  936. data/src/core/lib/gpr/{time_posix.cc → posix/time.cc} +5 -0
  937. data/src/core/lib/gprpp/crash.cc +10 -0
  938. data/src/core/lib/gprpp/crash.h +3 -0
  939. data/src/core/lib/gprpp/dual_ref_counted.h +9 -9
  940. data/src/core/lib/gprpp/fork.cc +16 -23
  941. data/src/core/lib/gprpp/fork.h +7 -6
  942. data/src/core/lib/gprpp/if_list.h +4530 -0
  943. data/src/core/lib/gprpp/manual_constructor.h +1 -2
  944. data/src/core/lib/gprpp/no_destruct.h +1 -1
  945. data/src/core/lib/gprpp/orphanable.h +7 -6
  946. data/src/core/lib/gprpp/per_cpu.cc +35 -0
  947. data/src/core/lib/gprpp/per_cpu.h +64 -6
  948. data/src/core/lib/gprpp/{thd_posix.cc → posix/thd.cc} +49 -37
  949. data/src/core/lib/gprpp/ref_counted.h +42 -41
  950. data/src/core/lib/gprpp/ref_counted_ptr.h +63 -0
  951. data/src/core/lib/gprpp/ref_counted_string.cc +44 -0
  952. data/src/core/lib/gprpp/ref_counted_string.h +146 -0
  953. data/src/core/lib/gprpp/sorted_pack.h +3 -12
  954. data/src/core/lib/gprpp/status_helper.cc +2 -2
  955. data/src/core/lib/gprpp/status_helper.h +16 -15
  956. data/src/core/lib/gprpp/thd.h +16 -0
  957. data/src/core/lib/gprpp/time.cc +2 -0
  958. data/src/core/lib/gprpp/time.h +16 -4
  959. data/src/core/lib/gprpp/{global_config_custom.h → type_list.h} +17 -14
  960. data/src/core/lib/gprpp/validation_errors.cc +8 -3
  961. data/src/core/lib/gprpp/validation_errors.h +16 -9
  962. data/src/core/lib/gprpp/{thd_windows.cc → windows/thd.cc} +2 -2
  963. data/src/core/lib/gprpp/work_serializer.cc +320 -12
  964. data/src/core/lib/gprpp/work_serializer.h +30 -9
  965. data/src/core/lib/http/httpcli.h +6 -9
  966. data/src/core/lib/http/httpcli_security_connector.cc +1 -0
  967. data/src/core/lib/iomgr/buffer_list.cc +2 -0
  968. data/src/core/lib/iomgr/buffer_list.h +0 -1
  969. data/src/core/lib/iomgr/call_combiner.h +2 -2
  970. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  971. data/src/core/lib/iomgr/combiner.cc +57 -15
  972. data/src/core/lib/iomgr/combiner.h +8 -3
  973. data/src/core/lib/iomgr/endpoint_cfstream.cc +14 -10
  974. data/src/core/lib/iomgr/endpoint_pair.h +2 -2
  975. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -2
  976. data/src/core/lib/iomgr/endpoint_pair_windows.cc +1 -1
  977. data/src/core/lib/iomgr/error.cc +32 -2
  978. data/src/core/lib/iomgr/error.h +9 -10
  979. data/src/core/lib/iomgr/ev_apple.cc +12 -12
  980. data/src/core/lib/iomgr/ev_epoll1_linux.cc +15 -10
  981. data/src/core/lib/iomgr/ev_poll_posix.cc +6 -5
  982. data/src/core/lib/iomgr/ev_posix.cc +13 -53
  983. data/src/core/lib/iomgr/ev_posix.h +0 -3
  984. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +125 -101
  985. data/src/core/lib/iomgr/exec_ctx.cc +12 -0
  986. data/src/core/lib/iomgr/exec_ctx.h +66 -19
  987. data/src/core/lib/iomgr/iocp_windows.cc +24 -3
  988. data/src/core/lib/iomgr/iocp_windows.h +11 -0
  989. data/src/core/lib/iomgr/iomgr.cc +4 -8
  990. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -1
  991. data/src/core/lib/iomgr/iomgr_windows.cc +8 -2
  992. data/src/core/lib/iomgr/polling_entity.cc +10 -0
  993. data/src/core/lib/iomgr/polling_entity.h +2 -0
  994. data/src/core/lib/iomgr/pollset.h +4 -5
  995. data/src/core/lib/iomgr/pollset_set_windows.cc +9 -9
  996. data/src/core/lib/iomgr/pollset_windows.cc +1 -1
  997. data/src/core/lib/iomgr/port.h +24 -0
  998. data/src/core/lib/iomgr/resolve_address.cc +13 -1
  999. data/src/core/lib/iomgr/resolve_address.h +17 -3
  1000. data/src/core/lib/iomgr/sockaddr_posix.h +7 -0
  1001. data/src/core/lib/iomgr/socket_utils_common_posix.cc +49 -5
  1002. data/src/core/lib/iomgr/socket_utils_posix.cc +5 -0
  1003. data/src/core/lib/iomgr/socket_utils_posix.h +9 -0
  1004. data/src/core/lib/iomgr/socket_windows.cc +61 -7
  1005. data/src/core/lib/iomgr/socket_windows.h +9 -2
  1006. data/src/core/lib/iomgr/tcp_client_cfstream.cc +14 -3
  1007. data/src/core/lib/iomgr/tcp_client_posix.cc +8 -1
  1008. data/src/core/lib/iomgr/tcp_client_windows.cc +2 -2
  1009. data/src/core/lib/iomgr/tcp_posix.cc +41 -22
  1010. data/src/core/lib/iomgr/tcp_server_posix.cc +186 -133
  1011. data/src/core/lib/iomgr/tcp_server_utils_posix.h +13 -1
  1012. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +26 -2
  1013. data/src/core/lib/iomgr/tcp_server_windows.cc +176 -9
  1014. data/src/core/lib/iomgr/tcp_windows.cc +13 -11
  1015. data/src/core/lib/iomgr/timer_generic.cc +17 -16
  1016. data/src/core/lib/iomgr/vsock.cc +59 -0
  1017. data/src/core/lib/iomgr/vsock.h +38 -0
  1018. data/src/core/lib/iomgr/wakeup_fd_posix.h +3 -6
  1019. data/src/core/lib/json/json.h +2 -218
  1020. data/src/core/lib/json/json_object_loader.cc +24 -25
  1021. data/src/core/lib/json/json_object_loader.h +30 -18
  1022. data/src/core/lib/json/json_reader.cc +69 -42
  1023. data/src/core/{ext/filters/client_channel/lb_call_state_internal.h → lib/json/json_reader.h} +7 -12
  1024. data/src/core/lib/json/json_util.cc +10 -15
  1025. data/src/core/lib/json/json_util.h +5 -4
  1026. data/src/core/lib/json/json_writer.cc +24 -25
  1027. data/src/core/lib/{security/security_connector/ssl_utils_config.h → json/json_writer.h} +14 -10
  1028. data/src/core/lib/load_balancing/delegating_helper.h +115 -0
  1029. data/src/core/lib/load_balancing/lb_policy.cc +9 -13
  1030. data/src/core/lib/load_balancing/lb_policy.h +47 -11
  1031. data/src/core/lib/load_balancing/lb_policy_registry.cc +9 -8
  1032. data/src/core/lib/load_balancing/subchannel_interface.h +6 -0
  1033. data/src/core/lib/matchers/matchers.cc +3 -4
  1034. data/src/core/lib/matchers/matchers.h +2 -1
  1035. data/src/core/lib/promise/activity.cc +27 -6
  1036. data/src/core/lib/promise/activity.h +71 -24
  1037. data/src/core/lib/promise/arena_promise.h +5 -1
  1038. data/src/core/lib/promise/cancel_callback.h +77 -0
  1039. data/src/core/lib/promise/detail/basic_seq.h +1 -372
  1040. data/src/core/lib/promise/detail/promise_factory.h +5 -1
  1041. data/src/core/lib/promise/detail/seq_state.h +2494 -0
  1042. data/src/core/lib/promise/for_each.h +176 -0
  1043. data/src/core/lib/promise/if.h +9 -0
  1044. data/src/core/lib/promise/interceptor_list.h +23 -2
  1045. data/src/core/lib/promise/latch.h +90 -3
  1046. data/src/core/lib/promise/loop.h +19 -12
  1047. data/src/core/lib/promise/map.h +7 -0
  1048. data/src/core/lib/promise/party.cc +304 -0
  1049. data/src/core/lib/promise/party.h +508 -0
  1050. data/src/core/lib/promise/pipe.h +213 -59
  1051. data/src/core/lib/promise/poll.h +52 -6
  1052. data/src/core/lib/promise/prioritized_race.h +95 -0
  1053. data/src/core/lib/promise/promise.h +2 -2
  1054. data/src/core/lib/promise/seq.h +19 -2
  1055. data/src/core/lib/promise/sleep.cc +2 -1
  1056. data/src/core/lib/promise/sleep.h +5 -10
  1057. data/src/core/lib/promise/try_seq.h +34 -2
  1058. data/src/core/lib/resolver/resolver_factory.h +3 -2
  1059. data/src/core/lib/resolver/server_address.cc +9 -102
  1060. data/src/core/lib/resolver/server_address.h +11 -70
  1061. data/src/core/lib/resource_quota/api.cc +1 -0
  1062. data/src/core/lib/resource_quota/arena.cc +21 -3
  1063. data/src/core/lib/resource_quota/arena.h +158 -10
  1064. data/src/core/lib/resource_quota/memory_quota.cc +66 -11
  1065. data/src/core/lib/resource_quota/memory_quota.h +6 -4
  1066. data/src/core/lib/resource_quota/resource_quota.h +1 -0
  1067. data/src/core/lib/security/authorization/audit_logging.cc +98 -0
  1068. data/src/core/lib/security/authorization/audit_logging.h +73 -0
  1069. data/src/core/lib/security/authorization/authorization_policy_provider.h +1 -1
  1070. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +47 -2
  1071. data/src/core/lib/security/authorization/grpc_authorization_engine.h +18 -1
  1072. data/src/core/lib/security/authorization/rbac_policy.cc +36 -4
  1073. data/src/core/lib/security/authorization/rbac_policy.h +19 -2
  1074. data/src/core/lib/security/authorization/stdout_logger.cc +75 -0
  1075. data/src/core/lib/security/authorization/stdout_logger.h +61 -0
  1076. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +8 -4
  1077. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +8 -18
  1078. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +14 -8
  1079. data/src/core/lib/security/credentials/channel_creds_registry.h +51 -27
  1080. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +169 -9
  1081. data/src/core/lib/security/credentials/composite/composite_credentials.cc +1 -1
  1082. data/src/core/lib/security/credentials/composite/composite_credentials.h +3 -1
  1083. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +66 -84
  1084. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -0
  1085. data/src/core/lib/security/credentials/external/aws_request_signer.cc +8 -0
  1086. data/src/core/lib/security/credentials/external/external_account_credentials.cc +104 -65
  1087. data/src/core/lib/security/credentials/external/external_account_credentials.h +6 -0
  1088. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +23 -21
  1089. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +29 -27
  1090. data/src/core/lib/security/credentials/fake/fake_credentials.cc +30 -38
  1091. data/src/core/lib/security/credentials/fake/fake_credentials.h +28 -0
  1092. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +6 -61
  1093. data/src/core/lib/security/credentials/jwt/json_token.cc +36 -16
  1094. data/src/core/lib/security/credentials/jwt/json_token.h +4 -0
  1095. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +10 -5
  1096. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +82 -38
  1097. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +28 -21
  1098. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -1
  1099. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +116 -9
  1100. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +14 -0
  1101. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +86 -0
  1102. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +11 -53
  1103. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +2 -0
  1104. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +2 -0
  1105. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +8 -0
  1106. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +5 -1
  1107. data/src/core/lib/security/credentials/tls/tls_credentials.cc +2 -1
  1108. data/src/core/lib/security/credentials/tls/tls_credentials.h +3 -1
  1109. data/src/core/lib/security/credentials/xds/xds_credentials.cc +1 -0
  1110. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +2 -5
  1111. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -0
  1112. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +5 -9
  1113. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +7 -57
  1114. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +1 -1
  1115. data/src/core/lib/security/security_connector/ssl_utils.cc +14 -26
  1116. data/src/core/lib/security/security_connector/ssl_utils.h +1 -1
  1117. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +15 -15
  1118. data/src/core/lib/security/transport/client_auth_filter.cc +8 -5
  1119. data/src/core/lib/security/transport/secure_endpoint.cc +4 -2
  1120. data/src/core/lib/security/transport/security_handshaker.cc +1 -0
  1121. data/src/core/lib/security/transport/server_auth_filter.cc +21 -1
  1122. data/src/core/lib/security/util/json_util.cc +6 -5
  1123. data/src/core/lib/service_config/service_config_call_data.h +54 -20
  1124. data/src/core/lib/service_config/service_config_impl.cc +13 -6
  1125. data/src/core/lib/slice/slice.cc +1 -1
  1126. data/src/core/lib/slice/slice.h +24 -0
  1127. data/src/core/lib/slice/slice_buffer.cc +15 -0
  1128. data/src/core/lib/slice/slice_buffer.h +16 -4
  1129. data/src/core/lib/slice/slice_refcount.h +1 -1
  1130. data/src/core/lib/surface/builtins.cc +2 -0
  1131. data/src/core/lib/surface/call.cc +1108 -1062
  1132. data/src/core/lib/surface/call.h +15 -5
  1133. data/src/core/lib/surface/channel.cc +8 -4
  1134. data/src/core/lib/surface/channel_init.h +3 -2
  1135. data/src/core/lib/surface/completion_queue.cc +18 -3
  1136. data/src/core/lib/surface/init.cc +1 -0
  1137. data/src/core/lib/surface/lame_client.cc +1 -0
  1138. data/src/core/lib/surface/server.cc +151 -80
  1139. data/src/core/lib/surface/server.h +19 -21
  1140. data/src/core/lib/surface/validate_metadata.cc +57 -41
  1141. data/src/core/lib/surface/validate_metadata.h +19 -0
  1142. data/src/core/lib/surface/version.cc +2 -2
  1143. data/src/core/lib/transport/batch_builder.cc +180 -0
  1144. data/src/core/lib/transport/batch_builder.h +480 -0
  1145. data/src/core/lib/transport/bdp_estimator.cc +7 -7
  1146. data/src/core/lib/transport/bdp_estimator.h +10 -6
  1147. data/src/core/lib/transport/custom_metadata.h +30 -0
  1148. data/src/core/lib/transport/metadata_batch.cc +22 -13
  1149. data/src/core/lib/transport/metadata_batch.h +239 -79
  1150. data/src/core/lib/transport/metadata_compression_traits.h +67 -0
  1151. data/src/core/lib/transport/parsed_metadata.h +50 -28
  1152. data/src/core/lib/transport/simple_slice_based_metadata.h +54 -0
  1153. data/src/core/lib/transport/timeout_encoding.cc +6 -1
  1154. data/src/core/lib/transport/transport.cc +30 -2
  1155. data/src/core/lib/transport/transport.h +100 -25
  1156. data/src/core/lib/transport/transport_impl.h +7 -0
  1157. data/src/core/lib/transport/transport_op_string.cc +52 -42
  1158. data/src/core/plugin_registry/grpc_plugin_registry.cc +4 -8
  1159. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -0
  1160. data/src/core/tsi/alts/crypt/aes_gcm.cc +27 -2
  1161. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +1 -0
  1162. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +21 -4
  1163. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +5 -0
  1164. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
  1165. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +4 -6
  1166. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +1 -2
  1167. data/src/core/tsi/ssl_transport_security.cc +55 -11
  1168. data/src/core/tsi/ssl_transport_security.h +17 -1
  1169. data/src/ruby/bin/math_pb.rb +24 -18
  1170. data/src/ruby/ext/grpc/extconf.rb +27 -27
  1171. data/src/ruby/ext/grpc/rb_call.c +62 -39
  1172. data/src/ruby/ext/grpc/rb_call_credentials.c +0 -1
  1173. data/src/ruby/ext/grpc/rb_channel.c +109 -84
  1174. data/src/ruby/ext/grpc/rb_channel.h +1 -0
  1175. data/src/ruby/ext/grpc/rb_channel_args.c +18 -2
  1176. data/src/ruby/ext/grpc/rb_channel_args.h +4 -0
  1177. data/src/ruby/ext/grpc/rb_channel_credentials.c +0 -1
  1178. data/src/ruby/ext/grpc/rb_compression_options.c +0 -1
  1179. data/src/ruby/ext/grpc/rb_event_thread.c +22 -6
  1180. data/src/ruby/ext/grpc/rb_event_thread.h +1 -0
  1181. data/src/ruby/ext/grpc/rb_grpc.c +192 -30
  1182. data/src/ruby/ext/grpc/rb_grpc.h +8 -2
  1183. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -0
  1184. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +3 -0
  1185. data/src/ruby/ext/grpc/rb_server.c +62 -45
  1186. data/src/ruby/ext/grpc/rb_server_credentials.c +0 -1
  1187. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +0 -1
  1188. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +0 -1
  1189. data/src/ruby/lib/grpc/generic/active_call.rb +9 -14
  1190. data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -0
  1191. data/src/ruby/lib/grpc/version.rb +1 -1
  1192. data/src/ruby/pb/grpc/health/v1/health_pb.rb +24 -13
  1193. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +24 -3
  1194. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +28 -111
  1195. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +25 -2
  1196. data/src/ruby/pb/test/client.rb +16 -0
  1197. data/src/ruby/spec/generic/rpc_server_spec.rb +3 -3
  1198. data/third_party/abseil-cpp/absl/algorithm/container.h +3 -2
  1199. data/third_party/abseil-cpp/absl/base/attributes.h +58 -5
  1200. data/third_party/abseil-cpp/absl/base/call_once.h +1 -1
  1201. data/third_party/abseil-cpp/absl/base/casts.h +8 -8
  1202. data/third_party/abseil-cpp/absl/base/config.h +88 -105
  1203. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +26 -1
  1204. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +2 -2
  1205. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +50 -39
  1206. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +2 -1
  1207. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +17 -18
  1208. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +32 -3
  1209. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +24 -4
  1210. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +31 -73
  1211. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +9 -8
  1212. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +11 -11
  1213. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.cc +23 -32
  1214. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +2 -3
  1215. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1216. data/third_party/abseil-cpp/absl/base/policy_checks.h +3 -3
  1217. data/third_party/abseil-cpp/absl/base/prefetch.h +198 -0
  1218. data/third_party/abseil-cpp/absl/container/fixed_array.h +54 -29
  1219. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +5 -1
  1220. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +6 -2
  1221. data/third_party/abseil-cpp/absl/container/inlined_vector.h +167 -79
  1222. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +1 -1
  1223. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +3 -21
  1224. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +1 -1
  1225. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +46 -0
  1226. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +2 -0
  1227. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +85 -26
  1228. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +35 -18
  1229. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +70 -29
  1230. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +437 -236
  1231. data/third_party/abseil-cpp/absl/crc/crc32c.h +8 -1
  1232. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.cc +14 -8
  1233. data/third_party/abseil-cpp/absl/crc/internal/crc.cc +4 -35
  1234. data/third_party/abseil-cpp/absl/crc/internal/crc.h +2 -10
  1235. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +1 -1
  1236. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +1 -1
  1237. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.h +4 -4
  1238. data/third_party/abseil-cpp/absl/crc/internal/crc_internal.h +8 -10
  1239. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_64.cc +17 -19
  1240. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +8 -8
  1241. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +2 -1
  1242. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +59 -23
  1243. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +1 -1
  1244. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +1 -1
  1245. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +1 -1
  1246. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +43 -19
  1247. data/third_party/abseil-cpp/absl/debugging/symbolize_emscripten.inc +3 -0
  1248. data/third_party/abseil-cpp/absl/flags/commandlineflag.cc +34 -0
  1249. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +200 -0
  1250. data/third_party/abseil-cpp/absl/flags/config.h +68 -0
  1251. data/third_party/abseil-cpp/absl/flags/declare.h +73 -0
  1252. data/third_party/abseil-cpp/absl/flags/flag.cc +38 -0
  1253. data/third_party/abseil-cpp/absl/flags/flag.h +310 -0
  1254. data/third_party/abseil-cpp/absl/flags/internal/commandlineflag.cc +26 -0
  1255. data/third_party/abseil-cpp/absl/flags/internal/commandlineflag.h +68 -0
  1256. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +615 -0
  1257. data/third_party/abseil-cpp/absl/flags/internal/flag.h +801 -0
  1258. data/third_party/abseil-cpp/absl/flags/internal/flag_msvc.inc +116 -0
  1259. data/third_party/abseil-cpp/absl/flags/internal/path_util.h +62 -0
  1260. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +65 -0
  1261. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.h +61 -0
  1262. data/third_party/abseil-cpp/absl/flags/internal/program_name.cc +60 -0
  1263. data/third_party/abseil-cpp/absl/flags/internal/program_name.h +50 -0
  1264. data/third_party/abseil-cpp/absl/flags/internal/registry.h +97 -0
  1265. data/third_party/abseil-cpp/absl/flags/internal/sequence_lock.h +187 -0
  1266. data/third_party/abseil-cpp/absl/flags/marshalling.cc +282 -0
  1267. data/third_party/abseil-cpp/absl/flags/marshalling.h +361 -0
  1268. data/third_party/abseil-cpp/absl/flags/reflection.cc +354 -0
  1269. data/third_party/abseil-cpp/absl/flags/reflection.h +90 -0
  1270. data/third_party/abseil-cpp/absl/flags/usage_config.cc +165 -0
  1271. data/third_party/abseil-cpp/absl/flags/usage_config.h +135 -0
  1272. data/third_party/abseil-cpp/absl/functional/any_invocable.h +9 -1
  1273. data/third_party/abseil-cpp/absl/functional/bind_front.h +1 -1
  1274. data/third_party/abseil-cpp/absl/functional/function_ref.h +3 -3
  1275. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +37 -24
  1276. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +19 -9
  1277. data/third_party/abseil-cpp/absl/hash/hash.h +7 -4
  1278. data/third_party/abseil-cpp/absl/hash/internal/hash.h +38 -15
  1279. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +6 -0
  1280. data/third_party/abseil-cpp/absl/meta/type_traits.h +48 -373
  1281. data/third_party/abseil-cpp/absl/numeric/bits.h +4 -4
  1282. data/third_party/abseil-cpp/absl/numeric/int128.cc +20 -8
  1283. data/third_party/abseil-cpp/absl/numeric/int128.h +36 -39
  1284. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +0 -3
  1285. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +47 -30
  1286. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +185 -0
  1287. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +4 -3
  1288. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +1 -1
  1289. data/third_party/abseil-cpp/absl/random/internal/platform.h +1 -1
  1290. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +4 -0
  1291. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +1 -1
  1292. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.cc +1 -1
  1293. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +1 -1
  1294. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +4 -0
  1295. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +12 -24
  1296. data/third_party/abseil-cpp/absl/status/status.cc +11 -7
  1297. data/third_party/abseil-cpp/absl/status/status.h +11 -2
  1298. data/third_party/abseil-cpp/absl/status/statusor.h +22 -8
  1299. data/third_party/abseil-cpp/absl/strings/ascii.cc +54 -6
  1300. data/third_party/abseil-cpp/absl/strings/charconv.cc +21 -4
  1301. data/third_party/abseil-cpp/absl/strings/charconv.h +2 -2
  1302. data/third_party/abseil-cpp/absl/strings/cord.cc +1 -2
  1303. data/third_party/abseil-cpp/absl/strings/cord.h +32 -5
  1304. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +23 -1
  1305. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +18 -0
  1306. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +2 -5
  1307. data/third_party/abseil-cpp/absl/strings/escaping.cc +10 -32
  1308. data/third_party/abseil-cpp/absl/strings/escaping.h +1 -1
  1309. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +2 -4
  1310. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +3 -3
  1311. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -1
  1312. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +27 -21
  1313. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +13 -4
  1314. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +8 -0
  1315. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +5 -3
  1316. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.h +4 -7
  1317. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +8 -0
  1318. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +2 -2
  1319. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +46 -20
  1320. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.h +1 -34
  1321. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +2 -1
  1322. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +23 -0
  1323. data/third_party/abseil-cpp/absl/strings/internal/escaping.h +1 -0
  1324. data/third_party/abseil-cpp/absl/strings/internal/memutil.cc +2 -77
  1325. data/third_party/abseil-cpp/absl/strings/internal/memutil.h +4 -112
  1326. data/third_party/abseil-cpp/absl/strings/internal/stl_type_traits.h +1 -1
  1327. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +10 -31
  1328. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +8 -8
  1329. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +5 -20
  1330. data/third_party/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +1 -0
  1331. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +1 -1
  1332. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +9 -9
  1333. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +56 -6
  1334. data/third_party/abseil-cpp/absl/strings/match.cc +87 -0
  1335. data/third_party/abseil-cpp/absl/strings/match.h +19 -0
  1336. data/third_party/abseil-cpp/absl/strings/numbers.cc +154 -122
  1337. data/third_party/abseil-cpp/absl/strings/numbers.h +1 -6
  1338. data/third_party/abseil-cpp/absl/strings/str_cat.cc +7 -50
  1339. data/third_party/abseil-cpp/absl/strings/str_cat.h +83 -15
  1340. data/third_party/abseil-cpp/absl/strings/str_format.h +6 -3
  1341. data/third_party/abseil-cpp/absl/strings/str_split.cc +9 -6
  1342. data/third_party/abseil-cpp/absl/strings/string_view.cc +26 -4
  1343. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +5 -0
  1344. data/third_party/abseil-cpp/absl/synchronization/internal/futex.h +63 -43
  1345. data/third_party/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +111 -0
  1346. data/third_party/abseil-cpp/absl/synchronization/internal/futex_waiter.h +63 -0
  1347. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -7
  1348. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +225 -0
  1349. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +122 -114
  1350. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +12 -8
  1351. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +10 -1
  1352. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +167 -0
  1353. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.h +60 -0
  1354. data/third_party/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +122 -0
  1355. data/third_party/abseil-cpp/absl/synchronization/internal/sem_waiter.h +65 -0
  1356. data/third_party/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +91 -0
  1357. data/third_party/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.h +56 -0
  1358. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +19 -113
  1359. data/third_party/abseil-cpp/absl/synchronization/internal/waiter_base.cc +42 -0
  1360. data/third_party/abseil-cpp/absl/synchronization/internal/waiter_base.h +90 -0
  1361. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +151 -0
  1362. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.h +70 -0
  1363. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +407 -411
  1364. data/third_party/abseil-cpp/absl/synchronization/mutex.h +152 -118
  1365. data/third_party/abseil-cpp/absl/time/clock.cc +6 -7
  1366. data/third_party/abseil-cpp/absl/time/duration.cc +24 -26
  1367. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +1 -0
  1368. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +1 -1
  1369. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +3 -3
  1370. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +8 -6
  1371. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +6 -3
  1372. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +4 -2
  1373. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +4 -0
  1374. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +322 -295
  1375. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +8 -17
  1376. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +51 -33
  1377. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +7 -2
  1378. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +128 -2
  1379. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +1 -1
  1380. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +5 -1
  1381. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +34 -34
  1382. data/third_party/abseil-cpp/absl/time/time.cc +9 -2
  1383. data/third_party/abseil-cpp/absl/time/time.h +115 -15
  1384. data/third_party/abseil-cpp/absl/types/internal/optional.h +0 -52
  1385. data/third_party/abseil-cpp/absl/types/internal/span.h +2 -2
  1386. data/third_party/abseil-cpp/absl/types/internal/variant.h +2 -2
  1387. data/third_party/abseil-cpp/absl/types/optional.h +15 -13
  1388. data/third_party/abseil-cpp/absl/types/span.h +1 -2
  1389. data/third_party/boringssl-with-bazel/err_data.c +731 -714
  1390. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +177 -177
  1391. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +28 -55
  1392. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +21 -23
  1393. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +20 -23
  1394. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +70 -185
  1395. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +18 -21
  1396. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +356 -311
  1397. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +177 -196
  1398. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +146 -210
  1399. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +6 -9
  1400. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +346 -526
  1401. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +111 -132
  1402. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +158 -111
  1403. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +93 -60
  1404. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +101 -182
  1405. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +242 -305
  1406. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +41 -18
  1407. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +30 -33
  1408. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +36 -33
  1409. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +29 -26
  1410. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +135 -90
  1411. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.c +230 -0
  1412. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +797 -793
  1413. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +529 -526
  1414. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +114 -135
  1415. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +201 -207
  1416. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +21 -26
  1417. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +55 -68
  1418. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +2 -4
  1419. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +20 -14
  1420. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +42 -57
  1421. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +22 -16
  1422. data/third_party/boringssl-with-bazel/src/crypto/{asn1/a_print.c → bio/errno.c} +29 -20
  1423. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +18 -58
  1424. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +39 -31
  1425. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +16 -6
  1426. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +5 -5
  1427. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -13
  1428. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +7 -10
  1429. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +13 -2
  1430. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +40 -27
  1431. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +10 -23
  1432. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +2 -6
  1433. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +2 -1
  1434. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +29 -28
  1435. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +161 -201
  1436. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +255 -40
  1437. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +2 -2
  1438. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +19 -3
  1439. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +8 -1
  1440. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +4 -4
  1441. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +9 -8
  1442. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +37 -75
  1443. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +8 -10
  1444. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/cipher → cipher_extra}/e_des.c +100 -78
  1445. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +1 -0
  1446. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +1 -0
  1447. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +2 -0
  1448. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +34 -37
  1449. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +22 -11
  1450. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +189 -13
  1451. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +37 -202
  1452. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +3 -8
  1453. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +20 -0
  1454. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +75 -0
  1455. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-fuchsia.c → cpu_aarch64_fuchsia.c} +8 -8
  1456. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-linux.c → cpu_aarch64_linux.c} +6 -6
  1457. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.c +61 -0
  1458. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.c +93 -0
  1459. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-win.c → cpu_aarch64_win.c} +4 -4
  1460. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.c +54 -0
  1461. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm-linux.c → cpu_arm_linux.c} +11 -92
  1462. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm-linux.h → cpu_arm_linux.h} +0 -38
  1463. data/third_party/boringssl-with-bazel/src/crypto/{cpu-intel.c → cpu_intel.c} +1 -2
  1464. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +25 -20
  1465. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +71 -77
  1466. data/third_party/boringssl-with-bazel/src/crypto/{cpu-ppc64le.c → curve25519/curve25519_64_adx.c} +3 -23
  1467. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +2834 -7442
  1468. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +26 -8
  1469. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +17 -32
  1470. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/des → des}/des.c +232 -232
  1471. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/des → des}/internal.h +1 -1
  1472. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +5 -0
  1473. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +237 -29
  1474. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -3
  1475. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +43 -16
  1476. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +37 -7
  1477. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +23 -3
  1478. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +118 -105
  1479. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +4 -3
  1480. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +234 -111
  1481. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +29 -7
  1482. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +1 -1
  1483. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +2 -4
  1484. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +106 -81
  1485. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +80 -23
  1486. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +3 -3
  1487. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +25 -23
  1488. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +43 -9
  1489. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +75 -44
  1490. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +21 -29
  1491. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +99 -52
  1492. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +7 -8
  1493. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +26 -23
  1494. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.c +233 -0
  1495. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +6 -6
  1496. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +42 -25
  1497. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +4 -5
  1498. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +35 -47
  1499. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +3 -3
  1500. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +138 -246
  1501. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +2 -4
  1502. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +15 -10
  1503. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +47 -71
  1504. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +0 -2
  1505. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c +13 -14
  1506. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +3 -13
  1507. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c +13 -7
  1508. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +9 -7
  1509. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +37 -28
  1510. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +16 -26
  1511. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +88 -60
  1512. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c +4 -3
  1513. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +0 -2
  1514. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +13 -6
  1515. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +1 -1
  1516. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +99 -113
  1517. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +5 -7
  1518. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +5 -3
  1519. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +112 -168
  1520. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +98 -37
  1521. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +28 -24
  1522. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +55 -20
  1523. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +4 -5
  1524. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +13 -0
  1525. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +13 -5
  1526. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +25 -114
  1527. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +19 -15
  1528. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c +15 -16
  1529. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +22 -21
  1530. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c +3 -0
  1531. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +79 -19
  1532. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +102 -99
  1533. data/third_party/boringssl-with-bazel/src/crypto/{cipher_extra → fipsmodule/cipher}/e_aesccm.c +52 -46
  1534. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +39 -0
  1535. data/third_party/boringssl-with-bazel/src/crypto/{cmac → fipsmodule/cmac}/cmac.c +55 -11
  1536. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +5 -6
  1537. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +39 -11
  1538. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +62 -25
  1539. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +65 -0
  1540. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +5 -3
  1541. data/third_party/boringssl-with-bazel/src/crypto/{evp → fipsmodule/digestsign}/digestsign.c +51 -15
  1542. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/builtin_curves.h +277 -0
  1543. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +226 -450
  1544. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +95 -21
  1545. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +36 -69
  1546. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +17 -13
  1547. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +139 -155
  1548. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +71 -40
  1549. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +60 -78
  1550. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64-table.h → p256-nistz-table.h} +1 -1
  1551. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64.c → p256-nistz.c} +87 -83
  1552. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64.h → p256-nistz.h} +5 -13
  1553. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +71 -62
  1554. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +1 -1
  1555. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +24 -30
  1556. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +21 -42
  1557. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +33 -34
  1558. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +16 -17
  1559. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +9 -1
  1560. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +53 -19
  1561. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +6 -0
  1562. data/third_party/boringssl-with-bazel/src/crypto/{hkdf → fipsmodule/hkdf}/hkdf.c +2 -2
  1563. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c +52 -24
  1564. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +9 -23
  1565. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +1 -4
  1566. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +3 -8
  1567. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +170 -160
  1568. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +12 -14
  1569. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +69 -61
  1570. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +2 -12
  1571. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +27 -28
  1572. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c +31 -13
  1573. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +56 -34
  1574. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +3 -2
  1575. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/getrandom_fillin.h +2 -2
  1576. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +30 -45
  1577. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +111 -78
  1578. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +12 -85
  1579. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +0 -1
  1580. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +98 -16
  1581. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +42 -314
  1582. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +244 -139
  1583. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +175 -255
  1584. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +41 -0
  1585. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +617 -427
  1586. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +89 -0
  1587. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +331 -0
  1588. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +3 -12
  1589. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +2 -0
  1590. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +12 -8
  1591. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +14 -12
  1592. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +8 -0
  1593. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +52 -6
  1594. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +199 -18
  1595. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +65 -29
  1596. data/third_party/boringssl-with-bazel/src/crypto/internal.h +568 -84
  1597. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +91 -0
  1598. data/third_party/boringssl-with-bazel/src/crypto/kyber/keccak.c +204 -0
  1599. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +834 -0
  1600. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +13 -1
  1601. data/third_party/boringssl-with-bazel/src/crypto/mem.c +219 -13
  1602. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +43 -52
  1603. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +9 -4
  1604. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +81 -90
  1605. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +150 -245
  1606. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +633 -613
  1607. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +17 -17
  1608. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +142 -149
  1609. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +99 -131
  1610. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -1
  1611. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -1
  1612. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -1
  1613. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +3 -3
  1614. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +3 -3
  1615. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +7 -10
  1616. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +44 -71
  1617. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +31 -38
  1618. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +2 -1
  1619. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +18 -31
  1620. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +2 -0
  1621. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +8 -1
  1622. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +7 -6
  1623. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +6 -12
  1624. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +52 -0
  1625. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/{fuchsia.c → ios.c} +8 -8
  1626. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +129 -5
  1627. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm.c → rand_extra/trusty.c} +16 -16
  1628. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +41 -19
  1629. data/third_party/boringssl-with-bazel/src/crypto/{refcount_c11.c → refcount.c} +11 -19
  1630. data/third_party/boringssl-with-bazel/src/crypto/{asn1/a_enum.c → rsa_extra/internal.h} +14 -132
  1631. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +568 -0
  1632. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +8 -11
  1633. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +176 -62
  1634. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -8
  1635. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +12 -44
  1636. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +11 -35
  1637. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +128 -34
  1638. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +428 -147
  1639. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +116 -284
  1640. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +686 -161
  1641. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +22 -24
  1642. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +63 -55
  1643. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +32 -34
  1644. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +32 -16
  1645. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +465 -704
  1646. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +278 -335
  1647. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +182 -180
  1648. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +11 -15
  1649. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +69 -51
  1650. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +132 -151
  1651. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +790 -0
  1652. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +95 -102
  1653. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +72 -57
  1654. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +12 -10
  1655. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +220 -254
  1656. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +52 -47
  1657. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +3 -4
  1658. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +136 -270
  1659. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +161 -327
  1660. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +38 -36
  1661. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +14 -31
  1662. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +55 -85
  1663. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +526 -616
  1664. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +129 -122
  1665. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +164 -181
  1666. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +132 -132
  1667. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +186 -203
  1668. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +64 -79
  1669. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +171 -160
  1670. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +1863 -2050
  1671. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +380 -480
  1672. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +156 -163
  1673. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +262 -265
  1674. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +40 -15
  1675. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +59 -63
  1676. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +63 -67
  1677. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +114 -144
  1678. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +25 -26
  1679. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +330 -417
  1680. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +8 -7
  1681. data/third_party/boringssl-with-bazel/src/crypto/x509/x_info.c +30 -28
  1682. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +354 -370
  1683. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +37 -32
  1684. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +121 -124
  1685. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +36 -26
  1686. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +3 -4
  1687. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +10 -13
  1688. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +3 -4
  1689. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +419 -261
  1690. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +113 -105
  1691. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +11 -15
  1692. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +79 -171
  1693. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +126 -131
  1694. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akeya.c +3 -4
  1695. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +464 -469
  1696. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bcons.c +56 -54
  1697. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +46 -49
  1698. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +294 -344
  1699. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +342 -365
  1700. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +429 -393
  1701. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +29 -24
  1702. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_extku.c +65 -59
  1703. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +125 -121
  1704. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ia5.c +43 -42
  1705. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +120 -125
  1706. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_int.c +50 -20
  1707. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +227 -265
  1708. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +386 -389
  1709. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ocsp.c +45 -32
  1710. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcons.c +57 -54
  1711. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pmaps.c +63 -67
  1712. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +130 -135
  1713. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +650 -691
  1714. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +90 -75
  1715. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +1063 -1145
  1716. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +13 -11
  1717. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +25 -160
  1718. data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +207 -0
  1719. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +222 -191
  1720. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +26 -78
  1721. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +54 -124
  1722. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +40 -15
  1723. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +1 -4
  1724. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +49 -19
  1725. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +99 -29
  1726. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +6 -0
  1727. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +49 -60
  1728. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +7 -16
  1729. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +16 -200
  1730. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +34 -0
  1731. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +82 -0
  1732. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +36 -31
  1733. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +7 -0
  1734. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +4 -21
  1735. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +67 -7
  1736. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +56 -14
  1737. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +1 -0
  1738. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +33 -5
  1739. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +36 -40
  1740. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +1 -1
  1741. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +7 -0
  1742. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +75 -18
  1743. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +91 -0
  1744. data/third_party/boringssl-with-bazel/src/include/openssl/kyber.h +128 -0
  1745. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +74 -8
  1746. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +7 -3
  1747. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +8 -1
  1748. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +1 -0
  1749. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +11 -18
  1750. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +8 -0
  1751. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +15 -5
  1752. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +97 -65
  1753. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +96 -0
  1754. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +40 -41
  1755. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +400 -157
  1756. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +1 -6
  1757. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +349 -232
  1758. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +201 -0
  1759. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +1 -26
  1760. data/third_party/boringssl-with-bazel/src/include/openssl/time.h +41 -0
  1761. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +22 -7
  1762. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +57 -23
  1763. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +0 -11
  1764. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +2071 -1407
  1765. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +244 -214
  1766. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +2 -2
  1767. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +6 -13
  1768. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +17 -18
  1769. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +4 -5
  1770. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +25 -33
  1771. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +45 -26
  1772. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +72 -99
  1773. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +218 -74
  1774. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +5 -5
  1775. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +53 -34
  1776. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +77 -45
  1777. data/third_party/boringssl-with-bazel/src/ssl/internal.h +204 -132
  1778. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +47 -12
  1779. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +2 -2
  1780. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +91 -75
  1781. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +8 -10
  1782. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +47 -69
  1783. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +1 -0
  1784. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +5 -9
  1785. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +239 -242
  1786. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +78 -101
  1787. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +126 -155
  1788. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +358 -48
  1789. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +167 -64
  1790. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +41 -32
  1791. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +27 -19
  1792. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +22 -6
  1793. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +15 -13
  1794. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +7 -44
  1795. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +6 -4
  1796. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +7 -23
  1797. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +25 -34
  1798. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +2 -2
  1799. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +16 -98
  1800. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +1241 -657
  1801. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +751 -398
  1802. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +691 -0
  1803. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_msvc.h +1281 -0
  1804. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +3551 -1938
  1805. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +1272 -487
  1806. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64_msvc.h +2002 -0
  1807. data/third_party/cares/cares/include/ares.h +23 -1
  1808. data/third_party/cares/cares/{src/lib → include}/ares_nameser.h +9 -7
  1809. data/third_party/cares/cares/include/ares_rules.h +2 -2
  1810. data/third_party/cares/cares/include/ares_version.h +3 -3
  1811. data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +266 -0
  1812. data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +240 -0
  1813. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +49 -80
  1814. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +37 -43
  1815. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +12 -4
  1816. data/third_party/cares/cares/src/lib/ares_data.c +16 -0
  1817. data/third_party/cares/cares/src/lib/ares_data.h +7 -0
  1818. data/third_party/cares/cares/src/lib/ares_destroy.c +8 -0
  1819. data/third_party/cares/cares/src/lib/ares_expand_name.c +17 -6
  1820. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +1 -0
  1821. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +156 -78
  1822. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +130 -326
  1823. data/third_party/cares/cares/src/lib/ares_init.c +97 -485
  1824. data/third_party/cares/cares/src/lib/ares_library_init.c +2 -89
  1825. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +23 -142
  1826. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +22 -142
  1827. data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +184 -0
  1828. data/third_party/cares/cares/src/lib/ares_private.h +30 -16
  1829. data/third_party/cares/cares/src/lib/ares_process.c +55 -16
  1830. data/third_party/cares/cares/src/lib/ares_query.c +1 -35
  1831. data/third_party/cares/cares/src/lib/ares_rand.c +279 -0
  1832. data/third_party/cares/cares/src/lib/ares_send.c +5 -7
  1833. data/third_party/cares/cares/src/lib/ares_strdup.c +12 -19
  1834. data/third_party/cares/cares/src/lib/ares_strsplit.c +44 -128
  1835. data/third_party/cares/cares/src/lib/ares_strsplit.h +9 -10
  1836. data/third_party/cares/cares/src/lib/inet_net_pton.c +78 -116
  1837. data/third_party/cares/cares/src/tools/ares_getopt.h +53 -0
  1838. data/third_party/upb/upb/{table_internal.h → alloc.h} +6 -6
  1839. data/third_party/upb/upb/arena.h +4 -193
  1840. data/third_party/upb/upb/array.h +4 -51
  1841. data/third_party/upb/upb/base/descriptor_constants.h +104 -0
  1842. data/third_party/upb/upb/base/log2.h +57 -0
  1843. data/third_party/upb/upb/{status.c → base/status.c} +2 -7
  1844. data/third_party/upb/upb/base/status.h +66 -0
  1845. data/third_party/upb/upb/base/string_view.h +75 -0
  1846. data/third_party/upb/upb/{array.c → collections/array.c} +73 -36
  1847. data/third_party/upb/upb/collections/array.h +91 -0
  1848. data/third_party/upb/upb/collections/array_internal.h +135 -0
  1849. data/third_party/upb/upb/{map.c → collections/map.c} +60 -26
  1850. data/third_party/upb/upb/collections/map.h +140 -0
  1851. data/third_party/upb/upb/collections/map_gencode_util.h +78 -0
  1852. data/third_party/upb/upb/collections/map_internal.h +170 -0
  1853. data/third_party/upb/upb/collections/map_sorter.c +166 -0
  1854. data/third_party/upb/upb/collections/map_sorter_internal.h +109 -0
  1855. data/third_party/upb/upb/{message_value.h → collections/message_value.h} +19 -13
  1856. data/third_party/upb/upb/decode.h +3 -62
  1857. data/third_party/upb/upb/def.h +4 -384
  1858. data/third_party/upb/upb/def.hpp +3 -411
  1859. data/third_party/upb/upb/encode.h +3 -48
  1860. data/third_party/upb/upb/extension_registry.h +3 -52
  1861. data/third_party/upb/upb/generated_code_support.h +54 -0
  1862. data/third_party/upb/upb/{table.c → hash/common.c} +55 -108
  1863. data/third_party/upb/upb/hash/common.h +200 -0
  1864. data/third_party/upb/upb/hash/int_table.h +102 -0
  1865. data/third_party/upb/upb/hash/str_table.h +162 -0
  1866. data/third_party/upb/upb/{json_decode.c → json/decode.c} +63 -98
  1867. data/third_party/upb/upb/{json_decode.h → json/decode.h} +8 -3
  1868. data/third_party/upb/upb/{json_encode.c → json/encode.c} +69 -45
  1869. data/third_party/upb/upb/{json_encode.h → json/encode.h} +8 -3
  1870. data/third_party/upb/upb/lex/atoi.c +68 -0
  1871. data/third_party/upb/upb/lex/atoi.h +53 -0
  1872. data/third_party/upb/upb/{upb.c → lex/round_trip.c} +2 -11
  1873. data/third_party/upb/upb/{internal/upb.h → lex/round_trip.h} +17 -30
  1874. data/third_party/upb/upb/lex/strtod.c +97 -0
  1875. data/third_party/upb/upb/lex/strtod.h +46 -0
  1876. data/third_party/upb/upb/lex/unicode.c +57 -0
  1877. data/third_party/upb/upb/lex/unicode.h +77 -0
  1878. data/third_party/upb/upb/map.h +4 -85
  1879. data/third_party/upb/upb/mem/alloc.c +47 -0
  1880. data/third_party/upb/upb/mem/alloc.h +98 -0
  1881. data/third_party/upb/upb/mem/arena.c +367 -0
  1882. data/third_party/upb/upb/mem/arena.h +160 -0
  1883. data/third_party/upb/upb/mem/arena_internal.h +114 -0
  1884. data/third_party/upb/upb/message/accessors.c +92 -0
  1885. data/third_party/upb/upb/message/accessors.h +400 -0
  1886. data/third_party/upb/upb/message/accessors_internal.h +391 -0
  1887. data/third_party/upb/upb/message/extension_internal.h +83 -0
  1888. data/third_party/upb/upb/message/internal/map_entry.h +64 -0
  1889. data/third_party/upb/upb/message/internal.h +131 -0
  1890. data/third_party/upb/upb/message/message.c +174 -0
  1891. data/third_party/upb/upb/message/message.h +69 -0
  1892. data/third_party/upb/upb/message/tagged_ptr.h +89 -0
  1893. data/third_party/upb/upb/mini_descriptor/build_enum.c +150 -0
  1894. data/third_party/upb/upb/mini_descriptor/build_enum.h +63 -0
  1895. data/third_party/upb/upb/mini_descriptor/decode.c +875 -0
  1896. data/third_party/upb/upb/mini_descriptor/decode.h +140 -0
  1897. data/third_party/upb/upb/mini_descriptor/internal/base92.c +46 -0
  1898. data/third_party/upb/upb/mini_descriptor/internal/base92.h +81 -0
  1899. data/third_party/upb/upb/mini_descriptor/internal/decoder.h +73 -0
  1900. data/third_party/upb/upb/mini_descriptor/internal/encode.c +326 -0
  1901. data/third_party/upb/upb/mini_descriptor/internal/encode.h +110 -0
  1902. data/third_party/upb/upb/{mini_table.hpp → mini_descriptor/internal/encode.hpp} +32 -8
  1903. data/third_party/upb/upb/mini_descriptor/internal/modifiers.h +50 -0
  1904. data/third_party/upb/upb/mini_descriptor/internal/wire_constants.h +91 -0
  1905. data/third_party/upb/upb/mini_descriptor/link.c +142 -0
  1906. data/third_party/upb/upb/mini_descriptor/link.h +104 -0
  1907. data/third_party/upb/upb/mini_table/enum.h +50 -0
  1908. data/third_party/upb/upb/mini_table/extension.h +40 -0
  1909. data/third_party/upb/upb/{extension_registry.c → mini_table/extension_registry.c} +27 -24
  1910. data/third_party/upb/upb/mini_table/extension_registry.h +105 -0
  1911. data/third_party/upb/upb/mini_table/field.h +118 -0
  1912. data/third_party/upb/upb/{collections.h → mini_table/file.h} +6 -7
  1913. data/third_party/upb/upb/mini_table/internal/enum.h +76 -0
  1914. data/third_party/upb/upb/mini_table/internal/extension.h +47 -0
  1915. data/third_party/upb/upb/mini_table/internal/field.h +136 -0
  1916. data/third_party/upb/upb/mini_table/internal/file.h +49 -0
  1917. data/third_party/upb/upb/mini_table/internal/message.c +39 -0
  1918. data/third_party/upb/upb/mini_table/internal/message.h +113 -0
  1919. data/third_party/upb/upb/mini_table/internal/sub.h +39 -0
  1920. data/third_party/upb/upb/mini_table/message.c +97 -0
  1921. data/third_party/upb/upb/mini_table/message.h +105 -0
  1922. data/third_party/upb/upb/mini_table/sub.h +35 -0
  1923. data/third_party/upb/upb/msg.h +3 -38
  1924. data/third_party/upb/upb/port/atomic.h +101 -0
  1925. data/third_party/upb/upb/{port_def.inc → port/def.inc} +94 -27
  1926. data/third_party/upb/upb/{port_undef.inc → port/undef.inc} +13 -3
  1927. data/third_party/upb/upb/{internal → port}/vsnprintf_compat.h +5 -7
  1928. data/third_party/upb/upb/reflection/common.h +67 -0
  1929. data/third_party/upb/upb/reflection/def.h +42 -0
  1930. data/third_party/upb/upb/reflection/def.hpp +622 -0
  1931. data/third_party/upb/upb/reflection/def_builder.c +357 -0
  1932. data/third_party/upb/upb/reflection/def_builder_internal.h +157 -0
  1933. data/third_party/upb/upb/reflection/def_pool.c +462 -0
  1934. data/third_party/upb/upb/reflection/def_pool.h +108 -0
  1935. data/third_party/upb/upb/reflection/def_pool_internal.h +77 -0
  1936. data/third_party/upb/upb/reflection/def_type.c +50 -0
  1937. data/third_party/upb/upb/reflection/def_type.h +81 -0
  1938. data/third_party/upb/upb/reflection/desc_state.c +53 -0
  1939. data/third_party/upb/upb/reflection/desc_state_internal.h +64 -0
  1940. data/third_party/upb/upb/reflection/enum_def.c +310 -0
  1941. data/third_party/upb/upb/reflection/enum_def.h +80 -0
  1942. data/third_party/upb/upb/reflection/enum_def_internal.h +56 -0
  1943. data/third_party/upb/upb/reflection/enum_reserved_range.c +84 -0
  1944. data/third_party/upb/upb/reflection/enum_reserved_range.h +51 -0
  1945. data/third_party/upb/upb/reflection/enum_reserved_range_internal.h +55 -0
  1946. data/third_party/upb/upb/reflection/enum_value_def.c +144 -0
  1947. data/third_party/upb/upb/reflection/enum_value_def.h +57 -0
  1948. data/third_party/upb/upb/reflection/enum_value_def_internal.h +57 -0
  1949. data/third_party/upb/upb/reflection/extension_range.c +93 -0
  1950. data/third_party/upb/upb/reflection/extension_range.h +55 -0
  1951. data/third_party/upb/upb/reflection/extension_range_internal.h +54 -0
  1952. data/third_party/upb/upb/reflection/field_def.c +931 -0
  1953. data/third_party/upb/upb/reflection/field_def.h +91 -0
  1954. data/third_party/upb/upb/reflection/field_def_internal.h +76 -0
  1955. data/third_party/upb/upb/reflection/file_def.c +370 -0
  1956. data/third_party/upb/upb/reflection/file_def.h +77 -0
  1957. data/third_party/upb/upb/reflection/file_def_internal.h +57 -0
  1958. data/third_party/upb/upb/reflection/message.c +233 -0
  1959. data/third_party/upb/upb/reflection/message.h +102 -0
  1960. data/third_party/upb/upb/reflection/message.hpp +37 -0
  1961. data/third_party/upb/upb/reflection/message_def.c +720 -0
  1962. data/third_party/upb/upb/reflection/message_def.h +174 -0
  1963. data/third_party/upb/upb/reflection/message_def_internal.h +63 -0
  1964. data/third_party/upb/upb/reflection/message_reserved_range.c +81 -0
  1965. data/third_party/upb/upb/reflection/message_reserved_range.h +51 -0
  1966. data/third_party/upb/upb/reflection/message_reserved_range_internal.h +55 -0
  1967. data/third_party/upb/upb/reflection/method_def.c +124 -0
  1968. data/third_party/upb/upb/reflection/method_def.h +59 -0
  1969. data/third_party/upb/upb/reflection/method_def_internal.h +53 -0
  1970. data/third_party/upb/upb/reflection/oneof_def.c +226 -0
  1971. data/third_party/upb/upb/reflection/oneof_def.h +66 -0
  1972. data/third_party/upb/upb/reflection/oneof_def_internal.h +57 -0
  1973. data/third_party/upb/upb/reflection/service_def.c +128 -0
  1974. data/third_party/upb/upb/reflection/service_def.h +60 -0
  1975. data/third_party/upb/upb/reflection/service_def_internal.h +53 -0
  1976. data/third_party/upb/upb/reflection.h +4 -78
  1977. data/third_party/upb/upb/reflection.hpp +3 -7
  1978. data/third_party/upb/upb/status.h +4 -34
  1979. data/third_party/upb/upb/string_view.h +36 -0
  1980. data/third_party/upb/upb/{text_encode.c → text/encode.c} +74 -70
  1981. data/third_party/upb/upb/text/encode.h +69 -0
  1982. data/third_party/upb/upb/text_encode.h +4 -32
  1983. data/third_party/upb/upb/upb.h +6 -151
  1984. data/third_party/upb/upb/upb.hpp +10 -18
  1985. data/third_party/upb/upb/wire/common.h +44 -0
  1986. data/third_party/upb/upb/wire/common_internal.h +50 -0
  1987. data/third_party/upb/upb/wire/decode.c +1382 -0
  1988. data/third_party/upb/upb/wire/decode.h +148 -0
  1989. data/third_party/upb/upb/{decode_fast.c → wire/decode_fast.c} +184 -225
  1990. data/third_party/upb/upb/{decode_fast.h → wire/decode_fast.h} +21 -7
  1991. data/third_party/upb/upb/{internal/decode.h → wire/decode_internal.h} +44 -92
  1992. data/third_party/upb/upb/{encode.c → wire/encode.c} +134 -105
  1993. data/third_party/upb/upb/wire/encode.h +92 -0
  1994. data/third_party/upb/upb/wire/eps_copy_input_stream.c +39 -0
  1995. data/third_party/upb/upb/wire/eps_copy_input_stream.h +425 -0
  1996. data/third_party/upb/upb/wire/reader.c +67 -0
  1997. data/third_party/upb/upb/wire/reader.h +227 -0
  1998. data/third_party/upb/upb/wire/swap_internal.h +63 -0
  1999. data/third_party/upb/upb/wire/types.h +41 -0
  2000. data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-neon.c +1 -1
  2001. data/third_party/{upb/third_party/utf8_range → utf8_range}/utf8_range.h +12 -0
  2002. metadata +386 -152
  2003. data/src/core/ext/filters/client_channel/health/health_check_client.cc +0 -175
  2004. data/src/core/ext/filters/client_channel/health/health_check_client.h +0 -43
  2005. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +0 -42
  2006. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.h +0 -64
  2007. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +0 -30
  2008. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  2009. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  2010. data/src/core/ext/transport/chttp2/transport/stream_map.cc +0 -177
  2011. data/src/core/ext/transport/chttp2/transport/stream_map.h +0 -68
  2012. data/src/core/lib/event_engine/thread_pool.cc +0 -253
  2013. data/src/core/lib/event_engine/thread_pool.h +0 -141
  2014. data/src/core/lib/gprpp/global_config.h +0 -93
  2015. data/src/core/lib/gprpp/global_config_env.cc +0 -140
  2016. data/src/core/lib/gprpp/global_config_env.h +0 -133
  2017. data/src/core/lib/gprpp/global_config_generic.h +0 -40
  2018. data/src/core/lib/promise/detail/basic_join.h +0 -197
  2019. data/src/core/lib/promise/detail/switch.h +0 -1455
  2020. data/src/core/lib/promise/intra_activity_waiter.h +0 -55
  2021. data/src/core/lib/promise/try_join.h +0 -82
  2022. data/src/core/lib/security/security_connector/ssl_utils_config.cc +0 -32
  2023. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -403
  2024. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +0 -236
  2025. data/third_party/boringssl-with-bazel/src/crypto/asn1/charmap.h +0 -15
  2026. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +0 -206
  2027. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1-altivec.c +0 -361
  2028. data/third_party/boringssl-with-bazel/src/crypto/refcount_lock.c +0 -53
  2029. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +0 -287
  2030. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +0 -132
  2031. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_lib.c +0 -155
  2032. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +0 -131
  2033. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_node.c +0 -189
  2034. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +0 -843
  2035. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +0 -289
  2036. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcia.c +0 -57
  2037. data/third_party/cares/cares/src/lib/ares_library_init.h +0 -43
  2038. data/third_party/re2/util/benchmark.h +0 -156
  2039. data/third_party/re2/util/flags.h +0 -26
  2040. data/third_party/re2/util/malloc_counter.h +0 -19
  2041. data/third_party/re2/util/pcre.cc +0 -1025
  2042. data/third_party/re2/util/pcre.h +0 -681
  2043. data/third_party/re2/util/test.h +0 -50
  2044. data/third_party/upb/upb/arena.c +0 -277
  2045. data/third_party/upb/upb/decode.c +0 -1221
  2046. data/third_party/upb/upb/def.c +0 -3269
  2047. data/third_party/upb/upb/internal/table.h +0 -385
  2048. data/third_party/upb/upb/mini_table.c +0 -1147
  2049. data/third_party/upb/upb/mini_table.h +0 -189
  2050. data/third_party/upb/upb/msg.c +0 -368
  2051. data/third_party/upb/upb/msg_internal.h +0 -837
  2052. data/third_party/upb/upb/reflection.c +0 -323
  2053. data/third_party/zlib/gzclose.c +0 -25
  2054. data/third_party/zlib/gzlib.c +0 -639
  2055. data/third_party/zlib/gzread.c +0 -650
  2056. data/third_party/zlib/gzwrite.c +0 -677
  2057. /data/src/core/lib/gpr/{log_android.cc → android/log.cc} +0 -0
  2058. /data/src/core/lib/gpr/{cpu_iphone.cc → iphone/cpu.cc} +0 -0
  2059. /data/src/core/lib/gpr/{cpu_linux.cc → linux/cpu.cc} +0 -0
  2060. /data/src/core/lib/gpr/{log_linux.cc → linux/log.cc} +0 -0
  2061. /data/src/core/lib/gpr/{tmpfile_msys.cc → msys/tmpfile.cc} +0 -0
  2062. /data/src/core/lib/gpr/{cpu_posix.cc → posix/cpu.cc} +0 -0
  2063. /data/src/core/lib/gpr/{log_posix.cc → posix/log.cc} +0 -0
  2064. /data/src/core/lib/gpr/{string_posix.cc → posix/string.cc} +0 -0
  2065. /data/src/core/lib/gpr/{sync_posix.cc → posix/sync.cc} +0 -0
  2066. /data/src/core/lib/gpr/{tmpfile_posix.cc → posix/tmpfile.cc} +0 -0
  2067. /data/src/core/lib/gpr/{cpu_windows.cc → windows/cpu.cc} +0 -0
  2068. /data/src/core/lib/gpr/{log_windows.cc → windows/log.cc} +0 -0
  2069. /data/src/core/lib/gpr/{string_windows.cc → windows/string.cc} +0 -0
  2070. /data/src/core/lib/gpr/{string_util_windows.cc → windows/string_util.cc} +0 -0
  2071. /data/src/core/lib/gpr/{sync_windows.cc → windows/sync.cc} +0 -0
  2072. /data/src/core/lib/gpr/{time_windows.cc → windows/time.cc} +0 -0
  2073. /data/src/core/lib/gpr/{tmpfile_windows.cc → windows/tmpfile.cc} +0 -0
  2074. /data/src/core/lib/gprpp/{env_linux.cc → linux/env.cc} +0 -0
  2075. /data/src/core/lib/gprpp/{env_posix.cc → posix/env.cc} +0 -0
  2076. /data/src/core/lib/gprpp/{stat_posix.cc → posix/stat.cc} +0 -0
  2077. /data/src/core/lib/gprpp/{env_windows.cc → windows/env.cc} +0 -0
  2078. /data/src/core/lib/gprpp/{stat_windows.cc → windows/stat.cc} +0 -0
  2079. /data/third_party/{upb/third_party/utf8_range → utf8_range}/naive.c +0 -0
  2080. /data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-sse.c +0 -0
@@ -1,8 +1,8 @@
1
- /* Autogenerated: src/ExtractionOCaml/word_by_word_montgomery --static p256 '2^256 - 2^224 + 2^192 + 2^96 - 1' 64 mul square add sub opp from_montgomery nonzero selectznz to_bytes from_bytes */
1
+ /* Autogenerated: 'src/ExtractionOCaml/word_by_word_montgomery' --inline --static --use-value-barrier p256 64 '2^256 - 2^224 + 2^192 + 2^96 - 1' mul square add sub opp from_montgomery to_montgomery nonzero selectznz to_bytes from_bytes one msat divstep divstep_precomp */
2
2
  /* curve description: p256 */
3
- /* requested operations: mul, square, add, sub, opp, from_montgomery, nonzero, selectznz, to_bytes, from_bytes */
4
- /* m = 0xffffffff00000001000000000000000000000000ffffffffffffffffffffffff (from "2^256 - 2^224 + 2^192 + 2^96 - 1") */
5
3
  /* machine_wordsize = 64 (from "64") */
4
+ /* requested operations: mul, square, add, sub, opp, from_montgomery, to_montgomery, nonzero, selectznz, to_bytes, from_bytes, one, msat, divstep, divstep_precomp */
5
+ /* m = 0xffffffff00000001000000000000000000000000ffffffffffffffffffffffff (from "2^256 - 2^224 + 2^192 + 2^96 - 1") */
6
6
  /* */
7
7
  /* NOTE: In addition to the bounds specified above each function, all */
8
8
  /* functions synthesized for this Montgomery arithmetic require the */
@@ -10,20 +10,52 @@
10
10
  /* require the input to be in the unique saturated representation. */
11
11
  /* All functions also ensure that these two properties are true of */
12
12
  /* return values. */
13
+ /* */
14
+ /* Computed values: */
15
+ /* eval z = z[0] + (z[1] << 64) + (z[2] << 128) + (z[3] << 192) */
16
+ /* bytes_eval z = z[0] + (z[1] << 8) + (z[2] << 16) + (z[3] << 24) + (z[4] << 32) + (z[5] << 40) + (z[6] << 48) + (z[7] << 56) + (z[8] << 64) + (z[9] << 72) + (z[10] << 80) + (z[11] << 88) + (z[12] << 96) + (z[13] << 104) + (z[14] << 112) + (z[15] << 120) + (z[16] << 128) + (z[17] << 136) + (z[18] << 144) + (z[19] << 152) + (z[20] << 160) + (z[21] << 168) + (z[22] << 176) + (z[23] << 184) + (z[24] << 192) + (z[25] << 200) + (z[26] << 208) + (z[27] << 216) + (z[28] << 224) + (z[29] << 232) + (z[30] << 240) + (z[31] << 248) */
17
+ /* twos_complement_eval z = let x1 := z[0] + (z[1] << 64) + (z[2] << 128) + (z[3] << 192) in */
18
+ /* if x1 & (2^256-1) < 2^255 then x1 & (2^256-1) else (x1 & (2^256-1)) - 2^256 */
13
19
 
14
20
  #include <stdint.h>
15
21
  typedef unsigned char fiat_p256_uint1;
16
22
  typedef signed char fiat_p256_int1;
17
- typedef signed __int128 fiat_p256_int128;
18
- typedef unsigned __int128 fiat_p256_uint128;
23
+ #if defined(__GNUC__) || defined(__clang__)
24
+ # define FIAT_P256_FIAT_EXTENSION __extension__
25
+ # define FIAT_P256_FIAT_INLINE __inline__
26
+ #else
27
+ # define FIAT_P256_FIAT_EXTENSION
28
+ # define FIAT_P256_FIAT_INLINE
29
+ #endif
30
+
31
+ FIAT_P256_FIAT_EXTENSION typedef signed __int128 fiat_p256_int128;
32
+ FIAT_P256_FIAT_EXTENSION typedef unsigned __int128 fiat_p256_uint128;
33
+
34
+ /* The type fiat_p256_montgomery_domain_field_element is a field element in the Montgomery domain. */
35
+ /* Bounds: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]] */
36
+ typedef uint64_t fiat_p256_montgomery_domain_field_element[4];
37
+
38
+ /* The type fiat_p256_non_montgomery_domain_field_element is a field element NOT in the Montgomery domain. */
39
+ /* Bounds: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]] */
40
+ typedef uint64_t fiat_p256_non_montgomery_domain_field_element[4];
19
41
 
20
42
  #if (-1 & 3) != 3
21
43
  #error "This code only works on a two's complement system"
22
44
  #endif
23
45
 
46
+ #if !defined(FIAT_P256_NO_ASM) && (defined(__GNUC__) || defined(__clang__))
47
+ static __inline__ uint64_t fiat_p256_value_barrier_u64(uint64_t a) {
48
+ __asm__("" : "+r"(a) : /* no inputs */);
49
+ return a;
50
+ }
51
+ #else
52
+ # define fiat_p256_value_barrier_u64(x) (x)
53
+ #endif
54
+
24
55
 
25
56
  /*
26
57
  * The function fiat_p256_addcarryx_u64 is an addition with carry.
58
+ *
27
59
  * Postconditions:
28
60
  * out1 = (arg1 + arg2 + arg3) mod 2^64
29
61
  * out2 = ⌊(arg1 + arg2 + arg3) / 2^64⌋
@@ -36,16 +68,20 @@ typedef unsigned __int128 fiat_p256_uint128;
36
68
  * out1: [0x0 ~> 0xffffffffffffffff]
37
69
  * out2: [0x0 ~> 0x1]
38
70
  */
39
- static void fiat_p256_addcarryx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
40
- fiat_p256_uint128 x1 = ((arg1 + (fiat_p256_uint128)arg2) + arg3);
41
- uint64_t x2 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
42
- fiat_p256_uint1 x3 = (fiat_p256_uint1)(x1 >> 64);
71
+ static FIAT_P256_FIAT_INLINE void fiat_p256_addcarryx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
72
+ fiat_p256_uint128 x1;
73
+ uint64_t x2;
74
+ fiat_p256_uint1 x3;
75
+ x1 = ((arg1 + (fiat_p256_uint128)arg2) + arg3);
76
+ x2 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
77
+ x3 = (fiat_p256_uint1)(x1 >> 64);
43
78
  *out1 = x2;
44
79
  *out2 = x3;
45
80
  }
46
81
 
47
82
  /*
48
83
  * The function fiat_p256_subborrowx_u64 is a subtraction with borrow.
84
+ *
49
85
  * Postconditions:
50
86
  * out1 = (-arg1 + arg2 + -arg3) mod 2^64
51
87
  * out2 = -⌊(-arg1 + arg2 + -arg3) / 2^64⌋
@@ -58,16 +94,20 @@ static void fiat_p256_addcarryx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat_
58
94
  * out1: [0x0 ~> 0xffffffffffffffff]
59
95
  * out2: [0x0 ~> 0x1]
60
96
  */
61
- static void fiat_p256_subborrowx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
62
- fiat_p256_int128 x1 = ((arg2 - (fiat_p256_int128)arg1) - arg3);
63
- fiat_p256_int1 x2 = (fiat_p256_int1)(x1 >> 64);
64
- uint64_t x3 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
97
+ static FIAT_P256_FIAT_INLINE void fiat_p256_subborrowx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
98
+ fiat_p256_int128 x1;
99
+ fiat_p256_int1 x2;
100
+ uint64_t x3;
101
+ x1 = ((arg2 - (fiat_p256_int128)arg1) - arg3);
102
+ x2 = (fiat_p256_int1)(x1 >> 64);
103
+ x3 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
65
104
  *out1 = x3;
66
105
  *out2 = (fiat_p256_uint1)(0x0 - x2);
67
106
  }
68
107
 
69
108
  /*
70
109
  * The function fiat_p256_mulx_u64 is a multiplication, returning the full double-width result.
110
+ *
71
111
  * Postconditions:
72
112
  * out1 = (arg1 * arg2) mod 2^64
73
113
  * out2 = ⌊arg1 * arg2 / 2^64⌋
@@ -79,16 +119,20 @@ static void fiat_p256_subborrowx_u64(uint64_t* out1, fiat_p256_uint1* out2, fiat
79
119
  * out1: [0x0 ~> 0xffffffffffffffff]
80
120
  * out2: [0x0 ~> 0xffffffffffffffff]
81
121
  */
82
- static void fiat_p256_mulx_u64(uint64_t* out1, uint64_t* out2, uint64_t arg1, uint64_t arg2) {
83
- fiat_p256_uint128 x1 = ((fiat_p256_uint128)arg1 * arg2);
84
- uint64_t x2 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
85
- uint64_t x3 = (uint64_t)(x1 >> 64);
122
+ static FIAT_P256_FIAT_INLINE void fiat_p256_mulx_u64(uint64_t* out1, uint64_t* out2, uint64_t arg1, uint64_t arg2) {
123
+ fiat_p256_uint128 x1;
124
+ uint64_t x2;
125
+ uint64_t x3;
126
+ x1 = ((fiat_p256_uint128)arg1 * arg2);
127
+ x2 = (uint64_t)(x1 & UINT64_C(0xffffffffffffffff));
128
+ x3 = (uint64_t)(x1 >> 64);
86
129
  *out1 = x2;
87
130
  *out2 = x3;
88
131
  }
89
132
 
90
133
  /*
91
134
  * The function fiat_p256_cmovznz_u64 is a single-word conditional move.
135
+ *
92
136
  * Postconditions:
93
137
  * out1 = (if arg1 = 0 then arg2 else arg3)
94
138
  *
@@ -99,21 +143,19 @@ static void fiat_p256_mulx_u64(uint64_t* out1, uint64_t* out2, uint64_t arg1, ui
99
143
  * Output Bounds:
100
144
  * out1: [0x0 ~> 0xffffffffffffffff]
101
145
  */
102
- static void fiat_p256_cmovznz_u64(uint64_t* out1, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
103
- fiat_p256_uint1 x1 = (!(!arg1));
104
- uint64_t x2 = ((fiat_p256_int1)(0x0 - x1) & UINT64_C(0xffffffffffffffff));
105
- // Note this line has been patched from the synthesized code to add value
106
- // barriers.
107
- //
108
- // Clang recognizes this pattern as a select. While it usually transforms it
109
- // to a cmov, it sometimes further transforms it into a branch, which we do
110
- // not want.
111
- uint64_t x3 = ((value_barrier_u64(x2) & arg3) | (value_barrier_u64(~x2) & arg2));
146
+ static FIAT_P256_FIAT_INLINE void fiat_p256_cmovznz_u64(uint64_t* out1, fiat_p256_uint1 arg1, uint64_t arg2, uint64_t arg3) {
147
+ fiat_p256_uint1 x1;
148
+ uint64_t x2;
149
+ uint64_t x3;
150
+ x1 = (!(!arg1));
151
+ x2 = ((fiat_p256_int1)(0x0 - x1) & UINT64_C(0xffffffffffffffff));
152
+ x3 = ((fiat_p256_value_barrier_u64(x2) & arg3) | (fiat_p256_value_barrier_u64((~x2)) & arg2));
112
153
  *out1 = x3;
113
154
  }
114
155
 
115
156
  /*
116
157
  * The function fiat_p256_mul multiplies two field elements in the Montgomery domain.
158
+ *
117
159
  * Preconditions:
118
160
  * 0 ≤ eval arg1 < m
119
161
  * 0 ≤ eval arg2 < m
@@ -121,287 +163,297 @@ static void fiat_p256_cmovznz_u64(uint64_t* out1, fiat_p256_uint1 arg1, uint64_t
121
163
  * eval (from_montgomery out1) mod m = (eval (from_montgomery arg1) * eval (from_montgomery arg2)) mod m
122
164
  * 0 ≤ eval out1 < m
123
165
  *
124
- * Input Bounds:
125
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
126
- * arg2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
127
- * Output Bounds:
128
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
129
166
  */
130
- static void fiat_p256_mul(uint64_t out1[4], const uint64_t arg1[4], const uint64_t arg2[4]) {
131
- uint64_t x1 = (arg1[1]);
132
- uint64_t x2 = (arg1[2]);
133
- uint64_t x3 = (arg1[3]);
134
- uint64_t x4 = (arg1[0]);
167
+ static FIAT_P256_FIAT_INLINE void fiat_p256_mul(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1, const fiat_p256_montgomery_domain_field_element arg2) {
168
+ uint64_t x1;
169
+ uint64_t x2;
170
+ uint64_t x3;
171
+ uint64_t x4;
135
172
  uint64_t x5;
136
173
  uint64_t x6;
137
- fiat_p256_mulx_u64(&x5, &x6, x4, (arg2[3]));
138
174
  uint64_t x7;
139
175
  uint64_t x8;
140
- fiat_p256_mulx_u64(&x7, &x8, x4, (arg2[2]));
141
176
  uint64_t x9;
142
177
  uint64_t x10;
143
- fiat_p256_mulx_u64(&x9, &x10, x4, (arg2[1]));
144
178
  uint64_t x11;
145
179
  uint64_t x12;
146
- fiat_p256_mulx_u64(&x11, &x12, x4, (arg2[0]));
147
180
  uint64_t x13;
148
181
  fiat_p256_uint1 x14;
149
- fiat_p256_addcarryx_u64(&x13, &x14, 0x0, x12, x9);
150
182
  uint64_t x15;
151
183
  fiat_p256_uint1 x16;
152
- fiat_p256_addcarryx_u64(&x15, &x16, x14, x10, x7);
153
184
  uint64_t x17;
154
185
  fiat_p256_uint1 x18;
155
- fiat_p256_addcarryx_u64(&x17, &x18, x16, x8, x5);
156
- uint64_t x19 = (x18 + x6);
186
+ uint64_t x19;
157
187
  uint64_t x20;
158
188
  uint64_t x21;
159
- fiat_p256_mulx_u64(&x20, &x21, x11, UINT64_C(0xffffffff00000001));
160
189
  uint64_t x22;
161
190
  uint64_t x23;
162
- fiat_p256_mulx_u64(&x22, &x23, x11, UINT32_C(0xffffffff));
163
191
  uint64_t x24;
164
192
  uint64_t x25;
165
- fiat_p256_mulx_u64(&x24, &x25, x11, UINT64_C(0xffffffffffffffff));
166
193
  uint64_t x26;
167
194
  fiat_p256_uint1 x27;
168
- fiat_p256_addcarryx_u64(&x26, &x27, 0x0, x25, x22);
169
- uint64_t x28 = (x27 + x23);
195
+ uint64_t x28;
170
196
  uint64_t x29;
171
197
  fiat_p256_uint1 x30;
172
- fiat_p256_addcarryx_u64(&x29, &x30, 0x0, x11, x24);
173
198
  uint64_t x31;
174
199
  fiat_p256_uint1 x32;
175
- fiat_p256_addcarryx_u64(&x31, &x32, x30, x13, x26);
176
200
  uint64_t x33;
177
201
  fiat_p256_uint1 x34;
178
- fiat_p256_addcarryx_u64(&x33, &x34, x32, x15, x28);
179
202
  uint64_t x35;
180
203
  fiat_p256_uint1 x36;
181
- fiat_p256_addcarryx_u64(&x35, &x36, x34, x17, x20);
182
204
  uint64_t x37;
183
205
  fiat_p256_uint1 x38;
184
- fiat_p256_addcarryx_u64(&x37, &x38, x36, x19, x21);
185
206
  uint64_t x39;
186
207
  uint64_t x40;
187
- fiat_p256_mulx_u64(&x39, &x40, x1, (arg2[3]));
188
208
  uint64_t x41;
189
209
  uint64_t x42;
190
- fiat_p256_mulx_u64(&x41, &x42, x1, (arg2[2]));
191
210
  uint64_t x43;
192
211
  uint64_t x44;
193
- fiat_p256_mulx_u64(&x43, &x44, x1, (arg2[1]));
194
212
  uint64_t x45;
195
213
  uint64_t x46;
196
- fiat_p256_mulx_u64(&x45, &x46, x1, (arg2[0]));
197
214
  uint64_t x47;
198
215
  fiat_p256_uint1 x48;
199
- fiat_p256_addcarryx_u64(&x47, &x48, 0x0, x46, x43);
200
216
  uint64_t x49;
201
217
  fiat_p256_uint1 x50;
202
- fiat_p256_addcarryx_u64(&x49, &x50, x48, x44, x41);
203
218
  uint64_t x51;
204
219
  fiat_p256_uint1 x52;
205
- fiat_p256_addcarryx_u64(&x51, &x52, x50, x42, x39);
206
- uint64_t x53 = (x52 + x40);
220
+ uint64_t x53;
207
221
  uint64_t x54;
208
222
  fiat_p256_uint1 x55;
209
- fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x31, x45);
210
223
  uint64_t x56;
211
224
  fiat_p256_uint1 x57;
212
- fiat_p256_addcarryx_u64(&x56, &x57, x55, x33, x47);
213
225
  uint64_t x58;
214
226
  fiat_p256_uint1 x59;
215
- fiat_p256_addcarryx_u64(&x58, &x59, x57, x35, x49);
216
227
  uint64_t x60;
217
228
  fiat_p256_uint1 x61;
218
- fiat_p256_addcarryx_u64(&x60, &x61, x59, x37, x51);
219
229
  uint64_t x62;
220
230
  fiat_p256_uint1 x63;
221
- fiat_p256_addcarryx_u64(&x62, &x63, x61, x38, x53);
222
231
  uint64_t x64;
223
232
  uint64_t x65;
224
- fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffff00000001));
225
233
  uint64_t x66;
226
234
  uint64_t x67;
227
- fiat_p256_mulx_u64(&x66, &x67, x54, UINT32_C(0xffffffff));
228
235
  uint64_t x68;
229
236
  uint64_t x69;
230
- fiat_p256_mulx_u64(&x68, &x69, x54, UINT64_C(0xffffffffffffffff));
231
237
  uint64_t x70;
232
238
  fiat_p256_uint1 x71;
233
- fiat_p256_addcarryx_u64(&x70, &x71, 0x0, x69, x66);
234
- uint64_t x72 = (x71 + x67);
239
+ uint64_t x72;
235
240
  uint64_t x73;
236
241
  fiat_p256_uint1 x74;
237
- fiat_p256_addcarryx_u64(&x73, &x74, 0x0, x54, x68);
238
242
  uint64_t x75;
239
243
  fiat_p256_uint1 x76;
240
- fiat_p256_addcarryx_u64(&x75, &x76, x74, x56, x70);
241
244
  uint64_t x77;
242
245
  fiat_p256_uint1 x78;
243
- fiat_p256_addcarryx_u64(&x77, &x78, x76, x58, x72);
244
246
  uint64_t x79;
245
247
  fiat_p256_uint1 x80;
246
- fiat_p256_addcarryx_u64(&x79, &x80, x78, x60, x64);
247
248
  uint64_t x81;
248
249
  fiat_p256_uint1 x82;
249
- fiat_p256_addcarryx_u64(&x81, &x82, x80, x62, x65);
250
- uint64_t x83 = ((uint64_t)x82 + x63);
250
+ uint64_t x83;
251
251
  uint64_t x84;
252
252
  uint64_t x85;
253
- fiat_p256_mulx_u64(&x84, &x85, x2, (arg2[3]));
254
253
  uint64_t x86;
255
254
  uint64_t x87;
256
- fiat_p256_mulx_u64(&x86, &x87, x2, (arg2[2]));
257
255
  uint64_t x88;
258
256
  uint64_t x89;
259
- fiat_p256_mulx_u64(&x88, &x89, x2, (arg2[1]));
260
257
  uint64_t x90;
261
258
  uint64_t x91;
262
- fiat_p256_mulx_u64(&x90, &x91, x2, (arg2[0]));
263
259
  uint64_t x92;
264
260
  fiat_p256_uint1 x93;
265
- fiat_p256_addcarryx_u64(&x92, &x93, 0x0, x91, x88);
266
261
  uint64_t x94;
267
262
  fiat_p256_uint1 x95;
268
- fiat_p256_addcarryx_u64(&x94, &x95, x93, x89, x86);
269
263
  uint64_t x96;
270
264
  fiat_p256_uint1 x97;
271
- fiat_p256_addcarryx_u64(&x96, &x97, x95, x87, x84);
272
- uint64_t x98 = (x97 + x85);
265
+ uint64_t x98;
273
266
  uint64_t x99;
274
267
  fiat_p256_uint1 x100;
275
- fiat_p256_addcarryx_u64(&x99, &x100, 0x0, x75, x90);
276
268
  uint64_t x101;
277
269
  fiat_p256_uint1 x102;
278
- fiat_p256_addcarryx_u64(&x101, &x102, x100, x77, x92);
279
270
  uint64_t x103;
280
271
  fiat_p256_uint1 x104;
281
- fiat_p256_addcarryx_u64(&x103, &x104, x102, x79, x94);
282
272
  uint64_t x105;
283
273
  fiat_p256_uint1 x106;
284
- fiat_p256_addcarryx_u64(&x105, &x106, x104, x81, x96);
285
274
  uint64_t x107;
286
275
  fiat_p256_uint1 x108;
287
- fiat_p256_addcarryx_u64(&x107, &x108, x106, x83, x98);
288
276
  uint64_t x109;
289
277
  uint64_t x110;
290
- fiat_p256_mulx_u64(&x109, &x110, x99, UINT64_C(0xffffffff00000001));
291
278
  uint64_t x111;
292
279
  uint64_t x112;
293
- fiat_p256_mulx_u64(&x111, &x112, x99, UINT32_C(0xffffffff));
294
280
  uint64_t x113;
295
281
  uint64_t x114;
296
- fiat_p256_mulx_u64(&x113, &x114, x99, UINT64_C(0xffffffffffffffff));
297
282
  uint64_t x115;
298
283
  fiat_p256_uint1 x116;
299
- fiat_p256_addcarryx_u64(&x115, &x116, 0x0, x114, x111);
300
- uint64_t x117 = (x116 + x112);
284
+ uint64_t x117;
301
285
  uint64_t x118;
302
286
  fiat_p256_uint1 x119;
303
- fiat_p256_addcarryx_u64(&x118, &x119, 0x0, x99, x113);
304
287
  uint64_t x120;
305
288
  fiat_p256_uint1 x121;
306
- fiat_p256_addcarryx_u64(&x120, &x121, x119, x101, x115);
307
289
  uint64_t x122;
308
290
  fiat_p256_uint1 x123;
309
- fiat_p256_addcarryx_u64(&x122, &x123, x121, x103, x117);
310
291
  uint64_t x124;
311
292
  fiat_p256_uint1 x125;
312
- fiat_p256_addcarryx_u64(&x124, &x125, x123, x105, x109);
313
293
  uint64_t x126;
314
294
  fiat_p256_uint1 x127;
315
- fiat_p256_addcarryx_u64(&x126, &x127, x125, x107, x110);
316
- uint64_t x128 = ((uint64_t)x127 + x108);
295
+ uint64_t x128;
317
296
  uint64_t x129;
318
297
  uint64_t x130;
319
- fiat_p256_mulx_u64(&x129, &x130, x3, (arg2[3]));
320
298
  uint64_t x131;
321
299
  uint64_t x132;
322
- fiat_p256_mulx_u64(&x131, &x132, x3, (arg2[2]));
323
300
  uint64_t x133;
324
301
  uint64_t x134;
325
- fiat_p256_mulx_u64(&x133, &x134, x3, (arg2[1]));
326
302
  uint64_t x135;
327
303
  uint64_t x136;
328
- fiat_p256_mulx_u64(&x135, &x136, x3, (arg2[0]));
329
304
  uint64_t x137;
330
305
  fiat_p256_uint1 x138;
331
- fiat_p256_addcarryx_u64(&x137, &x138, 0x0, x136, x133);
332
306
  uint64_t x139;
333
307
  fiat_p256_uint1 x140;
334
- fiat_p256_addcarryx_u64(&x139, &x140, x138, x134, x131);
335
308
  uint64_t x141;
336
309
  fiat_p256_uint1 x142;
337
- fiat_p256_addcarryx_u64(&x141, &x142, x140, x132, x129);
338
- uint64_t x143 = (x142 + x130);
310
+ uint64_t x143;
339
311
  uint64_t x144;
340
312
  fiat_p256_uint1 x145;
341
- fiat_p256_addcarryx_u64(&x144, &x145, 0x0, x120, x135);
342
313
  uint64_t x146;
343
314
  fiat_p256_uint1 x147;
344
- fiat_p256_addcarryx_u64(&x146, &x147, x145, x122, x137);
345
315
  uint64_t x148;
346
316
  fiat_p256_uint1 x149;
347
- fiat_p256_addcarryx_u64(&x148, &x149, x147, x124, x139);
348
317
  uint64_t x150;
349
318
  fiat_p256_uint1 x151;
350
- fiat_p256_addcarryx_u64(&x150, &x151, x149, x126, x141);
351
319
  uint64_t x152;
352
320
  fiat_p256_uint1 x153;
353
- fiat_p256_addcarryx_u64(&x152, &x153, x151, x128, x143);
354
321
  uint64_t x154;
355
322
  uint64_t x155;
356
- fiat_p256_mulx_u64(&x154, &x155, x144, UINT64_C(0xffffffff00000001));
357
323
  uint64_t x156;
358
324
  uint64_t x157;
359
- fiat_p256_mulx_u64(&x156, &x157, x144, UINT32_C(0xffffffff));
360
325
  uint64_t x158;
361
326
  uint64_t x159;
362
- fiat_p256_mulx_u64(&x158, &x159, x144, UINT64_C(0xffffffffffffffff));
363
327
  uint64_t x160;
364
328
  fiat_p256_uint1 x161;
365
- fiat_p256_addcarryx_u64(&x160, &x161, 0x0, x159, x156);
366
- uint64_t x162 = (x161 + x157);
329
+ uint64_t x162;
367
330
  uint64_t x163;
368
331
  fiat_p256_uint1 x164;
369
- fiat_p256_addcarryx_u64(&x163, &x164, 0x0, x144, x158);
370
332
  uint64_t x165;
371
333
  fiat_p256_uint1 x166;
372
- fiat_p256_addcarryx_u64(&x165, &x166, x164, x146, x160);
373
334
  uint64_t x167;
374
335
  fiat_p256_uint1 x168;
375
- fiat_p256_addcarryx_u64(&x167, &x168, x166, x148, x162);
376
336
  uint64_t x169;
377
337
  fiat_p256_uint1 x170;
378
- fiat_p256_addcarryx_u64(&x169, &x170, x168, x150, x154);
379
338
  uint64_t x171;
380
339
  fiat_p256_uint1 x172;
381
- fiat_p256_addcarryx_u64(&x171, &x172, x170, x152, x155);
382
- uint64_t x173 = ((uint64_t)x172 + x153);
340
+ uint64_t x173;
383
341
  uint64_t x174;
384
342
  fiat_p256_uint1 x175;
385
- fiat_p256_subborrowx_u64(&x174, &x175, 0x0, x165, UINT64_C(0xffffffffffffffff));
386
343
  uint64_t x176;
387
344
  fiat_p256_uint1 x177;
388
- fiat_p256_subborrowx_u64(&x176, &x177, x175, x167, UINT32_C(0xffffffff));
389
345
  uint64_t x178;
390
346
  fiat_p256_uint1 x179;
391
- fiat_p256_subborrowx_u64(&x178, &x179, x177, x169, 0x0);
392
347
  uint64_t x180;
393
348
  fiat_p256_uint1 x181;
394
- fiat_p256_subborrowx_u64(&x180, &x181, x179, x171, UINT64_C(0xffffffff00000001));
395
349
  uint64_t x182;
396
350
  fiat_p256_uint1 x183;
397
- fiat_p256_subborrowx_u64(&x182, &x183, x181, x173, 0x0);
398
351
  uint64_t x184;
399
- fiat_p256_cmovznz_u64(&x184, x183, x174, x165);
400
352
  uint64_t x185;
401
- fiat_p256_cmovznz_u64(&x185, x183, x176, x167);
402
353
  uint64_t x186;
403
- fiat_p256_cmovznz_u64(&x186, x183, x178, x169);
404
354
  uint64_t x187;
355
+ x1 = (arg1[1]);
356
+ x2 = (arg1[2]);
357
+ x3 = (arg1[3]);
358
+ x4 = (arg1[0]);
359
+ fiat_p256_mulx_u64(&x5, &x6, x4, (arg2[3]));
360
+ fiat_p256_mulx_u64(&x7, &x8, x4, (arg2[2]));
361
+ fiat_p256_mulx_u64(&x9, &x10, x4, (arg2[1]));
362
+ fiat_p256_mulx_u64(&x11, &x12, x4, (arg2[0]));
363
+ fiat_p256_addcarryx_u64(&x13, &x14, 0x0, x12, x9);
364
+ fiat_p256_addcarryx_u64(&x15, &x16, x14, x10, x7);
365
+ fiat_p256_addcarryx_u64(&x17, &x18, x16, x8, x5);
366
+ x19 = (x18 + x6);
367
+ fiat_p256_mulx_u64(&x20, &x21, x11, UINT64_C(0xffffffff00000001));
368
+ fiat_p256_mulx_u64(&x22, &x23, x11, UINT32_C(0xffffffff));
369
+ fiat_p256_mulx_u64(&x24, &x25, x11, UINT64_C(0xffffffffffffffff));
370
+ fiat_p256_addcarryx_u64(&x26, &x27, 0x0, x25, x22);
371
+ x28 = (x27 + x23);
372
+ fiat_p256_addcarryx_u64(&x29, &x30, 0x0, x11, x24);
373
+ fiat_p256_addcarryx_u64(&x31, &x32, x30, x13, x26);
374
+ fiat_p256_addcarryx_u64(&x33, &x34, x32, x15, x28);
375
+ fiat_p256_addcarryx_u64(&x35, &x36, x34, x17, x20);
376
+ fiat_p256_addcarryx_u64(&x37, &x38, x36, x19, x21);
377
+ fiat_p256_mulx_u64(&x39, &x40, x1, (arg2[3]));
378
+ fiat_p256_mulx_u64(&x41, &x42, x1, (arg2[2]));
379
+ fiat_p256_mulx_u64(&x43, &x44, x1, (arg2[1]));
380
+ fiat_p256_mulx_u64(&x45, &x46, x1, (arg2[0]));
381
+ fiat_p256_addcarryx_u64(&x47, &x48, 0x0, x46, x43);
382
+ fiat_p256_addcarryx_u64(&x49, &x50, x48, x44, x41);
383
+ fiat_p256_addcarryx_u64(&x51, &x52, x50, x42, x39);
384
+ x53 = (x52 + x40);
385
+ fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x31, x45);
386
+ fiat_p256_addcarryx_u64(&x56, &x57, x55, x33, x47);
387
+ fiat_p256_addcarryx_u64(&x58, &x59, x57, x35, x49);
388
+ fiat_p256_addcarryx_u64(&x60, &x61, x59, x37, x51);
389
+ fiat_p256_addcarryx_u64(&x62, &x63, x61, x38, x53);
390
+ fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffff00000001));
391
+ fiat_p256_mulx_u64(&x66, &x67, x54, UINT32_C(0xffffffff));
392
+ fiat_p256_mulx_u64(&x68, &x69, x54, UINT64_C(0xffffffffffffffff));
393
+ fiat_p256_addcarryx_u64(&x70, &x71, 0x0, x69, x66);
394
+ x72 = (x71 + x67);
395
+ fiat_p256_addcarryx_u64(&x73, &x74, 0x0, x54, x68);
396
+ fiat_p256_addcarryx_u64(&x75, &x76, x74, x56, x70);
397
+ fiat_p256_addcarryx_u64(&x77, &x78, x76, x58, x72);
398
+ fiat_p256_addcarryx_u64(&x79, &x80, x78, x60, x64);
399
+ fiat_p256_addcarryx_u64(&x81, &x82, x80, x62, x65);
400
+ x83 = ((uint64_t)x82 + x63);
401
+ fiat_p256_mulx_u64(&x84, &x85, x2, (arg2[3]));
402
+ fiat_p256_mulx_u64(&x86, &x87, x2, (arg2[2]));
403
+ fiat_p256_mulx_u64(&x88, &x89, x2, (arg2[1]));
404
+ fiat_p256_mulx_u64(&x90, &x91, x2, (arg2[0]));
405
+ fiat_p256_addcarryx_u64(&x92, &x93, 0x0, x91, x88);
406
+ fiat_p256_addcarryx_u64(&x94, &x95, x93, x89, x86);
407
+ fiat_p256_addcarryx_u64(&x96, &x97, x95, x87, x84);
408
+ x98 = (x97 + x85);
409
+ fiat_p256_addcarryx_u64(&x99, &x100, 0x0, x75, x90);
410
+ fiat_p256_addcarryx_u64(&x101, &x102, x100, x77, x92);
411
+ fiat_p256_addcarryx_u64(&x103, &x104, x102, x79, x94);
412
+ fiat_p256_addcarryx_u64(&x105, &x106, x104, x81, x96);
413
+ fiat_p256_addcarryx_u64(&x107, &x108, x106, x83, x98);
414
+ fiat_p256_mulx_u64(&x109, &x110, x99, UINT64_C(0xffffffff00000001));
415
+ fiat_p256_mulx_u64(&x111, &x112, x99, UINT32_C(0xffffffff));
416
+ fiat_p256_mulx_u64(&x113, &x114, x99, UINT64_C(0xffffffffffffffff));
417
+ fiat_p256_addcarryx_u64(&x115, &x116, 0x0, x114, x111);
418
+ x117 = (x116 + x112);
419
+ fiat_p256_addcarryx_u64(&x118, &x119, 0x0, x99, x113);
420
+ fiat_p256_addcarryx_u64(&x120, &x121, x119, x101, x115);
421
+ fiat_p256_addcarryx_u64(&x122, &x123, x121, x103, x117);
422
+ fiat_p256_addcarryx_u64(&x124, &x125, x123, x105, x109);
423
+ fiat_p256_addcarryx_u64(&x126, &x127, x125, x107, x110);
424
+ x128 = ((uint64_t)x127 + x108);
425
+ fiat_p256_mulx_u64(&x129, &x130, x3, (arg2[3]));
426
+ fiat_p256_mulx_u64(&x131, &x132, x3, (arg2[2]));
427
+ fiat_p256_mulx_u64(&x133, &x134, x3, (arg2[1]));
428
+ fiat_p256_mulx_u64(&x135, &x136, x3, (arg2[0]));
429
+ fiat_p256_addcarryx_u64(&x137, &x138, 0x0, x136, x133);
430
+ fiat_p256_addcarryx_u64(&x139, &x140, x138, x134, x131);
431
+ fiat_p256_addcarryx_u64(&x141, &x142, x140, x132, x129);
432
+ x143 = (x142 + x130);
433
+ fiat_p256_addcarryx_u64(&x144, &x145, 0x0, x120, x135);
434
+ fiat_p256_addcarryx_u64(&x146, &x147, x145, x122, x137);
435
+ fiat_p256_addcarryx_u64(&x148, &x149, x147, x124, x139);
436
+ fiat_p256_addcarryx_u64(&x150, &x151, x149, x126, x141);
437
+ fiat_p256_addcarryx_u64(&x152, &x153, x151, x128, x143);
438
+ fiat_p256_mulx_u64(&x154, &x155, x144, UINT64_C(0xffffffff00000001));
439
+ fiat_p256_mulx_u64(&x156, &x157, x144, UINT32_C(0xffffffff));
440
+ fiat_p256_mulx_u64(&x158, &x159, x144, UINT64_C(0xffffffffffffffff));
441
+ fiat_p256_addcarryx_u64(&x160, &x161, 0x0, x159, x156);
442
+ x162 = (x161 + x157);
443
+ fiat_p256_addcarryx_u64(&x163, &x164, 0x0, x144, x158);
444
+ fiat_p256_addcarryx_u64(&x165, &x166, x164, x146, x160);
445
+ fiat_p256_addcarryx_u64(&x167, &x168, x166, x148, x162);
446
+ fiat_p256_addcarryx_u64(&x169, &x170, x168, x150, x154);
447
+ fiat_p256_addcarryx_u64(&x171, &x172, x170, x152, x155);
448
+ x173 = ((uint64_t)x172 + x153);
449
+ fiat_p256_subborrowx_u64(&x174, &x175, 0x0, x165, UINT64_C(0xffffffffffffffff));
450
+ fiat_p256_subborrowx_u64(&x176, &x177, x175, x167, UINT32_C(0xffffffff));
451
+ fiat_p256_subborrowx_u64(&x178, &x179, x177, x169, 0x0);
452
+ fiat_p256_subborrowx_u64(&x180, &x181, x179, x171, UINT64_C(0xffffffff00000001));
453
+ fiat_p256_subborrowx_u64(&x182, &x183, x181, x173, 0x0);
454
+ fiat_p256_cmovznz_u64(&x184, x183, x174, x165);
455
+ fiat_p256_cmovznz_u64(&x185, x183, x176, x167);
456
+ fiat_p256_cmovznz_u64(&x186, x183, x178, x169);
405
457
  fiat_p256_cmovznz_u64(&x187, x183, x180, x171);
406
458
  out1[0] = x184;
407
459
  out1[1] = x185;
@@ -411,292 +463,304 @@ static void fiat_p256_mul(uint64_t out1[4], const uint64_t arg1[4], const uint64
411
463
 
412
464
  /*
413
465
  * The function fiat_p256_square squares a field element in the Montgomery domain.
466
+ *
414
467
  * Preconditions:
415
468
  * 0 ≤ eval arg1 < m
416
469
  * Postconditions:
417
470
  * eval (from_montgomery out1) mod m = (eval (from_montgomery arg1) * eval (from_montgomery arg1)) mod m
418
471
  * 0 ≤ eval out1 < m
419
472
  *
420
- * Input Bounds:
421
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
422
- * Output Bounds:
423
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
424
473
  */
425
- static void fiat_p256_square(uint64_t out1[4], const uint64_t arg1[4]) {
426
- uint64_t x1 = (arg1[1]);
427
- uint64_t x2 = (arg1[2]);
428
- uint64_t x3 = (arg1[3]);
429
- uint64_t x4 = (arg1[0]);
474
+ static FIAT_P256_FIAT_INLINE void fiat_p256_square(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1) {
475
+ uint64_t x1;
476
+ uint64_t x2;
477
+ uint64_t x3;
478
+ uint64_t x4;
430
479
  uint64_t x5;
431
480
  uint64_t x6;
432
- fiat_p256_mulx_u64(&x5, &x6, x4, (arg1[3]));
433
481
  uint64_t x7;
434
482
  uint64_t x8;
435
- fiat_p256_mulx_u64(&x7, &x8, x4, (arg1[2]));
436
483
  uint64_t x9;
437
484
  uint64_t x10;
438
- fiat_p256_mulx_u64(&x9, &x10, x4, (arg1[1]));
439
485
  uint64_t x11;
440
486
  uint64_t x12;
441
- fiat_p256_mulx_u64(&x11, &x12, x4, (arg1[0]));
442
487
  uint64_t x13;
443
488
  fiat_p256_uint1 x14;
444
- fiat_p256_addcarryx_u64(&x13, &x14, 0x0, x12, x9);
445
489
  uint64_t x15;
446
490
  fiat_p256_uint1 x16;
447
- fiat_p256_addcarryx_u64(&x15, &x16, x14, x10, x7);
448
491
  uint64_t x17;
449
492
  fiat_p256_uint1 x18;
450
- fiat_p256_addcarryx_u64(&x17, &x18, x16, x8, x5);
451
- uint64_t x19 = (x18 + x6);
493
+ uint64_t x19;
452
494
  uint64_t x20;
453
495
  uint64_t x21;
454
- fiat_p256_mulx_u64(&x20, &x21, x11, UINT64_C(0xffffffff00000001));
455
496
  uint64_t x22;
456
497
  uint64_t x23;
457
- fiat_p256_mulx_u64(&x22, &x23, x11, UINT32_C(0xffffffff));
458
498
  uint64_t x24;
459
499
  uint64_t x25;
460
- fiat_p256_mulx_u64(&x24, &x25, x11, UINT64_C(0xffffffffffffffff));
461
500
  uint64_t x26;
462
501
  fiat_p256_uint1 x27;
463
- fiat_p256_addcarryx_u64(&x26, &x27, 0x0, x25, x22);
464
- uint64_t x28 = (x27 + x23);
502
+ uint64_t x28;
465
503
  uint64_t x29;
466
504
  fiat_p256_uint1 x30;
467
- fiat_p256_addcarryx_u64(&x29, &x30, 0x0, x11, x24);
468
505
  uint64_t x31;
469
506
  fiat_p256_uint1 x32;
470
- fiat_p256_addcarryx_u64(&x31, &x32, x30, x13, x26);
471
507
  uint64_t x33;
472
508
  fiat_p256_uint1 x34;
473
- fiat_p256_addcarryx_u64(&x33, &x34, x32, x15, x28);
474
509
  uint64_t x35;
475
510
  fiat_p256_uint1 x36;
476
- fiat_p256_addcarryx_u64(&x35, &x36, x34, x17, x20);
477
511
  uint64_t x37;
478
512
  fiat_p256_uint1 x38;
479
- fiat_p256_addcarryx_u64(&x37, &x38, x36, x19, x21);
480
513
  uint64_t x39;
481
514
  uint64_t x40;
482
- fiat_p256_mulx_u64(&x39, &x40, x1, (arg1[3]));
483
515
  uint64_t x41;
484
516
  uint64_t x42;
485
- fiat_p256_mulx_u64(&x41, &x42, x1, (arg1[2]));
486
517
  uint64_t x43;
487
518
  uint64_t x44;
488
- fiat_p256_mulx_u64(&x43, &x44, x1, (arg1[1]));
489
519
  uint64_t x45;
490
520
  uint64_t x46;
491
- fiat_p256_mulx_u64(&x45, &x46, x1, (arg1[0]));
492
521
  uint64_t x47;
493
522
  fiat_p256_uint1 x48;
494
- fiat_p256_addcarryx_u64(&x47, &x48, 0x0, x46, x43);
495
523
  uint64_t x49;
496
524
  fiat_p256_uint1 x50;
497
- fiat_p256_addcarryx_u64(&x49, &x50, x48, x44, x41);
498
525
  uint64_t x51;
499
526
  fiat_p256_uint1 x52;
500
- fiat_p256_addcarryx_u64(&x51, &x52, x50, x42, x39);
501
- uint64_t x53 = (x52 + x40);
527
+ uint64_t x53;
502
528
  uint64_t x54;
503
529
  fiat_p256_uint1 x55;
504
- fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x31, x45);
505
530
  uint64_t x56;
506
531
  fiat_p256_uint1 x57;
507
- fiat_p256_addcarryx_u64(&x56, &x57, x55, x33, x47);
508
532
  uint64_t x58;
509
533
  fiat_p256_uint1 x59;
510
- fiat_p256_addcarryx_u64(&x58, &x59, x57, x35, x49);
511
534
  uint64_t x60;
512
535
  fiat_p256_uint1 x61;
513
- fiat_p256_addcarryx_u64(&x60, &x61, x59, x37, x51);
514
536
  uint64_t x62;
515
537
  fiat_p256_uint1 x63;
516
- fiat_p256_addcarryx_u64(&x62, &x63, x61, x38, x53);
517
538
  uint64_t x64;
518
539
  uint64_t x65;
519
- fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffff00000001));
520
540
  uint64_t x66;
521
541
  uint64_t x67;
522
- fiat_p256_mulx_u64(&x66, &x67, x54, UINT32_C(0xffffffff));
523
542
  uint64_t x68;
524
543
  uint64_t x69;
525
- fiat_p256_mulx_u64(&x68, &x69, x54, UINT64_C(0xffffffffffffffff));
526
544
  uint64_t x70;
527
545
  fiat_p256_uint1 x71;
528
- fiat_p256_addcarryx_u64(&x70, &x71, 0x0, x69, x66);
529
- uint64_t x72 = (x71 + x67);
546
+ uint64_t x72;
530
547
  uint64_t x73;
531
548
  fiat_p256_uint1 x74;
532
- fiat_p256_addcarryx_u64(&x73, &x74, 0x0, x54, x68);
533
549
  uint64_t x75;
534
550
  fiat_p256_uint1 x76;
535
- fiat_p256_addcarryx_u64(&x75, &x76, x74, x56, x70);
536
551
  uint64_t x77;
537
552
  fiat_p256_uint1 x78;
538
- fiat_p256_addcarryx_u64(&x77, &x78, x76, x58, x72);
539
553
  uint64_t x79;
540
554
  fiat_p256_uint1 x80;
541
- fiat_p256_addcarryx_u64(&x79, &x80, x78, x60, x64);
542
555
  uint64_t x81;
543
556
  fiat_p256_uint1 x82;
544
- fiat_p256_addcarryx_u64(&x81, &x82, x80, x62, x65);
545
- uint64_t x83 = ((uint64_t)x82 + x63);
557
+ uint64_t x83;
546
558
  uint64_t x84;
547
559
  uint64_t x85;
548
- fiat_p256_mulx_u64(&x84, &x85, x2, (arg1[3]));
549
560
  uint64_t x86;
550
561
  uint64_t x87;
551
- fiat_p256_mulx_u64(&x86, &x87, x2, (arg1[2]));
552
562
  uint64_t x88;
553
563
  uint64_t x89;
554
- fiat_p256_mulx_u64(&x88, &x89, x2, (arg1[1]));
555
564
  uint64_t x90;
556
565
  uint64_t x91;
557
- fiat_p256_mulx_u64(&x90, &x91, x2, (arg1[0]));
558
566
  uint64_t x92;
559
567
  fiat_p256_uint1 x93;
560
- fiat_p256_addcarryx_u64(&x92, &x93, 0x0, x91, x88);
561
568
  uint64_t x94;
562
569
  fiat_p256_uint1 x95;
563
- fiat_p256_addcarryx_u64(&x94, &x95, x93, x89, x86);
564
570
  uint64_t x96;
565
571
  fiat_p256_uint1 x97;
566
- fiat_p256_addcarryx_u64(&x96, &x97, x95, x87, x84);
567
- uint64_t x98 = (x97 + x85);
572
+ uint64_t x98;
568
573
  uint64_t x99;
569
574
  fiat_p256_uint1 x100;
570
- fiat_p256_addcarryx_u64(&x99, &x100, 0x0, x75, x90);
571
575
  uint64_t x101;
572
576
  fiat_p256_uint1 x102;
573
- fiat_p256_addcarryx_u64(&x101, &x102, x100, x77, x92);
574
577
  uint64_t x103;
575
578
  fiat_p256_uint1 x104;
576
- fiat_p256_addcarryx_u64(&x103, &x104, x102, x79, x94);
577
579
  uint64_t x105;
578
580
  fiat_p256_uint1 x106;
579
- fiat_p256_addcarryx_u64(&x105, &x106, x104, x81, x96);
580
581
  uint64_t x107;
581
582
  fiat_p256_uint1 x108;
582
- fiat_p256_addcarryx_u64(&x107, &x108, x106, x83, x98);
583
583
  uint64_t x109;
584
584
  uint64_t x110;
585
- fiat_p256_mulx_u64(&x109, &x110, x99, UINT64_C(0xffffffff00000001));
586
585
  uint64_t x111;
587
586
  uint64_t x112;
588
- fiat_p256_mulx_u64(&x111, &x112, x99, UINT32_C(0xffffffff));
589
587
  uint64_t x113;
590
588
  uint64_t x114;
591
- fiat_p256_mulx_u64(&x113, &x114, x99, UINT64_C(0xffffffffffffffff));
592
589
  uint64_t x115;
593
590
  fiat_p256_uint1 x116;
594
- fiat_p256_addcarryx_u64(&x115, &x116, 0x0, x114, x111);
595
- uint64_t x117 = (x116 + x112);
591
+ uint64_t x117;
596
592
  uint64_t x118;
597
593
  fiat_p256_uint1 x119;
598
- fiat_p256_addcarryx_u64(&x118, &x119, 0x0, x99, x113);
599
594
  uint64_t x120;
600
595
  fiat_p256_uint1 x121;
601
- fiat_p256_addcarryx_u64(&x120, &x121, x119, x101, x115);
602
596
  uint64_t x122;
603
597
  fiat_p256_uint1 x123;
604
- fiat_p256_addcarryx_u64(&x122, &x123, x121, x103, x117);
605
598
  uint64_t x124;
606
599
  fiat_p256_uint1 x125;
607
- fiat_p256_addcarryx_u64(&x124, &x125, x123, x105, x109);
608
600
  uint64_t x126;
609
601
  fiat_p256_uint1 x127;
610
- fiat_p256_addcarryx_u64(&x126, &x127, x125, x107, x110);
611
- uint64_t x128 = ((uint64_t)x127 + x108);
602
+ uint64_t x128;
612
603
  uint64_t x129;
613
604
  uint64_t x130;
614
- fiat_p256_mulx_u64(&x129, &x130, x3, (arg1[3]));
615
605
  uint64_t x131;
616
606
  uint64_t x132;
617
- fiat_p256_mulx_u64(&x131, &x132, x3, (arg1[2]));
618
607
  uint64_t x133;
619
608
  uint64_t x134;
620
- fiat_p256_mulx_u64(&x133, &x134, x3, (arg1[1]));
621
609
  uint64_t x135;
622
610
  uint64_t x136;
623
- fiat_p256_mulx_u64(&x135, &x136, x3, (arg1[0]));
624
611
  uint64_t x137;
625
612
  fiat_p256_uint1 x138;
626
- fiat_p256_addcarryx_u64(&x137, &x138, 0x0, x136, x133);
627
613
  uint64_t x139;
628
614
  fiat_p256_uint1 x140;
629
- fiat_p256_addcarryx_u64(&x139, &x140, x138, x134, x131);
630
615
  uint64_t x141;
631
616
  fiat_p256_uint1 x142;
632
- fiat_p256_addcarryx_u64(&x141, &x142, x140, x132, x129);
633
- uint64_t x143 = (x142 + x130);
617
+ uint64_t x143;
634
618
  uint64_t x144;
635
619
  fiat_p256_uint1 x145;
636
- fiat_p256_addcarryx_u64(&x144, &x145, 0x0, x120, x135);
637
620
  uint64_t x146;
638
621
  fiat_p256_uint1 x147;
639
- fiat_p256_addcarryx_u64(&x146, &x147, x145, x122, x137);
640
622
  uint64_t x148;
641
623
  fiat_p256_uint1 x149;
642
- fiat_p256_addcarryx_u64(&x148, &x149, x147, x124, x139);
643
624
  uint64_t x150;
644
625
  fiat_p256_uint1 x151;
645
- fiat_p256_addcarryx_u64(&x150, &x151, x149, x126, x141);
646
626
  uint64_t x152;
647
627
  fiat_p256_uint1 x153;
648
- fiat_p256_addcarryx_u64(&x152, &x153, x151, x128, x143);
649
628
  uint64_t x154;
650
629
  uint64_t x155;
651
- fiat_p256_mulx_u64(&x154, &x155, x144, UINT64_C(0xffffffff00000001));
652
630
  uint64_t x156;
653
631
  uint64_t x157;
654
- fiat_p256_mulx_u64(&x156, &x157, x144, UINT32_C(0xffffffff));
655
632
  uint64_t x158;
656
633
  uint64_t x159;
657
- fiat_p256_mulx_u64(&x158, &x159, x144, UINT64_C(0xffffffffffffffff));
658
634
  uint64_t x160;
659
635
  fiat_p256_uint1 x161;
660
- fiat_p256_addcarryx_u64(&x160, &x161, 0x0, x159, x156);
661
- uint64_t x162 = (x161 + x157);
636
+ uint64_t x162;
662
637
  uint64_t x163;
663
638
  fiat_p256_uint1 x164;
664
- fiat_p256_addcarryx_u64(&x163, &x164, 0x0, x144, x158);
665
639
  uint64_t x165;
666
640
  fiat_p256_uint1 x166;
667
- fiat_p256_addcarryx_u64(&x165, &x166, x164, x146, x160);
668
641
  uint64_t x167;
669
642
  fiat_p256_uint1 x168;
670
- fiat_p256_addcarryx_u64(&x167, &x168, x166, x148, x162);
671
643
  uint64_t x169;
672
644
  fiat_p256_uint1 x170;
673
- fiat_p256_addcarryx_u64(&x169, &x170, x168, x150, x154);
674
645
  uint64_t x171;
675
646
  fiat_p256_uint1 x172;
676
- fiat_p256_addcarryx_u64(&x171, &x172, x170, x152, x155);
677
- uint64_t x173 = ((uint64_t)x172 + x153);
647
+ uint64_t x173;
678
648
  uint64_t x174;
679
649
  fiat_p256_uint1 x175;
680
- fiat_p256_subborrowx_u64(&x174, &x175, 0x0, x165, UINT64_C(0xffffffffffffffff));
681
650
  uint64_t x176;
682
651
  fiat_p256_uint1 x177;
683
- fiat_p256_subborrowx_u64(&x176, &x177, x175, x167, UINT32_C(0xffffffff));
684
652
  uint64_t x178;
685
653
  fiat_p256_uint1 x179;
686
- fiat_p256_subborrowx_u64(&x178, &x179, x177, x169, 0x0);
687
654
  uint64_t x180;
688
655
  fiat_p256_uint1 x181;
689
- fiat_p256_subborrowx_u64(&x180, &x181, x179, x171, UINT64_C(0xffffffff00000001));
690
656
  uint64_t x182;
691
657
  fiat_p256_uint1 x183;
692
- fiat_p256_subborrowx_u64(&x182, &x183, x181, x173, 0x0);
693
658
  uint64_t x184;
694
- fiat_p256_cmovznz_u64(&x184, x183, x174, x165);
695
659
  uint64_t x185;
696
- fiat_p256_cmovznz_u64(&x185, x183, x176, x167);
697
660
  uint64_t x186;
698
- fiat_p256_cmovznz_u64(&x186, x183, x178, x169);
699
661
  uint64_t x187;
662
+ x1 = (arg1[1]);
663
+ x2 = (arg1[2]);
664
+ x3 = (arg1[3]);
665
+ x4 = (arg1[0]);
666
+ fiat_p256_mulx_u64(&x5, &x6, x4, (arg1[3]));
667
+ fiat_p256_mulx_u64(&x7, &x8, x4, (arg1[2]));
668
+ fiat_p256_mulx_u64(&x9, &x10, x4, (arg1[1]));
669
+ fiat_p256_mulx_u64(&x11, &x12, x4, (arg1[0]));
670
+ fiat_p256_addcarryx_u64(&x13, &x14, 0x0, x12, x9);
671
+ fiat_p256_addcarryx_u64(&x15, &x16, x14, x10, x7);
672
+ fiat_p256_addcarryx_u64(&x17, &x18, x16, x8, x5);
673
+ x19 = (x18 + x6);
674
+ fiat_p256_mulx_u64(&x20, &x21, x11, UINT64_C(0xffffffff00000001));
675
+ fiat_p256_mulx_u64(&x22, &x23, x11, UINT32_C(0xffffffff));
676
+ fiat_p256_mulx_u64(&x24, &x25, x11, UINT64_C(0xffffffffffffffff));
677
+ fiat_p256_addcarryx_u64(&x26, &x27, 0x0, x25, x22);
678
+ x28 = (x27 + x23);
679
+ fiat_p256_addcarryx_u64(&x29, &x30, 0x0, x11, x24);
680
+ fiat_p256_addcarryx_u64(&x31, &x32, x30, x13, x26);
681
+ fiat_p256_addcarryx_u64(&x33, &x34, x32, x15, x28);
682
+ fiat_p256_addcarryx_u64(&x35, &x36, x34, x17, x20);
683
+ fiat_p256_addcarryx_u64(&x37, &x38, x36, x19, x21);
684
+ fiat_p256_mulx_u64(&x39, &x40, x1, (arg1[3]));
685
+ fiat_p256_mulx_u64(&x41, &x42, x1, (arg1[2]));
686
+ fiat_p256_mulx_u64(&x43, &x44, x1, (arg1[1]));
687
+ fiat_p256_mulx_u64(&x45, &x46, x1, (arg1[0]));
688
+ fiat_p256_addcarryx_u64(&x47, &x48, 0x0, x46, x43);
689
+ fiat_p256_addcarryx_u64(&x49, &x50, x48, x44, x41);
690
+ fiat_p256_addcarryx_u64(&x51, &x52, x50, x42, x39);
691
+ x53 = (x52 + x40);
692
+ fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x31, x45);
693
+ fiat_p256_addcarryx_u64(&x56, &x57, x55, x33, x47);
694
+ fiat_p256_addcarryx_u64(&x58, &x59, x57, x35, x49);
695
+ fiat_p256_addcarryx_u64(&x60, &x61, x59, x37, x51);
696
+ fiat_p256_addcarryx_u64(&x62, &x63, x61, x38, x53);
697
+ fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffff00000001));
698
+ fiat_p256_mulx_u64(&x66, &x67, x54, UINT32_C(0xffffffff));
699
+ fiat_p256_mulx_u64(&x68, &x69, x54, UINT64_C(0xffffffffffffffff));
700
+ fiat_p256_addcarryx_u64(&x70, &x71, 0x0, x69, x66);
701
+ x72 = (x71 + x67);
702
+ fiat_p256_addcarryx_u64(&x73, &x74, 0x0, x54, x68);
703
+ fiat_p256_addcarryx_u64(&x75, &x76, x74, x56, x70);
704
+ fiat_p256_addcarryx_u64(&x77, &x78, x76, x58, x72);
705
+ fiat_p256_addcarryx_u64(&x79, &x80, x78, x60, x64);
706
+ fiat_p256_addcarryx_u64(&x81, &x82, x80, x62, x65);
707
+ x83 = ((uint64_t)x82 + x63);
708
+ fiat_p256_mulx_u64(&x84, &x85, x2, (arg1[3]));
709
+ fiat_p256_mulx_u64(&x86, &x87, x2, (arg1[2]));
710
+ fiat_p256_mulx_u64(&x88, &x89, x2, (arg1[1]));
711
+ fiat_p256_mulx_u64(&x90, &x91, x2, (arg1[0]));
712
+ fiat_p256_addcarryx_u64(&x92, &x93, 0x0, x91, x88);
713
+ fiat_p256_addcarryx_u64(&x94, &x95, x93, x89, x86);
714
+ fiat_p256_addcarryx_u64(&x96, &x97, x95, x87, x84);
715
+ x98 = (x97 + x85);
716
+ fiat_p256_addcarryx_u64(&x99, &x100, 0x0, x75, x90);
717
+ fiat_p256_addcarryx_u64(&x101, &x102, x100, x77, x92);
718
+ fiat_p256_addcarryx_u64(&x103, &x104, x102, x79, x94);
719
+ fiat_p256_addcarryx_u64(&x105, &x106, x104, x81, x96);
720
+ fiat_p256_addcarryx_u64(&x107, &x108, x106, x83, x98);
721
+ fiat_p256_mulx_u64(&x109, &x110, x99, UINT64_C(0xffffffff00000001));
722
+ fiat_p256_mulx_u64(&x111, &x112, x99, UINT32_C(0xffffffff));
723
+ fiat_p256_mulx_u64(&x113, &x114, x99, UINT64_C(0xffffffffffffffff));
724
+ fiat_p256_addcarryx_u64(&x115, &x116, 0x0, x114, x111);
725
+ x117 = (x116 + x112);
726
+ fiat_p256_addcarryx_u64(&x118, &x119, 0x0, x99, x113);
727
+ fiat_p256_addcarryx_u64(&x120, &x121, x119, x101, x115);
728
+ fiat_p256_addcarryx_u64(&x122, &x123, x121, x103, x117);
729
+ fiat_p256_addcarryx_u64(&x124, &x125, x123, x105, x109);
730
+ fiat_p256_addcarryx_u64(&x126, &x127, x125, x107, x110);
731
+ x128 = ((uint64_t)x127 + x108);
732
+ fiat_p256_mulx_u64(&x129, &x130, x3, (arg1[3]));
733
+ fiat_p256_mulx_u64(&x131, &x132, x3, (arg1[2]));
734
+ fiat_p256_mulx_u64(&x133, &x134, x3, (arg1[1]));
735
+ fiat_p256_mulx_u64(&x135, &x136, x3, (arg1[0]));
736
+ fiat_p256_addcarryx_u64(&x137, &x138, 0x0, x136, x133);
737
+ fiat_p256_addcarryx_u64(&x139, &x140, x138, x134, x131);
738
+ fiat_p256_addcarryx_u64(&x141, &x142, x140, x132, x129);
739
+ x143 = (x142 + x130);
740
+ fiat_p256_addcarryx_u64(&x144, &x145, 0x0, x120, x135);
741
+ fiat_p256_addcarryx_u64(&x146, &x147, x145, x122, x137);
742
+ fiat_p256_addcarryx_u64(&x148, &x149, x147, x124, x139);
743
+ fiat_p256_addcarryx_u64(&x150, &x151, x149, x126, x141);
744
+ fiat_p256_addcarryx_u64(&x152, &x153, x151, x128, x143);
745
+ fiat_p256_mulx_u64(&x154, &x155, x144, UINT64_C(0xffffffff00000001));
746
+ fiat_p256_mulx_u64(&x156, &x157, x144, UINT32_C(0xffffffff));
747
+ fiat_p256_mulx_u64(&x158, &x159, x144, UINT64_C(0xffffffffffffffff));
748
+ fiat_p256_addcarryx_u64(&x160, &x161, 0x0, x159, x156);
749
+ x162 = (x161 + x157);
750
+ fiat_p256_addcarryx_u64(&x163, &x164, 0x0, x144, x158);
751
+ fiat_p256_addcarryx_u64(&x165, &x166, x164, x146, x160);
752
+ fiat_p256_addcarryx_u64(&x167, &x168, x166, x148, x162);
753
+ fiat_p256_addcarryx_u64(&x169, &x170, x168, x150, x154);
754
+ fiat_p256_addcarryx_u64(&x171, &x172, x170, x152, x155);
755
+ x173 = ((uint64_t)x172 + x153);
756
+ fiat_p256_subborrowx_u64(&x174, &x175, 0x0, x165, UINT64_C(0xffffffffffffffff));
757
+ fiat_p256_subborrowx_u64(&x176, &x177, x175, x167, UINT32_C(0xffffffff));
758
+ fiat_p256_subborrowx_u64(&x178, &x179, x177, x169, 0x0);
759
+ fiat_p256_subborrowx_u64(&x180, &x181, x179, x171, UINT64_C(0xffffffff00000001));
760
+ fiat_p256_subborrowx_u64(&x182, &x183, x181, x173, 0x0);
761
+ fiat_p256_cmovznz_u64(&x184, x183, x174, x165);
762
+ fiat_p256_cmovznz_u64(&x185, x183, x176, x167);
763
+ fiat_p256_cmovznz_u64(&x186, x183, x178, x169);
700
764
  fiat_p256_cmovznz_u64(&x187, x183, x180, x171);
701
765
  out1[0] = x184;
702
766
  out1[1] = x185;
@@ -706,6 +770,7 @@ static void fiat_p256_square(uint64_t out1[4], const uint64_t arg1[4]) {
706
770
 
707
771
  /*
708
772
  * The function fiat_p256_add adds two field elements in the Montgomery domain.
773
+ *
709
774
  * Preconditions:
710
775
  * 0 ≤ eval arg1 < m
711
776
  * 0 ≤ eval arg2 < m
@@ -713,47 +778,42 @@ static void fiat_p256_square(uint64_t out1[4], const uint64_t arg1[4]) {
713
778
  * eval (from_montgomery out1) mod m = (eval (from_montgomery arg1) + eval (from_montgomery arg2)) mod m
714
779
  * 0 ≤ eval out1 < m
715
780
  *
716
- * Input Bounds:
717
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
718
- * arg2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
719
- * Output Bounds:
720
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
721
781
  */
722
- static void fiat_p256_add(uint64_t out1[4], const uint64_t arg1[4], const uint64_t arg2[4]) {
782
+ static FIAT_P256_FIAT_INLINE void fiat_p256_add(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1, const fiat_p256_montgomery_domain_field_element arg2) {
723
783
  uint64_t x1;
724
784
  fiat_p256_uint1 x2;
725
- fiat_p256_addcarryx_u64(&x1, &x2, 0x0, (arg1[0]), (arg2[0]));
726
785
  uint64_t x3;
727
786
  fiat_p256_uint1 x4;
728
- fiat_p256_addcarryx_u64(&x3, &x4, x2, (arg1[1]), (arg2[1]));
729
787
  uint64_t x5;
730
788
  fiat_p256_uint1 x6;
731
- fiat_p256_addcarryx_u64(&x5, &x6, x4, (arg1[2]), (arg2[2]));
732
789
  uint64_t x7;
733
790
  fiat_p256_uint1 x8;
734
- fiat_p256_addcarryx_u64(&x7, &x8, x6, (arg1[3]), (arg2[3]));
735
791
  uint64_t x9;
736
792
  fiat_p256_uint1 x10;
737
- fiat_p256_subborrowx_u64(&x9, &x10, 0x0, x1, UINT64_C(0xffffffffffffffff));
738
793
  uint64_t x11;
739
794
  fiat_p256_uint1 x12;
740
- fiat_p256_subborrowx_u64(&x11, &x12, x10, x3, UINT32_C(0xffffffff));
741
795
  uint64_t x13;
742
796
  fiat_p256_uint1 x14;
743
- fiat_p256_subborrowx_u64(&x13, &x14, x12, x5, 0x0);
744
797
  uint64_t x15;
745
798
  fiat_p256_uint1 x16;
746
- fiat_p256_subborrowx_u64(&x15, &x16, x14, x7, UINT64_C(0xffffffff00000001));
747
799
  uint64_t x17;
748
800
  fiat_p256_uint1 x18;
749
- fiat_p256_subborrowx_u64(&x17, &x18, x16, x8, 0x0);
750
801
  uint64_t x19;
751
- fiat_p256_cmovznz_u64(&x19, x18, x9, x1);
752
802
  uint64_t x20;
753
- fiat_p256_cmovznz_u64(&x20, x18, x11, x3);
754
803
  uint64_t x21;
755
- fiat_p256_cmovznz_u64(&x21, x18, x13, x5);
756
804
  uint64_t x22;
805
+ fiat_p256_addcarryx_u64(&x1, &x2, 0x0, (arg1[0]), (arg2[0]));
806
+ fiat_p256_addcarryx_u64(&x3, &x4, x2, (arg1[1]), (arg2[1]));
807
+ fiat_p256_addcarryx_u64(&x5, &x6, x4, (arg1[2]), (arg2[2]));
808
+ fiat_p256_addcarryx_u64(&x7, &x8, x6, (arg1[3]), (arg2[3]));
809
+ fiat_p256_subborrowx_u64(&x9, &x10, 0x0, x1, UINT64_C(0xffffffffffffffff));
810
+ fiat_p256_subborrowx_u64(&x11, &x12, x10, x3, UINT32_C(0xffffffff));
811
+ fiat_p256_subborrowx_u64(&x13, &x14, x12, x5, 0x0);
812
+ fiat_p256_subborrowx_u64(&x15, &x16, x14, x7, UINT64_C(0xffffffff00000001));
813
+ fiat_p256_subborrowx_u64(&x17, &x18, x16, x8, 0x0);
814
+ fiat_p256_cmovznz_u64(&x19, x18, x9, x1);
815
+ fiat_p256_cmovznz_u64(&x20, x18, x11, x3);
816
+ fiat_p256_cmovznz_u64(&x21, x18, x13, x5);
757
817
  fiat_p256_cmovznz_u64(&x22, x18, x15, x7);
758
818
  out1[0] = x19;
759
819
  out1[1] = x20;
@@ -763,6 +823,7 @@ static void fiat_p256_add(uint64_t out1[4], const uint64_t arg1[4], const uint64
763
823
 
764
824
  /*
765
825
  * The function fiat_p256_sub subtracts two field elements in the Montgomery domain.
826
+ *
766
827
  * Preconditions:
767
828
  * 0 ≤ eval arg1 < m
768
829
  * 0 ≤ eval arg2 < m
@@ -770,38 +831,33 @@ static void fiat_p256_add(uint64_t out1[4], const uint64_t arg1[4], const uint64
770
831
  * eval (from_montgomery out1) mod m = (eval (from_montgomery arg1) - eval (from_montgomery arg2)) mod m
771
832
  * 0 ≤ eval out1 < m
772
833
  *
773
- * Input Bounds:
774
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
775
- * arg2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
776
- * Output Bounds:
777
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
778
834
  */
779
- static void fiat_p256_sub(uint64_t out1[4], const uint64_t arg1[4], const uint64_t arg2[4]) {
835
+ static FIAT_P256_FIAT_INLINE void fiat_p256_sub(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1, const fiat_p256_montgomery_domain_field_element arg2) {
780
836
  uint64_t x1;
781
837
  fiat_p256_uint1 x2;
782
- fiat_p256_subborrowx_u64(&x1, &x2, 0x0, (arg1[0]), (arg2[0]));
783
838
  uint64_t x3;
784
839
  fiat_p256_uint1 x4;
785
- fiat_p256_subborrowx_u64(&x3, &x4, x2, (arg1[1]), (arg2[1]));
786
840
  uint64_t x5;
787
841
  fiat_p256_uint1 x6;
788
- fiat_p256_subborrowx_u64(&x5, &x6, x4, (arg1[2]), (arg2[2]));
789
842
  uint64_t x7;
790
843
  fiat_p256_uint1 x8;
791
- fiat_p256_subborrowx_u64(&x7, &x8, x6, (arg1[3]), (arg2[3]));
792
844
  uint64_t x9;
793
- fiat_p256_cmovznz_u64(&x9, x8, 0x0, UINT64_C(0xffffffffffffffff));
794
845
  uint64_t x10;
795
846
  fiat_p256_uint1 x11;
796
- fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, (x9 & UINT64_C(0xffffffffffffffff)));
797
847
  uint64_t x12;
798
848
  fiat_p256_uint1 x13;
799
- fiat_p256_addcarryx_u64(&x12, &x13, x11, x3, (x9 & UINT32_C(0xffffffff)));
800
849
  uint64_t x14;
801
850
  fiat_p256_uint1 x15;
802
- fiat_p256_addcarryx_u64(&x14, &x15, x13, x5, 0x0);
803
851
  uint64_t x16;
804
852
  fiat_p256_uint1 x17;
853
+ fiat_p256_subborrowx_u64(&x1, &x2, 0x0, (arg1[0]), (arg2[0]));
854
+ fiat_p256_subborrowx_u64(&x3, &x4, x2, (arg1[1]), (arg2[1]));
855
+ fiat_p256_subborrowx_u64(&x5, &x6, x4, (arg1[2]), (arg2[2]));
856
+ fiat_p256_subborrowx_u64(&x7, &x8, x6, (arg1[3]), (arg2[3]));
857
+ fiat_p256_cmovznz_u64(&x9, x8, 0x0, UINT64_C(0xffffffffffffffff));
858
+ fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, x9);
859
+ fiat_p256_addcarryx_u64(&x12, &x13, x11, x3, (x9 & UINT32_C(0xffffffff)));
860
+ fiat_p256_addcarryx_u64(&x14, &x15, x13, x5, 0x0);
805
861
  fiat_p256_addcarryx_u64(&x16, &x17, x15, x7, (x9 & UINT64_C(0xffffffff00000001)));
806
862
  out1[0] = x10;
807
863
  out1[1] = x12;
@@ -811,43 +867,40 @@ static void fiat_p256_sub(uint64_t out1[4], const uint64_t arg1[4], const uint64
811
867
 
812
868
  /*
813
869
  * The function fiat_p256_opp negates a field element in the Montgomery domain.
870
+ *
814
871
  * Preconditions:
815
872
  * 0 ≤ eval arg1 < m
816
873
  * Postconditions:
817
874
  * eval (from_montgomery out1) mod m = -eval (from_montgomery arg1) mod m
818
875
  * 0 ≤ eval out1 < m
819
876
  *
820
- * Input Bounds:
821
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
822
- * Output Bounds:
823
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
824
877
  */
825
- static void fiat_p256_opp(uint64_t out1[4], const uint64_t arg1[4]) {
878
+ static FIAT_P256_FIAT_INLINE void fiat_p256_opp(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1) {
826
879
  uint64_t x1;
827
880
  fiat_p256_uint1 x2;
828
- fiat_p256_subborrowx_u64(&x1, &x2, 0x0, 0x0, (arg1[0]));
829
881
  uint64_t x3;
830
882
  fiat_p256_uint1 x4;
831
- fiat_p256_subborrowx_u64(&x3, &x4, x2, 0x0, (arg1[1]));
832
883
  uint64_t x5;
833
884
  fiat_p256_uint1 x6;
834
- fiat_p256_subborrowx_u64(&x5, &x6, x4, 0x0, (arg1[2]));
835
885
  uint64_t x7;
836
886
  fiat_p256_uint1 x8;
837
- fiat_p256_subborrowx_u64(&x7, &x8, x6, 0x0, (arg1[3]));
838
887
  uint64_t x9;
839
- fiat_p256_cmovznz_u64(&x9, x8, 0x0, UINT64_C(0xffffffffffffffff));
840
888
  uint64_t x10;
841
889
  fiat_p256_uint1 x11;
842
- fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, (x9 & UINT64_C(0xffffffffffffffff)));
843
890
  uint64_t x12;
844
891
  fiat_p256_uint1 x13;
845
- fiat_p256_addcarryx_u64(&x12, &x13, x11, x3, (x9 & UINT32_C(0xffffffff)));
846
892
  uint64_t x14;
847
893
  fiat_p256_uint1 x15;
848
- fiat_p256_addcarryx_u64(&x14, &x15, x13, x5, 0x0);
849
894
  uint64_t x16;
850
895
  fiat_p256_uint1 x17;
896
+ fiat_p256_subborrowx_u64(&x1, &x2, 0x0, 0x0, (arg1[0]));
897
+ fiat_p256_subborrowx_u64(&x3, &x4, x2, 0x0, (arg1[1]));
898
+ fiat_p256_subborrowx_u64(&x5, &x6, x4, 0x0, (arg1[2]));
899
+ fiat_p256_subborrowx_u64(&x7, &x8, x6, 0x0, (arg1[3]));
900
+ fiat_p256_cmovznz_u64(&x9, x8, 0x0, UINT64_C(0xffffffffffffffff));
901
+ fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, x9);
902
+ fiat_p256_addcarryx_u64(&x12, &x13, x11, x3, (x9 & UINT32_C(0xffffffff)));
903
+ fiat_p256_addcarryx_u64(&x14, &x15, x13, x5, 0x0);
851
904
  fiat_p256_addcarryx_u64(&x16, &x17, x15, x7, (x9 & UINT64_C(0xffffffff00000001)));
852
905
  out1[0] = x10;
853
906
  out1[1] = x12;
@@ -857,153 +910,152 @@ static void fiat_p256_opp(uint64_t out1[4], const uint64_t arg1[4]) {
857
910
 
858
911
  /*
859
912
  * The function fiat_p256_from_montgomery translates a field element out of the Montgomery domain.
913
+ *
860
914
  * Preconditions:
861
915
  * 0 ≤ eval arg1 < m
862
916
  * Postconditions:
863
917
  * eval out1 mod m = (eval arg1 * ((2^64)⁻¹ mod m)^4) mod m
864
918
  * 0 ≤ eval out1 < m
865
919
  *
866
- * Input Bounds:
867
- * arg1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
868
- * Output Bounds:
869
- * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
870
920
  */
871
- static void fiat_p256_from_montgomery(uint64_t out1[4], const uint64_t arg1[4]) {
872
- uint64_t x1 = (arg1[0]);
921
+ static FIAT_P256_FIAT_INLINE void fiat_p256_from_montgomery(fiat_p256_non_montgomery_domain_field_element out1, const fiat_p256_montgomery_domain_field_element arg1) {
922
+ uint64_t x1;
873
923
  uint64_t x2;
874
924
  uint64_t x3;
875
- fiat_p256_mulx_u64(&x2, &x3, x1, UINT64_C(0xffffffff00000001));
876
925
  uint64_t x4;
877
926
  uint64_t x5;
878
- fiat_p256_mulx_u64(&x4, &x5, x1, UINT32_C(0xffffffff));
879
927
  uint64_t x6;
880
928
  uint64_t x7;
881
- fiat_p256_mulx_u64(&x6, &x7, x1, UINT64_C(0xffffffffffffffff));
882
929
  uint64_t x8;
883
930
  fiat_p256_uint1 x9;
884
- fiat_p256_addcarryx_u64(&x8, &x9, 0x0, x7, x4);
885
931
  uint64_t x10;
886
932
  fiat_p256_uint1 x11;
887
- fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, x6);
888
933
  uint64_t x12;
889
934
  fiat_p256_uint1 x13;
890
- fiat_p256_addcarryx_u64(&x12, &x13, x11, 0x0, x8);
891
935
  uint64_t x14;
892
936
  fiat_p256_uint1 x15;
893
- fiat_p256_addcarryx_u64(&x14, &x15, 0x0, x12, (arg1[1]));
894
937
  uint64_t x16;
895
938
  uint64_t x17;
896
- fiat_p256_mulx_u64(&x16, &x17, x14, UINT64_C(0xffffffff00000001));
897
939
  uint64_t x18;
898
940
  uint64_t x19;
899
- fiat_p256_mulx_u64(&x18, &x19, x14, UINT32_C(0xffffffff));
900
941
  uint64_t x20;
901
942
  uint64_t x21;
902
- fiat_p256_mulx_u64(&x20, &x21, x14, UINT64_C(0xffffffffffffffff));
903
943
  uint64_t x22;
904
944
  fiat_p256_uint1 x23;
905
- fiat_p256_addcarryx_u64(&x22, &x23, 0x0, x21, x18);
906
945
  uint64_t x24;
907
946
  fiat_p256_uint1 x25;
908
- fiat_p256_addcarryx_u64(&x24, &x25, 0x0, x14, x20);
909
947
  uint64_t x26;
910
948
  fiat_p256_uint1 x27;
911
- fiat_p256_addcarryx_u64(&x26, &x27, x25, (x15 + (x13 + (x9 + x5))), x22);
912
949
  uint64_t x28;
913
950
  fiat_p256_uint1 x29;
914
- fiat_p256_addcarryx_u64(&x28, &x29, x27, x2, (x23 + x19));
915
951
  uint64_t x30;
916
952
  fiat_p256_uint1 x31;
917
- fiat_p256_addcarryx_u64(&x30, &x31, x29, x3, x16);
918
953
  uint64_t x32;
919
954
  fiat_p256_uint1 x33;
920
- fiat_p256_addcarryx_u64(&x32, &x33, 0x0, x26, (arg1[2]));
921
955
  uint64_t x34;
922
956
  fiat_p256_uint1 x35;
923
- fiat_p256_addcarryx_u64(&x34, &x35, x33, x28, 0x0);
924
957
  uint64_t x36;
925
958
  fiat_p256_uint1 x37;
926
- fiat_p256_addcarryx_u64(&x36, &x37, x35, x30, 0x0);
927
959
  uint64_t x38;
928
960
  uint64_t x39;
929
- fiat_p256_mulx_u64(&x38, &x39, x32, UINT64_C(0xffffffff00000001));
930
961
  uint64_t x40;
931
962
  uint64_t x41;
932
- fiat_p256_mulx_u64(&x40, &x41, x32, UINT32_C(0xffffffff));
933
963
  uint64_t x42;
934
964
  uint64_t x43;
935
- fiat_p256_mulx_u64(&x42, &x43, x32, UINT64_C(0xffffffffffffffff));
936
965
  uint64_t x44;
937
966
  fiat_p256_uint1 x45;
938
- fiat_p256_addcarryx_u64(&x44, &x45, 0x0, x43, x40);
939
967
  uint64_t x46;
940
968
  fiat_p256_uint1 x47;
941
- fiat_p256_addcarryx_u64(&x46, &x47, 0x0, x32, x42);
942
969
  uint64_t x48;
943
970
  fiat_p256_uint1 x49;
944
- fiat_p256_addcarryx_u64(&x48, &x49, x47, x34, x44);
945
971
  uint64_t x50;
946
972
  fiat_p256_uint1 x51;
947
- fiat_p256_addcarryx_u64(&x50, &x51, x49, x36, (x45 + x41));
948
973
  uint64_t x52;
949
974
  fiat_p256_uint1 x53;
950
- fiat_p256_addcarryx_u64(&x52, &x53, x51, (x37 + (x31 + x17)), x38);
951
975
  uint64_t x54;
952
976
  fiat_p256_uint1 x55;
953
- fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x48, (arg1[3]));
954
977
  uint64_t x56;
955
978
  fiat_p256_uint1 x57;
956
- fiat_p256_addcarryx_u64(&x56, &x57, x55, x50, 0x0);
957
979
  uint64_t x58;
958
980
  fiat_p256_uint1 x59;
959
- fiat_p256_addcarryx_u64(&x58, &x59, x57, x52, 0x0);
960
981
  uint64_t x60;
961
982
  uint64_t x61;
962
- fiat_p256_mulx_u64(&x60, &x61, x54, UINT64_C(0xffffffff00000001));
963
983
  uint64_t x62;
964
984
  uint64_t x63;
965
- fiat_p256_mulx_u64(&x62, &x63, x54, UINT32_C(0xffffffff));
966
985
  uint64_t x64;
967
986
  uint64_t x65;
968
- fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffffffffffff));
969
987
  uint64_t x66;
970
988
  fiat_p256_uint1 x67;
971
- fiat_p256_addcarryx_u64(&x66, &x67, 0x0, x65, x62);
972
989
  uint64_t x68;
973
990
  fiat_p256_uint1 x69;
974
- fiat_p256_addcarryx_u64(&x68, &x69, 0x0, x54, x64);
975
991
  uint64_t x70;
976
992
  fiat_p256_uint1 x71;
977
- fiat_p256_addcarryx_u64(&x70, &x71, x69, x56, x66);
978
993
  uint64_t x72;
979
994
  fiat_p256_uint1 x73;
980
- fiat_p256_addcarryx_u64(&x72, &x73, x71, x58, (x67 + x63));
981
995
  uint64_t x74;
982
996
  fiat_p256_uint1 x75;
983
- fiat_p256_addcarryx_u64(&x74, &x75, x73, (x59 + (x53 + x39)), x60);
984
- uint64_t x76 = (x75 + x61);
997
+ uint64_t x76;
985
998
  uint64_t x77;
986
999
  fiat_p256_uint1 x78;
987
- fiat_p256_subborrowx_u64(&x77, &x78, 0x0, x70, UINT64_C(0xffffffffffffffff));
988
1000
  uint64_t x79;
989
1001
  fiat_p256_uint1 x80;
990
- fiat_p256_subborrowx_u64(&x79, &x80, x78, x72, UINT32_C(0xffffffff));
991
1002
  uint64_t x81;
992
1003
  fiat_p256_uint1 x82;
993
- fiat_p256_subborrowx_u64(&x81, &x82, x80, x74, 0x0);
994
1004
  uint64_t x83;
995
1005
  fiat_p256_uint1 x84;
996
- fiat_p256_subborrowx_u64(&x83, &x84, x82, x76, UINT64_C(0xffffffff00000001));
997
1006
  uint64_t x85;
998
1007
  fiat_p256_uint1 x86;
999
- fiat_p256_subborrowx_u64(&x85, &x86, x84, 0x0, 0x0);
1000
1008
  uint64_t x87;
1001
- fiat_p256_cmovznz_u64(&x87, x86, x77, x70);
1002
1009
  uint64_t x88;
1003
- fiat_p256_cmovznz_u64(&x88, x86, x79, x72);
1004
1010
  uint64_t x89;
1005
- fiat_p256_cmovznz_u64(&x89, x86, x81, x74);
1006
1011
  uint64_t x90;
1012
+ x1 = (arg1[0]);
1013
+ fiat_p256_mulx_u64(&x2, &x3, x1, UINT64_C(0xffffffff00000001));
1014
+ fiat_p256_mulx_u64(&x4, &x5, x1, UINT32_C(0xffffffff));
1015
+ fiat_p256_mulx_u64(&x6, &x7, x1, UINT64_C(0xffffffffffffffff));
1016
+ fiat_p256_addcarryx_u64(&x8, &x9, 0x0, x7, x4);
1017
+ fiat_p256_addcarryx_u64(&x10, &x11, 0x0, x1, x6);
1018
+ fiat_p256_addcarryx_u64(&x12, &x13, x11, 0x0, x8);
1019
+ fiat_p256_addcarryx_u64(&x14, &x15, 0x0, x12, (arg1[1]));
1020
+ fiat_p256_mulx_u64(&x16, &x17, x14, UINT64_C(0xffffffff00000001));
1021
+ fiat_p256_mulx_u64(&x18, &x19, x14, UINT32_C(0xffffffff));
1022
+ fiat_p256_mulx_u64(&x20, &x21, x14, UINT64_C(0xffffffffffffffff));
1023
+ fiat_p256_addcarryx_u64(&x22, &x23, 0x0, x21, x18);
1024
+ fiat_p256_addcarryx_u64(&x24, &x25, 0x0, x14, x20);
1025
+ fiat_p256_addcarryx_u64(&x26, &x27, x25, (x15 + (x13 + (x9 + x5))), x22);
1026
+ fiat_p256_addcarryx_u64(&x28, &x29, x27, x2, (x23 + x19));
1027
+ fiat_p256_addcarryx_u64(&x30, &x31, x29, x3, x16);
1028
+ fiat_p256_addcarryx_u64(&x32, &x33, 0x0, x26, (arg1[2]));
1029
+ fiat_p256_addcarryx_u64(&x34, &x35, x33, x28, 0x0);
1030
+ fiat_p256_addcarryx_u64(&x36, &x37, x35, x30, 0x0);
1031
+ fiat_p256_mulx_u64(&x38, &x39, x32, UINT64_C(0xffffffff00000001));
1032
+ fiat_p256_mulx_u64(&x40, &x41, x32, UINT32_C(0xffffffff));
1033
+ fiat_p256_mulx_u64(&x42, &x43, x32, UINT64_C(0xffffffffffffffff));
1034
+ fiat_p256_addcarryx_u64(&x44, &x45, 0x0, x43, x40);
1035
+ fiat_p256_addcarryx_u64(&x46, &x47, 0x0, x32, x42);
1036
+ fiat_p256_addcarryx_u64(&x48, &x49, x47, x34, x44);
1037
+ fiat_p256_addcarryx_u64(&x50, &x51, x49, x36, (x45 + x41));
1038
+ fiat_p256_addcarryx_u64(&x52, &x53, x51, (x37 + (x31 + x17)), x38);
1039
+ fiat_p256_addcarryx_u64(&x54, &x55, 0x0, x48, (arg1[3]));
1040
+ fiat_p256_addcarryx_u64(&x56, &x57, x55, x50, 0x0);
1041
+ fiat_p256_addcarryx_u64(&x58, &x59, x57, x52, 0x0);
1042
+ fiat_p256_mulx_u64(&x60, &x61, x54, UINT64_C(0xffffffff00000001));
1043
+ fiat_p256_mulx_u64(&x62, &x63, x54, UINT32_C(0xffffffff));
1044
+ fiat_p256_mulx_u64(&x64, &x65, x54, UINT64_C(0xffffffffffffffff));
1045
+ fiat_p256_addcarryx_u64(&x66, &x67, 0x0, x65, x62);
1046
+ fiat_p256_addcarryx_u64(&x68, &x69, 0x0, x54, x64);
1047
+ fiat_p256_addcarryx_u64(&x70, &x71, x69, x56, x66);
1048
+ fiat_p256_addcarryx_u64(&x72, &x73, x71, x58, (x67 + x63));
1049
+ fiat_p256_addcarryx_u64(&x74, &x75, x73, (x59 + (x53 + x39)), x60);
1050
+ x76 = (x75 + x61);
1051
+ fiat_p256_subborrowx_u64(&x77, &x78, 0x0, x70, UINT64_C(0xffffffffffffffff));
1052
+ fiat_p256_subborrowx_u64(&x79, &x80, x78, x72, UINT32_C(0xffffffff));
1053
+ fiat_p256_subborrowx_u64(&x81, &x82, x80, x74, 0x0);
1054
+ fiat_p256_subborrowx_u64(&x83, &x84, x82, x76, UINT64_C(0xffffffff00000001));
1055
+ fiat_p256_subborrowx_u64(&x85, &x86, x84, 0x0, 0x0);
1056
+ fiat_p256_cmovznz_u64(&x87, x86, x77, x70);
1057
+ fiat_p256_cmovznz_u64(&x88, x86, x79, x72);
1058
+ fiat_p256_cmovznz_u64(&x89, x86, x81, x74);
1007
1059
  fiat_p256_cmovznz_u64(&x90, x86, x83, x76);
1008
1060
  out1[0] = x87;
1009
1061
  out1[1] = x88;
@@ -1011,8 +1063,285 @@ static void fiat_p256_from_montgomery(uint64_t out1[4], const uint64_t arg1[4])
1011
1063
  out1[3] = x90;
1012
1064
  }
1013
1065
 
1066
+ /*
1067
+ * The function fiat_p256_to_montgomery translates a field element into the Montgomery domain.
1068
+ *
1069
+ * Preconditions:
1070
+ * 0 ≤ eval arg1 < m
1071
+ * Postconditions:
1072
+ * eval (from_montgomery out1) mod m = eval arg1 mod m
1073
+ * 0 ≤ eval out1 < m
1074
+ *
1075
+ */
1076
+ static FIAT_P256_FIAT_INLINE void fiat_p256_to_montgomery(fiat_p256_montgomery_domain_field_element out1, const fiat_p256_non_montgomery_domain_field_element arg1) {
1077
+ uint64_t x1;
1078
+ uint64_t x2;
1079
+ uint64_t x3;
1080
+ uint64_t x4;
1081
+ uint64_t x5;
1082
+ uint64_t x6;
1083
+ uint64_t x7;
1084
+ uint64_t x8;
1085
+ uint64_t x9;
1086
+ uint64_t x10;
1087
+ uint64_t x11;
1088
+ uint64_t x12;
1089
+ uint64_t x13;
1090
+ fiat_p256_uint1 x14;
1091
+ uint64_t x15;
1092
+ fiat_p256_uint1 x16;
1093
+ uint64_t x17;
1094
+ fiat_p256_uint1 x18;
1095
+ uint64_t x19;
1096
+ uint64_t x20;
1097
+ uint64_t x21;
1098
+ uint64_t x22;
1099
+ uint64_t x23;
1100
+ uint64_t x24;
1101
+ uint64_t x25;
1102
+ fiat_p256_uint1 x26;
1103
+ uint64_t x27;
1104
+ fiat_p256_uint1 x28;
1105
+ uint64_t x29;
1106
+ fiat_p256_uint1 x30;
1107
+ uint64_t x31;
1108
+ fiat_p256_uint1 x32;
1109
+ uint64_t x33;
1110
+ fiat_p256_uint1 x34;
1111
+ uint64_t x35;
1112
+ fiat_p256_uint1 x36;
1113
+ uint64_t x37;
1114
+ uint64_t x38;
1115
+ uint64_t x39;
1116
+ uint64_t x40;
1117
+ uint64_t x41;
1118
+ uint64_t x42;
1119
+ uint64_t x43;
1120
+ uint64_t x44;
1121
+ uint64_t x45;
1122
+ fiat_p256_uint1 x46;
1123
+ uint64_t x47;
1124
+ fiat_p256_uint1 x48;
1125
+ uint64_t x49;
1126
+ fiat_p256_uint1 x50;
1127
+ uint64_t x51;
1128
+ fiat_p256_uint1 x52;
1129
+ uint64_t x53;
1130
+ fiat_p256_uint1 x54;
1131
+ uint64_t x55;
1132
+ fiat_p256_uint1 x56;
1133
+ uint64_t x57;
1134
+ fiat_p256_uint1 x58;
1135
+ uint64_t x59;
1136
+ uint64_t x60;
1137
+ uint64_t x61;
1138
+ uint64_t x62;
1139
+ uint64_t x63;
1140
+ uint64_t x64;
1141
+ uint64_t x65;
1142
+ fiat_p256_uint1 x66;
1143
+ uint64_t x67;
1144
+ fiat_p256_uint1 x68;
1145
+ uint64_t x69;
1146
+ fiat_p256_uint1 x70;
1147
+ uint64_t x71;
1148
+ fiat_p256_uint1 x72;
1149
+ uint64_t x73;
1150
+ fiat_p256_uint1 x74;
1151
+ uint64_t x75;
1152
+ fiat_p256_uint1 x76;
1153
+ uint64_t x77;
1154
+ uint64_t x78;
1155
+ uint64_t x79;
1156
+ uint64_t x80;
1157
+ uint64_t x81;
1158
+ uint64_t x82;
1159
+ uint64_t x83;
1160
+ uint64_t x84;
1161
+ uint64_t x85;
1162
+ fiat_p256_uint1 x86;
1163
+ uint64_t x87;
1164
+ fiat_p256_uint1 x88;
1165
+ uint64_t x89;
1166
+ fiat_p256_uint1 x90;
1167
+ uint64_t x91;
1168
+ fiat_p256_uint1 x92;
1169
+ uint64_t x93;
1170
+ fiat_p256_uint1 x94;
1171
+ uint64_t x95;
1172
+ fiat_p256_uint1 x96;
1173
+ uint64_t x97;
1174
+ fiat_p256_uint1 x98;
1175
+ uint64_t x99;
1176
+ uint64_t x100;
1177
+ uint64_t x101;
1178
+ uint64_t x102;
1179
+ uint64_t x103;
1180
+ uint64_t x104;
1181
+ uint64_t x105;
1182
+ fiat_p256_uint1 x106;
1183
+ uint64_t x107;
1184
+ fiat_p256_uint1 x108;
1185
+ uint64_t x109;
1186
+ fiat_p256_uint1 x110;
1187
+ uint64_t x111;
1188
+ fiat_p256_uint1 x112;
1189
+ uint64_t x113;
1190
+ fiat_p256_uint1 x114;
1191
+ uint64_t x115;
1192
+ fiat_p256_uint1 x116;
1193
+ uint64_t x117;
1194
+ uint64_t x118;
1195
+ uint64_t x119;
1196
+ uint64_t x120;
1197
+ uint64_t x121;
1198
+ uint64_t x122;
1199
+ uint64_t x123;
1200
+ uint64_t x124;
1201
+ uint64_t x125;
1202
+ fiat_p256_uint1 x126;
1203
+ uint64_t x127;
1204
+ fiat_p256_uint1 x128;
1205
+ uint64_t x129;
1206
+ fiat_p256_uint1 x130;
1207
+ uint64_t x131;
1208
+ fiat_p256_uint1 x132;
1209
+ uint64_t x133;
1210
+ fiat_p256_uint1 x134;
1211
+ uint64_t x135;
1212
+ fiat_p256_uint1 x136;
1213
+ uint64_t x137;
1214
+ fiat_p256_uint1 x138;
1215
+ uint64_t x139;
1216
+ uint64_t x140;
1217
+ uint64_t x141;
1218
+ uint64_t x142;
1219
+ uint64_t x143;
1220
+ uint64_t x144;
1221
+ uint64_t x145;
1222
+ fiat_p256_uint1 x146;
1223
+ uint64_t x147;
1224
+ fiat_p256_uint1 x148;
1225
+ uint64_t x149;
1226
+ fiat_p256_uint1 x150;
1227
+ uint64_t x151;
1228
+ fiat_p256_uint1 x152;
1229
+ uint64_t x153;
1230
+ fiat_p256_uint1 x154;
1231
+ uint64_t x155;
1232
+ fiat_p256_uint1 x156;
1233
+ uint64_t x157;
1234
+ fiat_p256_uint1 x158;
1235
+ uint64_t x159;
1236
+ fiat_p256_uint1 x160;
1237
+ uint64_t x161;
1238
+ fiat_p256_uint1 x162;
1239
+ uint64_t x163;
1240
+ fiat_p256_uint1 x164;
1241
+ uint64_t x165;
1242
+ fiat_p256_uint1 x166;
1243
+ uint64_t x167;
1244
+ uint64_t x168;
1245
+ uint64_t x169;
1246
+ uint64_t x170;
1247
+ x1 = (arg1[1]);
1248
+ x2 = (arg1[2]);
1249
+ x3 = (arg1[3]);
1250
+ x4 = (arg1[0]);
1251
+ fiat_p256_mulx_u64(&x5, &x6, x4, UINT64_C(0x4fffffffd));
1252
+ fiat_p256_mulx_u64(&x7, &x8, x4, UINT64_C(0xfffffffffffffffe));
1253
+ fiat_p256_mulx_u64(&x9, &x10, x4, UINT64_C(0xfffffffbffffffff));
1254
+ fiat_p256_mulx_u64(&x11, &x12, x4, 0x3);
1255
+ fiat_p256_addcarryx_u64(&x13, &x14, 0x0, x12, x9);
1256
+ fiat_p256_addcarryx_u64(&x15, &x16, x14, x10, x7);
1257
+ fiat_p256_addcarryx_u64(&x17, &x18, x16, x8, x5);
1258
+ fiat_p256_mulx_u64(&x19, &x20, x11, UINT64_C(0xffffffff00000001));
1259
+ fiat_p256_mulx_u64(&x21, &x22, x11, UINT32_C(0xffffffff));
1260
+ fiat_p256_mulx_u64(&x23, &x24, x11, UINT64_C(0xffffffffffffffff));
1261
+ fiat_p256_addcarryx_u64(&x25, &x26, 0x0, x24, x21);
1262
+ fiat_p256_addcarryx_u64(&x27, &x28, 0x0, x11, x23);
1263
+ fiat_p256_addcarryx_u64(&x29, &x30, x28, x13, x25);
1264
+ fiat_p256_addcarryx_u64(&x31, &x32, x30, x15, (x26 + x22));
1265
+ fiat_p256_addcarryx_u64(&x33, &x34, x32, x17, x19);
1266
+ fiat_p256_addcarryx_u64(&x35, &x36, x34, (x18 + x6), x20);
1267
+ fiat_p256_mulx_u64(&x37, &x38, x1, UINT64_C(0x4fffffffd));
1268
+ fiat_p256_mulx_u64(&x39, &x40, x1, UINT64_C(0xfffffffffffffffe));
1269
+ fiat_p256_mulx_u64(&x41, &x42, x1, UINT64_C(0xfffffffbffffffff));
1270
+ fiat_p256_mulx_u64(&x43, &x44, x1, 0x3);
1271
+ fiat_p256_addcarryx_u64(&x45, &x46, 0x0, x44, x41);
1272
+ fiat_p256_addcarryx_u64(&x47, &x48, x46, x42, x39);
1273
+ fiat_p256_addcarryx_u64(&x49, &x50, x48, x40, x37);
1274
+ fiat_p256_addcarryx_u64(&x51, &x52, 0x0, x29, x43);
1275
+ fiat_p256_addcarryx_u64(&x53, &x54, x52, x31, x45);
1276
+ fiat_p256_addcarryx_u64(&x55, &x56, x54, x33, x47);
1277
+ fiat_p256_addcarryx_u64(&x57, &x58, x56, x35, x49);
1278
+ fiat_p256_mulx_u64(&x59, &x60, x51, UINT64_C(0xffffffff00000001));
1279
+ fiat_p256_mulx_u64(&x61, &x62, x51, UINT32_C(0xffffffff));
1280
+ fiat_p256_mulx_u64(&x63, &x64, x51, UINT64_C(0xffffffffffffffff));
1281
+ fiat_p256_addcarryx_u64(&x65, &x66, 0x0, x64, x61);
1282
+ fiat_p256_addcarryx_u64(&x67, &x68, 0x0, x51, x63);
1283
+ fiat_p256_addcarryx_u64(&x69, &x70, x68, x53, x65);
1284
+ fiat_p256_addcarryx_u64(&x71, &x72, x70, x55, (x66 + x62));
1285
+ fiat_p256_addcarryx_u64(&x73, &x74, x72, x57, x59);
1286
+ fiat_p256_addcarryx_u64(&x75, &x76, x74, (((uint64_t)x58 + x36) + (x50 + x38)), x60);
1287
+ fiat_p256_mulx_u64(&x77, &x78, x2, UINT64_C(0x4fffffffd));
1288
+ fiat_p256_mulx_u64(&x79, &x80, x2, UINT64_C(0xfffffffffffffffe));
1289
+ fiat_p256_mulx_u64(&x81, &x82, x2, UINT64_C(0xfffffffbffffffff));
1290
+ fiat_p256_mulx_u64(&x83, &x84, x2, 0x3);
1291
+ fiat_p256_addcarryx_u64(&x85, &x86, 0x0, x84, x81);
1292
+ fiat_p256_addcarryx_u64(&x87, &x88, x86, x82, x79);
1293
+ fiat_p256_addcarryx_u64(&x89, &x90, x88, x80, x77);
1294
+ fiat_p256_addcarryx_u64(&x91, &x92, 0x0, x69, x83);
1295
+ fiat_p256_addcarryx_u64(&x93, &x94, x92, x71, x85);
1296
+ fiat_p256_addcarryx_u64(&x95, &x96, x94, x73, x87);
1297
+ fiat_p256_addcarryx_u64(&x97, &x98, x96, x75, x89);
1298
+ fiat_p256_mulx_u64(&x99, &x100, x91, UINT64_C(0xffffffff00000001));
1299
+ fiat_p256_mulx_u64(&x101, &x102, x91, UINT32_C(0xffffffff));
1300
+ fiat_p256_mulx_u64(&x103, &x104, x91, UINT64_C(0xffffffffffffffff));
1301
+ fiat_p256_addcarryx_u64(&x105, &x106, 0x0, x104, x101);
1302
+ fiat_p256_addcarryx_u64(&x107, &x108, 0x0, x91, x103);
1303
+ fiat_p256_addcarryx_u64(&x109, &x110, x108, x93, x105);
1304
+ fiat_p256_addcarryx_u64(&x111, &x112, x110, x95, (x106 + x102));
1305
+ fiat_p256_addcarryx_u64(&x113, &x114, x112, x97, x99);
1306
+ fiat_p256_addcarryx_u64(&x115, &x116, x114, (((uint64_t)x98 + x76) + (x90 + x78)), x100);
1307
+ fiat_p256_mulx_u64(&x117, &x118, x3, UINT64_C(0x4fffffffd));
1308
+ fiat_p256_mulx_u64(&x119, &x120, x3, UINT64_C(0xfffffffffffffffe));
1309
+ fiat_p256_mulx_u64(&x121, &x122, x3, UINT64_C(0xfffffffbffffffff));
1310
+ fiat_p256_mulx_u64(&x123, &x124, x3, 0x3);
1311
+ fiat_p256_addcarryx_u64(&x125, &x126, 0x0, x124, x121);
1312
+ fiat_p256_addcarryx_u64(&x127, &x128, x126, x122, x119);
1313
+ fiat_p256_addcarryx_u64(&x129, &x130, x128, x120, x117);
1314
+ fiat_p256_addcarryx_u64(&x131, &x132, 0x0, x109, x123);
1315
+ fiat_p256_addcarryx_u64(&x133, &x134, x132, x111, x125);
1316
+ fiat_p256_addcarryx_u64(&x135, &x136, x134, x113, x127);
1317
+ fiat_p256_addcarryx_u64(&x137, &x138, x136, x115, x129);
1318
+ fiat_p256_mulx_u64(&x139, &x140, x131, UINT64_C(0xffffffff00000001));
1319
+ fiat_p256_mulx_u64(&x141, &x142, x131, UINT32_C(0xffffffff));
1320
+ fiat_p256_mulx_u64(&x143, &x144, x131, UINT64_C(0xffffffffffffffff));
1321
+ fiat_p256_addcarryx_u64(&x145, &x146, 0x0, x144, x141);
1322
+ fiat_p256_addcarryx_u64(&x147, &x148, 0x0, x131, x143);
1323
+ fiat_p256_addcarryx_u64(&x149, &x150, x148, x133, x145);
1324
+ fiat_p256_addcarryx_u64(&x151, &x152, x150, x135, (x146 + x142));
1325
+ fiat_p256_addcarryx_u64(&x153, &x154, x152, x137, x139);
1326
+ fiat_p256_addcarryx_u64(&x155, &x156, x154, (((uint64_t)x138 + x116) + (x130 + x118)), x140);
1327
+ fiat_p256_subborrowx_u64(&x157, &x158, 0x0, x149, UINT64_C(0xffffffffffffffff));
1328
+ fiat_p256_subborrowx_u64(&x159, &x160, x158, x151, UINT32_C(0xffffffff));
1329
+ fiat_p256_subborrowx_u64(&x161, &x162, x160, x153, 0x0);
1330
+ fiat_p256_subborrowx_u64(&x163, &x164, x162, x155, UINT64_C(0xffffffff00000001));
1331
+ fiat_p256_subborrowx_u64(&x165, &x166, x164, x156, 0x0);
1332
+ fiat_p256_cmovznz_u64(&x167, x166, x157, x149);
1333
+ fiat_p256_cmovznz_u64(&x168, x166, x159, x151);
1334
+ fiat_p256_cmovznz_u64(&x169, x166, x161, x153);
1335
+ fiat_p256_cmovznz_u64(&x170, x166, x163, x155);
1336
+ out1[0] = x167;
1337
+ out1[1] = x168;
1338
+ out1[2] = x169;
1339
+ out1[3] = x170;
1340
+ }
1341
+
1014
1342
  /*
1015
1343
  * The function fiat_p256_nonzero outputs a single non-zero word if the input is non-zero and zero otherwise.
1344
+ *
1016
1345
  * Preconditions:
1017
1346
  * 0 ≤ eval arg1 < m
1018
1347
  * Postconditions:
@@ -1023,13 +1352,15 @@ static void fiat_p256_from_montgomery(uint64_t out1[4], const uint64_t arg1[4])
1023
1352
  * Output Bounds:
1024
1353
  * out1: [0x0 ~> 0xffffffffffffffff]
1025
1354
  */
1026
- static void fiat_p256_nonzero(uint64_t* out1, const uint64_t arg1[4]) {
1027
- uint64_t x1 = ((arg1[0]) | ((arg1[1]) | ((arg1[2]) | ((arg1[3]) | (uint64_t)0x0))));
1355
+ static FIAT_P256_FIAT_INLINE void fiat_p256_nonzero(uint64_t* out1, const uint64_t arg1[4]) {
1356
+ uint64_t x1;
1357
+ x1 = ((arg1[0]) | ((arg1[1]) | ((arg1[2]) | (arg1[3]))));
1028
1358
  *out1 = x1;
1029
1359
  }
1030
1360
 
1031
1361
  /*
1032
1362
  * The function fiat_p256_selectznz is a multi-limb conditional select.
1363
+ *
1033
1364
  * Postconditions:
1034
1365
  * eval out1 = (if arg1 = 0 then eval arg2 else eval arg3)
1035
1366
  *
@@ -1040,14 +1371,14 @@ static void fiat_p256_nonzero(uint64_t* out1, const uint64_t arg1[4]) {
1040
1371
  * Output Bounds:
1041
1372
  * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1042
1373
  */
1043
- static void fiat_p256_selectznz(uint64_t out1[4], fiat_p256_uint1 arg1, const uint64_t arg2[4], const uint64_t arg3[4]) {
1374
+ static FIAT_P256_FIAT_INLINE void fiat_p256_selectznz(uint64_t out1[4], fiat_p256_uint1 arg1, const uint64_t arg2[4], const uint64_t arg3[4]) {
1044
1375
  uint64_t x1;
1045
- fiat_p256_cmovznz_u64(&x1, arg1, (arg2[0]), (arg3[0]));
1046
1376
  uint64_t x2;
1047
- fiat_p256_cmovznz_u64(&x2, arg1, (arg2[1]), (arg3[1]));
1048
1377
  uint64_t x3;
1049
- fiat_p256_cmovznz_u64(&x3, arg1, (arg2[2]), (arg3[2]));
1050
1378
  uint64_t x4;
1379
+ fiat_p256_cmovznz_u64(&x1, arg1, (arg2[0]), (arg3[0]));
1380
+ fiat_p256_cmovznz_u64(&x2, arg1, (arg2[1]), (arg3[1]));
1381
+ fiat_p256_cmovznz_u64(&x3, arg1, (arg2[2]), (arg3[2]));
1051
1382
  fiat_p256_cmovznz_u64(&x4, arg1, (arg2[3]), (arg3[3]));
1052
1383
  out1[0] = x1;
1053
1384
  out1[1] = x2;
@@ -1056,7 +1387,8 @@ static void fiat_p256_selectznz(uint64_t out1[4], fiat_p256_uint1 arg1, const ui
1056
1387
  }
1057
1388
 
1058
1389
  /*
1059
- * The function fiat_p256_to_bytes serializes a field element in the Montgomery domain to bytes in little-endian order.
1390
+ * The function fiat_p256_to_bytes serializes a field element NOT in the Montgomery domain to bytes in little-endian order.
1391
+ *
1060
1392
  * Preconditions:
1061
1393
  * 0 ≤ eval arg1 < m
1062
1394
  * Postconditions:
@@ -1067,106 +1399,164 @@ static void fiat_p256_selectznz(uint64_t out1[4], fiat_p256_uint1 arg1, const ui
1067
1399
  * Output Bounds:
1068
1400
  * out1: [[0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff]]
1069
1401
  */
1070
- static void fiat_p256_to_bytes(uint8_t out1[32], const uint64_t arg1[4]) {
1071
- uint64_t x1 = (arg1[3]);
1072
- uint64_t x2 = (arg1[2]);
1073
- uint64_t x3 = (arg1[1]);
1074
- uint64_t x4 = (arg1[0]);
1075
- uint64_t x5 = (x4 >> 8);
1076
- uint8_t x6 = (uint8_t)(x4 & UINT8_C(0xff));
1077
- uint64_t x7 = (x5 >> 8);
1078
- uint8_t x8 = (uint8_t)(x5 & UINT8_C(0xff));
1079
- uint64_t x9 = (x7 >> 8);
1080
- uint8_t x10 = (uint8_t)(x7 & UINT8_C(0xff));
1081
- uint64_t x11 = (x9 >> 8);
1082
- uint8_t x12 = (uint8_t)(x9 & UINT8_C(0xff));
1083
- uint64_t x13 = (x11 >> 8);
1084
- uint8_t x14 = (uint8_t)(x11 & UINT8_C(0xff));
1085
- uint64_t x15 = (x13 >> 8);
1086
- uint8_t x16 = (uint8_t)(x13 & UINT8_C(0xff));
1087
- uint8_t x17 = (uint8_t)(x15 >> 8);
1088
- uint8_t x18 = (uint8_t)(x15 & UINT8_C(0xff));
1089
- uint8_t x19 = (uint8_t)(x17 & UINT8_C(0xff));
1090
- uint64_t x20 = (x3 >> 8);
1091
- uint8_t x21 = (uint8_t)(x3 & UINT8_C(0xff));
1092
- uint64_t x22 = (x20 >> 8);
1093
- uint8_t x23 = (uint8_t)(x20 & UINT8_C(0xff));
1094
- uint64_t x24 = (x22 >> 8);
1095
- uint8_t x25 = (uint8_t)(x22 & UINT8_C(0xff));
1096
- uint64_t x26 = (x24 >> 8);
1097
- uint8_t x27 = (uint8_t)(x24 & UINT8_C(0xff));
1098
- uint64_t x28 = (x26 >> 8);
1099
- uint8_t x29 = (uint8_t)(x26 & UINT8_C(0xff));
1100
- uint64_t x30 = (x28 >> 8);
1101
- uint8_t x31 = (uint8_t)(x28 & UINT8_C(0xff));
1102
- uint8_t x32 = (uint8_t)(x30 >> 8);
1103
- uint8_t x33 = (uint8_t)(x30 & UINT8_C(0xff));
1104
- uint8_t x34 = (uint8_t)(x32 & UINT8_C(0xff));
1105
- uint64_t x35 = (x2 >> 8);
1106
- uint8_t x36 = (uint8_t)(x2 & UINT8_C(0xff));
1107
- uint64_t x37 = (x35 >> 8);
1108
- uint8_t x38 = (uint8_t)(x35 & UINT8_C(0xff));
1109
- uint64_t x39 = (x37 >> 8);
1110
- uint8_t x40 = (uint8_t)(x37 & UINT8_C(0xff));
1111
- uint64_t x41 = (x39 >> 8);
1112
- uint8_t x42 = (uint8_t)(x39 & UINT8_C(0xff));
1113
- uint64_t x43 = (x41 >> 8);
1114
- uint8_t x44 = (uint8_t)(x41 & UINT8_C(0xff));
1115
- uint64_t x45 = (x43 >> 8);
1116
- uint8_t x46 = (uint8_t)(x43 & UINT8_C(0xff));
1117
- uint8_t x47 = (uint8_t)(x45 >> 8);
1118
- uint8_t x48 = (uint8_t)(x45 & UINT8_C(0xff));
1119
- uint8_t x49 = (uint8_t)(x47 & UINT8_C(0xff));
1120
- uint64_t x50 = (x1 >> 8);
1121
- uint8_t x51 = (uint8_t)(x1 & UINT8_C(0xff));
1122
- uint64_t x52 = (x50 >> 8);
1123
- uint8_t x53 = (uint8_t)(x50 & UINT8_C(0xff));
1124
- uint64_t x54 = (x52 >> 8);
1125
- uint8_t x55 = (uint8_t)(x52 & UINT8_C(0xff));
1126
- uint64_t x56 = (x54 >> 8);
1127
- uint8_t x57 = (uint8_t)(x54 & UINT8_C(0xff));
1128
- uint64_t x58 = (x56 >> 8);
1129
- uint8_t x59 = (uint8_t)(x56 & UINT8_C(0xff));
1130
- uint64_t x60 = (x58 >> 8);
1131
- uint8_t x61 = (uint8_t)(x58 & UINT8_C(0xff));
1132
- uint8_t x62 = (uint8_t)(x60 >> 8);
1133
- uint8_t x63 = (uint8_t)(x60 & UINT8_C(0xff));
1134
- out1[0] = x6;
1135
- out1[1] = x8;
1136
- out1[2] = x10;
1137
- out1[3] = x12;
1138
- out1[4] = x14;
1139
- out1[5] = x16;
1140
- out1[6] = x18;
1141
- out1[7] = x19;
1142
- out1[8] = x21;
1143
- out1[9] = x23;
1144
- out1[10] = x25;
1145
- out1[11] = x27;
1146
- out1[12] = x29;
1147
- out1[13] = x31;
1148
- out1[14] = x33;
1149
- out1[15] = x34;
1150
- out1[16] = x36;
1151
- out1[17] = x38;
1152
- out1[18] = x40;
1153
- out1[19] = x42;
1154
- out1[20] = x44;
1155
- out1[21] = x46;
1156
- out1[22] = x48;
1157
- out1[23] = x49;
1158
- out1[24] = x51;
1159
- out1[25] = x53;
1160
- out1[26] = x55;
1161
- out1[27] = x57;
1162
- out1[28] = x59;
1163
- out1[29] = x61;
1164
- out1[30] = x63;
1165
- out1[31] = x62;
1402
+ static FIAT_P256_FIAT_INLINE void fiat_p256_to_bytes(uint8_t out1[32], const uint64_t arg1[4]) {
1403
+ uint64_t x1;
1404
+ uint64_t x2;
1405
+ uint64_t x3;
1406
+ uint64_t x4;
1407
+ uint8_t x5;
1408
+ uint64_t x6;
1409
+ uint8_t x7;
1410
+ uint64_t x8;
1411
+ uint8_t x9;
1412
+ uint64_t x10;
1413
+ uint8_t x11;
1414
+ uint64_t x12;
1415
+ uint8_t x13;
1416
+ uint64_t x14;
1417
+ uint8_t x15;
1418
+ uint64_t x16;
1419
+ uint8_t x17;
1420
+ uint8_t x18;
1421
+ uint8_t x19;
1422
+ uint64_t x20;
1423
+ uint8_t x21;
1424
+ uint64_t x22;
1425
+ uint8_t x23;
1426
+ uint64_t x24;
1427
+ uint8_t x25;
1428
+ uint64_t x26;
1429
+ uint8_t x27;
1430
+ uint64_t x28;
1431
+ uint8_t x29;
1432
+ uint64_t x30;
1433
+ uint8_t x31;
1434
+ uint8_t x32;
1435
+ uint8_t x33;
1436
+ uint64_t x34;
1437
+ uint8_t x35;
1438
+ uint64_t x36;
1439
+ uint8_t x37;
1440
+ uint64_t x38;
1441
+ uint8_t x39;
1442
+ uint64_t x40;
1443
+ uint8_t x41;
1444
+ uint64_t x42;
1445
+ uint8_t x43;
1446
+ uint64_t x44;
1447
+ uint8_t x45;
1448
+ uint8_t x46;
1449
+ uint8_t x47;
1450
+ uint64_t x48;
1451
+ uint8_t x49;
1452
+ uint64_t x50;
1453
+ uint8_t x51;
1454
+ uint64_t x52;
1455
+ uint8_t x53;
1456
+ uint64_t x54;
1457
+ uint8_t x55;
1458
+ uint64_t x56;
1459
+ uint8_t x57;
1460
+ uint64_t x58;
1461
+ uint8_t x59;
1462
+ uint8_t x60;
1463
+ x1 = (arg1[3]);
1464
+ x2 = (arg1[2]);
1465
+ x3 = (arg1[1]);
1466
+ x4 = (arg1[0]);
1467
+ x5 = (uint8_t)(x4 & UINT8_C(0xff));
1468
+ x6 = (x4 >> 8);
1469
+ x7 = (uint8_t)(x6 & UINT8_C(0xff));
1470
+ x8 = (x6 >> 8);
1471
+ x9 = (uint8_t)(x8 & UINT8_C(0xff));
1472
+ x10 = (x8 >> 8);
1473
+ x11 = (uint8_t)(x10 & UINT8_C(0xff));
1474
+ x12 = (x10 >> 8);
1475
+ x13 = (uint8_t)(x12 & UINT8_C(0xff));
1476
+ x14 = (x12 >> 8);
1477
+ x15 = (uint8_t)(x14 & UINT8_C(0xff));
1478
+ x16 = (x14 >> 8);
1479
+ x17 = (uint8_t)(x16 & UINT8_C(0xff));
1480
+ x18 = (uint8_t)(x16 >> 8);
1481
+ x19 = (uint8_t)(x3 & UINT8_C(0xff));
1482
+ x20 = (x3 >> 8);
1483
+ x21 = (uint8_t)(x20 & UINT8_C(0xff));
1484
+ x22 = (x20 >> 8);
1485
+ x23 = (uint8_t)(x22 & UINT8_C(0xff));
1486
+ x24 = (x22 >> 8);
1487
+ x25 = (uint8_t)(x24 & UINT8_C(0xff));
1488
+ x26 = (x24 >> 8);
1489
+ x27 = (uint8_t)(x26 & UINT8_C(0xff));
1490
+ x28 = (x26 >> 8);
1491
+ x29 = (uint8_t)(x28 & UINT8_C(0xff));
1492
+ x30 = (x28 >> 8);
1493
+ x31 = (uint8_t)(x30 & UINT8_C(0xff));
1494
+ x32 = (uint8_t)(x30 >> 8);
1495
+ x33 = (uint8_t)(x2 & UINT8_C(0xff));
1496
+ x34 = (x2 >> 8);
1497
+ x35 = (uint8_t)(x34 & UINT8_C(0xff));
1498
+ x36 = (x34 >> 8);
1499
+ x37 = (uint8_t)(x36 & UINT8_C(0xff));
1500
+ x38 = (x36 >> 8);
1501
+ x39 = (uint8_t)(x38 & UINT8_C(0xff));
1502
+ x40 = (x38 >> 8);
1503
+ x41 = (uint8_t)(x40 & UINT8_C(0xff));
1504
+ x42 = (x40 >> 8);
1505
+ x43 = (uint8_t)(x42 & UINT8_C(0xff));
1506
+ x44 = (x42 >> 8);
1507
+ x45 = (uint8_t)(x44 & UINT8_C(0xff));
1508
+ x46 = (uint8_t)(x44 >> 8);
1509
+ x47 = (uint8_t)(x1 & UINT8_C(0xff));
1510
+ x48 = (x1 >> 8);
1511
+ x49 = (uint8_t)(x48 & UINT8_C(0xff));
1512
+ x50 = (x48 >> 8);
1513
+ x51 = (uint8_t)(x50 & UINT8_C(0xff));
1514
+ x52 = (x50 >> 8);
1515
+ x53 = (uint8_t)(x52 & UINT8_C(0xff));
1516
+ x54 = (x52 >> 8);
1517
+ x55 = (uint8_t)(x54 & UINT8_C(0xff));
1518
+ x56 = (x54 >> 8);
1519
+ x57 = (uint8_t)(x56 & UINT8_C(0xff));
1520
+ x58 = (x56 >> 8);
1521
+ x59 = (uint8_t)(x58 & UINT8_C(0xff));
1522
+ x60 = (uint8_t)(x58 >> 8);
1523
+ out1[0] = x5;
1524
+ out1[1] = x7;
1525
+ out1[2] = x9;
1526
+ out1[3] = x11;
1527
+ out1[4] = x13;
1528
+ out1[5] = x15;
1529
+ out1[6] = x17;
1530
+ out1[7] = x18;
1531
+ out1[8] = x19;
1532
+ out1[9] = x21;
1533
+ out1[10] = x23;
1534
+ out1[11] = x25;
1535
+ out1[12] = x27;
1536
+ out1[13] = x29;
1537
+ out1[14] = x31;
1538
+ out1[15] = x32;
1539
+ out1[16] = x33;
1540
+ out1[17] = x35;
1541
+ out1[18] = x37;
1542
+ out1[19] = x39;
1543
+ out1[20] = x41;
1544
+ out1[21] = x43;
1545
+ out1[22] = x45;
1546
+ out1[23] = x46;
1547
+ out1[24] = x47;
1548
+ out1[25] = x49;
1549
+ out1[26] = x51;
1550
+ out1[27] = x53;
1551
+ out1[28] = x55;
1552
+ out1[29] = x57;
1553
+ out1[30] = x59;
1554
+ out1[31] = x60;
1166
1555
  }
1167
1556
 
1168
1557
  /*
1169
- * The function fiat_p256_from_bytes deserializes a field element in the Montgomery domain from bytes in little-endian order.
1558
+ * The function fiat_p256_from_bytes deserializes a field element NOT in the Montgomery domain from bytes in little-endian order.
1559
+ *
1170
1560
  * Preconditions:
1171
1561
  * 0 ≤ bytes_eval arg1 < m
1172
1562
  * Postconditions:
@@ -1178,49 +1568,444 @@ static void fiat_p256_to_bytes(uint8_t out1[32], const uint64_t arg1[4]) {
1178
1568
  * Output Bounds:
1179
1569
  * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1180
1570
  */
1181
- static void fiat_p256_from_bytes(uint64_t out1[4], const uint8_t arg1[32]) {
1182
- uint64_t x1 = ((uint64_t)(arg1[31]) << 56);
1183
- uint64_t x2 = ((uint64_t)(arg1[30]) << 48);
1184
- uint64_t x3 = ((uint64_t)(arg1[29]) << 40);
1185
- uint64_t x4 = ((uint64_t)(arg1[28]) << 32);
1186
- uint64_t x5 = ((uint64_t)(arg1[27]) << 24);
1187
- uint64_t x6 = ((uint64_t)(arg1[26]) << 16);
1188
- uint64_t x7 = ((uint64_t)(arg1[25]) << 8);
1189
- uint8_t x8 = (arg1[24]);
1190
- uint64_t x9 = ((uint64_t)(arg1[23]) << 56);
1191
- uint64_t x10 = ((uint64_t)(arg1[22]) << 48);
1192
- uint64_t x11 = ((uint64_t)(arg1[21]) << 40);
1193
- uint64_t x12 = ((uint64_t)(arg1[20]) << 32);
1194
- uint64_t x13 = ((uint64_t)(arg1[19]) << 24);
1195
- uint64_t x14 = ((uint64_t)(arg1[18]) << 16);
1196
- uint64_t x15 = ((uint64_t)(arg1[17]) << 8);
1197
- uint8_t x16 = (arg1[16]);
1198
- uint64_t x17 = ((uint64_t)(arg1[15]) << 56);
1199
- uint64_t x18 = ((uint64_t)(arg1[14]) << 48);
1200
- uint64_t x19 = ((uint64_t)(arg1[13]) << 40);
1201
- uint64_t x20 = ((uint64_t)(arg1[12]) << 32);
1202
- uint64_t x21 = ((uint64_t)(arg1[11]) << 24);
1203
- uint64_t x22 = ((uint64_t)(arg1[10]) << 16);
1204
- uint64_t x23 = ((uint64_t)(arg1[9]) << 8);
1205
- uint8_t x24 = (arg1[8]);
1206
- uint64_t x25 = ((uint64_t)(arg1[7]) << 56);
1207
- uint64_t x26 = ((uint64_t)(arg1[6]) << 48);
1208
- uint64_t x27 = ((uint64_t)(arg1[5]) << 40);
1209
- uint64_t x28 = ((uint64_t)(arg1[4]) << 32);
1210
- uint64_t x29 = ((uint64_t)(arg1[3]) << 24);
1211
- uint64_t x30 = ((uint64_t)(arg1[2]) << 16);
1212
- uint64_t x31 = ((uint64_t)(arg1[1]) << 8);
1213
- uint8_t x32 = (arg1[0]);
1214
- uint64_t x33 = (x32 + (x31 + (x30 + (x29 + (x28 + (x27 + (x26 + x25)))))));
1215
- uint64_t x34 = (x33 & UINT64_C(0xffffffffffffffff));
1216
- uint64_t x35 = (x8 + (x7 + (x6 + (x5 + (x4 + (x3 + (x2 + x1)))))));
1217
- uint64_t x36 = (x16 + (x15 + (x14 + (x13 + (x12 + (x11 + (x10 + x9)))))));
1218
- uint64_t x37 = (x24 + (x23 + (x22 + (x21 + (x20 + (x19 + (x18 + x17)))))));
1219
- uint64_t x38 = (x37 & UINT64_C(0xffffffffffffffff));
1220
- uint64_t x39 = (x36 & UINT64_C(0xffffffffffffffff));
1221
- out1[0] = x34;
1222
- out1[1] = x38;
1223
- out1[2] = x39;
1224
- out1[3] = x35;
1571
+ static FIAT_P256_FIAT_INLINE void fiat_p256_from_bytes(uint64_t out1[4], const uint8_t arg1[32]) {
1572
+ uint64_t x1;
1573
+ uint64_t x2;
1574
+ uint64_t x3;
1575
+ uint64_t x4;
1576
+ uint64_t x5;
1577
+ uint64_t x6;
1578
+ uint64_t x7;
1579
+ uint8_t x8;
1580
+ uint64_t x9;
1581
+ uint64_t x10;
1582
+ uint64_t x11;
1583
+ uint64_t x12;
1584
+ uint64_t x13;
1585
+ uint64_t x14;
1586
+ uint64_t x15;
1587
+ uint8_t x16;
1588
+ uint64_t x17;
1589
+ uint64_t x18;
1590
+ uint64_t x19;
1591
+ uint64_t x20;
1592
+ uint64_t x21;
1593
+ uint64_t x22;
1594
+ uint64_t x23;
1595
+ uint8_t x24;
1596
+ uint64_t x25;
1597
+ uint64_t x26;
1598
+ uint64_t x27;
1599
+ uint64_t x28;
1600
+ uint64_t x29;
1601
+ uint64_t x30;
1602
+ uint64_t x31;
1603
+ uint8_t x32;
1604
+ uint64_t x33;
1605
+ uint64_t x34;
1606
+ uint64_t x35;
1607
+ uint64_t x36;
1608
+ uint64_t x37;
1609
+ uint64_t x38;
1610
+ uint64_t x39;
1611
+ uint64_t x40;
1612
+ uint64_t x41;
1613
+ uint64_t x42;
1614
+ uint64_t x43;
1615
+ uint64_t x44;
1616
+ uint64_t x45;
1617
+ uint64_t x46;
1618
+ uint64_t x47;
1619
+ uint64_t x48;
1620
+ uint64_t x49;
1621
+ uint64_t x50;
1622
+ uint64_t x51;
1623
+ uint64_t x52;
1624
+ uint64_t x53;
1625
+ uint64_t x54;
1626
+ uint64_t x55;
1627
+ uint64_t x56;
1628
+ uint64_t x57;
1629
+ uint64_t x58;
1630
+ uint64_t x59;
1631
+ uint64_t x60;
1632
+ x1 = ((uint64_t)(arg1[31]) << 56);
1633
+ x2 = ((uint64_t)(arg1[30]) << 48);
1634
+ x3 = ((uint64_t)(arg1[29]) << 40);
1635
+ x4 = ((uint64_t)(arg1[28]) << 32);
1636
+ x5 = ((uint64_t)(arg1[27]) << 24);
1637
+ x6 = ((uint64_t)(arg1[26]) << 16);
1638
+ x7 = ((uint64_t)(arg1[25]) << 8);
1639
+ x8 = (arg1[24]);
1640
+ x9 = ((uint64_t)(arg1[23]) << 56);
1641
+ x10 = ((uint64_t)(arg1[22]) << 48);
1642
+ x11 = ((uint64_t)(arg1[21]) << 40);
1643
+ x12 = ((uint64_t)(arg1[20]) << 32);
1644
+ x13 = ((uint64_t)(arg1[19]) << 24);
1645
+ x14 = ((uint64_t)(arg1[18]) << 16);
1646
+ x15 = ((uint64_t)(arg1[17]) << 8);
1647
+ x16 = (arg1[16]);
1648
+ x17 = ((uint64_t)(arg1[15]) << 56);
1649
+ x18 = ((uint64_t)(arg1[14]) << 48);
1650
+ x19 = ((uint64_t)(arg1[13]) << 40);
1651
+ x20 = ((uint64_t)(arg1[12]) << 32);
1652
+ x21 = ((uint64_t)(arg1[11]) << 24);
1653
+ x22 = ((uint64_t)(arg1[10]) << 16);
1654
+ x23 = ((uint64_t)(arg1[9]) << 8);
1655
+ x24 = (arg1[8]);
1656
+ x25 = ((uint64_t)(arg1[7]) << 56);
1657
+ x26 = ((uint64_t)(arg1[6]) << 48);
1658
+ x27 = ((uint64_t)(arg1[5]) << 40);
1659
+ x28 = ((uint64_t)(arg1[4]) << 32);
1660
+ x29 = ((uint64_t)(arg1[3]) << 24);
1661
+ x30 = ((uint64_t)(arg1[2]) << 16);
1662
+ x31 = ((uint64_t)(arg1[1]) << 8);
1663
+ x32 = (arg1[0]);
1664
+ x33 = (x31 + (uint64_t)x32);
1665
+ x34 = (x30 + x33);
1666
+ x35 = (x29 + x34);
1667
+ x36 = (x28 + x35);
1668
+ x37 = (x27 + x36);
1669
+ x38 = (x26 + x37);
1670
+ x39 = (x25 + x38);
1671
+ x40 = (x23 + (uint64_t)x24);
1672
+ x41 = (x22 + x40);
1673
+ x42 = (x21 + x41);
1674
+ x43 = (x20 + x42);
1675
+ x44 = (x19 + x43);
1676
+ x45 = (x18 + x44);
1677
+ x46 = (x17 + x45);
1678
+ x47 = (x15 + (uint64_t)x16);
1679
+ x48 = (x14 + x47);
1680
+ x49 = (x13 + x48);
1681
+ x50 = (x12 + x49);
1682
+ x51 = (x11 + x50);
1683
+ x52 = (x10 + x51);
1684
+ x53 = (x9 + x52);
1685
+ x54 = (x7 + (uint64_t)x8);
1686
+ x55 = (x6 + x54);
1687
+ x56 = (x5 + x55);
1688
+ x57 = (x4 + x56);
1689
+ x58 = (x3 + x57);
1690
+ x59 = (x2 + x58);
1691
+ x60 = (x1 + x59);
1692
+ out1[0] = x39;
1693
+ out1[1] = x46;
1694
+ out1[2] = x53;
1695
+ out1[3] = x60;
1696
+ }
1697
+
1698
+ /*
1699
+ * The function fiat_p256_set_one returns the field element one in the Montgomery domain.
1700
+ *
1701
+ * Postconditions:
1702
+ * eval (from_montgomery out1) mod m = 1 mod m
1703
+ * 0 ≤ eval out1 < m
1704
+ *
1705
+ */
1706
+ static FIAT_P256_FIAT_INLINE void fiat_p256_set_one(fiat_p256_montgomery_domain_field_element out1) {
1707
+ out1[0] = 0x1;
1708
+ out1[1] = UINT64_C(0xffffffff00000000);
1709
+ out1[2] = UINT64_C(0xffffffffffffffff);
1710
+ out1[3] = UINT32_C(0xfffffffe);
1711
+ }
1712
+
1713
+ /*
1714
+ * The function fiat_p256_msat returns the saturated representation of the prime modulus.
1715
+ *
1716
+ * Postconditions:
1717
+ * twos_complement_eval out1 = m
1718
+ * 0 ≤ eval out1 < m
1719
+ *
1720
+ * Output Bounds:
1721
+ * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1722
+ */
1723
+ static FIAT_P256_FIAT_INLINE void fiat_p256_msat(uint64_t out1[5]) {
1724
+ out1[0] = UINT64_C(0xffffffffffffffff);
1725
+ out1[1] = UINT32_C(0xffffffff);
1726
+ out1[2] = 0x0;
1727
+ out1[3] = UINT64_C(0xffffffff00000001);
1728
+ out1[4] = 0x0;
1729
+ }
1730
+
1731
+ /*
1732
+ * The function fiat_p256_divstep computes a divstep.
1733
+ *
1734
+ * Preconditions:
1735
+ * 0 ≤ eval arg4 < m
1736
+ * 0 ≤ eval arg5 < m
1737
+ * Postconditions:
1738
+ * out1 = (if 0 < arg1 ∧ (twos_complement_eval arg3) is odd then 1 - arg1 else 1 + arg1)
1739
+ * twos_complement_eval out2 = (if 0 < arg1 ∧ (twos_complement_eval arg3) is odd then twos_complement_eval arg3 else twos_complement_eval arg2)
1740
+ * twos_complement_eval out3 = (if 0 < arg1 ∧ (twos_complement_eval arg3) is odd then ⌊(twos_complement_eval arg3 - twos_complement_eval arg2) / 2⌋ else ⌊(twos_complement_eval arg3 + (twos_complement_eval arg3 mod 2) * twos_complement_eval arg2) / 2⌋)
1741
+ * eval (from_montgomery out4) mod m = (if 0 < arg1 ∧ (twos_complement_eval arg3) is odd then (2 * eval (from_montgomery arg5)) mod m else (2 * eval (from_montgomery arg4)) mod m)
1742
+ * eval (from_montgomery out5) mod m = (if 0 < arg1 ∧ (twos_complement_eval arg3) is odd then (eval (from_montgomery arg4) - eval (from_montgomery arg4)) mod m else (eval (from_montgomery arg5) + (twos_complement_eval arg3 mod 2) * eval (from_montgomery arg4)) mod m)
1743
+ * 0 ≤ eval out5 < m
1744
+ * 0 ≤ eval out5 < m
1745
+ * 0 ≤ eval out2 < m
1746
+ * 0 ≤ eval out3 < m
1747
+ *
1748
+ * Input Bounds:
1749
+ * arg1: [0x0 ~> 0xffffffffffffffff]
1750
+ * arg2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1751
+ * arg3: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1752
+ * arg4: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1753
+ * arg5: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1754
+ * Output Bounds:
1755
+ * out1: [0x0 ~> 0xffffffffffffffff]
1756
+ * out2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1757
+ * out3: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1758
+ * out4: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1759
+ * out5: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1760
+ */
1761
+ static FIAT_P256_FIAT_INLINE void fiat_p256_divstep(uint64_t* out1, uint64_t out2[5], uint64_t out3[5], uint64_t out4[4], uint64_t out5[4], uint64_t arg1, const uint64_t arg2[5], const uint64_t arg3[5], const uint64_t arg4[4], const uint64_t arg5[4]) {
1762
+ uint64_t x1;
1763
+ fiat_p256_uint1 x2;
1764
+ fiat_p256_uint1 x3;
1765
+ uint64_t x4;
1766
+ fiat_p256_uint1 x5;
1767
+ uint64_t x6;
1768
+ uint64_t x7;
1769
+ uint64_t x8;
1770
+ uint64_t x9;
1771
+ uint64_t x10;
1772
+ uint64_t x11;
1773
+ uint64_t x12;
1774
+ fiat_p256_uint1 x13;
1775
+ uint64_t x14;
1776
+ fiat_p256_uint1 x15;
1777
+ uint64_t x16;
1778
+ fiat_p256_uint1 x17;
1779
+ uint64_t x18;
1780
+ fiat_p256_uint1 x19;
1781
+ uint64_t x20;
1782
+ fiat_p256_uint1 x21;
1783
+ uint64_t x22;
1784
+ uint64_t x23;
1785
+ uint64_t x24;
1786
+ uint64_t x25;
1787
+ uint64_t x26;
1788
+ uint64_t x27;
1789
+ uint64_t x28;
1790
+ uint64_t x29;
1791
+ uint64_t x30;
1792
+ uint64_t x31;
1793
+ fiat_p256_uint1 x32;
1794
+ uint64_t x33;
1795
+ fiat_p256_uint1 x34;
1796
+ uint64_t x35;
1797
+ fiat_p256_uint1 x36;
1798
+ uint64_t x37;
1799
+ fiat_p256_uint1 x38;
1800
+ uint64_t x39;
1801
+ fiat_p256_uint1 x40;
1802
+ uint64_t x41;
1803
+ fiat_p256_uint1 x42;
1804
+ uint64_t x43;
1805
+ fiat_p256_uint1 x44;
1806
+ uint64_t x45;
1807
+ fiat_p256_uint1 x46;
1808
+ uint64_t x47;
1809
+ fiat_p256_uint1 x48;
1810
+ uint64_t x49;
1811
+ uint64_t x50;
1812
+ uint64_t x51;
1813
+ uint64_t x52;
1814
+ uint64_t x53;
1815
+ fiat_p256_uint1 x54;
1816
+ uint64_t x55;
1817
+ fiat_p256_uint1 x56;
1818
+ uint64_t x57;
1819
+ fiat_p256_uint1 x58;
1820
+ uint64_t x59;
1821
+ fiat_p256_uint1 x60;
1822
+ uint64_t x61;
1823
+ uint64_t x62;
1824
+ fiat_p256_uint1 x63;
1825
+ uint64_t x64;
1826
+ fiat_p256_uint1 x65;
1827
+ uint64_t x66;
1828
+ fiat_p256_uint1 x67;
1829
+ uint64_t x68;
1830
+ fiat_p256_uint1 x69;
1831
+ uint64_t x70;
1832
+ uint64_t x71;
1833
+ uint64_t x72;
1834
+ uint64_t x73;
1835
+ fiat_p256_uint1 x74;
1836
+ uint64_t x75;
1837
+ uint64_t x76;
1838
+ uint64_t x77;
1839
+ uint64_t x78;
1840
+ uint64_t x79;
1841
+ uint64_t x80;
1842
+ fiat_p256_uint1 x81;
1843
+ uint64_t x82;
1844
+ fiat_p256_uint1 x83;
1845
+ uint64_t x84;
1846
+ fiat_p256_uint1 x85;
1847
+ uint64_t x86;
1848
+ fiat_p256_uint1 x87;
1849
+ uint64_t x88;
1850
+ fiat_p256_uint1 x89;
1851
+ uint64_t x90;
1852
+ uint64_t x91;
1853
+ uint64_t x92;
1854
+ uint64_t x93;
1855
+ uint64_t x94;
1856
+ fiat_p256_uint1 x95;
1857
+ uint64_t x96;
1858
+ fiat_p256_uint1 x97;
1859
+ uint64_t x98;
1860
+ fiat_p256_uint1 x99;
1861
+ uint64_t x100;
1862
+ fiat_p256_uint1 x101;
1863
+ uint64_t x102;
1864
+ fiat_p256_uint1 x103;
1865
+ uint64_t x104;
1866
+ fiat_p256_uint1 x105;
1867
+ uint64_t x106;
1868
+ fiat_p256_uint1 x107;
1869
+ uint64_t x108;
1870
+ fiat_p256_uint1 x109;
1871
+ uint64_t x110;
1872
+ fiat_p256_uint1 x111;
1873
+ uint64_t x112;
1874
+ fiat_p256_uint1 x113;
1875
+ uint64_t x114;
1876
+ uint64_t x115;
1877
+ uint64_t x116;
1878
+ uint64_t x117;
1879
+ uint64_t x118;
1880
+ uint64_t x119;
1881
+ uint64_t x120;
1882
+ uint64_t x121;
1883
+ uint64_t x122;
1884
+ uint64_t x123;
1885
+ uint64_t x124;
1886
+ uint64_t x125;
1887
+ uint64_t x126;
1888
+ fiat_p256_addcarryx_u64(&x1, &x2, 0x0, (~arg1), 0x1);
1889
+ x3 = (fiat_p256_uint1)((fiat_p256_uint1)(x1 >> 63) & (fiat_p256_uint1)((arg3[0]) & 0x1));
1890
+ fiat_p256_addcarryx_u64(&x4, &x5, 0x0, (~arg1), 0x1);
1891
+ fiat_p256_cmovznz_u64(&x6, x3, arg1, x4);
1892
+ fiat_p256_cmovznz_u64(&x7, x3, (arg2[0]), (arg3[0]));
1893
+ fiat_p256_cmovznz_u64(&x8, x3, (arg2[1]), (arg3[1]));
1894
+ fiat_p256_cmovznz_u64(&x9, x3, (arg2[2]), (arg3[2]));
1895
+ fiat_p256_cmovznz_u64(&x10, x3, (arg2[3]), (arg3[3]));
1896
+ fiat_p256_cmovznz_u64(&x11, x3, (arg2[4]), (arg3[4]));
1897
+ fiat_p256_addcarryx_u64(&x12, &x13, 0x0, 0x1, (~(arg2[0])));
1898
+ fiat_p256_addcarryx_u64(&x14, &x15, x13, 0x0, (~(arg2[1])));
1899
+ fiat_p256_addcarryx_u64(&x16, &x17, x15, 0x0, (~(arg2[2])));
1900
+ fiat_p256_addcarryx_u64(&x18, &x19, x17, 0x0, (~(arg2[3])));
1901
+ fiat_p256_addcarryx_u64(&x20, &x21, x19, 0x0, (~(arg2[4])));
1902
+ fiat_p256_cmovznz_u64(&x22, x3, (arg3[0]), x12);
1903
+ fiat_p256_cmovznz_u64(&x23, x3, (arg3[1]), x14);
1904
+ fiat_p256_cmovznz_u64(&x24, x3, (arg3[2]), x16);
1905
+ fiat_p256_cmovznz_u64(&x25, x3, (arg3[3]), x18);
1906
+ fiat_p256_cmovznz_u64(&x26, x3, (arg3[4]), x20);
1907
+ fiat_p256_cmovznz_u64(&x27, x3, (arg4[0]), (arg5[0]));
1908
+ fiat_p256_cmovznz_u64(&x28, x3, (arg4[1]), (arg5[1]));
1909
+ fiat_p256_cmovznz_u64(&x29, x3, (arg4[2]), (arg5[2]));
1910
+ fiat_p256_cmovznz_u64(&x30, x3, (arg4[3]), (arg5[3]));
1911
+ fiat_p256_addcarryx_u64(&x31, &x32, 0x0, x27, x27);
1912
+ fiat_p256_addcarryx_u64(&x33, &x34, x32, x28, x28);
1913
+ fiat_p256_addcarryx_u64(&x35, &x36, x34, x29, x29);
1914
+ fiat_p256_addcarryx_u64(&x37, &x38, x36, x30, x30);
1915
+ fiat_p256_subborrowx_u64(&x39, &x40, 0x0, x31, UINT64_C(0xffffffffffffffff));
1916
+ fiat_p256_subborrowx_u64(&x41, &x42, x40, x33, UINT32_C(0xffffffff));
1917
+ fiat_p256_subborrowx_u64(&x43, &x44, x42, x35, 0x0);
1918
+ fiat_p256_subborrowx_u64(&x45, &x46, x44, x37, UINT64_C(0xffffffff00000001));
1919
+ fiat_p256_subborrowx_u64(&x47, &x48, x46, x38, 0x0);
1920
+ x49 = (arg4[3]);
1921
+ x50 = (arg4[2]);
1922
+ x51 = (arg4[1]);
1923
+ x52 = (arg4[0]);
1924
+ fiat_p256_subborrowx_u64(&x53, &x54, 0x0, 0x0, x52);
1925
+ fiat_p256_subborrowx_u64(&x55, &x56, x54, 0x0, x51);
1926
+ fiat_p256_subborrowx_u64(&x57, &x58, x56, 0x0, x50);
1927
+ fiat_p256_subborrowx_u64(&x59, &x60, x58, 0x0, x49);
1928
+ fiat_p256_cmovznz_u64(&x61, x60, 0x0, UINT64_C(0xffffffffffffffff));
1929
+ fiat_p256_addcarryx_u64(&x62, &x63, 0x0, x53, x61);
1930
+ fiat_p256_addcarryx_u64(&x64, &x65, x63, x55, (x61 & UINT32_C(0xffffffff)));
1931
+ fiat_p256_addcarryx_u64(&x66, &x67, x65, x57, 0x0);
1932
+ fiat_p256_addcarryx_u64(&x68, &x69, x67, x59, (x61 & UINT64_C(0xffffffff00000001)));
1933
+ fiat_p256_cmovznz_u64(&x70, x3, (arg5[0]), x62);
1934
+ fiat_p256_cmovznz_u64(&x71, x3, (arg5[1]), x64);
1935
+ fiat_p256_cmovznz_u64(&x72, x3, (arg5[2]), x66);
1936
+ fiat_p256_cmovznz_u64(&x73, x3, (arg5[3]), x68);
1937
+ x74 = (fiat_p256_uint1)(x22 & 0x1);
1938
+ fiat_p256_cmovznz_u64(&x75, x74, 0x0, x7);
1939
+ fiat_p256_cmovznz_u64(&x76, x74, 0x0, x8);
1940
+ fiat_p256_cmovznz_u64(&x77, x74, 0x0, x9);
1941
+ fiat_p256_cmovznz_u64(&x78, x74, 0x0, x10);
1942
+ fiat_p256_cmovznz_u64(&x79, x74, 0x0, x11);
1943
+ fiat_p256_addcarryx_u64(&x80, &x81, 0x0, x22, x75);
1944
+ fiat_p256_addcarryx_u64(&x82, &x83, x81, x23, x76);
1945
+ fiat_p256_addcarryx_u64(&x84, &x85, x83, x24, x77);
1946
+ fiat_p256_addcarryx_u64(&x86, &x87, x85, x25, x78);
1947
+ fiat_p256_addcarryx_u64(&x88, &x89, x87, x26, x79);
1948
+ fiat_p256_cmovznz_u64(&x90, x74, 0x0, x27);
1949
+ fiat_p256_cmovznz_u64(&x91, x74, 0x0, x28);
1950
+ fiat_p256_cmovznz_u64(&x92, x74, 0x0, x29);
1951
+ fiat_p256_cmovznz_u64(&x93, x74, 0x0, x30);
1952
+ fiat_p256_addcarryx_u64(&x94, &x95, 0x0, x70, x90);
1953
+ fiat_p256_addcarryx_u64(&x96, &x97, x95, x71, x91);
1954
+ fiat_p256_addcarryx_u64(&x98, &x99, x97, x72, x92);
1955
+ fiat_p256_addcarryx_u64(&x100, &x101, x99, x73, x93);
1956
+ fiat_p256_subborrowx_u64(&x102, &x103, 0x0, x94, UINT64_C(0xffffffffffffffff));
1957
+ fiat_p256_subborrowx_u64(&x104, &x105, x103, x96, UINT32_C(0xffffffff));
1958
+ fiat_p256_subborrowx_u64(&x106, &x107, x105, x98, 0x0);
1959
+ fiat_p256_subborrowx_u64(&x108, &x109, x107, x100, UINT64_C(0xffffffff00000001));
1960
+ fiat_p256_subborrowx_u64(&x110, &x111, x109, x101, 0x0);
1961
+ fiat_p256_addcarryx_u64(&x112, &x113, 0x0, x6, 0x1);
1962
+ x114 = ((x80 >> 1) | ((x82 << 63) & UINT64_C(0xffffffffffffffff)));
1963
+ x115 = ((x82 >> 1) | ((x84 << 63) & UINT64_C(0xffffffffffffffff)));
1964
+ x116 = ((x84 >> 1) | ((x86 << 63) & UINT64_C(0xffffffffffffffff)));
1965
+ x117 = ((x86 >> 1) | ((x88 << 63) & UINT64_C(0xffffffffffffffff)));
1966
+ x118 = ((x88 & UINT64_C(0x8000000000000000)) | (x88 >> 1));
1967
+ fiat_p256_cmovznz_u64(&x119, x48, x39, x31);
1968
+ fiat_p256_cmovznz_u64(&x120, x48, x41, x33);
1969
+ fiat_p256_cmovznz_u64(&x121, x48, x43, x35);
1970
+ fiat_p256_cmovznz_u64(&x122, x48, x45, x37);
1971
+ fiat_p256_cmovznz_u64(&x123, x111, x102, x94);
1972
+ fiat_p256_cmovznz_u64(&x124, x111, x104, x96);
1973
+ fiat_p256_cmovznz_u64(&x125, x111, x106, x98);
1974
+ fiat_p256_cmovznz_u64(&x126, x111, x108, x100);
1975
+ *out1 = x112;
1976
+ out2[0] = x7;
1977
+ out2[1] = x8;
1978
+ out2[2] = x9;
1979
+ out2[3] = x10;
1980
+ out2[4] = x11;
1981
+ out3[0] = x114;
1982
+ out3[1] = x115;
1983
+ out3[2] = x116;
1984
+ out3[3] = x117;
1985
+ out3[4] = x118;
1986
+ out4[0] = x119;
1987
+ out4[1] = x120;
1988
+ out4[2] = x121;
1989
+ out4[3] = x122;
1990
+ out5[0] = x123;
1991
+ out5[1] = x124;
1992
+ out5[2] = x125;
1993
+ out5[3] = x126;
1225
1994
  }
1226
1995
 
1996
+ /*
1997
+ * The function fiat_p256_divstep_precomp returns the precomputed value for Bernstein-Yang-inversion (in montgomery form).
1998
+ *
1999
+ * Postconditions:
2000
+ * eval (from_montgomery out1) = ⌊(m - 1) / 2⌋^(if ⌊log2 m⌋ + 1 < 46 then ⌊(49 * (⌊log2 m⌋ + 1) + 80) / 17⌋ else ⌊(49 * (⌊log2 m⌋ + 1) + 57) / 17⌋)
2001
+ * 0 ≤ eval out1 < m
2002
+ *
2003
+ * Output Bounds:
2004
+ * out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
2005
+ */
2006
+ static FIAT_P256_FIAT_INLINE void fiat_p256_divstep_precomp(uint64_t out1[4]) {
2007
+ out1[0] = UINT64_C(0x67ffffffb8000000);
2008
+ out1[1] = UINT64_C(0xc000000038000000);
2009
+ out1[2] = UINT64_C(0xd80000007fffffff);
2010
+ out1[3] = UINT64_C(0x2fffffffffffffff);
2011
+ }