grpc 1.53.0 → 1.56.0

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

Potentially problematic release.


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

Files changed (1668) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +218 -143
  3. data/include/grpc/event_engine/event_engine.h +34 -17
  4. data/include/grpc/grpc_audit_logging.h +96 -0
  5. data/include/grpc/grpc_security.h +4 -0
  6. data/include/grpc/impl/grpc_types.h +13 -2
  7. data/include/grpc/module.modulemap +2 -0
  8. data/include/grpc/support/json.h +218 -0
  9. data/include/grpc/support/port_platform.h +4 -4
  10. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +17 -1
  11. data/src/core/ext/filters/client_channel/backend_metric.cc +10 -1
  12. data/src/core/ext/filters/client_channel/backup_poller.cc +2 -11
  13. data/src/core/ext/filters/client_channel/backup_poller.h +0 -3
  14. data/src/core/ext/filters/client_channel/channel_connectivity.cc +4 -4
  15. data/src/core/ext/filters/client_channel/client_channel.cc +911 -898
  16. data/src/core/ext/filters/client_channel/client_channel.h +145 -177
  17. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +20 -19
  18. data/src/core/ext/filters/client_channel/client_channel_internal.h +77 -0
  19. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +2 -2
  20. data/src/core/ext/filters/client_channel/config_selector.h +13 -39
  21. data/src/core/ext/filters/client_channel/http_proxy.cc +35 -2
  22. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +9 -1
  23. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +24 -24
  24. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +1 -1
  25. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -1
  26. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.cc +455 -0
  27. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.h +54 -0
  28. data/src/core/ext/filters/client_channel/lb_policy/health_check_client_internal.h +186 -0
  29. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +2 -7
  30. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +56 -24
  31. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +23 -2
  32. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +19 -6
  33. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +3 -11
  34. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +150 -158
  35. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +18 -1
  36. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +54 -66
  37. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +20 -14
  38. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +36 -13
  39. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/static_stride_scheduler.cc +76 -6
  40. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +83 -53
  41. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +17 -15
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +54 -49
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +12 -13
  44. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +18 -23
  45. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +48 -51
  46. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +12 -17
  47. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +16 -22
  48. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +46 -153
  49. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.h +30 -0
  50. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +4 -4
  51. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +35 -33
  52. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.cc +60 -0
  53. data/src/core/ext/filters/client_channel/resolver/dns/{dns_resolver_selection.h → dns_resolver_plugin.h} +10 -12
  54. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +549 -0
  55. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.h +35 -0
  56. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.cc +97 -0
  57. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.h +32 -0
  58. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +19 -36
  59. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.h +24 -0
  60. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +61 -207
  61. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +1 -2
  62. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +1 -2
  63. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +160 -68
  64. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +16 -1
  65. data/src/core/ext/filters/client_channel/retry_filter.cc +117 -156
  66. data/src/core/ext/filters/client_channel/retry_service_config.cc +9 -8
  67. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +10 -40
  68. data/src/core/ext/filters/client_channel/subchannel.cc +12 -200
  69. data/src/core/ext/filters/client_channel/subchannel.h +3 -43
  70. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +26 -27
  71. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +8 -5
  72. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +1 -1
  73. data/src/core/ext/filters/http/client/http_client_filter.cc +3 -3
  74. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -12
  75. data/src/core/ext/filters/http/message_compress/compression_filter.cc +30 -14
  76. data/src/core/ext/filters/message_size/message_size_filter.cc +141 -224
  77. data/src/core/ext/filters/message_size/message_size_filter.h +48 -3
  78. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +168 -75
  79. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +6 -8
  80. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +10 -9
  81. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +16 -1
  82. data/src/core/ext/gcp/metadata_query.cc +137 -0
  83. data/src/core/ext/gcp/metadata_query.h +87 -0
  84. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +70 -55
  85. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +12 -8
  86. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +5 -1
  87. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +226 -82
  88. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +21 -0
  89. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +70 -0
  90. data/src/core/ext/transport/chttp2/transport/flow_control.cc +51 -97
  91. data/src/core/ext/transport/chttp2/transport/flow_control.h +2 -1
  92. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +1 -7
  93. data/src/core/ext/transport/chttp2/transport/frame_ping.h +0 -3
  94. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +4 -1
  95. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +118 -222
  96. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +296 -113
  97. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -0
  98. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +2 -0
  99. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +466 -273
  100. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +7 -3
  101. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +15 -12
  102. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +9 -1
  103. data/src/core/ext/transport/chttp2/transport/internal.h +21 -21
  104. data/src/core/ext/transport/chttp2/transport/parsing.cc +9 -2
  105. data/src/core/ext/transport/chttp2/transport/writing.cc +24 -8
  106. data/src/core/ext/transport/inproc/inproc_transport.cc +20 -14
  107. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +87 -52
  108. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +414 -181
  109. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +121 -60
  110. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +481 -224
  111. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +90 -55
  112. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +415 -188
  113. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +357 -210
  114. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1572 -729
  115. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +30 -17
  116. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +144 -47
  117. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +34 -21
  118. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +160 -62
  119. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +27 -14
  120. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +78 -38
  121. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +20 -11
  122. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +48 -26
  123. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +20 -11
  124. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +48 -26
  125. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +109 -62
  126. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +566 -244
  127. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +21 -12
  128. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +45 -30
  129. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +22 -19
  130. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +82 -29
  131. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +23 -16
  132. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +45 -30
  133. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +230 -143
  134. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +733 -404
  135. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +417 -262
  136. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1850 -888
  137. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -41
  138. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +286 -148
  139. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +531 -334
  140. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +2017 -1131
  141. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +21 -12
  142. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +45 -30
  143. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +89 -52
  144. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +347 -232
  145. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +264 -165
  146. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +888 -476
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +139 -80
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +527 -274
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +22 -13
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +50 -36
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +380 -221
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1168 -611
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +166 -94
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +666 -292
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +18 -11
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +37 -26
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +21 -12
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +45 -30
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +30 -17
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +144 -47
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +274 -167
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +789 -440
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +228 -137
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +1100 -501
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +22 -13
  166. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +60 -37
  167. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +350 -209
  168. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +1083 -635
  169. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +44 -11
  170. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +175 -18
  171. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +34 -19
  172. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +118 -56
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +38 -21
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +148 -64
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +31 -18
  176. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +143 -65
  177. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +22 -13
  178. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +51 -37
  179. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +78 -43
  180. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +265 -127
  181. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +145 -88
  182. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +438 -241
  183. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +115 -62
  184. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +559 -227
  185. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +18 -11
  186. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +35 -26
  187. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +187 -109
  188. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +956 -421
  189. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +172 -95
  190. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +864 -374
  191. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +49 -25
  192. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +171 -100
  193. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +39 -18
  194. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +74 -56
  195. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +28 -15
  196. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +71 -45
  197. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +131 -74
  198. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +489 -249
  199. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +135 -80
  200. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +505 -245
  201. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +256 -129
  202. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +996 -397
  203. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +80 -49
  204. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +616 -201
  205. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +1283 -774
  206. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +5430 -2509
  207. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +49 -28
  208. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +164 -84
  209. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +228 -141
  210. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +738 -399
  211. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +20 -11
  212. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +48 -26
  213. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +21 -12
  214. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +45 -30
  215. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +32 -19
  216. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +70 -49
  217. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +27 -14
  218. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +110 -43
  219. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +46 -25
  220. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +259 -100
  221. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +21 -13
  222. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +45 -30
  223. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +18 -11
  224. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +35 -26
  225. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +42 -23
  226. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +108 -70
  227. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +7 -4
  228. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +21 -16
  229. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +43 -24
  230. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +110 -75
  231. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +30 -17
  232. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +95 -50
  233. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +16 -9
  234. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +73 -23
  235. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +60 -37
  236. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +150 -108
  237. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +74 -43
  238. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +357 -167
  239. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +44 -25
  240. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +114 -80
  241. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +41 -20
  242. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +245 -82
  243. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.c +32 -19
  244. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +73 -51
  245. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +474 -292
  246. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +2144 -1055
  247. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.c +18 -11
  248. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +35 -26
  249. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +34 -19
  250. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +125 -67
  251. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.c +72 -45
  252. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +193 -138
  253. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +34 -19
  254. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +131 -66
  255. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +18 -11
  256. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +35 -26
  257. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +7 -4
  258. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +15 -10
  259. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +184 -96
  260. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +907 -360
  261. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +56 -33
  262. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +150 -101
  263. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +188 -111
  264. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +816 -419
  265. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +32 -19
  266. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +109 -53
  267. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +10 -7
  268. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +18 -14
  269. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +300 -177
  270. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +1284 -522
  271. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +42 -23
  272. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +188 -75
  273. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +130 -83
  274. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +510 -238
  275. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +22 -13
  276. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +55 -34
  277. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +39 -26
  278. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +124 -68
  279. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.c +21 -12
  280. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.h +47 -30
  281. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +60 -26
  282. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +130 -51
  283. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +37 -20
  284. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +133 -63
  285. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +22 -13
  286. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +91 -40
  287. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +21 -12
  288. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +50 -32
  289. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +18 -11
  290. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +37 -26
  291. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +46 -27
  292. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +101 -70
  293. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.c +13 -10
  294. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.h +25 -22
  295. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +40 -23
  296. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +161 -75
  297. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +31 -18
  298. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +114 -56
  299. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +46 -29
  300. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +139 -91
  301. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +65 -42
  302. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +200 -121
  303. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +80 -45
  304. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +208 -131
  305. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +34 -21
  306. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +74 -53
  307. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +7 -4
  308. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +13 -8
  309. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +16 -9
  310. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +28 -18
  311. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +28 -15
  312. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +55 -34
  313. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +43 -22
  314. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +91 -53
  315. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +35 -20
  316. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +92 -57
  317. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +7 -4
  318. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +13 -8
  319. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +20 -11
  320. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +48 -26
  321. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +23 -14
  322. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +61 -41
  323. data/src/core/ext/upb-generated/google/api/annotations.upb.c +14 -11
  324. data/src/core/ext/upb-generated/google/api/annotations.upb.h +30 -20
  325. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +255 -154
  326. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +934 -450
  327. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +299 -180
  328. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +946 -483
  329. data/src/core/ext/upb-generated/google/api/http.upb.c +68 -35
  330. data/src/core/ext/upb-generated/google/api/http.upb.h +284 -120
  331. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +22 -13
  332. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +95 -37
  333. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +19 -10
  334. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +38 -22
  335. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +1018 -424
  336. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +3851 -1412
  337. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +19 -10
  338. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +38 -22
  339. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +10 -7
  340. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +18 -14
  341. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +62 -39
  342. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +207 -102
  343. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +19 -10
  344. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +38 -22
  345. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +90 -51
  346. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +157 -107
  347. data/src/core/ext/upb-generated/google/rpc/status.upb.c +22 -13
  348. data/src/core/ext/upb-generated/google/rpc/status.upb.h +95 -37
  349. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +59 -34
  350. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +154 -92
  351. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +43 -24
  352. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +118 -60
  353. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +250 -145
  354. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +919 -415
  355. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +34 -19
  356. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +76 -51
  357. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +25 -14
  358. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +45 -30
  359. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +144 -81
  360. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +405 -217
  361. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +51 -26
  362. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +153 -61
  363. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +173 -102
  364. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +855 -298
  365. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +68 -49
  366. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +155 -104
  367. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +26 -17
  368. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +55 -34
  369. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +12 -9
  370. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +31 -14
  371. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +26 -17
  372. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +55 -34
  373. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +23 -16
  374. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +45 -30
  375. data/src/core/ext/upb-generated/validate/validate.upb.c +845 -455
  376. data/src/core/ext/upb-generated/validate/validate.upb.h +4347 -1908
  377. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +68 -49
  378. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +155 -104
  379. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +26 -17
  380. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +55 -34
  381. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +12 -9
  382. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +31 -14
  383. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +65 -44
  384. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +137 -91
  385. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +23 -16
  386. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +45 -30
  387. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +16 -9
  388. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +28 -18
  389. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.c +21 -12
  390. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.h +45 -30
  391. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +37 -22
  392. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +96 -63
  393. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +26 -17
  394. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +52 -29
  395. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +21 -12
  396. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +45 -30
  397. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +23 -14
  398. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +62 -42
  399. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +44 -25
  400. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +169 -79
  401. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +27 -14
  402. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +65 -38
  403. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +86 -31
  404. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +218 -58
  405. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +21 -12
  406. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +89 -34
  407. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.c +18 -11
  408. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.h +35 -26
  409. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.c +32 -19
  410. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.h +150 -54
  411. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.c +10 -7
  412. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.h +18 -14
  413. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.c +34 -21
  414. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.h +161 -63
  415. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +162 -101
  416. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +501 -293
  417. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.c +85 -52
  418. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.h +430 -164
  419. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +24 -15
  420. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +53 -37
  421. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +40 -23
  422. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +161 -75
  423. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.c +37 -22
  424. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.h +92 -66
  425. data/src/core/ext/upb-generated/xds/type/v3/range.upb.c +43 -22
  426. data/src/core/ext/upb-generated/xds/type/v3/range.upb.h +91 -53
  427. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +21 -12
  428. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +45 -30
  429. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +1 -1
  430. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +6 -5
  431. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +1 -1
  432. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +6 -5
  433. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +1 -1
  434. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +6 -5
  435. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +1 -1
  436. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +6 -5
  437. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +1 -1
  438. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +6 -5
  439. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +1 -1
  440. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +6 -5
  441. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +1 -1
  442. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +6 -5
  443. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +1 -1
  444. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +6 -5
  445. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +1 -1
  446. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +6 -5
  447. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +1 -1
  448. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +6 -5
  449. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +1 -1
  450. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +6 -5
  451. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +1 -1
  452. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +6 -5
  453. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +1 -1
  454. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +6 -5
  455. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +1 -1
  456. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +6 -5
  457. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +251 -248
  458. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +6 -5
  459. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +1 -1
  460. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +6 -5
  461. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +1 -1
  462. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +6 -5
  463. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +1 -1
  464. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +6 -5
  465. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +1 -1
  466. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +6 -5
  467. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +1 -1
  468. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +6 -5
  469. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +1 -1
  470. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +6 -5
  471. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +1 -1
  472. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +6 -5
  473. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +1 -1
  474. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +6 -5
  475. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +13 -12
  476. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +11 -5
  477. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +1 -1
  478. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +6 -5
  479. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +1 -1
  480. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +6 -5
  481. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +1 -1
  482. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +6 -5
  483. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +1 -1
  484. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +6 -5
  485. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +1 -1
  486. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +6 -5
  487. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +1 -1
  488. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +6 -5
  489. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +140 -137
  490. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +6 -5
  491. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +32 -16
  492. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +11 -5
  493. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +1 -1
  494. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +6 -5
  495. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +1 -1
  496. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +6 -5
  497. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +1 -1
  498. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +6 -5
  499. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +1 -1
  500. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +6 -5
  501. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +1 -1
  502. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +6 -5
  503. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +1 -1
  504. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +6 -5
  505. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +1 -1
  506. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +6 -5
  507. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +1 -1
  508. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +6 -5
  509. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +13 -10
  510. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +21 -5
  511. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +1 -1
  512. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +6 -5
  513. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +55 -46
  514. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +6 -5
  515. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +1 -1
  516. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +6 -5
  517. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +1 -1
  518. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +6 -5
  519. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +1 -1
  520. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +6 -5
  521. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +1 -1
  522. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +6 -5
  523. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +142 -120
  524. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +16 -5
  525. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +1 -1
  526. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +6 -5
  527. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +101 -98
  528. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +6 -5
  529. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +1 -1
  530. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +6 -5
  531. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +1 -1
  532. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +6 -5
  533. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +1 -1
  534. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +6 -5
  535. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +1 -1
  536. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +6 -5
  537. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +1 -1
  538. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +6 -5
  539. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +1 -1
  540. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +6 -5
  541. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +1 -1
  542. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +6 -5
  543. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +16 -19
  544. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +6 -5
  545. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +1 -1
  546. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +6 -5
  547. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +1 -1
  548. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +6 -5
  549. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +1 -1
  550. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +6 -5
  551. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +1 -1
  552. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +6 -5
  553. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +1 -1
  554. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +6 -5
  555. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +1 -1
  556. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +6 -5
  557. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +1 -1
  558. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +6 -5
  559. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +1 -1
  560. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +6 -5
  561. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +1 -1
  562. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +6 -5
  563. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +1 -1
  564. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +6 -5
  565. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +1 -1
  566. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +6 -5
  567. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +126 -115
  568. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +6 -5
  569. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +1 -1
  570. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +6 -5
  571. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +1 -1
  572. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +6 -5
  573. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +138 -136
  574. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +6 -5
  575. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +1 -1
  576. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +6 -5
  577. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +118 -118
  578. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +6 -5
  579. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +1 -1
  580. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +6 -5
  581. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +6 -6
  582. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +6 -5
  583. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +1 -1
  584. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +6 -5
  585. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +6 -6
  586. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +6 -5
  587. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +12 -13
  588. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +6 -5
  589. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +1 -1
  590. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +6 -5
  591. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +1 -1
  592. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +6 -5
  593. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.c +1 -1
  594. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.h +6 -5
  595. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +13 -10
  596. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +11 -5
  597. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +1 -1
  598. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +6 -5
  599. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +1 -1
  600. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +6 -5
  601. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +1 -1
  602. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +6 -5
  603. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +1 -1
  604. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +6 -5
  605. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +1 -1
  606. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +6 -5
  607. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.c +1 -1
  608. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.h +6 -5
  609. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +1 -1
  610. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +6 -5
  611. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +1 -1
  612. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +6 -5
  613. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +1 -1
  614. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +6 -5
  615. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +1 -1
  616. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +6 -5
  617. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +1 -1
  618. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +6 -5
  619. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +1 -1
  620. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +6 -5
  621. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +1 -1
  622. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +6 -5
  623. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +1 -1
  624. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +6 -5
  625. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +1 -1
  626. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +6 -5
  627. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +1 -1
  628. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +6 -5
  629. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +1 -1
  630. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +6 -5
  631. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +1 -1
  632. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +6 -5
  633. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +1 -1
  634. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +6 -5
  635. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +1 -1
  636. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +6 -5
  637. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +1 -1
  638. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +6 -5
  639. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +1 -1
  640. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +6 -5
  641. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +1 -1
  642. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +6 -5
  643. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +1 -1
  644. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +6 -5
  645. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +1 -1
  646. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +6 -5
  647. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +1 -1
  648. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +6 -5
  649. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +329 -273
  650. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +11 -5
  651. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +1 -1
  652. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +6 -5
  653. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +1 -1
  654. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +6 -5
  655. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +1 -1
  656. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +6 -5
  657. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +1 -1
  658. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +6 -5
  659. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +1 -1
  660. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +6 -5
  661. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +1 -1
  662. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +6 -5
  663. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +1 -1
  664. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +6 -5
  665. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +1 -1
  666. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +6 -5
  667. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +1 -1
  668. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +6 -5
  669. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +1 -1
  670. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +6 -5
  671. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +1 -1
  672. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +6 -5
  673. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +1 -1
  674. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +6 -5
  675. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +1 -1
  676. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +6 -5
  677. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +1 -1
  678. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +6 -5
  679. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +1 -1
  680. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +6 -5
  681. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +1 -1
  682. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +6 -5
  683. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +1 -1
  684. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +6 -5
  685. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +1 -1
  686. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +6 -5
  687. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +1 -1
  688. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +6 -5
  689. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +1 -1
  690. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +6 -5
  691. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.c +1 -1
  692. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.h +6 -5
  693. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +1 -1
  694. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +6 -5
  695. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +1 -1
  696. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +6 -5
  697. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +1 -1
  698. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +6 -5
  699. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +1 -1
  700. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +6 -5
  701. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +1 -1
  702. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +6 -5
  703. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +1 -1
  704. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +6 -5
  705. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.c +1 -1
  706. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.h +6 -5
  707. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.c +1 -1
  708. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.h +6 -5
  709. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  710. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  711. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.c +1 -1
  712. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.h +6 -5
  713. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +1 -1
  714. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +6 -5
  715. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.c +1 -1
  716. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.h +6 -5
  717. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +1 -1
  718. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +6 -5
  719. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +1 -1
  720. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +6 -5
  721. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.c +1 -1
  722. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.h +6 -5
  723. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.c +1 -1
  724. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.h +6 -5
  725. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +1 -1
  726. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +6 -5
  727. data/src/core/ext/xds/certificate_provider_store.cc +8 -13
  728. data/src/core/ext/xds/certificate_provider_store.h +1 -1
  729. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +30 -42
  730. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +14 -9
  731. data/src/core/ext/xds/upb_utils.h +1 -1
  732. data/src/core/ext/xds/xds_api.cc +41 -18
  733. data/src/core/ext/xds/xds_api.h +5 -4
  734. data/src/core/ext/xds/xds_audit_logger_registry.cc +122 -0
  735. data/src/core/ext/xds/xds_audit_logger_registry.h +68 -0
  736. data/src/core/ext/xds/xds_bootstrap.cc +3 -3
  737. data/src/core/ext/xds/xds_bootstrap_grpc.cc +35 -23
  738. data/src/core/ext/xds/xds_bootstrap_grpc.h +5 -0
  739. data/src/core/ext/xds/xds_channel_stack_modifier.cc +1 -2
  740. data/src/core/ext/xds/xds_client.cc +29 -7
  741. data/src/core/ext/xds/xds_client.h +1 -1
  742. data/src/core/ext/xds/xds_client_stats.cc +29 -15
  743. data/src/core/ext/xds/xds_client_stats.h +24 -20
  744. data/src/core/ext/xds/xds_cluster.cc +44 -51
  745. data/src/core/ext/xds/xds_cluster.h +1 -2
  746. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +15 -11
  747. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +2 -2
  748. data/src/core/ext/xds/xds_common_types.cc +8 -5
  749. data/src/core/ext/xds/xds_endpoint.cc +10 -4
  750. data/src/core/ext/xds/xds_endpoint.h +10 -2
  751. data/src/core/ext/xds/xds_http_fault_filter.cc +18 -15
  752. data/src/core/ext/xds/xds_http_fault_filter.h +3 -2
  753. data/src/core/ext/xds/xds_http_filters.h +7 -4
  754. data/src/core/ext/xds/xds_http_rbac_filter.cc +159 -74
  755. data/src/core/ext/xds/xds_http_rbac_filter.h +3 -2
  756. data/src/core/ext/xds/xds_http_stateful_session_filter.cc +17 -13
  757. data/src/core/ext/xds/xds_http_stateful_session_filter.h +3 -2
  758. data/src/core/ext/xds/xds_lb_policy_registry.cc +36 -35
  759. data/src/core/ext/xds/xds_listener.cc +11 -4
  760. data/src/core/ext/xds/xds_listener.h +1 -1
  761. data/src/core/ext/xds/xds_resource_type.h +2 -2
  762. data/src/core/ext/xds/xds_route_config.cc +48 -8
  763. data/src/core/ext/xds/xds_route_config.h +1 -1
  764. data/src/core/ext/xds/xds_routing.cc +2 -2
  765. data/src/core/ext/xds/xds_transport_grpc.cc +4 -2
  766. data/src/core/lib/avl/avl.h +5 -0
  767. data/src/core/lib/backoff/random_early_detection.cc +31 -0
  768. data/src/core/lib/backoff/random_early_detection.h +59 -0
  769. data/src/core/lib/channel/call_finalization.h +1 -1
  770. data/src/core/lib/channel/call_tracer.cc +51 -0
  771. data/src/core/lib/channel/call_tracer.h +101 -38
  772. data/src/core/lib/channel/channel_args.cc +80 -22
  773. data/src/core/lib/channel/channel_args.h +34 -1
  774. data/src/core/lib/channel/channel_trace.cc +16 -12
  775. data/src/core/lib/channel/channelz.cc +163 -135
  776. data/src/core/lib/channel/channelz.h +42 -35
  777. data/src/core/lib/channel/channelz_registry.cc +24 -20
  778. data/src/core/lib/channel/connected_channel.cc +542 -1043
  779. data/src/core/lib/channel/context.h +8 -1
  780. data/src/core/lib/channel/promise_based_filter.cc +100 -46
  781. data/src/core/lib/channel/promise_based_filter.h +29 -13
  782. data/src/core/lib/channel/server_call_tracer_filter.cc +110 -0
  783. data/src/core/lib/compression/compression_internal.cc +2 -5
  784. data/src/core/lib/config/config_vars.cc +153 -0
  785. data/src/core/lib/config/config_vars.h +127 -0
  786. data/src/core/lib/config/config_vars_non_generated.cc +51 -0
  787. data/src/core/lib/config/load_config.cc +79 -0
  788. data/src/core/lib/config/load_config.h +55 -0
  789. data/src/core/lib/debug/event_log.h +1 -1
  790. data/src/core/lib/debug/stats_data.h +1 -1
  791. data/src/core/lib/debug/trace.cc +38 -61
  792. data/src/core/lib/debug/trace.h +14 -9
  793. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +211 -0
  794. data/src/core/lib/event_engine/cf_engine/cf_engine.h +86 -0
  795. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +354 -0
  796. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +146 -0
  797. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +79 -0
  798. data/src/core/lib/event_engine/default_event_engine.cc +13 -1
  799. data/src/core/lib/event_engine/default_event_engine_factory.cc +14 -2
  800. data/src/core/lib/event_engine/event_engine.cc +37 -2
  801. data/src/core/lib/event_engine/handle_containers.h +7 -22
  802. data/src/core/lib/event_engine/memory_allocator_factory.h +47 -0
  803. data/src/core/lib/event_engine/poller.h +2 -2
  804. data/src/core/lib/event_engine/posix.h +4 -0
  805. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +1 -1
  806. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +0 -4
  807. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +3 -9
  808. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -18
  809. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +48 -15
  810. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +17 -8
  811. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +47 -50
  812. data/src/core/lib/event_engine/posix_engine/posix_engine.h +1 -1
  813. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +9 -6
  814. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +7 -8
  815. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +33 -19
  816. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +3 -3
  817. data/src/core/lib/event_engine/posix_engine/timer_manager.h +1 -1
  818. data/src/core/lib/event_engine/resolved_address.cc +2 -1
  819. data/src/core/lib/event_engine/shim.cc +9 -1
  820. data/src/core/lib/event_engine/{thread_pool.cc → thread_pool/original_thread_pool.cc} +28 -25
  821. data/src/core/lib/event_engine/{thread_pool.h → thread_pool/original_thread_pool.h} +11 -15
  822. data/src/core/lib/event_engine/thread_pool/thread_pool.h +50 -0
  823. data/src/core/lib/event_engine/{executor/executor.h → thread_pool/thread_pool_factory.cc} +17 -15
  824. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +489 -0
  825. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +249 -0
  826. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +166 -0
  827. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +108 -0
  828. data/src/core/lib/event_engine/trace.cc +1 -0
  829. data/src/core/lib/event_engine/trace.h +6 -0
  830. data/src/core/lib/event_engine/windows/iocp.cc +4 -3
  831. data/src/core/lib/event_engine/windows/iocp.h +3 -3
  832. data/src/core/lib/event_engine/windows/win_socket.cc +6 -7
  833. data/src/core/lib/event_engine/windows/win_socket.h +4 -4
  834. data/src/core/lib/event_engine/windows/windows_endpoint.cc +135 -87
  835. data/src/core/lib/event_engine/windows/windows_endpoint.h +23 -6
  836. data/src/core/lib/event_engine/windows/windows_engine.cc +55 -32
  837. data/src/core/lib/event_engine/windows/windows_engine.h +8 -7
  838. data/src/core/lib/event_engine/windows/windows_listener.cc +370 -0
  839. data/src/core/lib/event_engine/windows/windows_listener.h +156 -0
  840. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +63 -0
  841. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +71 -0
  842. data/src/core/lib/event_engine/work_queue/work_queue.h +62 -0
  843. data/src/core/lib/experiments/config.cc +41 -17
  844. data/src/core/lib/experiments/config.h +16 -0
  845. data/src/core/lib/experiments/experiments.cc +74 -17
  846. data/src/core/lib/experiments/experiments.h +35 -18
  847. data/src/core/lib/gpr/log.cc +15 -28
  848. data/src/core/lib/gpr/log_internal.h +55 -0
  849. data/src/core/lib/gpr/{time_posix.cc → posix/time.cc} +5 -0
  850. data/src/core/lib/gprpp/crash.cc +10 -0
  851. data/src/core/lib/gprpp/crash.h +3 -0
  852. data/src/core/lib/gprpp/fork.cc +8 -14
  853. data/src/core/lib/gprpp/orphanable.h +4 -3
  854. data/src/core/lib/gprpp/per_cpu.cc +33 -0
  855. data/src/core/lib/gprpp/per_cpu.h +33 -4
  856. data/src/core/lib/gprpp/{thd_posix.cc → posix/thd.cc} +49 -37
  857. data/src/core/lib/gprpp/ref_counted.h +33 -34
  858. data/src/core/lib/gprpp/status_helper.cc +2 -2
  859. data/src/core/lib/gprpp/thd.h +16 -0
  860. data/src/core/lib/gprpp/time.cc +2 -0
  861. data/src/core/lib/gprpp/time.h +4 -4
  862. data/src/core/lib/gprpp/validation_errors.cc +8 -3
  863. data/src/core/lib/gprpp/validation_errors.h +16 -9
  864. data/src/core/lib/gprpp/{thd_windows.cc → windows/thd.cc} +2 -2
  865. data/src/core/lib/iomgr/buffer_list.h +0 -1
  866. data/src/core/lib/iomgr/call_combiner.h +2 -2
  867. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  868. data/src/core/lib/iomgr/endpoint_cfstream.cc +14 -10
  869. data/src/core/lib/iomgr/endpoint_pair.h +2 -2
  870. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -2
  871. data/src/core/lib/iomgr/endpoint_pair_windows.cc +1 -1
  872. data/src/core/lib/iomgr/ev_apple.cc +12 -12
  873. data/src/core/lib/iomgr/ev_epoll1_linux.cc +10 -3
  874. data/src/core/lib/iomgr/ev_posix.cc +13 -53
  875. data/src/core/lib/iomgr/ev_posix.h +0 -3
  876. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +118 -77
  877. data/src/core/lib/iomgr/iocp_windows.cc +24 -3
  878. data/src/core/lib/iomgr/iocp_windows.h +11 -0
  879. data/src/core/lib/iomgr/iomgr.cc +4 -8
  880. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -1
  881. data/src/core/lib/iomgr/iomgr_windows.cc +8 -2
  882. data/src/core/lib/iomgr/pollset_set_windows.cc +9 -9
  883. data/src/core/lib/iomgr/pollset_windows.cc +1 -1
  884. data/src/core/lib/iomgr/socket_utils_common_posix.cc +20 -5
  885. data/src/core/lib/iomgr/socket_utils_posix.cc +3 -0
  886. data/src/core/lib/iomgr/socket_utils_posix.h +3 -0
  887. data/src/core/lib/iomgr/socket_windows.cc +61 -7
  888. data/src/core/lib/iomgr/socket_windows.h +9 -2
  889. data/src/core/lib/iomgr/tcp_client_cfstream.cc +14 -3
  890. data/src/core/lib/iomgr/tcp_client_posix.cc +4 -0
  891. data/src/core/lib/iomgr/tcp_client_windows.cc +2 -2
  892. data/src/core/lib/iomgr/tcp_posix.cc +0 -1
  893. data/src/core/lib/iomgr/tcp_server_posix.cc +150 -120
  894. data/src/core/lib/iomgr/tcp_server_utils_posix.h +1 -1
  895. data/src/core/lib/iomgr/tcp_server_windows.cc +176 -9
  896. data/src/core/lib/iomgr/tcp_windows.cc +12 -8
  897. data/src/core/lib/iomgr/timer_generic.cc +17 -16
  898. data/src/core/lib/json/json.h +2 -218
  899. data/src/core/lib/json/json_object_loader.cc +24 -25
  900. data/src/core/lib/json/json_object_loader.h +30 -18
  901. data/src/core/lib/json/json_reader.cc +69 -42
  902. data/src/core/{ext/filters/client_channel/lb_call_state_internal.h → lib/json/json_reader.h} +7 -12
  903. data/src/core/lib/json/json_util.cc +10 -15
  904. data/src/core/lib/json/json_util.h +5 -4
  905. data/src/core/lib/json/json_writer.cc +24 -25
  906. data/src/core/lib/{security/security_connector/ssl_utils_config.h → json/json_writer.h} +14 -10
  907. data/src/core/lib/load_balancing/lb_policy.cc +9 -13
  908. data/src/core/lib/load_balancing/lb_policy.h +17 -2
  909. data/src/core/lib/load_balancing/lb_policy_registry.cc +9 -8
  910. data/src/core/lib/matchers/matchers.cc +3 -4
  911. data/src/core/lib/matchers/matchers.h +2 -1
  912. data/src/core/lib/promise/activity.cc +27 -6
  913. data/src/core/lib/promise/activity.h +71 -24
  914. data/src/core/lib/promise/cancel_callback.h +77 -0
  915. data/src/core/lib/promise/detail/basic_seq.h +1 -1
  916. data/src/core/lib/promise/detail/promise_factory.h +5 -1
  917. data/src/core/lib/promise/for_each.h +176 -0
  918. data/src/core/lib/promise/if.h +9 -0
  919. data/src/core/lib/promise/interceptor_list.h +23 -2
  920. data/src/core/lib/promise/latch.h +89 -3
  921. data/src/core/lib/promise/loop.h +13 -9
  922. data/src/core/lib/promise/map.h +7 -0
  923. data/src/core/lib/promise/party.cc +304 -0
  924. data/src/core/lib/promise/party.h +508 -0
  925. data/src/core/lib/promise/pipe.h +213 -59
  926. data/src/core/lib/promise/poll.h +48 -0
  927. data/src/core/lib/promise/prioritized_race.h +95 -0
  928. data/src/core/lib/promise/promise.h +2 -2
  929. data/src/core/lib/promise/sleep.cc +2 -1
  930. data/src/core/lib/resolver/server_address.cc +0 -8
  931. data/src/core/lib/resolver/server_address.h +0 -6
  932. data/src/core/lib/resource_quota/arena.cc +19 -3
  933. data/src/core/lib/resource_quota/arena.h +119 -5
  934. data/src/core/lib/resource_quota/memory_quota.cc +8 -8
  935. data/src/core/lib/resource_quota/memory_quota.h +1 -2
  936. data/src/core/lib/security/authorization/audit_logging.cc +98 -0
  937. data/src/core/lib/security/authorization/audit_logging.h +73 -0
  938. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +47 -2
  939. data/src/core/lib/security/authorization/grpc_authorization_engine.h +18 -1
  940. data/src/core/lib/security/authorization/rbac_policy.cc +36 -4
  941. data/src/core/lib/security/authorization/rbac_policy.h +19 -2
  942. data/src/core/lib/security/authorization/stdout_logger.cc +75 -0
  943. data/src/core/lib/security/authorization/stdout_logger.h +61 -0
  944. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +8 -4
  945. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +8 -18
  946. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +14 -8
  947. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +66 -84
  948. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -0
  949. data/src/core/lib/security/credentials/external/external_account_credentials.cc +64 -64
  950. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +23 -21
  951. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +29 -27
  952. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +5 -61
  953. data/src/core/lib/security/credentials/jwt/json_token.cc +19 -16
  954. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +10 -5
  955. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +40 -38
  956. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +28 -21
  957. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -1
  958. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +13 -0
  959. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +2 -0
  960. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +1 -5
  961. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +5 -9
  962. data/src/core/lib/security/security_connector/ssl_utils.cc +11 -25
  963. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +12 -0
  964. data/src/core/lib/security/transport/secure_endpoint.cc +4 -2
  965. data/src/core/lib/security/transport/server_auth_filter.cc +20 -2
  966. data/src/core/lib/security/util/json_util.cc +6 -5
  967. data/src/core/lib/service_config/service_config_call_data.h +49 -20
  968. data/src/core/lib/service_config/service_config_impl.cc +13 -6
  969. data/src/core/lib/slice/slice.cc +1 -1
  970. data/src/core/lib/slice/slice.h +2 -0
  971. data/src/core/lib/surface/builtins.cc +2 -0
  972. data/src/core/lib/surface/call.cc +1011 -1049
  973. data/src/core/lib/surface/call.h +11 -5
  974. data/src/core/lib/surface/completion_queue.cc +8 -3
  975. data/src/core/lib/surface/lame_client.cc +1 -0
  976. data/src/core/lib/surface/server.cc +47 -19
  977. data/src/core/lib/surface/validate_metadata.cc +43 -42
  978. data/src/core/lib/surface/validate_metadata.h +9 -0
  979. data/src/core/lib/surface/version.cc +2 -2
  980. data/src/core/lib/transport/batch_builder.cc +182 -0
  981. data/src/core/lib/transport/batch_builder.h +480 -0
  982. data/src/core/lib/transport/bdp_estimator.cc +7 -7
  983. data/src/core/lib/transport/bdp_estimator.h +10 -6
  984. data/src/core/lib/transport/custom_metadata.h +30 -0
  985. data/src/core/lib/transport/metadata_batch.cc +9 -6
  986. data/src/core/lib/transport/metadata_batch.h +124 -31
  987. data/src/core/lib/transport/metadata_compression_traits.h +67 -0
  988. data/src/core/lib/transport/parsed_metadata.h +19 -9
  989. data/src/core/lib/transport/simple_slice_based_metadata.h +48 -0
  990. data/src/core/lib/transport/timeout_encoding.cc +6 -1
  991. data/src/core/lib/transport/transport.cc +30 -2
  992. data/src/core/lib/transport/transport.h +73 -14
  993. data/src/core/lib/transport/transport_impl.h +7 -0
  994. data/src/core/lib/transport/transport_op_string.cc +52 -42
  995. data/src/core/plugin_registry/grpc_plugin_registry.cc +4 -8
  996. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -0
  997. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +1 -0
  998. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +21 -4
  999. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +5 -0
  1000. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
  1001. data/src/core/tsi/ssl_transport_security.cc +4 -2
  1002. data/src/ruby/ext/grpc/extconf.rb +8 -9
  1003. data/src/ruby/lib/grpc/version.rb +1 -1
  1004. data/third_party/abseil-cpp/absl/base/config.h +1 -1
  1005. data/third_party/abseil-cpp/absl/flags/commandlineflag.cc +34 -0
  1006. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +200 -0
  1007. data/third_party/abseil-cpp/absl/flags/config.h +68 -0
  1008. data/third_party/abseil-cpp/absl/flags/declare.h +73 -0
  1009. data/third_party/abseil-cpp/absl/flags/flag.cc +38 -0
  1010. data/third_party/abseil-cpp/absl/flags/flag.h +310 -0
  1011. data/{src/core/lib/gprpp/global_config_custom.h → third_party/abseil-cpp/absl/flags/internal/commandlineflag.cc} +11 -14
  1012. data/third_party/abseil-cpp/absl/flags/internal/commandlineflag.h +68 -0
  1013. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +615 -0
  1014. data/third_party/abseil-cpp/absl/flags/internal/flag.h +800 -0
  1015. data/third_party/abseil-cpp/absl/flags/internal/flag_msvc.inc +116 -0
  1016. data/third_party/abseil-cpp/absl/flags/internal/path_util.h +62 -0
  1017. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +65 -0
  1018. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.h +61 -0
  1019. data/third_party/abseil-cpp/absl/flags/internal/program_name.cc +60 -0
  1020. data/third_party/abseil-cpp/absl/flags/internal/program_name.h +50 -0
  1021. data/third_party/abseil-cpp/absl/flags/internal/registry.h +97 -0
  1022. data/third_party/abseil-cpp/absl/flags/internal/sequence_lock.h +187 -0
  1023. data/third_party/abseil-cpp/absl/flags/marshalling.cc +241 -0
  1024. data/third_party/abseil-cpp/absl/flags/marshalling.h +356 -0
  1025. data/third_party/abseil-cpp/absl/flags/reflection.cc +354 -0
  1026. data/third_party/abseil-cpp/absl/flags/reflection.h +90 -0
  1027. data/third_party/abseil-cpp/absl/flags/usage_config.cc +165 -0
  1028. data/third_party/abseil-cpp/absl/flags/usage_config.h +135 -0
  1029. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +12 -8
  1030. data/third_party/boringssl-with-bazel/err_data.c +728 -712
  1031. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +177 -177
  1032. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +28 -55
  1033. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +21 -23
  1034. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +20 -23
  1035. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +66 -185
  1036. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +18 -21
  1037. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +356 -311
  1038. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +177 -196
  1039. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +146 -210
  1040. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +6 -9
  1041. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +346 -526
  1042. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +110 -131
  1043. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +130 -116
  1044. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +93 -60
  1045. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +93 -181
  1046. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +242 -305
  1047. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +41 -18
  1048. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +30 -33
  1049. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +36 -33
  1050. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +29 -26
  1051. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +135 -90
  1052. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.c +230 -0
  1053. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +797 -793
  1054. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +529 -526
  1055. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +114 -135
  1056. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +201 -207
  1057. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +21 -26
  1058. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +55 -68
  1059. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +2 -4
  1060. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +17 -11
  1061. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +37 -51
  1062. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +15 -9
  1063. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +13 -9
  1064. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +22 -19
  1065. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +5 -5
  1066. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -13
  1067. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +3 -6
  1068. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +2 -0
  1069. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +40 -27
  1070. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +10 -23
  1071. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +2 -6
  1072. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +2 -1
  1073. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +29 -28
  1074. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +161 -201
  1075. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +254 -39
  1076. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +2 -2
  1077. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +0 -2
  1078. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +4 -4
  1079. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +9 -8
  1080. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +37 -75
  1081. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +8 -10
  1082. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/cipher → cipher_extra}/e_des.c +100 -78
  1083. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +1 -0
  1084. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +1 -0
  1085. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +2 -0
  1086. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +34 -37
  1087. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +22 -11
  1088. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +189 -13
  1089. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +6 -10
  1090. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -1
  1091. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +12 -0
  1092. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +74 -0
  1093. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_freebsd.c +62 -0
  1094. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-fuchsia.c → cpu_aarch64_fuchsia.c} +8 -7
  1095. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-linux.c → cpu_aarch64_linux.c} +6 -4
  1096. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.c +62 -0
  1097. data/third_party/boringssl-with-bazel/src/crypto/{cpu-aarch64-win.c → cpu_aarch64_win.c} +4 -4
  1098. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm.c → cpu_arm.c} +1 -1
  1099. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.c +55 -0
  1100. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm-linux.c → cpu_arm_linux.c} +11 -90
  1101. data/third_party/boringssl-with-bazel/src/crypto/{cpu-arm-linux.h → cpu_arm_linux.h} +0 -38
  1102. data/third_party/boringssl-with-bazel/src/crypto/{cpu-ppc64le.c → cpu_arm_openbsd.c} +10 -17
  1103. data/third_party/boringssl-with-bazel/src/crypto/{cpu-intel.c → cpu_intel.c} +1 -2
  1104. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +25 -20
  1105. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +22 -31
  1106. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +795 -795
  1107. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +1 -5
  1108. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +17 -32
  1109. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/des → des}/des.c +232 -232
  1110. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/des → des}/internal.h +1 -1
  1111. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +1 -0
  1112. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +232 -29
  1113. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -3
  1114. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +43 -16
  1115. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +37 -7
  1116. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +3 -3
  1117. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +11 -36
  1118. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +229 -102
  1119. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +31 -7
  1120. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +1 -1
  1121. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +2 -4
  1122. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +83 -60
  1123. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +46 -12
  1124. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +3 -3
  1125. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +25 -23
  1126. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +43 -9
  1127. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +75 -44
  1128. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +19 -25
  1129. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +96 -45
  1130. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +7 -8
  1131. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +26 -23
  1132. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.c +233 -0
  1133. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +6 -6
  1134. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +42 -25
  1135. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +4 -5
  1136. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +35 -47
  1137. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +135 -244
  1138. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +2 -4
  1139. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +15 -10
  1140. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +29 -15
  1141. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +0 -2
  1142. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c +13 -14
  1143. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +3 -13
  1144. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c +13 -7
  1145. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +9 -7
  1146. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +36 -27
  1147. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +16 -26
  1148. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +88 -60
  1149. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c +4 -3
  1150. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +0 -2
  1151. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +1 -1
  1152. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +1 -1
  1153. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +99 -113
  1154. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +0 -1
  1155. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +5 -3
  1156. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +112 -168
  1157. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +86 -31
  1158. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +11 -6
  1159. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +4 -5
  1160. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +4 -5
  1161. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +13 -0
  1162. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +13 -5
  1163. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +19 -108
  1164. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +19 -15
  1165. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c +15 -16
  1166. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +22 -21
  1167. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c +3 -0
  1168. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +79 -19
  1169. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +102 -99
  1170. data/third_party/boringssl-with-bazel/src/crypto/{cipher_extra → fipsmodule/cipher}/e_aesccm.c +52 -46
  1171. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +39 -0
  1172. data/third_party/boringssl-with-bazel/src/crypto/{cmac → fipsmodule/cmac}/cmac.c +55 -11
  1173. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +2 -3
  1174. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +24 -6
  1175. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +56 -0
  1176. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +5 -3
  1177. data/third_party/boringssl-with-bazel/src/crypto/{evp → fipsmodule/digestsign}/digestsign.c +51 -15
  1178. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +49 -49
  1179. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +92 -18
  1180. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +12 -12
  1181. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +108 -86
  1182. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +55 -25
  1183. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +55 -71
  1184. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64-table.h → p256-nistz-table.h} +1 -1
  1185. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64.c → p256-nistz.c} +72 -65
  1186. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-x86_64.h → p256-nistz.h} +5 -13
  1187. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +62 -51
  1188. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +1 -1
  1189. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +2 -8
  1190. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +12 -17
  1191. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +25 -26
  1192. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +13 -14
  1193. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +9 -1
  1194. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +44 -16
  1195. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +6 -0
  1196. data/third_party/boringssl-with-bazel/src/crypto/{hkdf → fipsmodule/hkdf}/hkdf.c +1 -1
  1197. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c +52 -24
  1198. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +9 -23
  1199. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +1 -4
  1200. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +3 -8
  1201. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +170 -160
  1202. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +12 -14
  1203. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +69 -61
  1204. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +2 -12
  1205. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +27 -28
  1206. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c +31 -13
  1207. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +16 -8
  1208. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +3 -2
  1209. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/getrandom_fillin.h +2 -2
  1210. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +9 -38
  1211. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +73 -59
  1212. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +22 -68
  1213. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +0 -1
  1214. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +43 -16
  1215. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +42 -314
  1216. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +244 -139
  1217. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +144 -205
  1218. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +41 -0
  1219. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +593 -421
  1220. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +89 -0
  1221. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +334 -0
  1222. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +3 -12
  1223. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +2 -0
  1224. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +12 -8
  1225. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +14 -12
  1226. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +8 -0
  1227. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +52 -6
  1228. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +192 -18
  1229. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +65 -29
  1230. data/third_party/boringssl-with-bazel/src/crypto/internal.h +391 -18
  1231. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +91 -0
  1232. data/third_party/boringssl-with-bazel/src/crypto/kyber/keccak.c +204 -0
  1233. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +833 -0
  1234. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +13 -1
  1235. data/third_party/boringssl-with-bazel/src/crypto/mem.c +220 -13
  1236. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +19 -7
  1237. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +9 -4
  1238. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +81 -90
  1239. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +150 -245
  1240. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +633 -613
  1241. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +17 -17
  1242. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +142 -149
  1243. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +99 -131
  1244. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -1
  1245. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -1
  1246. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -1
  1247. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +0 -3
  1248. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +36 -66
  1249. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +31 -38
  1250. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +2 -1
  1251. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +18 -31
  1252. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +1 -0
  1253. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +8 -1
  1254. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +129 -5
  1255. data/third_party/boringssl-with-bazel/src/crypto/refcount_c11.c +0 -2
  1256. data/third_party/boringssl-with-bazel/src/crypto/{refcount_lock.c → refcount_no_threads.c} +6 -17
  1257. data/third_party/boringssl-with-bazel/src/crypto/refcount_win.c +89 -0
  1258. data/third_party/boringssl-with-bazel/src/crypto/{asn1/a_print.c → rsa_extra/internal.h} +15 -21
  1259. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +568 -0
  1260. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +8 -11
  1261. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +61 -27
  1262. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +10 -13
  1263. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +10 -13
  1264. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +128 -34
  1265. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +418 -133
  1266. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +116 -284
  1267. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +701 -87
  1268. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +22 -24
  1269. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +63 -55
  1270. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +32 -34
  1271. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +32 -16
  1272. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +465 -704
  1273. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +285 -331
  1274. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +183 -178
  1275. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +11 -15
  1276. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +68 -50
  1277. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +132 -151
  1278. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +790 -0
  1279. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +95 -102
  1280. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +72 -57
  1281. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +12 -10
  1282. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +220 -254
  1283. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +52 -47
  1284. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +3 -4
  1285. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +136 -270
  1286. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +161 -327
  1287. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +37 -33
  1288. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +14 -31
  1289. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +55 -85
  1290. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +528 -616
  1291. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +129 -122
  1292. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +164 -181
  1293. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +132 -132
  1294. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +186 -203
  1295. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +64 -79
  1296. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +175 -160
  1297. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +1864 -2050
  1298. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +380 -480
  1299. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +156 -163
  1300. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +266 -265
  1301. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +40 -15
  1302. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +59 -63
  1303. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +63 -67
  1304. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +114 -144
  1305. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +25 -26
  1306. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +329 -416
  1307. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +8 -7
  1308. data/third_party/boringssl-with-bazel/src/crypto/x509/x_info.c +30 -28
  1309. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +354 -370
  1310. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +37 -32
  1311. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +116 -119
  1312. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +36 -26
  1313. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +3 -4
  1314. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +10 -13
  1315. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +3 -4
  1316. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +419 -261
  1317. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +113 -105
  1318. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +11 -15
  1319. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +79 -171
  1320. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +126 -131
  1321. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akeya.c +3 -4
  1322. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +465 -469
  1323. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bcons.c +56 -54
  1324. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +46 -49
  1325. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +294 -344
  1326. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +342 -365
  1327. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +429 -393
  1328. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +29 -24
  1329. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_extku.c +65 -59
  1330. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +125 -121
  1331. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ia5.c +43 -42
  1332. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +120 -125
  1333. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_int.c +50 -20
  1334. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +228 -265
  1335. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +386 -389
  1336. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ocsp.c +45 -32
  1337. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcons.c +57 -54
  1338. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pmaps.c +63 -67
  1339. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +130 -135
  1340. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +652 -691
  1341. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +90 -75
  1342. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +1063 -1145
  1343. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +13 -11
  1344. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +28 -48
  1345. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +217 -191
  1346. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +26 -78
  1347. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +50 -14
  1348. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +29 -14
  1349. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +1 -4
  1350. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +49 -17
  1351. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +99 -29
  1352. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +49 -60
  1353. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +2 -15
  1354. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +16 -200
  1355. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +34 -0
  1356. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +82 -0
  1357. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +32 -30
  1358. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +7 -0
  1359. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +4 -0
  1360. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +48 -5
  1361. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +37 -8
  1362. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +1 -0
  1363. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +33 -5
  1364. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +25 -33
  1365. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +1 -1
  1366. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +7 -0
  1367. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +69 -16
  1368. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +91 -0
  1369. data/third_party/boringssl-with-bazel/src/include/openssl/kyber.h +128 -0
  1370. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +74 -8
  1371. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +7 -3
  1372. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +8 -1
  1373. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +1 -0
  1374. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +11 -18
  1375. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +8 -0
  1376. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +12 -1
  1377. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +98 -5
  1378. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +96 -0
  1379. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +18 -21
  1380. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +285 -92
  1381. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +1 -6
  1382. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +381 -287
  1383. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +9 -6
  1384. data/third_party/boringssl-with-bazel/src/include/openssl/time.h +41 -0
  1385. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +22 -7
  1386. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +57 -23
  1387. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +0 -11
  1388. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +2075 -1407
  1389. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +241 -212
  1390. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +2 -2
  1391. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +6 -13
  1392. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +17 -18
  1393. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +4 -5
  1394. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +25 -33
  1395. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +45 -26
  1396. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +64 -35
  1397. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +198 -54
  1398. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +5 -5
  1399. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +53 -34
  1400. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +76 -44
  1401. data/third_party/boringssl-with-bazel/src/ssl/internal.h +200 -121
  1402. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +47 -12
  1403. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +2 -2
  1404. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +91 -75
  1405. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +8 -10
  1406. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +47 -69
  1407. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +1 -0
  1408. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +5 -9
  1409. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +217 -226
  1410. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +78 -101
  1411. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +106 -142
  1412. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +244 -35
  1413. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +167 -64
  1414. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +41 -32
  1415. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +27 -19
  1416. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +22 -6
  1417. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +15 -13
  1418. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +7 -44
  1419. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +7 -4
  1420. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +7 -23
  1421. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +25 -34
  1422. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +2 -2
  1423. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +16 -98
  1424. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +1241 -657
  1425. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +751 -398
  1426. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_msvc.h +1281 -0
  1427. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +3551 -1938
  1428. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +1272 -487
  1429. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64_msvc.h +2002 -0
  1430. data/third_party/cares/cares/include/ares.h +23 -1
  1431. data/third_party/cares/cares/{src/lib → include}/ares_nameser.h +9 -7
  1432. data/third_party/cares/cares/include/ares_rules.h +2 -2
  1433. data/third_party/cares/cares/include/ares_version.h +3 -3
  1434. data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +266 -0
  1435. data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +240 -0
  1436. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +49 -80
  1437. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +37 -43
  1438. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +12 -4
  1439. data/third_party/cares/cares/src/lib/ares_data.c +16 -0
  1440. data/third_party/cares/cares/src/lib/ares_data.h +7 -0
  1441. data/third_party/cares/cares/src/lib/ares_destroy.c +8 -0
  1442. data/third_party/cares/cares/src/lib/ares_expand_name.c +17 -6
  1443. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +1 -0
  1444. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +156 -78
  1445. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +130 -326
  1446. data/third_party/cares/cares/src/lib/ares_init.c +97 -485
  1447. data/third_party/cares/cares/src/lib/ares_library_init.c +2 -89
  1448. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +23 -142
  1449. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +22 -142
  1450. data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +184 -0
  1451. data/third_party/cares/cares/src/lib/ares_private.h +30 -16
  1452. data/third_party/cares/cares/src/lib/ares_process.c +55 -16
  1453. data/third_party/cares/cares/src/lib/ares_query.c +1 -35
  1454. data/third_party/cares/cares/src/lib/ares_rand.c +279 -0
  1455. data/third_party/cares/cares/src/lib/ares_send.c +5 -7
  1456. data/third_party/cares/cares/src/lib/ares_strdup.c +12 -19
  1457. data/third_party/cares/cares/src/lib/ares_strsplit.c +44 -128
  1458. data/third_party/cares/cares/src/lib/ares_strsplit.h +9 -10
  1459. data/third_party/cares/cares/src/lib/inet_net_pton.c +78 -116
  1460. data/third_party/cares/cares/src/tools/ares_getopt.h +53 -0
  1461. data/third_party/upb/upb/{table_internal.h → alloc.h} +6 -6
  1462. data/third_party/upb/upb/arena.h +4 -193
  1463. data/third_party/upb/upb/array.h +4 -51
  1464. data/third_party/upb/upb/base/descriptor_constants.h +104 -0
  1465. data/third_party/upb/upb/base/log2.h +57 -0
  1466. data/third_party/upb/upb/{status.c → base/status.c} +2 -7
  1467. data/third_party/upb/upb/base/status.h +66 -0
  1468. data/third_party/upb/upb/base/string_view.h +75 -0
  1469. data/third_party/upb/upb/{array.c → collections/array.c} +67 -36
  1470. data/third_party/upb/upb/collections/array.h +85 -0
  1471. data/third_party/upb/upb/collections/array_internal.h +135 -0
  1472. data/third_party/upb/upb/{map.c → collections/map.c} +53 -26
  1473. data/third_party/upb/upb/collections/map.h +135 -0
  1474. data/third_party/upb/upb/collections/map_gencode_util.h +78 -0
  1475. data/third_party/upb/upb/collections/map_internal.h +170 -0
  1476. data/third_party/upb/upb/collections/map_sorter.c +166 -0
  1477. data/third_party/upb/upb/collections/map_sorter_internal.h +109 -0
  1478. data/third_party/upb/upb/{message_value.h → collections/message_value.h} +12 -13
  1479. data/third_party/upb/upb/decode.h +3 -62
  1480. data/third_party/upb/upb/def.h +4 -384
  1481. data/third_party/upb/upb/def.hpp +3 -411
  1482. data/third_party/upb/upb/encode.h +3 -48
  1483. data/third_party/upb/upb/extension_registry.h +3 -52
  1484. data/third_party/upb/upb/{table.c → hash/common.c} +52 -110
  1485. data/third_party/upb/upb/hash/common.h +199 -0
  1486. data/third_party/upb/upb/hash/int_table.h +102 -0
  1487. data/third_party/upb/upb/hash/str_table.h +161 -0
  1488. data/third_party/upb/upb/{json_decode.c → json/decode.c} +63 -98
  1489. data/third_party/upb/upb/json/decode.h +52 -0
  1490. data/third_party/upb/upb/{json_encode.c → json/encode.c} +69 -45
  1491. data/third_party/upb/upb/json/encode.h +70 -0
  1492. data/third_party/upb/upb/json_decode.h +4 -15
  1493. data/third_party/upb/upb/json_encode.h +4 -33
  1494. data/third_party/upb/upb/lex/atoi.c +68 -0
  1495. data/third_party/upb/upb/lex/atoi.h +53 -0
  1496. data/third_party/upb/upb/{upb.c → lex/round_trip.c} +2 -11
  1497. data/third_party/upb/upb/{internal/upb.h → lex/round_trip.h} +17 -30
  1498. data/third_party/upb/upb/lex/strtod.c +97 -0
  1499. data/third_party/upb/upb/lex/strtod.h +46 -0
  1500. data/third_party/upb/upb/lex/unicode.c +57 -0
  1501. data/third_party/upb/upb/lex/unicode.h +77 -0
  1502. data/third_party/upb/upb/map.h +4 -85
  1503. data/third_party/upb/upb/mem/alloc.c +47 -0
  1504. data/third_party/upb/upb/mem/alloc.h +98 -0
  1505. data/third_party/upb/upb/mem/arena.c +367 -0
  1506. data/third_party/upb/upb/mem/arena.h +160 -0
  1507. data/third_party/upb/upb/mem/arena_internal.h +114 -0
  1508. data/third_party/upb/upb/message/accessors.c +68 -0
  1509. data/third_party/upb/upb/message/accessors.h +379 -0
  1510. data/third_party/upb/upb/message/accessors_internal.h +325 -0
  1511. data/third_party/upb/upb/message/extension_internal.h +83 -0
  1512. data/third_party/upb/upb/message/internal.h +135 -0
  1513. data/third_party/upb/upb/message/message.c +180 -0
  1514. data/third_party/upb/upb/message/message.h +69 -0
  1515. data/third_party/upb/upb/mini_table/common.c +128 -0
  1516. data/third_party/upb/upb/mini_table/common.h +170 -0
  1517. data/third_party/upb/upb/mini_table/common_internal.h +111 -0
  1518. data/third_party/upb/upb/{mini_table.c → mini_table/decode.c} +513 -533
  1519. data/third_party/upb/upb/mini_table/decode.h +179 -0
  1520. data/third_party/upb/upb/mini_table/encode.c +300 -0
  1521. data/third_party/upb/upb/mini_table/encode_internal.h +111 -0
  1522. data/third_party/upb/upb/{mini_table.hpp → mini_table/encode_internal.hpp} +32 -8
  1523. data/third_party/upb/upb/mini_table/enum_internal.h +88 -0
  1524. data/third_party/upb/upb/mini_table/extension_internal.h +47 -0
  1525. data/third_party/upb/upb/{extension_registry.c → mini_table/extension_registry.c} +27 -24
  1526. data/third_party/upb/upb/mini_table/extension_registry.h +104 -0
  1527. data/third_party/upb/upb/mini_table/field_internal.h +192 -0
  1528. data/third_party/upb/upb/mini_table/file_internal.h +47 -0
  1529. data/third_party/upb/upb/mini_table/message_internal.h +136 -0
  1530. data/third_party/upb/upb/mini_table/sub_internal.h +38 -0
  1531. data/third_party/upb/upb/mini_table/types.h +40 -0
  1532. data/third_party/upb/upb/mini_table.h +4 -157
  1533. data/third_party/upb/upb/msg.h +3 -38
  1534. data/third_party/upb/upb/port/atomic.h +101 -0
  1535. data/third_party/upb/upb/{port_def.inc → port/def.inc} +94 -27
  1536. data/third_party/upb/upb/{port_undef.inc → port/undef.inc} +13 -3
  1537. data/third_party/upb/upb/{internal → port}/vsnprintf_compat.h +5 -7
  1538. data/third_party/upb/upb/reflection/common.h +67 -0
  1539. data/third_party/upb/upb/reflection/def.h +42 -0
  1540. data/third_party/upb/upb/reflection/def.hpp +610 -0
  1541. data/third_party/upb/upb/reflection/def_builder.c +357 -0
  1542. data/third_party/upb/upb/reflection/def_builder_internal.h +157 -0
  1543. data/third_party/upb/upb/reflection/def_pool.c +462 -0
  1544. data/third_party/upb/upb/reflection/def_pool.h +108 -0
  1545. data/third_party/upb/upb/reflection/def_pool_internal.h +77 -0
  1546. data/third_party/upb/upb/reflection/def_type.c +50 -0
  1547. data/third_party/upb/upb/reflection/def_type.h +81 -0
  1548. data/third_party/upb/upb/reflection/desc_state.c +53 -0
  1549. data/third_party/upb/upb/reflection/desc_state_internal.h +64 -0
  1550. data/third_party/upb/upb/reflection/enum_def.c +310 -0
  1551. data/third_party/upb/upb/reflection/enum_def.h +80 -0
  1552. data/third_party/upb/upb/reflection/enum_def_internal.h +56 -0
  1553. data/third_party/upb/upb/reflection/enum_reserved_range.c +84 -0
  1554. data/third_party/upb/upb/reflection/enum_reserved_range.h +51 -0
  1555. data/third_party/upb/upb/reflection/enum_reserved_range_internal.h +55 -0
  1556. data/third_party/upb/upb/reflection/enum_value_def.c +144 -0
  1557. data/third_party/upb/upb/reflection/enum_value_def.h +57 -0
  1558. data/third_party/upb/upb/reflection/enum_value_def_internal.h +57 -0
  1559. data/third_party/upb/upb/reflection/extension_range.c +93 -0
  1560. data/third_party/upb/upb/reflection/extension_range.h +55 -0
  1561. data/third_party/upb/upb/reflection/extension_range_internal.h +54 -0
  1562. data/third_party/upb/upb/reflection/field_def.c +930 -0
  1563. data/third_party/upb/upb/reflection/field_def.h +91 -0
  1564. data/third_party/upb/upb/reflection/field_def_internal.h +76 -0
  1565. data/third_party/upb/upb/reflection/file_def.c +370 -0
  1566. data/third_party/upb/upb/reflection/file_def.h +77 -0
  1567. data/third_party/upb/upb/reflection/file_def_internal.h +57 -0
  1568. data/third_party/upb/upb/reflection/message.c +233 -0
  1569. data/third_party/upb/upb/reflection/message.h +102 -0
  1570. data/third_party/upb/upb/reflection/message.hpp +37 -0
  1571. data/third_party/upb/upb/reflection/message_def.c +718 -0
  1572. data/third_party/upb/upb/reflection/message_def.h +174 -0
  1573. data/third_party/upb/upb/reflection/message_def_internal.h +63 -0
  1574. data/third_party/upb/upb/reflection/message_reserved_range.c +81 -0
  1575. data/third_party/upb/upb/reflection/message_reserved_range.h +51 -0
  1576. data/third_party/upb/upb/reflection/message_reserved_range_internal.h +55 -0
  1577. data/third_party/upb/upb/reflection/method_def.c +124 -0
  1578. data/third_party/upb/upb/reflection/method_def.h +59 -0
  1579. data/third_party/upb/upb/reflection/method_def_internal.h +53 -0
  1580. data/third_party/upb/upb/reflection/oneof_def.c +226 -0
  1581. data/third_party/upb/upb/reflection/oneof_def.h +66 -0
  1582. data/third_party/upb/upb/reflection/oneof_def_internal.h +57 -0
  1583. data/third_party/upb/upb/reflection/service_def.c +128 -0
  1584. data/third_party/upb/upb/reflection/service_def.h +60 -0
  1585. data/third_party/upb/upb/reflection/service_def_internal.h +53 -0
  1586. data/third_party/upb/upb/reflection.h +4 -78
  1587. data/third_party/upb/upb/reflection.hpp +3 -7
  1588. data/third_party/upb/upb/status.h +4 -34
  1589. data/third_party/upb/upb/{collections.h → string_view.h} +7 -7
  1590. data/third_party/upb/upb/{text_encode.c → text/encode.c} +74 -70
  1591. data/third_party/upb/upb/text/encode.h +69 -0
  1592. data/third_party/upb/upb/text_encode.h +4 -32
  1593. data/third_party/upb/upb/upb.h +6 -151
  1594. data/third_party/upb/upb/upb.hpp +10 -18
  1595. data/third_party/upb/upb/wire/common.h +44 -0
  1596. data/third_party/upb/upb/wire/common_internal.h +50 -0
  1597. data/third_party/upb/upb/wire/decode.c +1343 -0
  1598. data/third_party/upb/upb/wire/decode.h +108 -0
  1599. data/third_party/upb/upb/{decode_fast.c → wire/decode_fast.c} +184 -225
  1600. data/third_party/upb/upb/{decode_fast.h → wire/decode_fast.h} +21 -7
  1601. data/third_party/upb/upb/{internal/decode.h → wire/decode_internal.h} +44 -92
  1602. data/third_party/upb/upb/{encode.c → wire/encode.c} +114 -95
  1603. data/third_party/upb/upb/wire/encode.h +92 -0
  1604. data/third_party/upb/upb/wire/eps_copy_input_stream.c +39 -0
  1605. data/third_party/upb/upb/wire/eps_copy_input_stream.h +425 -0
  1606. data/third_party/upb/upb/wire/reader.c +67 -0
  1607. data/third_party/upb/upb/wire/reader.h +227 -0
  1608. data/third_party/upb/upb/wire/swap_internal.h +63 -0
  1609. data/third_party/upb/upb/wire/types.h +41 -0
  1610. data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-neon.c +1 -1
  1611. data/third_party/{upb/third_party/utf8_range → utf8_range}/utf8_range.h +12 -0
  1612. metadata +302 -116
  1613. data/src/core/ext/filters/client_channel/health/health_check_client.cc +0 -175
  1614. data/src/core/ext/filters/client_channel/health/health_check_client.h +0 -43
  1615. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +0 -30
  1616. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  1617. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  1618. data/src/core/lib/gprpp/global_config.h +0 -93
  1619. data/src/core/lib/gprpp/global_config_env.cc +0 -140
  1620. data/src/core/lib/gprpp/global_config_env.h +0 -133
  1621. data/src/core/lib/gprpp/global_config_generic.h +0 -40
  1622. data/src/core/lib/promise/intra_activity_waiter.h +0 -55
  1623. data/src/core/lib/security/security_connector/ssl_utils_config.cc +0 -32
  1624. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_enum.c +0 -195
  1625. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +0 -236
  1626. data/third_party/boringssl-with-bazel/src/crypto/asn1/charmap.h +0 -15
  1627. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +0 -206
  1628. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1-altivec.c +0 -361
  1629. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +0 -287
  1630. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +0 -132
  1631. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_lib.c +0 -155
  1632. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +0 -131
  1633. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_node.c +0 -189
  1634. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +0 -843
  1635. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +0 -289
  1636. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcia.c +0 -57
  1637. data/third_party/cares/cares/src/lib/ares_library_init.h +0 -43
  1638. data/third_party/upb/upb/arena.c +0 -277
  1639. data/third_party/upb/upb/decode.c +0 -1221
  1640. data/third_party/upb/upb/def.c +0 -3269
  1641. data/third_party/upb/upb/internal/table.h +0 -385
  1642. data/third_party/upb/upb/msg.c +0 -368
  1643. data/third_party/upb/upb/msg_internal.h +0 -837
  1644. data/third_party/upb/upb/reflection.c +0 -323
  1645. /data/src/core/lib/gpr/{log_android.cc → android/log.cc} +0 -0
  1646. /data/src/core/lib/gpr/{cpu_iphone.cc → iphone/cpu.cc} +0 -0
  1647. /data/src/core/lib/gpr/{cpu_linux.cc → linux/cpu.cc} +0 -0
  1648. /data/src/core/lib/gpr/{log_linux.cc → linux/log.cc} +0 -0
  1649. /data/src/core/lib/gpr/{tmpfile_msys.cc → msys/tmpfile.cc} +0 -0
  1650. /data/src/core/lib/gpr/{cpu_posix.cc → posix/cpu.cc} +0 -0
  1651. /data/src/core/lib/gpr/{log_posix.cc → posix/log.cc} +0 -0
  1652. /data/src/core/lib/gpr/{string_posix.cc → posix/string.cc} +0 -0
  1653. /data/src/core/lib/gpr/{sync_posix.cc → posix/sync.cc} +0 -0
  1654. /data/src/core/lib/gpr/{tmpfile_posix.cc → posix/tmpfile.cc} +0 -0
  1655. /data/src/core/lib/gpr/{cpu_windows.cc → windows/cpu.cc} +0 -0
  1656. /data/src/core/lib/gpr/{log_windows.cc → windows/log.cc} +0 -0
  1657. /data/src/core/lib/gpr/{string_windows.cc → windows/string.cc} +0 -0
  1658. /data/src/core/lib/gpr/{string_util_windows.cc → windows/string_util.cc} +0 -0
  1659. /data/src/core/lib/gpr/{sync_windows.cc → windows/sync.cc} +0 -0
  1660. /data/src/core/lib/gpr/{time_windows.cc → windows/time.cc} +0 -0
  1661. /data/src/core/lib/gpr/{tmpfile_windows.cc → windows/tmpfile.cc} +0 -0
  1662. /data/src/core/lib/gprpp/{env_linux.cc → linux/env.cc} +0 -0
  1663. /data/src/core/lib/gprpp/{env_posix.cc → posix/env.cc} +0 -0
  1664. /data/src/core/lib/gprpp/{stat_posix.cc → posix/stat.cc} +0 -0
  1665. /data/src/core/lib/gprpp/{env_windows.cc → windows/env.cc} +0 -0
  1666. /data/src/core/lib/gprpp/{stat_windows.cc → windows/stat.cc} +0 -0
  1667. /data/third_party/{upb/third_party/utf8_range → utf8_range}/naive.c +0 -0
  1668. /data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-sse.c +0 -0
@@ -1,24 +1,51 @@
1
- /* Autogenerated: src/ExtractionOCaml/unsaturated_solinas --static 25519 10 '2^255 - 19' 32 carry_mul carry_square carry add sub opp selectznz to_bytes from_bytes carry_scmul121666 */
1
+ /* Autogenerated: 'src/ExtractionOCaml/unsaturated_solinas' --inline --static --use-value-barrier 25519 32 '(auto)' '2^255 - 19' carry_mul carry_square carry add sub opp selectznz to_bytes from_bytes relax carry_scmul121666 */
2
2
  /* curve description: 25519 */
3
- /* requested operations: carry_mul, carry_square, carry, add, sub, opp, selectznz, to_bytes, from_bytes, carry_scmul121666 */
4
- /* n = 10 (from "10") */
5
- /* s-c = 2^255 - [(1, 19)] (from "2^255 - 19") */
6
3
  /* machine_wordsize = 32 (from "32") */
7
-
4
+ /* requested operations: carry_mul, carry_square, carry, add, sub, opp, selectznz, to_bytes, from_bytes, relax, carry_scmul121666 */
5
+ /* n = 10 (from "(auto)") */
6
+ /* s-c = 2^255 - [(1, 19)] (from "2^255 - 19") */
7
+ /* tight_bounds_multiplier = 1 (from "") */
8
+ /* */
8
9
  /* Computed values: */
9
- /* carry_chain = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1] */
10
+ /* carry_chain = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1] */
11
+ /* eval z = z[0] + (z[1] << 26) + (z[2] << 51) + (z[3] << 77) + (z[4] << 102) + (z[5] << 128) + (z[6] << 153) + (z[7] << 179) + (z[8] << 204) + (z[9] << 230) */
12
+ /* 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) */
13
+ /* balance = [0x7ffffda, 0x3fffffe, 0x7fffffe, 0x3fffffe, 0x7fffffe, 0x3fffffe, 0x7fffffe, 0x3fffffe, 0x7fffffe, 0x3fffffe] */
10
14
 
11
15
  #include <stdint.h>
12
16
  typedef unsigned char fiat_25519_uint1;
13
17
  typedef signed char fiat_25519_int1;
18
+ #if defined(__GNUC__) || defined(__clang__)
19
+ # define FIAT_25519_FIAT_INLINE __inline__
20
+ #else
21
+ # define FIAT_25519_FIAT_INLINE
22
+ #endif
23
+
24
+ /* The type fiat_25519_loose_field_element is a field element with loose bounds. */
25
+ /* Bounds: [[0x0 ~> 0xc000000], [0x0 ~> 0x6000000], [0x0 ~> 0xc000000], [0x0 ~> 0x6000000], [0x0 ~> 0xc000000], [0x0 ~> 0x6000000], [0x0 ~> 0xc000000], [0x0 ~> 0x6000000], [0x0 ~> 0xc000000], [0x0 ~> 0x6000000]] */
26
+ typedef uint32_t fiat_25519_loose_field_element[10];
27
+
28
+ /* The type fiat_25519_tight_field_element is a field element with tight bounds. */
29
+ /* Bounds: [[0x0 ~> 0x4000000], [0x0 ~> 0x2000000], [0x0 ~> 0x4000000], [0x0 ~> 0x2000000], [0x0 ~> 0x4000000], [0x0 ~> 0x2000000], [0x0 ~> 0x4000000], [0x0 ~> 0x2000000], [0x0 ~> 0x4000000], [0x0 ~> 0x2000000]] */
30
+ typedef uint32_t fiat_25519_tight_field_element[10];
14
31
 
15
32
  #if (-1 & 3) != 3
16
33
  #error "This code only works on a two's complement system"
17
34
  #endif
18
35
 
36
+ #if !defined(FIAT_25519_NO_ASM) && (defined(__GNUC__) || defined(__clang__))
37
+ static __inline__ uint32_t fiat_25519_value_barrier_u32(uint32_t a) {
38
+ __asm__("" : "+r"(a) : /* no inputs */);
39
+ return a;
40
+ }
41
+ #else
42
+ # define fiat_25519_value_barrier_u32(x) (x)
43
+ #endif
44
+
19
45
 
20
46
  /*
21
47
  * The function fiat_25519_addcarryx_u26 is an addition with carry.
48
+ *
22
49
  * Postconditions:
23
50
  * out1 = (arg1 + arg2 + arg3) mod 2^26
24
51
  * out2 = ⌊(arg1 + arg2 + arg3) / 2^26⌋
@@ -31,16 +58,20 @@ typedef signed char fiat_25519_int1;
31
58
  * out1: [0x0 ~> 0x3ffffff]
32
59
  * out2: [0x0 ~> 0x1]
33
60
  */
34
- static void fiat_25519_addcarryx_u26(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
35
- uint32_t x1 = ((arg1 + arg2) + arg3);
36
- uint32_t x2 = (x1 & UINT32_C(0x3ffffff));
37
- fiat_25519_uint1 x3 = (fiat_25519_uint1)(x1 >> 26);
61
+ static FIAT_25519_FIAT_INLINE void fiat_25519_addcarryx_u26(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
62
+ uint32_t x1;
63
+ uint32_t x2;
64
+ fiat_25519_uint1 x3;
65
+ x1 = ((arg1 + arg2) + arg3);
66
+ x2 = (x1 & UINT32_C(0x3ffffff));
67
+ x3 = (fiat_25519_uint1)(x1 >> 26);
38
68
  *out1 = x2;
39
69
  *out2 = x3;
40
70
  }
41
71
 
42
72
  /*
43
73
  * The function fiat_25519_subborrowx_u26 is a subtraction with borrow.
74
+ *
44
75
  * Postconditions:
45
76
  * out1 = (-arg1 + arg2 + -arg3) mod 2^26
46
77
  * out2 = -⌊(-arg1 + arg2 + -arg3) / 2^26⌋
@@ -53,16 +84,20 @@ static void fiat_25519_addcarryx_u26(uint32_t* out1, fiat_25519_uint1* out2, fia
53
84
  * out1: [0x0 ~> 0x3ffffff]
54
85
  * out2: [0x0 ~> 0x1]
55
86
  */
56
- static void fiat_25519_subborrowx_u26(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
57
- int32_t x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
58
- fiat_25519_int1 x2 = (fiat_25519_int1)(x1 >> 26);
59
- uint32_t x3 = (x1 & UINT32_C(0x3ffffff));
87
+ static FIAT_25519_FIAT_INLINE void fiat_25519_subborrowx_u26(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
88
+ int32_t x1;
89
+ fiat_25519_int1 x2;
90
+ uint32_t x3;
91
+ x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
92
+ x2 = (fiat_25519_int1)(x1 >> 26);
93
+ x3 = (x1 & UINT32_C(0x3ffffff));
60
94
  *out1 = x3;
61
95
  *out2 = (fiat_25519_uint1)(0x0 - x2);
62
96
  }
63
97
 
64
98
  /*
65
99
  * The function fiat_25519_addcarryx_u25 is an addition with carry.
100
+ *
66
101
  * Postconditions:
67
102
  * out1 = (arg1 + arg2 + arg3) mod 2^25
68
103
  * out2 = ⌊(arg1 + arg2 + arg3) / 2^25⌋
@@ -75,16 +110,20 @@ static void fiat_25519_subborrowx_u26(uint32_t* out1, fiat_25519_uint1* out2, fi
75
110
  * out1: [0x0 ~> 0x1ffffff]
76
111
  * out2: [0x0 ~> 0x1]
77
112
  */
78
- static void fiat_25519_addcarryx_u25(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
79
- uint32_t x1 = ((arg1 + arg2) + arg3);
80
- uint32_t x2 = (x1 & UINT32_C(0x1ffffff));
81
- fiat_25519_uint1 x3 = (fiat_25519_uint1)(x1 >> 25);
113
+ static FIAT_25519_FIAT_INLINE void fiat_25519_addcarryx_u25(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
114
+ uint32_t x1;
115
+ uint32_t x2;
116
+ fiat_25519_uint1 x3;
117
+ x1 = ((arg1 + arg2) + arg3);
118
+ x2 = (x1 & UINT32_C(0x1ffffff));
119
+ x3 = (fiat_25519_uint1)(x1 >> 25);
82
120
  *out1 = x2;
83
121
  *out2 = x3;
84
122
  }
85
123
 
86
124
  /*
87
125
  * The function fiat_25519_subborrowx_u25 is a subtraction with borrow.
126
+ *
88
127
  * Postconditions:
89
128
  * out1 = (-arg1 + arg2 + -arg3) mod 2^25
90
129
  * out2 = -⌊(-arg1 + arg2 + -arg3) / 2^25⌋
@@ -97,16 +136,20 @@ static void fiat_25519_addcarryx_u25(uint32_t* out1, fiat_25519_uint1* out2, fia
97
136
  * out1: [0x0 ~> 0x1ffffff]
98
137
  * out2: [0x0 ~> 0x1]
99
138
  */
100
- static void fiat_25519_subborrowx_u25(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
101
- int32_t x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
102
- fiat_25519_int1 x2 = (fiat_25519_int1)(x1 >> 25);
103
- uint32_t x3 = (x1 & UINT32_C(0x1ffffff));
139
+ static FIAT_25519_FIAT_INLINE void fiat_25519_subborrowx_u25(uint32_t* out1, fiat_25519_uint1* out2, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
140
+ int32_t x1;
141
+ fiat_25519_int1 x2;
142
+ uint32_t x3;
143
+ x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
144
+ x2 = (fiat_25519_int1)(x1 >> 25);
145
+ x3 = (x1 & UINT32_C(0x1ffffff));
104
146
  *out1 = x3;
105
147
  *out2 = (fiat_25519_uint1)(0x0 - x2);
106
148
  }
107
149
 
108
150
  /*
109
151
  * The function fiat_25519_cmovznz_u32 is a single-word conditional move.
152
+ *
110
153
  * Postconditions:
111
154
  * out1 = (if arg1 = 0 then arg2 else arg3)
112
155
  *
@@ -117,178 +160,318 @@ static void fiat_25519_subborrowx_u25(uint32_t* out1, fiat_25519_uint1* out2, fi
117
160
  * Output Bounds:
118
161
  * out1: [0x0 ~> 0xffffffff]
119
162
  */
120
- static void fiat_25519_cmovznz_u32(uint32_t* out1, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
121
- fiat_25519_uint1 x1 = (!(!arg1));
122
- uint32_t x2 = ((fiat_25519_int1)(0x0 - x1) & UINT32_C(0xffffffff));
123
- // Note this line has been patched from the synthesized code to add value
124
- // barriers.
125
- //
126
- // Clang recognizes this pattern as a select. While it usually transforms it
127
- // to a cmov, it sometimes further transforms it into a branch, which we do
128
- // not want.
129
- uint32_t x3 = ((value_barrier_u32(x2) & arg3) | (value_barrier_u32(~x2) & arg2));
163
+ static FIAT_25519_FIAT_INLINE void fiat_25519_cmovznz_u32(uint32_t* out1, fiat_25519_uint1 arg1, uint32_t arg2, uint32_t arg3) {
164
+ fiat_25519_uint1 x1;
165
+ uint32_t x2;
166
+ uint32_t x3;
167
+ x1 = (!(!arg1));
168
+ x2 = ((fiat_25519_int1)(0x0 - x1) & UINT32_C(0xffffffff));
169
+ x3 = ((fiat_25519_value_barrier_u32(x2) & arg3) | (fiat_25519_value_barrier_u32((~x2)) & arg2));
130
170
  *out1 = x3;
131
171
  }
132
172
 
133
173
  /*
134
174
  * The function fiat_25519_carry_mul multiplies two field elements and reduces the result.
175
+ *
135
176
  * Postconditions:
136
177
  * eval out1 mod m = (eval arg1 * eval arg2) mod m
137
178
  *
138
- * Input Bounds:
139
- * arg1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
140
- * arg2: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
141
- * Output Bounds:
142
- * out1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
143
179
  */
144
- static void fiat_25519_carry_mul(uint32_t out1[10], const uint32_t arg1[10], const uint32_t arg2[10]) {
145
- uint64_t x1 = ((uint64_t)(arg1[9]) * ((arg2[9]) * UINT8_C(0x26)));
146
- uint64_t x2 = ((uint64_t)(arg1[9]) * ((arg2[8]) * UINT8_C(0x13)));
147
- uint64_t x3 = ((uint64_t)(arg1[9]) * ((arg2[7]) * UINT8_C(0x26)));
148
- uint64_t x4 = ((uint64_t)(arg1[9]) * ((arg2[6]) * UINT8_C(0x13)));
149
- uint64_t x5 = ((uint64_t)(arg1[9]) * ((arg2[5]) * UINT8_C(0x26)));
150
- uint64_t x6 = ((uint64_t)(arg1[9]) * ((arg2[4]) * UINT8_C(0x13)));
151
- uint64_t x7 = ((uint64_t)(arg1[9]) * ((arg2[3]) * UINT8_C(0x26)));
152
- uint64_t x8 = ((uint64_t)(arg1[9]) * ((arg2[2]) * UINT8_C(0x13)));
153
- uint64_t x9 = ((uint64_t)(arg1[9]) * ((arg2[1]) * UINT8_C(0x26)));
154
- uint64_t x10 = ((uint64_t)(arg1[8]) * ((arg2[9]) * UINT8_C(0x13)));
155
- uint64_t x11 = ((uint64_t)(arg1[8]) * ((arg2[8]) * UINT8_C(0x13)));
156
- uint64_t x12 = ((uint64_t)(arg1[8]) * ((arg2[7]) * UINT8_C(0x13)));
157
- uint64_t x13 = ((uint64_t)(arg1[8]) * ((arg2[6]) * UINT8_C(0x13)));
158
- uint64_t x14 = ((uint64_t)(arg1[8]) * ((arg2[5]) * UINT8_C(0x13)));
159
- uint64_t x15 = ((uint64_t)(arg1[8]) * ((arg2[4]) * UINT8_C(0x13)));
160
- uint64_t x16 = ((uint64_t)(arg1[8]) * ((arg2[3]) * UINT8_C(0x13)));
161
- uint64_t x17 = ((uint64_t)(arg1[8]) * ((arg2[2]) * UINT8_C(0x13)));
162
- uint64_t x18 = ((uint64_t)(arg1[7]) * ((arg2[9]) * UINT8_C(0x26)));
163
- uint64_t x19 = ((uint64_t)(arg1[7]) * ((arg2[8]) * UINT8_C(0x13)));
164
- uint64_t x20 = ((uint64_t)(arg1[7]) * ((arg2[7]) * UINT8_C(0x26)));
165
- uint64_t x21 = ((uint64_t)(arg1[7]) * ((arg2[6]) * UINT8_C(0x13)));
166
- uint64_t x22 = ((uint64_t)(arg1[7]) * ((arg2[5]) * UINT8_C(0x26)));
167
- uint64_t x23 = ((uint64_t)(arg1[7]) * ((arg2[4]) * UINT8_C(0x13)));
168
- uint64_t x24 = ((uint64_t)(arg1[7]) * ((arg2[3]) * UINT8_C(0x26)));
169
- uint64_t x25 = ((uint64_t)(arg1[6]) * ((arg2[9]) * UINT8_C(0x13)));
170
- uint64_t x26 = ((uint64_t)(arg1[6]) * ((arg2[8]) * UINT8_C(0x13)));
171
- uint64_t x27 = ((uint64_t)(arg1[6]) * ((arg2[7]) * UINT8_C(0x13)));
172
- uint64_t x28 = ((uint64_t)(arg1[6]) * ((arg2[6]) * UINT8_C(0x13)));
173
- uint64_t x29 = ((uint64_t)(arg1[6]) * ((arg2[5]) * UINT8_C(0x13)));
174
- uint64_t x30 = ((uint64_t)(arg1[6]) * ((arg2[4]) * UINT8_C(0x13)));
175
- uint64_t x31 = ((uint64_t)(arg1[5]) * ((arg2[9]) * UINT8_C(0x26)));
176
- uint64_t x32 = ((uint64_t)(arg1[5]) * ((arg2[8]) * UINT8_C(0x13)));
177
- uint64_t x33 = ((uint64_t)(arg1[5]) * ((arg2[7]) * UINT8_C(0x26)));
178
- uint64_t x34 = ((uint64_t)(arg1[5]) * ((arg2[6]) * UINT8_C(0x13)));
179
- uint64_t x35 = ((uint64_t)(arg1[5]) * ((arg2[5]) * UINT8_C(0x26)));
180
- uint64_t x36 = ((uint64_t)(arg1[4]) * ((arg2[9]) * UINT8_C(0x13)));
181
- uint64_t x37 = ((uint64_t)(arg1[4]) * ((arg2[8]) * UINT8_C(0x13)));
182
- uint64_t x38 = ((uint64_t)(arg1[4]) * ((arg2[7]) * UINT8_C(0x13)));
183
- uint64_t x39 = ((uint64_t)(arg1[4]) * ((arg2[6]) * UINT8_C(0x13)));
184
- uint64_t x40 = ((uint64_t)(arg1[3]) * ((arg2[9]) * UINT8_C(0x26)));
185
- uint64_t x41 = ((uint64_t)(arg1[3]) * ((arg2[8]) * UINT8_C(0x13)));
186
- uint64_t x42 = ((uint64_t)(arg1[3]) * ((arg2[7]) * UINT8_C(0x26)));
187
- uint64_t x43 = ((uint64_t)(arg1[2]) * ((arg2[9]) * UINT8_C(0x13)));
188
- uint64_t x44 = ((uint64_t)(arg1[2]) * ((arg2[8]) * UINT8_C(0x13)));
189
- uint64_t x45 = ((uint64_t)(arg1[1]) * ((arg2[9]) * UINT8_C(0x26)));
190
- uint64_t x46 = ((uint64_t)(arg1[9]) * (arg2[0]));
191
- uint64_t x47 = ((uint64_t)(arg1[8]) * (arg2[1]));
192
- uint64_t x48 = ((uint64_t)(arg1[8]) * (arg2[0]));
193
- uint64_t x49 = ((uint64_t)(arg1[7]) * (arg2[2]));
194
- uint64_t x50 = ((uint64_t)(arg1[7]) * ((arg2[1]) * 0x2));
195
- uint64_t x51 = ((uint64_t)(arg1[7]) * (arg2[0]));
196
- uint64_t x52 = ((uint64_t)(arg1[6]) * (arg2[3]));
197
- uint64_t x53 = ((uint64_t)(arg1[6]) * (arg2[2]));
198
- uint64_t x54 = ((uint64_t)(arg1[6]) * (arg2[1]));
199
- uint64_t x55 = ((uint64_t)(arg1[6]) * (arg2[0]));
200
- uint64_t x56 = ((uint64_t)(arg1[5]) * (arg2[4]));
201
- uint64_t x57 = ((uint64_t)(arg1[5]) * ((arg2[3]) * 0x2));
202
- uint64_t x58 = ((uint64_t)(arg1[5]) * (arg2[2]));
203
- uint64_t x59 = ((uint64_t)(arg1[5]) * ((arg2[1]) * 0x2));
204
- uint64_t x60 = ((uint64_t)(arg1[5]) * (arg2[0]));
205
- uint64_t x61 = ((uint64_t)(arg1[4]) * (arg2[5]));
206
- uint64_t x62 = ((uint64_t)(arg1[4]) * (arg2[4]));
207
- uint64_t x63 = ((uint64_t)(arg1[4]) * (arg2[3]));
208
- uint64_t x64 = ((uint64_t)(arg1[4]) * (arg2[2]));
209
- uint64_t x65 = ((uint64_t)(arg1[4]) * (arg2[1]));
210
- uint64_t x66 = ((uint64_t)(arg1[4]) * (arg2[0]));
211
- uint64_t x67 = ((uint64_t)(arg1[3]) * (arg2[6]));
212
- uint64_t x68 = ((uint64_t)(arg1[3]) * ((arg2[5]) * 0x2));
213
- uint64_t x69 = ((uint64_t)(arg1[3]) * (arg2[4]));
214
- uint64_t x70 = ((uint64_t)(arg1[3]) * ((arg2[3]) * 0x2));
215
- uint64_t x71 = ((uint64_t)(arg1[3]) * (arg2[2]));
216
- uint64_t x72 = ((uint64_t)(arg1[3]) * ((arg2[1]) * 0x2));
217
- uint64_t x73 = ((uint64_t)(arg1[3]) * (arg2[0]));
218
- uint64_t x74 = ((uint64_t)(arg1[2]) * (arg2[7]));
219
- uint64_t x75 = ((uint64_t)(arg1[2]) * (arg2[6]));
220
- uint64_t x76 = ((uint64_t)(arg1[2]) * (arg2[5]));
221
- uint64_t x77 = ((uint64_t)(arg1[2]) * (arg2[4]));
222
- uint64_t x78 = ((uint64_t)(arg1[2]) * (arg2[3]));
223
- uint64_t x79 = ((uint64_t)(arg1[2]) * (arg2[2]));
224
- uint64_t x80 = ((uint64_t)(arg1[2]) * (arg2[1]));
225
- uint64_t x81 = ((uint64_t)(arg1[2]) * (arg2[0]));
226
- uint64_t x82 = ((uint64_t)(arg1[1]) * (arg2[8]));
227
- uint64_t x83 = ((uint64_t)(arg1[1]) * ((arg2[7]) * 0x2));
228
- uint64_t x84 = ((uint64_t)(arg1[1]) * (arg2[6]));
229
- uint64_t x85 = ((uint64_t)(arg1[1]) * ((arg2[5]) * 0x2));
230
- uint64_t x86 = ((uint64_t)(arg1[1]) * (arg2[4]));
231
- uint64_t x87 = ((uint64_t)(arg1[1]) * ((arg2[3]) * 0x2));
232
- uint64_t x88 = ((uint64_t)(arg1[1]) * (arg2[2]));
233
- uint64_t x89 = ((uint64_t)(arg1[1]) * ((arg2[1]) * 0x2));
234
- uint64_t x90 = ((uint64_t)(arg1[1]) * (arg2[0]));
235
- uint64_t x91 = ((uint64_t)(arg1[0]) * (arg2[9]));
236
- uint64_t x92 = ((uint64_t)(arg1[0]) * (arg2[8]));
237
- uint64_t x93 = ((uint64_t)(arg1[0]) * (arg2[7]));
238
- uint64_t x94 = ((uint64_t)(arg1[0]) * (arg2[6]));
239
- uint64_t x95 = ((uint64_t)(arg1[0]) * (arg2[5]));
240
- uint64_t x96 = ((uint64_t)(arg1[0]) * (arg2[4]));
241
- uint64_t x97 = ((uint64_t)(arg1[0]) * (arg2[3]));
242
- uint64_t x98 = ((uint64_t)(arg1[0]) * (arg2[2]));
243
- uint64_t x99 = ((uint64_t)(arg1[0]) * (arg2[1]));
244
- uint64_t x100 = ((uint64_t)(arg1[0]) * (arg2[0]));
245
- uint64_t x101 = (x100 + (x45 + (x44 + (x42 + (x39 + (x35 + (x30 + (x24 + (x17 + x9)))))))));
246
- uint64_t x102 = (x101 >> 26);
247
- uint32_t x103 = (uint32_t)(x101 & UINT32_C(0x3ffffff));
248
- uint64_t x104 = (x91 + (x82 + (x74 + (x67 + (x61 + (x56 + (x52 + (x49 + (x47 + x46)))))))));
249
- uint64_t x105 = (x92 + (x83 + (x75 + (x68 + (x62 + (x57 + (x53 + (x50 + (x48 + x1)))))))));
250
- uint64_t x106 = (x93 + (x84 + (x76 + (x69 + (x63 + (x58 + (x54 + (x51 + (x10 + x2)))))))));
251
- uint64_t x107 = (x94 + (x85 + (x77 + (x70 + (x64 + (x59 + (x55 + (x18 + (x11 + x3)))))))));
252
- uint64_t x108 = (x95 + (x86 + (x78 + (x71 + (x65 + (x60 + (x25 + (x19 + (x12 + x4)))))))));
253
- uint64_t x109 = (x96 + (x87 + (x79 + (x72 + (x66 + (x31 + (x26 + (x20 + (x13 + x5)))))))));
254
- uint64_t x110 = (x97 + (x88 + (x80 + (x73 + (x36 + (x32 + (x27 + (x21 + (x14 + x6)))))))));
255
- uint64_t x111 = (x98 + (x89 + (x81 + (x40 + (x37 + (x33 + (x28 + (x22 + (x15 + x7)))))))));
256
- uint64_t x112 = (x99 + (x90 + (x43 + (x41 + (x38 + (x34 + (x29 + (x23 + (x16 + x8)))))))));
257
- uint64_t x113 = (x102 + x112);
258
- uint64_t x114 = (x113 >> 25);
259
- uint32_t x115 = (uint32_t)(x113 & UINT32_C(0x1ffffff));
260
- uint64_t x116 = (x114 + x111);
261
- uint64_t x117 = (x116 >> 26);
262
- uint32_t x118 = (uint32_t)(x116 & UINT32_C(0x3ffffff));
263
- uint64_t x119 = (x117 + x110);
264
- uint64_t x120 = (x119 >> 25);
265
- uint32_t x121 = (uint32_t)(x119 & UINT32_C(0x1ffffff));
266
- uint64_t x122 = (x120 + x109);
267
- uint64_t x123 = (x122 >> 26);
268
- uint32_t x124 = (uint32_t)(x122 & UINT32_C(0x3ffffff));
269
- uint64_t x125 = (x123 + x108);
270
- uint64_t x126 = (x125 >> 25);
271
- uint32_t x127 = (uint32_t)(x125 & UINT32_C(0x1ffffff));
272
- uint64_t x128 = (x126 + x107);
273
- uint64_t x129 = (x128 >> 26);
274
- uint32_t x130 = (uint32_t)(x128 & UINT32_C(0x3ffffff));
275
- uint64_t x131 = (x129 + x106);
276
- uint64_t x132 = (x131 >> 25);
277
- uint32_t x133 = (uint32_t)(x131 & UINT32_C(0x1ffffff));
278
- uint64_t x134 = (x132 + x105);
279
- uint64_t x135 = (x134 >> 26);
280
- uint32_t x136 = (uint32_t)(x134 & UINT32_C(0x3ffffff));
281
- uint64_t x137 = (x135 + x104);
282
- uint64_t x138 = (x137 >> 25);
283
- uint32_t x139 = (uint32_t)(x137 & UINT32_C(0x1ffffff));
284
- uint64_t x140 = (x138 * UINT8_C(0x13));
285
- uint64_t x141 = (x103 + x140);
286
- uint32_t x142 = (uint32_t)(x141 >> 26);
287
- uint32_t x143 = (uint32_t)(x141 & UINT32_C(0x3ffffff));
288
- uint32_t x144 = (x142 + x115);
289
- fiat_25519_uint1 x145 = (fiat_25519_uint1)(x144 >> 25);
290
- uint32_t x146 = (x144 & UINT32_C(0x1ffffff));
291
- uint32_t x147 = (x145 + x118);
180
+ static FIAT_25519_FIAT_INLINE void fiat_25519_carry_mul(fiat_25519_tight_field_element out1, const fiat_25519_loose_field_element arg1, const fiat_25519_loose_field_element arg2) {
181
+ uint64_t x1;
182
+ uint64_t x2;
183
+ uint64_t x3;
184
+ uint64_t x4;
185
+ uint64_t x5;
186
+ uint64_t x6;
187
+ uint64_t x7;
188
+ uint64_t x8;
189
+ uint64_t x9;
190
+ uint64_t x10;
191
+ uint64_t x11;
192
+ uint64_t x12;
193
+ uint64_t x13;
194
+ uint64_t x14;
195
+ uint64_t x15;
196
+ uint64_t x16;
197
+ uint64_t x17;
198
+ uint64_t x18;
199
+ uint64_t x19;
200
+ uint64_t x20;
201
+ uint64_t x21;
202
+ uint64_t x22;
203
+ uint64_t x23;
204
+ uint64_t x24;
205
+ uint64_t x25;
206
+ uint64_t x26;
207
+ uint64_t x27;
208
+ uint64_t x28;
209
+ uint64_t x29;
210
+ uint64_t x30;
211
+ uint64_t x31;
212
+ uint64_t x32;
213
+ uint64_t x33;
214
+ uint64_t x34;
215
+ uint64_t x35;
216
+ uint64_t x36;
217
+ uint64_t x37;
218
+ uint64_t x38;
219
+ uint64_t x39;
220
+ uint64_t x40;
221
+ uint64_t x41;
222
+ uint64_t x42;
223
+ uint64_t x43;
224
+ uint64_t x44;
225
+ uint64_t x45;
226
+ uint64_t x46;
227
+ uint64_t x47;
228
+ uint64_t x48;
229
+ uint64_t x49;
230
+ uint64_t x50;
231
+ uint64_t x51;
232
+ uint64_t x52;
233
+ uint64_t x53;
234
+ uint64_t x54;
235
+ uint64_t x55;
236
+ uint64_t x56;
237
+ uint64_t x57;
238
+ uint64_t x58;
239
+ uint64_t x59;
240
+ uint64_t x60;
241
+ uint64_t x61;
242
+ uint64_t x62;
243
+ uint64_t x63;
244
+ uint64_t x64;
245
+ uint64_t x65;
246
+ uint64_t x66;
247
+ uint64_t x67;
248
+ uint64_t x68;
249
+ uint64_t x69;
250
+ uint64_t x70;
251
+ uint64_t x71;
252
+ uint64_t x72;
253
+ uint64_t x73;
254
+ uint64_t x74;
255
+ uint64_t x75;
256
+ uint64_t x76;
257
+ uint64_t x77;
258
+ uint64_t x78;
259
+ uint64_t x79;
260
+ uint64_t x80;
261
+ uint64_t x81;
262
+ uint64_t x82;
263
+ uint64_t x83;
264
+ uint64_t x84;
265
+ uint64_t x85;
266
+ uint64_t x86;
267
+ uint64_t x87;
268
+ uint64_t x88;
269
+ uint64_t x89;
270
+ uint64_t x90;
271
+ uint64_t x91;
272
+ uint64_t x92;
273
+ uint64_t x93;
274
+ uint64_t x94;
275
+ uint64_t x95;
276
+ uint64_t x96;
277
+ uint64_t x97;
278
+ uint64_t x98;
279
+ uint64_t x99;
280
+ uint64_t x100;
281
+ uint64_t x101;
282
+ uint64_t x102;
283
+ uint32_t x103;
284
+ uint64_t x104;
285
+ uint64_t x105;
286
+ uint64_t x106;
287
+ uint64_t x107;
288
+ uint64_t x108;
289
+ uint64_t x109;
290
+ uint64_t x110;
291
+ uint64_t x111;
292
+ uint64_t x112;
293
+ uint64_t x113;
294
+ uint64_t x114;
295
+ uint32_t x115;
296
+ uint64_t x116;
297
+ uint64_t x117;
298
+ uint32_t x118;
299
+ uint64_t x119;
300
+ uint64_t x120;
301
+ uint32_t x121;
302
+ uint64_t x122;
303
+ uint64_t x123;
304
+ uint32_t x124;
305
+ uint64_t x125;
306
+ uint64_t x126;
307
+ uint32_t x127;
308
+ uint64_t x128;
309
+ uint64_t x129;
310
+ uint32_t x130;
311
+ uint64_t x131;
312
+ uint64_t x132;
313
+ uint32_t x133;
314
+ uint64_t x134;
315
+ uint64_t x135;
316
+ uint32_t x136;
317
+ uint64_t x137;
318
+ uint64_t x138;
319
+ uint32_t x139;
320
+ uint64_t x140;
321
+ uint64_t x141;
322
+ uint32_t x142;
323
+ uint32_t x143;
324
+ uint32_t x144;
325
+ fiat_25519_uint1 x145;
326
+ uint32_t x146;
327
+ uint32_t x147;
328
+ x1 = ((uint64_t)(arg1[9]) * ((arg2[9]) * UINT8_C(0x26)));
329
+ x2 = ((uint64_t)(arg1[9]) * ((arg2[8]) * UINT8_C(0x13)));
330
+ x3 = ((uint64_t)(arg1[9]) * ((arg2[7]) * UINT8_C(0x26)));
331
+ x4 = ((uint64_t)(arg1[9]) * ((arg2[6]) * UINT8_C(0x13)));
332
+ x5 = ((uint64_t)(arg1[9]) * ((arg2[5]) * UINT8_C(0x26)));
333
+ x6 = ((uint64_t)(arg1[9]) * ((arg2[4]) * UINT8_C(0x13)));
334
+ x7 = ((uint64_t)(arg1[9]) * ((arg2[3]) * UINT8_C(0x26)));
335
+ x8 = ((uint64_t)(arg1[9]) * ((arg2[2]) * UINT8_C(0x13)));
336
+ x9 = ((uint64_t)(arg1[9]) * ((arg2[1]) * UINT8_C(0x26)));
337
+ x10 = ((uint64_t)(arg1[8]) * ((arg2[9]) * UINT8_C(0x13)));
338
+ x11 = ((uint64_t)(arg1[8]) * ((arg2[8]) * UINT8_C(0x13)));
339
+ x12 = ((uint64_t)(arg1[8]) * ((arg2[7]) * UINT8_C(0x13)));
340
+ x13 = ((uint64_t)(arg1[8]) * ((arg2[6]) * UINT8_C(0x13)));
341
+ x14 = ((uint64_t)(arg1[8]) * ((arg2[5]) * UINT8_C(0x13)));
342
+ x15 = ((uint64_t)(arg1[8]) * ((arg2[4]) * UINT8_C(0x13)));
343
+ x16 = ((uint64_t)(arg1[8]) * ((arg2[3]) * UINT8_C(0x13)));
344
+ x17 = ((uint64_t)(arg1[8]) * ((arg2[2]) * UINT8_C(0x13)));
345
+ x18 = ((uint64_t)(arg1[7]) * ((arg2[9]) * UINT8_C(0x26)));
346
+ x19 = ((uint64_t)(arg1[7]) * ((arg2[8]) * UINT8_C(0x13)));
347
+ x20 = ((uint64_t)(arg1[7]) * ((arg2[7]) * UINT8_C(0x26)));
348
+ x21 = ((uint64_t)(arg1[7]) * ((arg2[6]) * UINT8_C(0x13)));
349
+ x22 = ((uint64_t)(arg1[7]) * ((arg2[5]) * UINT8_C(0x26)));
350
+ x23 = ((uint64_t)(arg1[7]) * ((arg2[4]) * UINT8_C(0x13)));
351
+ x24 = ((uint64_t)(arg1[7]) * ((arg2[3]) * UINT8_C(0x26)));
352
+ x25 = ((uint64_t)(arg1[6]) * ((arg2[9]) * UINT8_C(0x13)));
353
+ x26 = ((uint64_t)(arg1[6]) * ((arg2[8]) * UINT8_C(0x13)));
354
+ x27 = ((uint64_t)(arg1[6]) * ((arg2[7]) * UINT8_C(0x13)));
355
+ x28 = ((uint64_t)(arg1[6]) * ((arg2[6]) * UINT8_C(0x13)));
356
+ x29 = ((uint64_t)(arg1[6]) * ((arg2[5]) * UINT8_C(0x13)));
357
+ x30 = ((uint64_t)(arg1[6]) * ((arg2[4]) * UINT8_C(0x13)));
358
+ x31 = ((uint64_t)(arg1[5]) * ((arg2[9]) * UINT8_C(0x26)));
359
+ x32 = ((uint64_t)(arg1[5]) * ((arg2[8]) * UINT8_C(0x13)));
360
+ x33 = ((uint64_t)(arg1[5]) * ((arg2[7]) * UINT8_C(0x26)));
361
+ x34 = ((uint64_t)(arg1[5]) * ((arg2[6]) * UINT8_C(0x13)));
362
+ x35 = ((uint64_t)(arg1[5]) * ((arg2[5]) * UINT8_C(0x26)));
363
+ x36 = ((uint64_t)(arg1[4]) * ((arg2[9]) * UINT8_C(0x13)));
364
+ x37 = ((uint64_t)(arg1[4]) * ((arg2[8]) * UINT8_C(0x13)));
365
+ x38 = ((uint64_t)(arg1[4]) * ((arg2[7]) * UINT8_C(0x13)));
366
+ x39 = ((uint64_t)(arg1[4]) * ((arg2[6]) * UINT8_C(0x13)));
367
+ x40 = ((uint64_t)(arg1[3]) * ((arg2[9]) * UINT8_C(0x26)));
368
+ x41 = ((uint64_t)(arg1[3]) * ((arg2[8]) * UINT8_C(0x13)));
369
+ x42 = ((uint64_t)(arg1[3]) * ((arg2[7]) * UINT8_C(0x26)));
370
+ x43 = ((uint64_t)(arg1[2]) * ((arg2[9]) * UINT8_C(0x13)));
371
+ x44 = ((uint64_t)(arg1[2]) * ((arg2[8]) * UINT8_C(0x13)));
372
+ x45 = ((uint64_t)(arg1[1]) * ((arg2[9]) * UINT8_C(0x26)));
373
+ x46 = ((uint64_t)(arg1[9]) * (arg2[0]));
374
+ x47 = ((uint64_t)(arg1[8]) * (arg2[1]));
375
+ x48 = ((uint64_t)(arg1[8]) * (arg2[0]));
376
+ x49 = ((uint64_t)(arg1[7]) * (arg2[2]));
377
+ x50 = ((uint64_t)(arg1[7]) * ((arg2[1]) * 0x2));
378
+ x51 = ((uint64_t)(arg1[7]) * (arg2[0]));
379
+ x52 = ((uint64_t)(arg1[6]) * (arg2[3]));
380
+ x53 = ((uint64_t)(arg1[6]) * (arg2[2]));
381
+ x54 = ((uint64_t)(arg1[6]) * (arg2[1]));
382
+ x55 = ((uint64_t)(arg1[6]) * (arg2[0]));
383
+ x56 = ((uint64_t)(arg1[5]) * (arg2[4]));
384
+ x57 = ((uint64_t)(arg1[5]) * ((arg2[3]) * 0x2));
385
+ x58 = ((uint64_t)(arg1[5]) * (arg2[2]));
386
+ x59 = ((uint64_t)(arg1[5]) * ((arg2[1]) * 0x2));
387
+ x60 = ((uint64_t)(arg1[5]) * (arg2[0]));
388
+ x61 = ((uint64_t)(arg1[4]) * (arg2[5]));
389
+ x62 = ((uint64_t)(arg1[4]) * (arg2[4]));
390
+ x63 = ((uint64_t)(arg1[4]) * (arg2[3]));
391
+ x64 = ((uint64_t)(arg1[4]) * (arg2[2]));
392
+ x65 = ((uint64_t)(arg1[4]) * (arg2[1]));
393
+ x66 = ((uint64_t)(arg1[4]) * (arg2[0]));
394
+ x67 = ((uint64_t)(arg1[3]) * (arg2[6]));
395
+ x68 = ((uint64_t)(arg1[3]) * ((arg2[5]) * 0x2));
396
+ x69 = ((uint64_t)(arg1[3]) * (arg2[4]));
397
+ x70 = ((uint64_t)(arg1[3]) * ((arg2[3]) * 0x2));
398
+ x71 = ((uint64_t)(arg1[3]) * (arg2[2]));
399
+ x72 = ((uint64_t)(arg1[3]) * ((arg2[1]) * 0x2));
400
+ x73 = ((uint64_t)(arg1[3]) * (arg2[0]));
401
+ x74 = ((uint64_t)(arg1[2]) * (arg2[7]));
402
+ x75 = ((uint64_t)(arg1[2]) * (arg2[6]));
403
+ x76 = ((uint64_t)(arg1[2]) * (arg2[5]));
404
+ x77 = ((uint64_t)(arg1[2]) * (arg2[4]));
405
+ x78 = ((uint64_t)(arg1[2]) * (arg2[3]));
406
+ x79 = ((uint64_t)(arg1[2]) * (arg2[2]));
407
+ x80 = ((uint64_t)(arg1[2]) * (arg2[1]));
408
+ x81 = ((uint64_t)(arg1[2]) * (arg2[0]));
409
+ x82 = ((uint64_t)(arg1[1]) * (arg2[8]));
410
+ x83 = ((uint64_t)(arg1[1]) * ((arg2[7]) * 0x2));
411
+ x84 = ((uint64_t)(arg1[1]) * (arg2[6]));
412
+ x85 = ((uint64_t)(arg1[1]) * ((arg2[5]) * 0x2));
413
+ x86 = ((uint64_t)(arg1[1]) * (arg2[4]));
414
+ x87 = ((uint64_t)(arg1[1]) * ((arg2[3]) * 0x2));
415
+ x88 = ((uint64_t)(arg1[1]) * (arg2[2]));
416
+ x89 = ((uint64_t)(arg1[1]) * ((arg2[1]) * 0x2));
417
+ x90 = ((uint64_t)(arg1[1]) * (arg2[0]));
418
+ x91 = ((uint64_t)(arg1[0]) * (arg2[9]));
419
+ x92 = ((uint64_t)(arg1[0]) * (arg2[8]));
420
+ x93 = ((uint64_t)(arg1[0]) * (arg2[7]));
421
+ x94 = ((uint64_t)(arg1[0]) * (arg2[6]));
422
+ x95 = ((uint64_t)(arg1[0]) * (arg2[5]));
423
+ x96 = ((uint64_t)(arg1[0]) * (arg2[4]));
424
+ x97 = ((uint64_t)(arg1[0]) * (arg2[3]));
425
+ x98 = ((uint64_t)(arg1[0]) * (arg2[2]));
426
+ x99 = ((uint64_t)(arg1[0]) * (arg2[1]));
427
+ x100 = ((uint64_t)(arg1[0]) * (arg2[0]));
428
+ x101 = (x100 + (x45 + (x44 + (x42 + (x39 + (x35 + (x30 + (x24 + (x17 + x9)))))))));
429
+ x102 = (x101 >> 26);
430
+ x103 = (uint32_t)(x101 & UINT32_C(0x3ffffff));
431
+ x104 = (x91 + (x82 + (x74 + (x67 + (x61 + (x56 + (x52 + (x49 + (x47 + x46)))))))));
432
+ x105 = (x92 + (x83 + (x75 + (x68 + (x62 + (x57 + (x53 + (x50 + (x48 + x1)))))))));
433
+ x106 = (x93 + (x84 + (x76 + (x69 + (x63 + (x58 + (x54 + (x51 + (x10 + x2)))))))));
434
+ x107 = (x94 + (x85 + (x77 + (x70 + (x64 + (x59 + (x55 + (x18 + (x11 + x3)))))))));
435
+ x108 = (x95 + (x86 + (x78 + (x71 + (x65 + (x60 + (x25 + (x19 + (x12 + x4)))))))));
436
+ x109 = (x96 + (x87 + (x79 + (x72 + (x66 + (x31 + (x26 + (x20 + (x13 + x5)))))))));
437
+ x110 = (x97 + (x88 + (x80 + (x73 + (x36 + (x32 + (x27 + (x21 + (x14 + x6)))))))));
438
+ x111 = (x98 + (x89 + (x81 + (x40 + (x37 + (x33 + (x28 + (x22 + (x15 + x7)))))))));
439
+ x112 = (x99 + (x90 + (x43 + (x41 + (x38 + (x34 + (x29 + (x23 + (x16 + x8)))))))));
440
+ x113 = (x102 + x112);
441
+ x114 = (x113 >> 25);
442
+ x115 = (uint32_t)(x113 & UINT32_C(0x1ffffff));
443
+ x116 = (x114 + x111);
444
+ x117 = (x116 >> 26);
445
+ x118 = (uint32_t)(x116 & UINT32_C(0x3ffffff));
446
+ x119 = (x117 + x110);
447
+ x120 = (x119 >> 25);
448
+ x121 = (uint32_t)(x119 & UINT32_C(0x1ffffff));
449
+ x122 = (x120 + x109);
450
+ x123 = (x122 >> 26);
451
+ x124 = (uint32_t)(x122 & UINT32_C(0x3ffffff));
452
+ x125 = (x123 + x108);
453
+ x126 = (x125 >> 25);
454
+ x127 = (uint32_t)(x125 & UINT32_C(0x1ffffff));
455
+ x128 = (x126 + x107);
456
+ x129 = (x128 >> 26);
457
+ x130 = (uint32_t)(x128 & UINT32_C(0x3ffffff));
458
+ x131 = (x129 + x106);
459
+ x132 = (x131 >> 25);
460
+ x133 = (uint32_t)(x131 & UINT32_C(0x1ffffff));
461
+ x134 = (x132 + x105);
462
+ x135 = (x134 >> 26);
463
+ x136 = (uint32_t)(x134 & UINT32_C(0x3ffffff));
464
+ x137 = (x135 + x104);
465
+ x138 = (x137 >> 25);
466
+ x139 = (uint32_t)(x137 & UINT32_C(0x1ffffff));
467
+ x140 = (x138 * UINT8_C(0x13));
468
+ x141 = (x103 + x140);
469
+ x142 = (uint32_t)(x141 >> 26);
470
+ x143 = (uint32_t)(x141 & UINT32_C(0x3ffffff));
471
+ x144 = (x142 + x115);
472
+ x145 = (fiat_25519_uint1)(x144 >> 25);
473
+ x146 = (x144 & UINT32_C(0x1ffffff));
474
+ x147 = (x145 + x118);
292
475
  out1[0] = x143;
293
476
  out1[1] = x146;
294
477
  out1[2] = x147;
@@ -303,135 +486,252 @@ static void fiat_25519_carry_mul(uint32_t out1[10], const uint32_t arg1[10], con
303
486
 
304
487
  /*
305
488
  * The function fiat_25519_carry_square squares a field element and reduces the result.
489
+ *
306
490
  * Postconditions:
307
491
  * eval out1 mod m = (eval arg1 * eval arg1) mod m
308
492
  *
309
- * Input Bounds:
310
- * arg1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
311
- * Output Bounds:
312
- * out1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
313
493
  */
314
- static void fiat_25519_carry_square(uint32_t out1[10], const uint32_t arg1[10]) {
315
- uint32_t x1 = ((arg1[9]) * UINT8_C(0x13));
316
- uint32_t x2 = (x1 * 0x2);
317
- uint32_t x3 = ((arg1[9]) * 0x2);
318
- uint32_t x4 = ((arg1[8]) * UINT8_C(0x13));
319
- uint64_t x5 = ((uint64_t)x4 * 0x2);
320
- uint32_t x6 = ((arg1[8]) * 0x2);
321
- uint32_t x7 = ((arg1[7]) * UINT8_C(0x13));
322
- uint32_t x8 = (x7 * 0x2);
323
- uint32_t x9 = ((arg1[7]) * 0x2);
324
- uint32_t x10 = ((arg1[6]) * UINT8_C(0x13));
325
- uint64_t x11 = ((uint64_t)x10 * 0x2);
326
- uint32_t x12 = ((arg1[6]) * 0x2);
327
- uint32_t x13 = ((arg1[5]) * UINT8_C(0x13));
328
- uint32_t x14 = ((arg1[5]) * 0x2);
329
- uint32_t x15 = ((arg1[4]) * 0x2);
330
- uint32_t x16 = ((arg1[3]) * 0x2);
331
- uint32_t x17 = ((arg1[2]) * 0x2);
332
- uint32_t x18 = ((arg1[1]) * 0x2);
333
- uint64_t x19 = ((uint64_t)(arg1[9]) * (x1 * 0x2));
334
- uint64_t x20 = ((uint64_t)(arg1[8]) * x2);
335
- uint64_t x21 = ((uint64_t)(arg1[8]) * x4);
336
- uint64_t x22 = ((arg1[7]) * ((uint64_t)x2 * 0x2));
337
- uint64_t x23 = ((arg1[7]) * x5);
338
- uint64_t x24 = ((uint64_t)(arg1[7]) * (x7 * 0x2));
339
- uint64_t x25 = ((uint64_t)(arg1[6]) * x2);
340
- uint64_t x26 = ((arg1[6]) * x5);
341
- uint64_t x27 = ((uint64_t)(arg1[6]) * x8);
342
- uint64_t x28 = ((uint64_t)(arg1[6]) * x10);
343
- uint64_t x29 = ((arg1[5]) * ((uint64_t)x2 * 0x2));
344
- uint64_t x30 = ((arg1[5]) * x5);
345
- uint64_t x31 = ((arg1[5]) * ((uint64_t)x8 * 0x2));
346
- uint64_t x32 = ((arg1[5]) * x11);
347
- uint64_t x33 = ((uint64_t)(arg1[5]) * (x13 * 0x2));
348
- uint64_t x34 = ((uint64_t)(arg1[4]) * x2);
349
- uint64_t x35 = ((arg1[4]) * x5);
350
- uint64_t x36 = ((uint64_t)(arg1[4]) * x8);
351
- uint64_t x37 = ((arg1[4]) * x11);
352
- uint64_t x38 = ((uint64_t)(arg1[4]) * x14);
353
- uint64_t x39 = ((uint64_t)(arg1[4]) * (arg1[4]));
354
- uint64_t x40 = ((arg1[3]) * ((uint64_t)x2 * 0x2));
355
- uint64_t x41 = ((arg1[3]) * x5);
356
- uint64_t x42 = ((arg1[3]) * ((uint64_t)x8 * 0x2));
357
- uint64_t x43 = ((uint64_t)(arg1[3]) * x12);
358
- uint64_t x44 = ((uint64_t)(arg1[3]) * (x14 * 0x2));
359
- uint64_t x45 = ((uint64_t)(arg1[3]) * x15);
360
- uint64_t x46 = ((uint64_t)(arg1[3]) * ((arg1[3]) * 0x2));
361
- uint64_t x47 = ((uint64_t)(arg1[2]) * x2);
362
- uint64_t x48 = ((arg1[2]) * x5);
363
- uint64_t x49 = ((uint64_t)(arg1[2]) * x9);
364
- uint64_t x50 = ((uint64_t)(arg1[2]) * x12);
365
- uint64_t x51 = ((uint64_t)(arg1[2]) * x14);
366
- uint64_t x52 = ((uint64_t)(arg1[2]) * x15);
367
- uint64_t x53 = ((uint64_t)(arg1[2]) * x16);
368
- uint64_t x54 = ((uint64_t)(arg1[2]) * (arg1[2]));
369
- uint64_t x55 = ((arg1[1]) * ((uint64_t)x2 * 0x2));
370
- uint64_t x56 = ((uint64_t)(arg1[1]) * x6);
371
- uint64_t x57 = ((uint64_t)(arg1[1]) * (x9 * 0x2));
372
- uint64_t x58 = ((uint64_t)(arg1[1]) * x12);
373
- uint64_t x59 = ((uint64_t)(arg1[1]) * (x14 * 0x2));
374
- uint64_t x60 = ((uint64_t)(arg1[1]) * x15);
375
- uint64_t x61 = ((uint64_t)(arg1[1]) * (x16 * 0x2));
376
- uint64_t x62 = ((uint64_t)(arg1[1]) * x17);
377
- uint64_t x63 = ((uint64_t)(arg1[1]) * ((arg1[1]) * 0x2));
378
- uint64_t x64 = ((uint64_t)(arg1[0]) * x3);
379
- uint64_t x65 = ((uint64_t)(arg1[0]) * x6);
380
- uint64_t x66 = ((uint64_t)(arg1[0]) * x9);
381
- uint64_t x67 = ((uint64_t)(arg1[0]) * x12);
382
- uint64_t x68 = ((uint64_t)(arg1[0]) * x14);
383
- uint64_t x69 = ((uint64_t)(arg1[0]) * x15);
384
- uint64_t x70 = ((uint64_t)(arg1[0]) * x16);
385
- uint64_t x71 = ((uint64_t)(arg1[0]) * x17);
386
- uint64_t x72 = ((uint64_t)(arg1[0]) * x18);
387
- uint64_t x73 = ((uint64_t)(arg1[0]) * (arg1[0]));
388
- uint64_t x74 = (x73 + (x55 + (x48 + (x42 + (x37 + x33)))));
389
- uint64_t x75 = (x74 >> 26);
390
- uint32_t x76 = (uint32_t)(x74 & UINT32_C(0x3ffffff));
391
- uint64_t x77 = (x64 + (x56 + (x49 + (x43 + x38))));
392
- uint64_t x78 = (x65 + (x57 + (x50 + (x44 + (x39 + x19)))));
393
- uint64_t x79 = (x66 + (x58 + (x51 + (x45 + x20))));
394
- uint64_t x80 = (x67 + (x59 + (x52 + (x46 + (x22 + x21)))));
395
- uint64_t x81 = (x68 + (x60 + (x53 + (x25 + x23))));
396
- uint64_t x82 = (x69 + (x61 + (x54 + (x29 + (x26 + x24)))));
397
- uint64_t x83 = (x70 + (x62 + (x34 + (x30 + x27))));
398
- uint64_t x84 = (x71 + (x63 + (x40 + (x35 + (x31 + x28)))));
399
- uint64_t x85 = (x72 + (x47 + (x41 + (x36 + x32))));
400
- uint64_t x86 = (x75 + x85);
401
- uint64_t x87 = (x86 >> 25);
402
- uint32_t x88 = (uint32_t)(x86 & UINT32_C(0x1ffffff));
403
- uint64_t x89 = (x87 + x84);
404
- uint64_t x90 = (x89 >> 26);
405
- uint32_t x91 = (uint32_t)(x89 & UINT32_C(0x3ffffff));
406
- uint64_t x92 = (x90 + x83);
407
- uint64_t x93 = (x92 >> 25);
408
- uint32_t x94 = (uint32_t)(x92 & UINT32_C(0x1ffffff));
409
- uint64_t x95 = (x93 + x82);
410
- uint64_t x96 = (x95 >> 26);
411
- uint32_t x97 = (uint32_t)(x95 & UINT32_C(0x3ffffff));
412
- uint64_t x98 = (x96 + x81);
413
- uint64_t x99 = (x98 >> 25);
414
- uint32_t x100 = (uint32_t)(x98 & UINT32_C(0x1ffffff));
415
- uint64_t x101 = (x99 + x80);
416
- uint64_t x102 = (x101 >> 26);
417
- uint32_t x103 = (uint32_t)(x101 & UINT32_C(0x3ffffff));
418
- uint64_t x104 = (x102 + x79);
419
- uint64_t x105 = (x104 >> 25);
420
- uint32_t x106 = (uint32_t)(x104 & UINT32_C(0x1ffffff));
421
- uint64_t x107 = (x105 + x78);
422
- uint64_t x108 = (x107 >> 26);
423
- uint32_t x109 = (uint32_t)(x107 & UINT32_C(0x3ffffff));
424
- uint64_t x110 = (x108 + x77);
425
- uint64_t x111 = (x110 >> 25);
426
- uint32_t x112 = (uint32_t)(x110 & UINT32_C(0x1ffffff));
427
- uint64_t x113 = (x111 * UINT8_C(0x13));
428
- uint64_t x114 = (x76 + x113);
429
- uint32_t x115 = (uint32_t)(x114 >> 26);
430
- uint32_t x116 = (uint32_t)(x114 & UINT32_C(0x3ffffff));
431
- uint32_t x117 = (x115 + x88);
432
- fiat_25519_uint1 x118 = (fiat_25519_uint1)(x117 >> 25);
433
- uint32_t x119 = (x117 & UINT32_C(0x1ffffff));
434
- uint32_t x120 = (x118 + x91);
494
+ static FIAT_25519_FIAT_INLINE void fiat_25519_carry_square(fiat_25519_tight_field_element out1, const fiat_25519_loose_field_element arg1) {
495
+ uint32_t x1;
496
+ uint32_t x2;
497
+ uint32_t x3;
498
+ uint32_t x4;
499
+ uint64_t x5;
500
+ uint32_t x6;
501
+ uint32_t x7;
502
+ uint32_t x8;
503
+ uint32_t x9;
504
+ uint32_t x10;
505
+ uint64_t x11;
506
+ uint32_t x12;
507
+ uint32_t x13;
508
+ uint32_t x14;
509
+ uint32_t x15;
510
+ uint32_t x16;
511
+ uint32_t x17;
512
+ uint32_t x18;
513
+ uint64_t x19;
514
+ uint64_t x20;
515
+ uint64_t x21;
516
+ uint64_t x22;
517
+ uint64_t x23;
518
+ uint64_t x24;
519
+ uint64_t x25;
520
+ uint64_t x26;
521
+ uint64_t x27;
522
+ uint64_t x28;
523
+ uint64_t x29;
524
+ uint64_t x30;
525
+ uint64_t x31;
526
+ uint64_t x32;
527
+ uint64_t x33;
528
+ uint64_t x34;
529
+ uint64_t x35;
530
+ uint64_t x36;
531
+ uint64_t x37;
532
+ uint64_t x38;
533
+ uint64_t x39;
534
+ uint64_t x40;
535
+ uint64_t x41;
536
+ uint64_t x42;
537
+ uint64_t x43;
538
+ uint64_t x44;
539
+ uint64_t x45;
540
+ uint64_t x46;
541
+ uint64_t x47;
542
+ uint64_t x48;
543
+ uint64_t x49;
544
+ uint64_t x50;
545
+ uint64_t x51;
546
+ uint64_t x52;
547
+ uint64_t x53;
548
+ uint64_t x54;
549
+ uint64_t x55;
550
+ uint64_t x56;
551
+ uint64_t x57;
552
+ uint64_t x58;
553
+ uint64_t x59;
554
+ uint64_t x60;
555
+ uint64_t x61;
556
+ uint64_t x62;
557
+ uint64_t x63;
558
+ uint64_t x64;
559
+ uint64_t x65;
560
+ uint64_t x66;
561
+ uint64_t x67;
562
+ uint64_t x68;
563
+ uint64_t x69;
564
+ uint64_t x70;
565
+ uint64_t x71;
566
+ uint64_t x72;
567
+ uint64_t x73;
568
+ uint64_t x74;
569
+ uint64_t x75;
570
+ uint32_t x76;
571
+ uint64_t x77;
572
+ uint64_t x78;
573
+ uint64_t x79;
574
+ uint64_t x80;
575
+ uint64_t x81;
576
+ uint64_t x82;
577
+ uint64_t x83;
578
+ uint64_t x84;
579
+ uint64_t x85;
580
+ uint64_t x86;
581
+ uint64_t x87;
582
+ uint32_t x88;
583
+ uint64_t x89;
584
+ uint64_t x90;
585
+ uint32_t x91;
586
+ uint64_t x92;
587
+ uint64_t x93;
588
+ uint32_t x94;
589
+ uint64_t x95;
590
+ uint64_t x96;
591
+ uint32_t x97;
592
+ uint64_t x98;
593
+ uint64_t x99;
594
+ uint32_t x100;
595
+ uint64_t x101;
596
+ uint64_t x102;
597
+ uint32_t x103;
598
+ uint64_t x104;
599
+ uint64_t x105;
600
+ uint32_t x106;
601
+ uint64_t x107;
602
+ uint64_t x108;
603
+ uint32_t x109;
604
+ uint64_t x110;
605
+ uint64_t x111;
606
+ uint32_t x112;
607
+ uint64_t x113;
608
+ uint64_t x114;
609
+ uint32_t x115;
610
+ uint32_t x116;
611
+ uint32_t x117;
612
+ fiat_25519_uint1 x118;
613
+ uint32_t x119;
614
+ uint32_t x120;
615
+ x1 = ((arg1[9]) * UINT8_C(0x13));
616
+ x2 = (x1 * 0x2);
617
+ x3 = ((arg1[9]) * 0x2);
618
+ x4 = ((arg1[8]) * UINT8_C(0x13));
619
+ x5 = ((uint64_t)x4 * 0x2);
620
+ x6 = ((arg1[8]) * 0x2);
621
+ x7 = ((arg1[7]) * UINT8_C(0x13));
622
+ x8 = (x7 * 0x2);
623
+ x9 = ((arg1[7]) * 0x2);
624
+ x10 = ((arg1[6]) * UINT8_C(0x13));
625
+ x11 = ((uint64_t)x10 * 0x2);
626
+ x12 = ((arg1[6]) * 0x2);
627
+ x13 = ((arg1[5]) * UINT8_C(0x13));
628
+ x14 = ((arg1[5]) * 0x2);
629
+ x15 = ((arg1[4]) * 0x2);
630
+ x16 = ((arg1[3]) * 0x2);
631
+ x17 = ((arg1[2]) * 0x2);
632
+ x18 = ((arg1[1]) * 0x2);
633
+ x19 = ((uint64_t)(arg1[9]) * (x1 * 0x2));
634
+ x20 = ((uint64_t)(arg1[8]) * x2);
635
+ x21 = ((uint64_t)(arg1[8]) * x4);
636
+ x22 = ((arg1[7]) * ((uint64_t)x2 * 0x2));
637
+ x23 = ((arg1[7]) * x5);
638
+ x24 = ((uint64_t)(arg1[7]) * (x7 * 0x2));
639
+ x25 = ((uint64_t)(arg1[6]) * x2);
640
+ x26 = ((arg1[6]) * x5);
641
+ x27 = ((uint64_t)(arg1[6]) * x8);
642
+ x28 = ((uint64_t)(arg1[6]) * x10);
643
+ x29 = ((arg1[5]) * ((uint64_t)x2 * 0x2));
644
+ x30 = ((arg1[5]) * x5);
645
+ x31 = ((arg1[5]) * ((uint64_t)x8 * 0x2));
646
+ x32 = ((arg1[5]) * x11);
647
+ x33 = ((uint64_t)(arg1[5]) * (x13 * 0x2));
648
+ x34 = ((uint64_t)(arg1[4]) * x2);
649
+ x35 = ((arg1[4]) * x5);
650
+ x36 = ((uint64_t)(arg1[4]) * x8);
651
+ x37 = ((arg1[4]) * x11);
652
+ x38 = ((uint64_t)(arg1[4]) * x14);
653
+ x39 = ((uint64_t)(arg1[4]) * (arg1[4]));
654
+ x40 = ((arg1[3]) * ((uint64_t)x2 * 0x2));
655
+ x41 = ((arg1[3]) * x5);
656
+ x42 = ((arg1[3]) * ((uint64_t)x8 * 0x2));
657
+ x43 = ((uint64_t)(arg1[3]) * x12);
658
+ x44 = ((uint64_t)(arg1[3]) * (x14 * 0x2));
659
+ x45 = ((uint64_t)(arg1[3]) * x15);
660
+ x46 = ((uint64_t)(arg1[3]) * ((arg1[3]) * 0x2));
661
+ x47 = ((uint64_t)(arg1[2]) * x2);
662
+ x48 = ((arg1[2]) * x5);
663
+ x49 = ((uint64_t)(arg1[2]) * x9);
664
+ x50 = ((uint64_t)(arg1[2]) * x12);
665
+ x51 = ((uint64_t)(arg1[2]) * x14);
666
+ x52 = ((uint64_t)(arg1[2]) * x15);
667
+ x53 = ((uint64_t)(arg1[2]) * x16);
668
+ x54 = ((uint64_t)(arg1[2]) * (arg1[2]));
669
+ x55 = ((arg1[1]) * ((uint64_t)x2 * 0x2));
670
+ x56 = ((uint64_t)(arg1[1]) * x6);
671
+ x57 = ((uint64_t)(arg1[1]) * (x9 * 0x2));
672
+ x58 = ((uint64_t)(arg1[1]) * x12);
673
+ x59 = ((uint64_t)(arg1[1]) * (x14 * 0x2));
674
+ x60 = ((uint64_t)(arg1[1]) * x15);
675
+ x61 = ((uint64_t)(arg1[1]) * (x16 * 0x2));
676
+ x62 = ((uint64_t)(arg1[1]) * x17);
677
+ x63 = ((uint64_t)(arg1[1]) * ((arg1[1]) * 0x2));
678
+ x64 = ((uint64_t)(arg1[0]) * x3);
679
+ x65 = ((uint64_t)(arg1[0]) * x6);
680
+ x66 = ((uint64_t)(arg1[0]) * x9);
681
+ x67 = ((uint64_t)(arg1[0]) * x12);
682
+ x68 = ((uint64_t)(arg1[0]) * x14);
683
+ x69 = ((uint64_t)(arg1[0]) * x15);
684
+ x70 = ((uint64_t)(arg1[0]) * x16);
685
+ x71 = ((uint64_t)(arg1[0]) * x17);
686
+ x72 = ((uint64_t)(arg1[0]) * x18);
687
+ x73 = ((uint64_t)(arg1[0]) * (arg1[0]));
688
+ x74 = (x73 + (x55 + (x48 + (x42 + (x37 + x33)))));
689
+ x75 = (x74 >> 26);
690
+ x76 = (uint32_t)(x74 & UINT32_C(0x3ffffff));
691
+ x77 = (x64 + (x56 + (x49 + (x43 + x38))));
692
+ x78 = (x65 + (x57 + (x50 + (x44 + (x39 + x19)))));
693
+ x79 = (x66 + (x58 + (x51 + (x45 + x20))));
694
+ x80 = (x67 + (x59 + (x52 + (x46 + (x22 + x21)))));
695
+ x81 = (x68 + (x60 + (x53 + (x25 + x23))));
696
+ x82 = (x69 + (x61 + (x54 + (x29 + (x26 + x24)))));
697
+ x83 = (x70 + (x62 + (x34 + (x30 + x27))));
698
+ x84 = (x71 + (x63 + (x40 + (x35 + (x31 + x28)))));
699
+ x85 = (x72 + (x47 + (x41 + (x36 + x32))));
700
+ x86 = (x75 + x85);
701
+ x87 = (x86 >> 25);
702
+ x88 = (uint32_t)(x86 & UINT32_C(0x1ffffff));
703
+ x89 = (x87 + x84);
704
+ x90 = (x89 >> 26);
705
+ x91 = (uint32_t)(x89 & UINT32_C(0x3ffffff));
706
+ x92 = (x90 + x83);
707
+ x93 = (x92 >> 25);
708
+ x94 = (uint32_t)(x92 & UINT32_C(0x1ffffff));
709
+ x95 = (x93 + x82);
710
+ x96 = (x95 >> 26);
711
+ x97 = (uint32_t)(x95 & UINT32_C(0x3ffffff));
712
+ x98 = (x96 + x81);
713
+ x99 = (x98 >> 25);
714
+ x100 = (uint32_t)(x98 & UINT32_C(0x1ffffff));
715
+ x101 = (x99 + x80);
716
+ x102 = (x101 >> 26);
717
+ x103 = (uint32_t)(x101 & UINT32_C(0x3ffffff));
718
+ x104 = (x102 + x79);
719
+ x105 = (x104 >> 25);
720
+ x106 = (uint32_t)(x104 & UINT32_C(0x1ffffff));
721
+ x107 = (x105 + x78);
722
+ x108 = (x107 >> 26);
723
+ x109 = (uint32_t)(x107 & UINT32_C(0x3ffffff));
724
+ x110 = (x108 + x77);
725
+ x111 = (x110 >> 25);
726
+ x112 = (uint32_t)(x110 & UINT32_C(0x1ffffff));
727
+ x113 = (x111 * UINT8_C(0x13));
728
+ x114 = (x76 + x113);
729
+ x115 = (uint32_t)(x114 >> 26);
730
+ x116 = (uint32_t)(x114 & UINT32_C(0x3ffffff));
731
+ x117 = (x115 + x88);
732
+ x118 = (fiat_25519_uint1)(x117 >> 25);
733
+ x119 = (x117 & UINT32_C(0x1ffffff));
734
+ x120 = (x118 + x91);
435
735
  out1[0] = x116;
436
736
  out1[1] = x119;
437
737
  out1[2] = x120;
@@ -446,37 +746,56 @@ static void fiat_25519_carry_square(uint32_t out1[10], const uint32_t arg1[10])
446
746
 
447
747
  /*
448
748
  * The function fiat_25519_carry reduces a field element.
749
+ *
449
750
  * Postconditions:
450
751
  * eval out1 mod m = eval arg1 mod m
451
752
  *
452
- * Input Bounds:
453
- * arg1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
454
- * Output Bounds:
455
- * out1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
456
753
  */
457
- static void fiat_25519_carry(uint32_t out1[10], const uint32_t arg1[10]) {
458
- uint32_t x1 = (arg1[0]);
459
- uint32_t x2 = ((x1 >> 26) + (arg1[1]));
460
- uint32_t x3 = ((x2 >> 25) + (arg1[2]));
461
- uint32_t x4 = ((x3 >> 26) + (arg1[3]));
462
- uint32_t x5 = ((x4 >> 25) + (arg1[4]));
463
- uint32_t x6 = ((x5 >> 26) + (arg1[5]));
464
- uint32_t x7 = ((x6 >> 25) + (arg1[6]));
465
- uint32_t x8 = ((x7 >> 26) + (arg1[7]));
466
- uint32_t x9 = ((x8 >> 25) + (arg1[8]));
467
- uint32_t x10 = ((x9 >> 26) + (arg1[9]));
468
- uint32_t x11 = ((x1 & UINT32_C(0x3ffffff)) + ((x10 >> 25) * UINT8_C(0x13)));
469
- uint32_t x12 = ((fiat_25519_uint1)(x11 >> 26) + (x2 & UINT32_C(0x1ffffff)));
470
- uint32_t x13 = (x11 & UINT32_C(0x3ffffff));
471
- uint32_t x14 = (x12 & UINT32_C(0x1ffffff));
472
- uint32_t x15 = ((fiat_25519_uint1)(x12 >> 25) + (x3 & UINT32_C(0x3ffffff)));
473
- uint32_t x16 = (x4 & UINT32_C(0x1ffffff));
474
- uint32_t x17 = (x5 & UINT32_C(0x3ffffff));
475
- uint32_t x18 = (x6 & UINT32_C(0x1ffffff));
476
- uint32_t x19 = (x7 & UINT32_C(0x3ffffff));
477
- uint32_t x20 = (x8 & UINT32_C(0x1ffffff));
478
- uint32_t x21 = (x9 & UINT32_C(0x3ffffff));
479
- uint32_t x22 = (x10 & UINT32_C(0x1ffffff));
754
+ static FIAT_25519_FIAT_INLINE void fiat_25519_carry(fiat_25519_tight_field_element out1, const fiat_25519_loose_field_element arg1) {
755
+ uint32_t x1;
756
+ uint32_t x2;
757
+ uint32_t x3;
758
+ uint32_t x4;
759
+ uint32_t x5;
760
+ uint32_t x6;
761
+ uint32_t x7;
762
+ uint32_t x8;
763
+ uint32_t x9;
764
+ uint32_t x10;
765
+ uint32_t x11;
766
+ uint32_t x12;
767
+ uint32_t x13;
768
+ uint32_t x14;
769
+ uint32_t x15;
770
+ uint32_t x16;
771
+ uint32_t x17;
772
+ uint32_t x18;
773
+ uint32_t x19;
774
+ uint32_t x20;
775
+ uint32_t x21;
776
+ uint32_t x22;
777
+ x1 = (arg1[0]);
778
+ x2 = ((x1 >> 26) + (arg1[1]));
779
+ x3 = ((x2 >> 25) + (arg1[2]));
780
+ x4 = ((x3 >> 26) + (arg1[3]));
781
+ x5 = ((x4 >> 25) + (arg1[4]));
782
+ x6 = ((x5 >> 26) + (arg1[5]));
783
+ x7 = ((x6 >> 25) + (arg1[6]));
784
+ x8 = ((x7 >> 26) + (arg1[7]));
785
+ x9 = ((x8 >> 25) + (arg1[8]));
786
+ x10 = ((x9 >> 26) + (arg1[9]));
787
+ x11 = ((x1 & UINT32_C(0x3ffffff)) + ((x10 >> 25) * UINT8_C(0x13)));
788
+ x12 = ((fiat_25519_uint1)(x11 >> 26) + (x2 & UINT32_C(0x1ffffff)));
789
+ x13 = (x11 & UINT32_C(0x3ffffff));
790
+ x14 = (x12 & UINT32_C(0x1ffffff));
791
+ x15 = ((fiat_25519_uint1)(x12 >> 25) + (x3 & UINT32_C(0x3ffffff)));
792
+ x16 = (x4 & UINT32_C(0x1ffffff));
793
+ x17 = (x5 & UINT32_C(0x3ffffff));
794
+ x18 = (x6 & UINT32_C(0x1ffffff));
795
+ x19 = (x7 & UINT32_C(0x3ffffff));
796
+ x20 = (x8 & UINT32_C(0x1ffffff));
797
+ x21 = (x9 & UINT32_C(0x3ffffff));
798
+ x22 = (x10 & UINT32_C(0x1ffffff));
480
799
  out1[0] = x13;
481
800
  out1[1] = x14;
482
801
  out1[2] = x15;
@@ -491,26 +810,32 @@ static void fiat_25519_carry(uint32_t out1[10], const uint32_t arg1[10]) {
491
810
 
492
811
  /*
493
812
  * The function fiat_25519_add adds two field elements.
813
+ *
494
814
  * Postconditions:
495
815
  * eval out1 mod m = (eval arg1 + eval arg2) mod m
496
816
  *
497
- * Input Bounds:
498
- * arg1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
499
- * arg2: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
500
- * Output Bounds:
501
- * out1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
502
817
  */
503
- static void fiat_25519_add(uint32_t out1[10], const uint32_t arg1[10], const uint32_t arg2[10]) {
504
- uint32_t x1 = ((arg1[0]) + (arg2[0]));
505
- uint32_t x2 = ((arg1[1]) + (arg2[1]));
506
- uint32_t x3 = ((arg1[2]) + (arg2[2]));
507
- uint32_t x4 = ((arg1[3]) + (arg2[3]));
508
- uint32_t x5 = ((arg1[4]) + (arg2[4]));
509
- uint32_t x6 = ((arg1[5]) + (arg2[5]));
510
- uint32_t x7 = ((arg1[6]) + (arg2[6]));
511
- uint32_t x8 = ((arg1[7]) + (arg2[7]));
512
- uint32_t x9 = ((arg1[8]) + (arg2[8]));
513
- uint32_t x10 = ((arg1[9]) + (arg2[9]));
818
+ static FIAT_25519_FIAT_INLINE void fiat_25519_add(fiat_25519_loose_field_element out1, const fiat_25519_tight_field_element arg1, const fiat_25519_tight_field_element arg2) {
819
+ uint32_t x1;
820
+ uint32_t x2;
821
+ uint32_t x3;
822
+ uint32_t x4;
823
+ uint32_t x5;
824
+ uint32_t x6;
825
+ uint32_t x7;
826
+ uint32_t x8;
827
+ uint32_t x9;
828
+ uint32_t x10;
829
+ x1 = ((arg1[0]) + (arg2[0]));
830
+ x2 = ((arg1[1]) + (arg2[1]));
831
+ x3 = ((arg1[2]) + (arg2[2]));
832
+ x4 = ((arg1[3]) + (arg2[3]));
833
+ x5 = ((arg1[4]) + (arg2[4]));
834
+ x6 = ((arg1[5]) + (arg2[5]));
835
+ x7 = ((arg1[6]) + (arg2[6]));
836
+ x8 = ((arg1[7]) + (arg2[7]));
837
+ x9 = ((arg1[8]) + (arg2[8]));
838
+ x10 = ((arg1[9]) + (arg2[9]));
514
839
  out1[0] = x1;
515
840
  out1[1] = x2;
516
841
  out1[2] = x3;
@@ -525,26 +850,32 @@ static void fiat_25519_add(uint32_t out1[10], const uint32_t arg1[10], const uin
525
850
 
526
851
  /*
527
852
  * The function fiat_25519_sub subtracts two field elements.
853
+ *
528
854
  * Postconditions:
529
855
  * eval out1 mod m = (eval arg1 - eval arg2) mod m
530
856
  *
531
- * Input Bounds:
532
- * arg1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
533
- * arg2: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
534
- * Output Bounds:
535
- * out1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
536
857
  */
537
- static void fiat_25519_sub(uint32_t out1[10], const uint32_t arg1[10], const uint32_t arg2[10]) {
538
- uint32_t x1 = ((UINT32_C(0x7ffffda) + (arg1[0])) - (arg2[0]));
539
- uint32_t x2 = ((UINT32_C(0x3fffffe) + (arg1[1])) - (arg2[1]));
540
- uint32_t x3 = ((UINT32_C(0x7fffffe) + (arg1[2])) - (arg2[2]));
541
- uint32_t x4 = ((UINT32_C(0x3fffffe) + (arg1[3])) - (arg2[3]));
542
- uint32_t x5 = ((UINT32_C(0x7fffffe) + (arg1[4])) - (arg2[4]));
543
- uint32_t x6 = ((UINT32_C(0x3fffffe) + (arg1[5])) - (arg2[5]));
544
- uint32_t x7 = ((UINT32_C(0x7fffffe) + (arg1[6])) - (arg2[6]));
545
- uint32_t x8 = ((UINT32_C(0x3fffffe) + (arg1[7])) - (arg2[7]));
546
- uint32_t x9 = ((UINT32_C(0x7fffffe) + (arg1[8])) - (arg2[8]));
547
- uint32_t x10 = ((UINT32_C(0x3fffffe) + (arg1[9])) - (arg2[9]));
858
+ static FIAT_25519_FIAT_INLINE void fiat_25519_sub(fiat_25519_loose_field_element out1, const fiat_25519_tight_field_element arg1, const fiat_25519_tight_field_element arg2) {
859
+ uint32_t x1;
860
+ uint32_t x2;
861
+ uint32_t x3;
862
+ uint32_t x4;
863
+ uint32_t x5;
864
+ uint32_t x6;
865
+ uint32_t x7;
866
+ uint32_t x8;
867
+ uint32_t x9;
868
+ uint32_t x10;
869
+ x1 = ((UINT32_C(0x7ffffda) + (arg1[0])) - (arg2[0]));
870
+ x2 = ((UINT32_C(0x3fffffe) + (arg1[1])) - (arg2[1]));
871
+ x3 = ((UINT32_C(0x7fffffe) + (arg1[2])) - (arg2[2]));
872
+ x4 = ((UINT32_C(0x3fffffe) + (arg1[3])) - (arg2[3]));
873
+ x5 = ((UINT32_C(0x7fffffe) + (arg1[4])) - (arg2[4]));
874
+ x6 = ((UINT32_C(0x3fffffe) + (arg1[5])) - (arg2[5]));
875
+ x7 = ((UINT32_C(0x7fffffe) + (arg1[6])) - (arg2[6]));
876
+ x8 = ((UINT32_C(0x3fffffe) + (arg1[7])) - (arg2[7]));
877
+ x9 = ((UINT32_C(0x7fffffe) + (arg1[8])) - (arg2[8]));
878
+ x10 = ((UINT32_C(0x3fffffe) + (arg1[9])) - (arg2[9]));
548
879
  out1[0] = x1;
549
880
  out1[1] = x2;
550
881
  out1[2] = x3;
@@ -559,25 +890,32 @@ static void fiat_25519_sub(uint32_t out1[10], const uint32_t arg1[10], const uin
559
890
 
560
891
  /*
561
892
  * The function fiat_25519_opp negates a field element.
893
+ *
562
894
  * Postconditions:
563
895
  * eval out1 mod m = -eval arg1 mod m
564
896
  *
565
- * Input Bounds:
566
- * arg1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
567
- * Output Bounds:
568
- * out1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
569
897
  */
570
- static void fiat_25519_opp(uint32_t out1[10], const uint32_t arg1[10]) {
571
- uint32_t x1 = (UINT32_C(0x7ffffda) - (arg1[0]));
572
- uint32_t x2 = (UINT32_C(0x3fffffe) - (arg1[1]));
573
- uint32_t x3 = (UINT32_C(0x7fffffe) - (arg1[2]));
574
- uint32_t x4 = (UINT32_C(0x3fffffe) - (arg1[3]));
575
- uint32_t x5 = (UINT32_C(0x7fffffe) - (arg1[4]));
576
- uint32_t x6 = (UINT32_C(0x3fffffe) - (arg1[5]));
577
- uint32_t x7 = (UINT32_C(0x7fffffe) - (arg1[6]));
578
- uint32_t x8 = (UINT32_C(0x3fffffe) - (arg1[7]));
579
- uint32_t x9 = (UINT32_C(0x7fffffe) - (arg1[8]));
580
- uint32_t x10 = (UINT32_C(0x3fffffe) - (arg1[9]));
898
+ static FIAT_25519_FIAT_INLINE void fiat_25519_opp(fiat_25519_loose_field_element out1, const fiat_25519_tight_field_element arg1) {
899
+ uint32_t x1;
900
+ uint32_t x2;
901
+ uint32_t x3;
902
+ uint32_t x4;
903
+ uint32_t x5;
904
+ uint32_t x6;
905
+ uint32_t x7;
906
+ uint32_t x8;
907
+ uint32_t x9;
908
+ uint32_t x10;
909
+ x1 = (UINT32_C(0x7ffffda) - (arg1[0]));
910
+ x2 = (UINT32_C(0x3fffffe) - (arg1[1]));
911
+ x3 = (UINT32_C(0x7fffffe) - (arg1[2]));
912
+ x4 = (UINT32_C(0x3fffffe) - (arg1[3]));
913
+ x5 = (UINT32_C(0x7fffffe) - (arg1[4]));
914
+ x6 = (UINT32_C(0x3fffffe) - (arg1[5]));
915
+ x7 = (UINT32_C(0x7fffffe) - (arg1[6]));
916
+ x8 = (UINT32_C(0x3fffffe) - (arg1[7]));
917
+ x9 = (UINT32_C(0x7fffffe) - (arg1[8]));
918
+ x10 = (UINT32_C(0x3fffffe) - (arg1[9]));
581
919
  out1[0] = x1;
582
920
  out1[1] = x2;
583
921
  out1[2] = x3;
@@ -592,6 +930,7 @@ static void fiat_25519_opp(uint32_t out1[10], const uint32_t arg1[10]) {
592
930
 
593
931
  /*
594
932
  * The function fiat_25519_selectznz is a multi-limb conditional select.
933
+ *
595
934
  * Postconditions:
596
935
  * eval out1 = (if arg1 = 0 then eval arg2 else eval arg3)
597
936
  *
@@ -602,26 +941,26 @@ static void fiat_25519_opp(uint32_t out1[10], const uint32_t arg1[10]) {
602
941
  * Output Bounds:
603
942
  * out1: [[0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff]]
604
943
  */
605
- static void fiat_25519_selectznz(uint32_t out1[10], fiat_25519_uint1 arg1, const uint32_t arg2[10], const uint32_t arg3[10]) {
944
+ static FIAT_25519_FIAT_INLINE void fiat_25519_selectznz(uint32_t out1[10], fiat_25519_uint1 arg1, const uint32_t arg2[10], const uint32_t arg3[10]) {
606
945
  uint32_t x1;
607
- fiat_25519_cmovznz_u32(&x1, arg1, (arg2[0]), (arg3[0]));
608
946
  uint32_t x2;
609
- fiat_25519_cmovznz_u32(&x2, arg1, (arg2[1]), (arg3[1]));
610
947
  uint32_t x3;
611
- fiat_25519_cmovznz_u32(&x3, arg1, (arg2[2]), (arg3[2]));
612
948
  uint32_t x4;
613
- fiat_25519_cmovznz_u32(&x4, arg1, (arg2[3]), (arg3[3]));
614
949
  uint32_t x5;
615
- fiat_25519_cmovznz_u32(&x5, arg1, (arg2[4]), (arg3[4]));
616
950
  uint32_t x6;
617
- fiat_25519_cmovznz_u32(&x6, arg1, (arg2[5]), (arg3[5]));
618
951
  uint32_t x7;
619
- fiat_25519_cmovznz_u32(&x7, arg1, (arg2[6]), (arg3[6]));
620
952
  uint32_t x8;
621
- fiat_25519_cmovznz_u32(&x8, arg1, (arg2[7]), (arg3[7]));
622
953
  uint32_t x9;
623
- fiat_25519_cmovznz_u32(&x9, arg1, (arg2[8]), (arg3[8]));
624
954
  uint32_t x10;
955
+ fiat_25519_cmovznz_u32(&x1, arg1, (arg2[0]), (arg3[0]));
956
+ fiat_25519_cmovznz_u32(&x2, arg1, (arg2[1]), (arg3[1]));
957
+ fiat_25519_cmovznz_u32(&x3, arg1, (arg2[2]), (arg3[2]));
958
+ fiat_25519_cmovznz_u32(&x4, arg1, (arg2[3]), (arg3[3]));
959
+ fiat_25519_cmovznz_u32(&x5, arg1, (arg2[4]), (arg3[4]));
960
+ fiat_25519_cmovznz_u32(&x6, arg1, (arg2[5]), (arg3[5]));
961
+ fiat_25519_cmovznz_u32(&x7, arg1, (arg2[6]), (arg3[6]));
962
+ fiat_25519_cmovznz_u32(&x8, arg1, (arg2[7]), (arg3[7]));
963
+ fiat_25519_cmovznz_u32(&x9, arg1, (arg2[8]), (arg3[8]));
625
964
  fiat_25519_cmovznz_u32(&x10, arg1, (arg2[9]), (arg3[9]));
626
965
  out1[0] = x1;
627
966
  out1[1] = x2;
@@ -637,336 +976,582 @@ static void fiat_25519_selectznz(uint32_t out1[10], fiat_25519_uint1 arg1, const
637
976
 
638
977
  /*
639
978
  * The function fiat_25519_to_bytes serializes a field element to bytes in little-endian order.
979
+ *
640
980
  * Postconditions:
641
981
  * out1 = map (λ x, ⌊((eval arg1 mod m) mod 2^(8 * (x + 1))) / 2^(8 * x)⌋) [0..31]
642
982
  *
643
- * Input Bounds:
644
- * arg1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
645
983
  * Output Bounds:
646
984
  * 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 ~> 0x7f]]
647
985
  */
648
- static void fiat_25519_to_bytes(uint8_t out1[32], const uint32_t arg1[10]) {
986
+ static FIAT_25519_FIAT_INLINE void fiat_25519_to_bytes(uint8_t out1[32], const fiat_25519_tight_field_element arg1) {
649
987
  uint32_t x1;
650
988
  fiat_25519_uint1 x2;
651
- fiat_25519_subborrowx_u26(&x1, &x2, 0x0, (arg1[0]), UINT32_C(0x3ffffed));
652
989
  uint32_t x3;
653
990
  fiat_25519_uint1 x4;
654
- fiat_25519_subborrowx_u25(&x3, &x4, x2, (arg1[1]), UINT32_C(0x1ffffff));
655
991
  uint32_t x5;
656
992
  fiat_25519_uint1 x6;
657
- fiat_25519_subborrowx_u26(&x5, &x6, x4, (arg1[2]), UINT32_C(0x3ffffff));
658
993
  uint32_t x7;
659
994
  fiat_25519_uint1 x8;
660
- fiat_25519_subborrowx_u25(&x7, &x8, x6, (arg1[3]), UINT32_C(0x1ffffff));
661
995
  uint32_t x9;
662
996
  fiat_25519_uint1 x10;
663
- fiat_25519_subborrowx_u26(&x9, &x10, x8, (arg1[4]), UINT32_C(0x3ffffff));
664
997
  uint32_t x11;
665
998
  fiat_25519_uint1 x12;
666
- fiat_25519_subborrowx_u25(&x11, &x12, x10, (arg1[5]), UINT32_C(0x1ffffff));
667
999
  uint32_t x13;
668
1000
  fiat_25519_uint1 x14;
669
- fiat_25519_subborrowx_u26(&x13, &x14, x12, (arg1[6]), UINT32_C(0x3ffffff));
670
1001
  uint32_t x15;
671
1002
  fiat_25519_uint1 x16;
672
- fiat_25519_subborrowx_u25(&x15, &x16, x14, (arg1[7]), UINT32_C(0x1ffffff));
673
1003
  uint32_t x17;
674
1004
  fiat_25519_uint1 x18;
675
- fiat_25519_subborrowx_u26(&x17, &x18, x16, (arg1[8]), UINT32_C(0x3ffffff));
676
1005
  uint32_t x19;
677
1006
  fiat_25519_uint1 x20;
678
- fiat_25519_subborrowx_u25(&x19, &x20, x18, (arg1[9]), UINT32_C(0x1ffffff));
679
1007
  uint32_t x21;
680
- fiat_25519_cmovznz_u32(&x21, x20, 0x0, UINT32_C(0xffffffff));
681
1008
  uint32_t x22;
682
1009
  fiat_25519_uint1 x23;
683
- fiat_25519_addcarryx_u26(&x22, &x23, 0x0, x1, (x21 & UINT32_C(0x3ffffed)));
684
1010
  uint32_t x24;
685
1011
  fiat_25519_uint1 x25;
686
- fiat_25519_addcarryx_u25(&x24, &x25, x23, x3, (x21 & UINT32_C(0x1ffffff)));
687
1012
  uint32_t x26;
688
1013
  fiat_25519_uint1 x27;
689
- fiat_25519_addcarryx_u26(&x26, &x27, x25, x5, (x21 & UINT32_C(0x3ffffff)));
690
1014
  uint32_t x28;
691
1015
  fiat_25519_uint1 x29;
692
- fiat_25519_addcarryx_u25(&x28, &x29, x27, x7, (x21 & UINT32_C(0x1ffffff)));
693
1016
  uint32_t x30;
694
1017
  fiat_25519_uint1 x31;
695
- fiat_25519_addcarryx_u26(&x30, &x31, x29, x9, (x21 & UINT32_C(0x3ffffff)));
696
1018
  uint32_t x32;
697
1019
  fiat_25519_uint1 x33;
698
- fiat_25519_addcarryx_u25(&x32, &x33, x31, x11, (x21 & UINT32_C(0x1ffffff)));
699
1020
  uint32_t x34;
700
1021
  fiat_25519_uint1 x35;
701
- fiat_25519_addcarryx_u26(&x34, &x35, x33, x13, (x21 & UINT32_C(0x3ffffff)));
702
1022
  uint32_t x36;
703
1023
  fiat_25519_uint1 x37;
704
- fiat_25519_addcarryx_u25(&x36, &x37, x35, x15, (x21 & UINT32_C(0x1ffffff)));
705
1024
  uint32_t x38;
706
1025
  fiat_25519_uint1 x39;
707
- fiat_25519_addcarryx_u26(&x38, &x39, x37, x17, (x21 & UINT32_C(0x3ffffff)));
708
1026
  uint32_t x40;
709
1027
  fiat_25519_uint1 x41;
1028
+ uint32_t x42;
1029
+ uint32_t x43;
1030
+ uint32_t x44;
1031
+ uint32_t x45;
1032
+ uint32_t x46;
1033
+ uint32_t x47;
1034
+ uint32_t x48;
1035
+ uint32_t x49;
1036
+ uint8_t x50;
1037
+ uint32_t x51;
1038
+ uint8_t x52;
1039
+ uint32_t x53;
1040
+ uint8_t x54;
1041
+ uint8_t x55;
1042
+ uint32_t x56;
1043
+ uint8_t x57;
1044
+ uint32_t x58;
1045
+ uint8_t x59;
1046
+ uint32_t x60;
1047
+ uint8_t x61;
1048
+ uint8_t x62;
1049
+ uint32_t x63;
1050
+ uint8_t x64;
1051
+ uint32_t x65;
1052
+ uint8_t x66;
1053
+ uint32_t x67;
1054
+ uint8_t x68;
1055
+ uint8_t x69;
1056
+ uint32_t x70;
1057
+ uint8_t x71;
1058
+ uint32_t x72;
1059
+ uint8_t x73;
1060
+ uint32_t x74;
1061
+ uint8_t x75;
1062
+ uint8_t x76;
1063
+ uint32_t x77;
1064
+ uint8_t x78;
1065
+ uint32_t x79;
1066
+ uint8_t x80;
1067
+ uint32_t x81;
1068
+ uint8_t x82;
1069
+ uint8_t x83;
1070
+ uint8_t x84;
1071
+ uint32_t x85;
1072
+ uint8_t x86;
1073
+ uint32_t x87;
1074
+ uint8_t x88;
1075
+ fiat_25519_uint1 x89;
1076
+ uint32_t x90;
1077
+ uint8_t x91;
1078
+ uint32_t x92;
1079
+ uint8_t x93;
1080
+ uint32_t x94;
1081
+ uint8_t x95;
1082
+ uint8_t x96;
1083
+ uint32_t x97;
1084
+ uint8_t x98;
1085
+ uint32_t x99;
1086
+ uint8_t x100;
1087
+ uint32_t x101;
1088
+ uint8_t x102;
1089
+ uint8_t x103;
1090
+ uint32_t x104;
1091
+ uint8_t x105;
1092
+ uint32_t x106;
1093
+ uint8_t x107;
1094
+ uint32_t x108;
1095
+ uint8_t x109;
1096
+ uint8_t x110;
1097
+ uint32_t x111;
1098
+ uint8_t x112;
1099
+ uint32_t x113;
1100
+ uint8_t x114;
1101
+ uint32_t x115;
1102
+ uint8_t x116;
1103
+ uint8_t x117;
1104
+ fiat_25519_subborrowx_u26(&x1, &x2, 0x0, (arg1[0]), UINT32_C(0x3ffffed));
1105
+ fiat_25519_subborrowx_u25(&x3, &x4, x2, (arg1[1]), UINT32_C(0x1ffffff));
1106
+ fiat_25519_subborrowx_u26(&x5, &x6, x4, (arg1[2]), UINT32_C(0x3ffffff));
1107
+ fiat_25519_subborrowx_u25(&x7, &x8, x6, (arg1[3]), UINT32_C(0x1ffffff));
1108
+ fiat_25519_subborrowx_u26(&x9, &x10, x8, (arg1[4]), UINT32_C(0x3ffffff));
1109
+ fiat_25519_subborrowx_u25(&x11, &x12, x10, (arg1[5]), UINT32_C(0x1ffffff));
1110
+ fiat_25519_subborrowx_u26(&x13, &x14, x12, (arg1[6]), UINT32_C(0x3ffffff));
1111
+ fiat_25519_subborrowx_u25(&x15, &x16, x14, (arg1[7]), UINT32_C(0x1ffffff));
1112
+ fiat_25519_subborrowx_u26(&x17, &x18, x16, (arg1[8]), UINT32_C(0x3ffffff));
1113
+ fiat_25519_subborrowx_u25(&x19, &x20, x18, (arg1[9]), UINT32_C(0x1ffffff));
1114
+ fiat_25519_cmovznz_u32(&x21, x20, 0x0, UINT32_C(0xffffffff));
1115
+ fiat_25519_addcarryx_u26(&x22, &x23, 0x0, x1, (x21 & UINT32_C(0x3ffffed)));
1116
+ fiat_25519_addcarryx_u25(&x24, &x25, x23, x3, (x21 & UINT32_C(0x1ffffff)));
1117
+ fiat_25519_addcarryx_u26(&x26, &x27, x25, x5, (x21 & UINT32_C(0x3ffffff)));
1118
+ fiat_25519_addcarryx_u25(&x28, &x29, x27, x7, (x21 & UINT32_C(0x1ffffff)));
1119
+ fiat_25519_addcarryx_u26(&x30, &x31, x29, x9, (x21 & UINT32_C(0x3ffffff)));
1120
+ fiat_25519_addcarryx_u25(&x32, &x33, x31, x11, (x21 & UINT32_C(0x1ffffff)));
1121
+ fiat_25519_addcarryx_u26(&x34, &x35, x33, x13, (x21 & UINT32_C(0x3ffffff)));
1122
+ fiat_25519_addcarryx_u25(&x36, &x37, x35, x15, (x21 & UINT32_C(0x1ffffff)));
1123
+ fiat_25519_addcarryx_u26(&x38, &x39, x37, x17, (x21 & UINT32_C(0x3ffffff)));
710
1124
  fiat_25519_addcarryx_u25(&x40, &x41, x39, x19, (x21 & UINT32_C(0x1ffffff)));
711
- uint32_t x42 = (x40 << 6);
712
- uint32_t x43 = (x38 << 4);
713
- uint32_t x44 = (x36 << 3);
714
- uint32_t x45 = (x34 * (uint32_t)0x2);
715
- uint32_t x46 = (x30 << 6);
716
- uint32_t x47 = (x28 << 5);
717
- uint32_t x48 = (x26 << 3);
718
- uint32_t x49 = (x24 << 2);
719
- uint32_t x50 = (x22 >> 8);
720
- uint8_t x51 = (uint8_t)(x22 & UINT8_C(0xff));
721
- uint32_t x52 = (x50 >> 8);
722
- uint8_t x53 = (uint8_t)(x50 & UINT8_C(0xff));
723
- uint8_t x54 = (uint8_t)(x52 >> 8);
724
- uint8_t x55 = (uint8_t)(x52 & UINT8_C(0xff));
725
- uint32_t x56 = (x54 + x49);
726
- uint32_t x57 = (x56 >> 8);
727
- uint8_t x58 = (uint8_t)(x56 & UINT8_C(0xff));
728
- uint32_t x59 = (x57 >> 8);
729
- uint8_t x60 = (uint8_t)(x57 & UINT8_C(0xff));
730
- uint8_t x61 = (uint8_t)(x59 >> 8);
731
- uint8_t x62 = (uint8_t)(x59 & UINT8_C(0xff));
732
- uint32_t x63 = (x61 + x48);
733
- uint32_t x64 = (x63 >> 8);
734
- uint8_t x65 = (uint8_t)(x63 & UINT8_C(0xff));
735
- uint32_t x66 = (x64 >> 8);
736
- uint8_t x67 = (uint8_t)(x64 & UINT8_C(0xff));
737
- uint8_t x68 = (uint8_t)(x66 >> 8);
738
- uint8_t x69 = (uint8_t)(x66 & UINT8_C(0xff));
739
- uint32_t x70 = (x68 + x47);
740
- uint32_t x71 = (x70 >> 8);
741
- uint8_t x72 = (uint8_t)(x70 & UINT8_C(0xff));
742
- uint32_t x73 = (x71 >> 8);
743
- uint8_t x74 = (uint8_t)(x71 & UINT8_C(0xff));
744
- uint8_t x75 = (uint8_t)(x73 >> 8);
745
- uint8_t x76 = (uint8_t)(x73 & UINT8_C(0xff));
746
- uint32_t x77 = (x75 + x46);
747
- uint32_t x78 = (x77 >> 8);
748
- uint8_t x79 = (uint8_t)(x77 & UINT8_C(0xff));
749
- uint32_t x80 = (x78 >> 8);
750
- uint8_t x81 = (uint8_t)(x78 & UINT8_C(0xff));
751
- uint8_t x82 = (uint8_t)(x80 >> 8);
752
- uint8_t x83 = (uint8_t)(x80 & UINT8_C(0xff));
753
- uint8_t x84 = (uint8_t)(x82 & UINT8_C(0xff));
754
- uint32_t x85 = (x32 >> 8);
755
- uint8_t x86 = (uint8_t)(x32 & UINT8_C(0xff));
756
- uint32_t x87 = (x85 >> 8);
757
- uint8_t x88 = (uint8_t)(x85 & UINT8_C(0xff));
758
- fiat_25519_uint1 x89 = (fiat_25519_uint1)(x87 >> 8);
759
- uint8_t x90 = (uint8_t)(x87 & UINT8_C(0xff));
760
- uint32_t x91 = (x89 + x45);
761
- uint32_t x92 = (x91 >> 8);
762
- uint8_t x93 = (uint8_t)(x91 & UINT8_C(0xff));
763
- uint32_t x94 = (x92 >> 8);
764
- uint8_t x95 = (uint8_t)(x92 & UINT8_C(0xff));
765
- uint8_t x96 = (uint8_t)(x94 >> 8);
766
- uint8_t x97 = (uint8_t)(x94 & UINT8_C(0xff));
767
- uint32_t x98 = (x96 + x44);
768
- uint32_t x99 = (x98 >> 8);
769
- uint8_t x100 = (uint8_t)(x98 & UINT8_C(0xff));
770
- uint32_t x101 = (x99 >> 8);
771
- uint8_t x102 = (uint8_t)(x99 & UINT8_C(0xff));
772
- uint8_t x103 = (uint8_t)(x101 >> 8);
773
- uint8_t x104 = (uint8_t)(x101 & UINT8_C(0xff));
774
- uint32_t x105 = (x103 + x43);
775
- uint32_t x106 = (x105 >> 8);
776
- uint8_t x107 = (uint8_t)(x105 & UINT8_C(0xff));
777
- uint32_t x108 = (x106 >> 8);
778
- uint8_t x109 = (uint8_t)(x106 & UINT8_C(0xff));
779
- uint8_t x110 = (uint8_t)(x108 >> 8);
780
- uint8_t x111 = (uint8_t)(x108 & UINT8_C(0xff));
781
- uint32_t x112 = (x110 + x42);
782
- uint32_t x113 = (x112 >> 8);
783
- uint8_t x114 = (uint8_t)(x112 & UINT8_C(0xff));
784
- uint32_t x115 = (x113 >> 8);
785
- uint8_t x116 = (uint8_t)(x113 & UINT8_C(0xff));
786
- uint8_t x117 = (uint8_t)(x115 >> 8);
787
- uint8_t x118 = (uint8_t)(x115 & UINT8_C(0xff));
788
- out1[0] = x51;
789
- out1[1] = x53;
790
- out1[2] = x55;
791
- out1[3] = x58;
792
- out1[4] = x60;
793
- out1[5] = x62;
794
- out1[6] = x65;
795
- out1[7] = x67;
796
- out1[8] = x69;
797
- out1[9] = x72;
798
- out1[10] = x74;
799
- out1[11] = x76;
800
- out1[12] = x79;
801
- out1[13] = x81;
802
- out1[14] = x83;
803
- out1[15] = x84;
804
- out1[16] = x86;
805
- out1[17] = x88;
806
- out1[18] = x90;
807
- out1[19] = x93;
808
- out1[20] = x95;
809
- out1[21] = x97;
810
- out1[22] = x100;
811
- out1[23] = x102;
812
- out1[24] = x104;
813
- out1[25] = x107;
814
- out1[26] = x109;
815
- out1[27] = x111;
816
- out1[28] = x114;
817
- out1[29] = x116;
818
- out1[30] = x118;
1125
+ x42 = (x40 << 6);
1126
+ x43 = (x38 << 4);
1127
+ x44 = (x36 << 3);
1128
+ x45 = (x34 * (uint32_t)0x2);
1129
+ x46 = (x30 << 6);
1130
+ x47 = (x28 << 5);
1131
+ x48 = (x26 << 3);
1132
+ x49 = (x24 << 2);
1133
+ x50 = (uint8_t)(x22 & UINT8_C(0xff));
1134
+ x51 = (x22 >> 8);
1135
+ x52 = (uint8_t)(x51 & UINT8_C(0xff));
1136
+ x53 = (x51 >> 8);
1137
+ x54 = (uint8_t)(x53 & UINT8_C(0xff));
1138
+ x55 = (uint8_t)(x53 >> 8);
1139
+ x56 = (x49 + (uint32_t)x55);
1140
+ x57 = (uint8_t)(x56 & UINT8_C(0xff));
1141
+ x58 = (x56 >> 8);
1142
+ x59 = (uint8_t)(x58 & UINT8_C(0xff));
1143
+ x60 = (x58 >> 8);
1144
+ x61 = (uint8_t)(x60 & UINT8_C(0xff));
1145
+ x62 = (uint8_t)(x60 >> 8);
1146
+ x63 = (x48 + (uint32_t)x62);
1147
+ x64 = (uint8_t)(x63 & UINT8_C(0xff));
1148
+ x65 = (x63 >> 8);
1149
+ x66 = (uint8_t)(x65 & UINT8_C(0xff));
1150
+ x67 = (x65 >> 8);
1151
+ x68 = (uint8_t)(x67 & UINT8_C(0xff));
1152
+ x69 = (uint8_t)(x67 >> 8);
1153
+ x70 = (x47 + (uint32_t)x69);
1154
+ x71 = (uint8_t)(x70 & UINT8_C(0xff));
1155
+ x72 = (x70 >> 8);
1156
+ x73 = (uint8_t)(x72 & UINT8_C(0xff));
1157
+ x74 = (x72 >> 8);
1158
+ x75 = (uint8_t)(x74 & UINT8_C(0xff));
1159
+ x76 = (uint8_t)(x74 >> 8);
1160
+ x77 = (x46 + (uint32_t)x76);
1161
+ x78 = (uint8_t)(x77 & UINT8_C(0xff));
1162
+ x79 = (x77 >> 8);
1163
+ x80 = (uint8_t)(x79 & UINT8_C(0xff));
1164
+ x81 = (x79 >> 8);
1165
+ x82 = (uint8_t)(x81 & UINT8_C(0xff));
1166
+ x83 = (uint8_t)(x81 >> 8);
1167
+ x84 = (uint8_t)(x32 & UINT8_C(0xff));
1168
+ x85 = (x32 >> 8);
1169
+ x86 = (uint8_t)(x85 & UINT8_C(0xff));
1170
+ x87 = (x85 >> 8);
1171
+ x88 = (uint8_t)(x87 & UINT8_C(0xff));
1172
+ x89 = (fiat_25519_uint1)(x87 >> 8);
1173
+ x90 = (x45 + (uint32_t)x89);
1174
+ x91 = (uint8_t)(x90 & UINT8_C(0xff));
1175
+ x92 = (x90 >> 8);
1176
+ x93 = (uint8_t)(x92 & UINT8_C(0xff));
1177
+ x94 = (x92 >> 8);
1178
+ x95 = (uint8_t)(x94 & UINT8_C(0xff));
1179
+ x96 = (uint8_t)(x94 >> 8);
1180
+ x97 = (x44 + (uint32_t)x96);
1181
+ x98 = (uint8_t)(x97 & UINT8_C(0xff));
1182
+ x99 = (x97 >> 8);
1183
+ x100 = (uint8_t)(x99 & UINT8_C(0xff));
1184
+ x101 = (x99 >> 8);
1185
+ x102 = (uint8_t)(x101 & UINT8_C(0xff));
1186
+ x103 = (uint8_t)(x101 >> 8);
1187
+ x104 = (x43 + (uint32_t)x103);
1188
+ x105 = (uint8_t)(x104 & UINT8_C(0xff));
1189
+ x106 = (x104 >> 8);
1190
+ x107 = (uint8_t)(x106 & UINT8_C(0xff));
1191
+ x108 = (x106 >> 8);
1192
+ x109 = (uint8_t)(x108 & UINT8_C(0xff));
1193
+ x110 = (uint8_t)(x108 >> 8);
1194
+ x111 = (x42 + (uint32_t)x110);
1195
+ x112 = (uint8_t)(x111 & UINT8_C(0xff));
1196
+ x113 = (x111 >> 8);
1197
+ x114 = (uint8_t)(x113 & UINT8_C(0xff));
1198
+ x115 = (x113 >> 8);
1199
+ x116 = (uint8_t)(x115 & UINT8_C(0xff));
1200
+ x117 = (uint8_t)(x115 >> 8);
1201
+ out1[0] = x50;
1202
+ out1[1] = x52;
1203
+ out1[2] = x54;
1204
+ out1[3] = x57;
1205
+ out1[4] = x59;
1206
+ out1[5] = x61;
1207
+ out1[6] = x64;
1208
+ out1[7] = x66;
1209
+ out1[8] = x68;
1210
+ out1[9] = x71;
1211
+ out1[10] = x73;
1212
+ out1[11] = x75;
1213
+ out1[12] = x78;
1214
+ out1[13] = x80;
1215
+ out1[14] = x82;
1216
+ out1[15] = x83;
1217
+ out1[16] = x84;
1218
+ out1[17] = x86;
1219
+ out1[18] = x88;
1220
+ out1[19] = x91;
1221
+ out1[20] = x93;
1222
+ out1[21] = x95;
1223
+ out1[22] = x98;
1224
+ out1[23] = x100;
1225
+ out1[24] = x102;
1226
+ out1[25] = x105;
1227
+ out1[26] = x107;
1228
+ out1[27] = x109;
1229
+ out1[28] = x112;
1230
+ out1[29] = x114;
1231
+ out1[30] = x116;
819
1232
  out1[31] = x117;
820
1233
  }
821
1234
 
822
1235
  /*
823
1236
  * The function fiat_25519_from_bytes deserializes a field element from bytes in little-endian order.
1237
+ *
824
1238
  * Postconditions:
825
1239
  * eval out1 mod m = bytes_eval arg1 mod m
826
1240
  *
827
1241
  * Input Bounds:
828
1242
  * arg1: [[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 ~> 0x7f]]
829
- * Output Bounds:
830
- * out1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
831
1243
  */
832
- static void fiat_25519_from_bytes(uint32_t out1[10], const uint8_t arg1[32]) {
833
- uint32_t x1 = ((uint32_t)(arg1[31]) << 18);
834
- uint32_t x2 = ((uint32_t)(arg1[30]) << 10);
835
- uint32_t x3 = ((uint32_t)(arg1[29]) << 2);
836
- uint32_t x4 = ((uint32_t)(arg1[28]) << 20);
837
- uint32_t x5 = ((uint32_t)(arg1[27]) << 12);
838
- uint32_t x6 = ((uint32_t)(arg1[26]) << 4);
839
- uint32_t x7 = ((uint32_t)(arg1[25]) << 21);
840
- uint32_t x8 = ((uint32_t)(arg1[24]) << 13);
841
- uint32_t x9 = ((uint32_t)(arg1[23]) << 5);
842
- uint32_t x10 = ((uint32_t)(arg1[22]) << 23);
843
- uint32_t x11 = ((uint32_t)(arg1[21]) << 15);
844
- uint32_t x12 = ((uint32_t)(arg1[20]) << 7);
845
- uint32_t x13 = ((uint32_t)(arg1[19]) << 24);
846
- uint32_t x14 = ((uint32_t)(arg1[18]) << 16);
847
- uint32_t x15 = ((uint32_t)(arg1[17]) << 8);
848
- uint8_t x16 = (arg1[16]);
849
- uint32_t x17 = ((uint32_t)(arg1[15]) << 18);
850
- uint32_t x18 = ((uint32_t)(arg1[14]) << 10);
851
- uint32_t x19 = ((uint32_t)(arg1[13]) << 2);
852
- uint32_t x20 = ((uint32_t)(arg1[12]) << 19);
853
- uint32_t x21 = ((uint32_t)(arg1[11]) << 11);
854
- uint32_t x22 = ((uint32_t)(arg1[10]) << 3);
855
- uint32_t x23 = ((uint32_t)(arg1[9]) << 21);
856
- uint32_t x24 = ((uint32_t)(arg1[8]) << 13);
857
- uint32_t x25 = ((uint32_t)(arg1[7]) << 5);
858
- uint32_t x26 = ((uint32_t)(arg1[6]) << 22);
859
- uint32_t x27 = ((uint32_t)(arg1[5]) << 14);
860
- uint32_t x28 = ((uint32_t)(arg1[4]) << 6);
861
- uint32_t x29 = ((uint32_t)(arg1[3]) << 24);
862
- uint32_t x30 = ((uint32_t)(arg1[2]) << 16);
863
- uint32_t x31 = ((uint32_t)(arg1[1]) << 8);
864
- uint8_t x32 = (arg1[0]);
865
- uint32_t x33 = (x32 + (x31 + (x30 + x29)));
866
- uint8_t x34 = (uint8_t)(x33 >> 26);
867
- uint32_t x35 = (x33 & UINT32_C(0x3ffffff));
868
- uint32_t x36 = (x3 + (x2 + x1));
869
- uint32_t x37 = (x6 + (x5 + x4));
870
- uint32_t x38 = (x9 + (x8 + x7));
871
- uint32_t x39 = (x12 + (x11 + x10));
872
- uint32_t x40 = (x16 + (x15 + (x14 + x13)));
873
- uint32_t x41 = (x19 + (x18 + x17));
874
- uint32_t x42 = (x22 + (x21 + x20));
875
- uint32_t x43 = (x25 + (x24 + x23));
876
- uint32_t x44 = (x28 + (x27 + x26));
877
- uint32_t x45 = (x34 + x44);
878
- uint8_t x46 = (uint8_t)(x45 >> 25);
879
- uint32_t x47 = (x45 & UINT32_C(0x1ffffff));
880
- uint32_t x48 = (x46 + x43);
881
- uint8_t x49 = (uint8_t)(x48 >> 26);
882
- uint32_t x50 = (x48 & UINT32_C(0x3ffffff));
883
- uint32_t x51 = (x49 + x42);
884
- uint8_t x52 = (uint8_t)(x51 >> 25);
885
- uint32_t x53 = (x51 & UINT32_C(0x1ffffff));
886
- uint32_t x54 = (x52 + x41);
887
- uint32_t x55 = (x54 & UINT32_C(0x3ffffff));
888
- uint8_t x56 = (uint8_t)(x40 >> 25);
889
- uint32_t x57 = (x40 & UINT32_C(0x1ffffff));
890
- uint32_t x58 = (x56 + x39);
891
- uint8_t x59 = (uint8_t)(x58 >> 26);
892
- uint32_t x60 = (x58 & UINT32_C(0x3ffffff));
893
- uint32_t x61 = (x59 + x38);
894
- uint8_t x62 = (uint8_t)(x61 >> 25);
895
- uint32_t x63 = (x61 & UINT32_C(0x1ffffff));
896
- uint32_t x64 = (x62 + x37);
897
- uint8_t x65 = (uint8_t)(x64 >> 26);
898
- uint32_t x66 = (x64 & UINT32_C(0x3ffffff));
899
- uint32_t x67 = (x65 + x36);
900
- out1[0] = x35;
901
- out1[1] = x47;
902
- out1[2] = x50;
903
- out1[3] = x53;
1244
+ static FIAT_25519_FIAT_INLINE void fiat_25519_from_bytes(fiat_25519_tight_field_element out1, const uint8_t arg1[32]) {
1245
+ uint32_t x1;
1246
+ uint32_t x2;
1247
+ uint32_t x3;
1248
+ uint32_t x4;
1249
+ uint32_t x5;
1250
+ uint32_t x6;
1251
+ uint32_t x7;
1252
+ uint32_t x8;
1253
+ uint32_t x9;
1254
+ uint32_t x10;
1255
+ uint32_t x11;
1256
+ uint32_t x12;
1257
+ uint32_t x13;
1258
+ uint32_t x14;
1259
+ uint32_t x15;
1260
+ uint8_t x16;
1261
+ uint32_t x17;
1262
+ uint32_t x18;
1263
+ uint32_t x19;
1264
+ uint32_t x20;
1265
+ uint32_t x21;
1266
+ uint32_t x22;
1267
+ uint32_t x23;
1268
+ uint32_t x24;
1269
+ uint32_t x25;
1270
+ uint32_t x26;
1271
+ uint32_t x27;
1272
+ uint32_t x28;
1273
+ uint32_t x29;
1274
+ uint32_t x30;
1275
+ uint32_t x31;
1276
+ uint8_t x32;
1277
+ uint32_t x33;
1278
+ uint32_t x34;
1279
+ uint32_t x35;
1280
+ uint32_t x36;
1281
+ uint8_t x37;
1282
+ uint32_t x38;
1283
+ uint32_t x39;
1284
+ uint32_t x40;
1285
+ uint32_t x41;
1286
+ uint8_t x42;
1287
+ uint32_t x43;
1288
+ uint32_t x44;
1289
+ uint32_t x45;
1290
+ uint32_t x46;
1291
+ uint8_t x47;
1292
+ uint32_t x48;
1293
+ uint32_t x49;
1294
+ uint32_t x50;
1295
+ uint32_t x51;
1296
+ uint8_t x52;
1297
+ uint32_t x53;
1298
+ uint32_t x54;
1299
+ uint32_t x55;
1300
+ uint32_t x56;
1301
+ uint32_t x57;
1302
+ uint32_t x58;
1303
+ uint32_t x59;
1304
+ uint8_t x60;
1305
+ uint32_t x61;
1306
+ uint32_t x62;
1307
+ uint32_t x63;
1308
+ uint32_t x64;
1309
+ uint8_t x65;
1310
+ uint32_t x66;
1311
+ uint32_t x67;
1312
+ uint32_t x68;
1313
+ uint32_t x69;
1314
+ uint8_t x70;
1315
+ uint32_t x71;
1316
+ uint32_t x72;
1317
+ uint32_t x73;
1318
+ uint32_t x74;
1319
+ uint8_t x75;
1320
+ uint32_t x76;
1321
+ uint32_t x77;
1322
+ uint32_t x78;
1323
+ x1 = ((uint32_t)(arg1[31]) << 18);
1324
+ x2 = ((uint32_t)(arg1[30]) << 10);
1325
+ x3 = ((uint32_t)(arg1[29]) << 2);
1326
+ x4 = ((uint32_t)(arg1[28]) << 20);
1327
+ x5 = ((uint32_t)(arg1[27]) << 12);
1328
+ x6 = ((uint32_t)(arg1[26]) << 4);
1329
+ x7 = ((uint32_t)(arg1[25]) << 21);
1330
+ x8 = ((uint32_t)(arg1[24]) << 13);
1331
+ x9 = ((uint32_t)(arg1[23]) << 5);
1332
+ x10 = ((uint32_t)(arg1[22]) << 23);
1333
+ x11 = ((uint32_t)(arg1[21]) << 15);
1334
+ x12 = ((uint32_t)(arg1[20]) << 7);
1335
+ x13 = ((uint32_t)(arg1[19]) << 24);
1336
+ x14 = ((uint32_t)(arg1[18]) << 16);
1337
+ x15 = ((uint32_t)(arg1[17]) << 8);
1338
+ x16 = (arg1[16]);
1339
+ x17 = ((uint32_t)(arg1[15]) << 18);
1340
+ x18 = ((uint32_t)(arg1[14]) << 10);
1341
+ x19 = ((uint32_t)(arg1[13]) << 2);
1342
+ x20 = ((uint32_t)(arg1[12]) << 19);
1343
+ x21 = ((uint32_t)(arg1[11]) << 11);
1344
+ x22 = ((uint32_t)(arg1[10]) << 3);
1345
+ x23 = ((uint32_t)(arg1[9]) << 21);
1346
+ x24 = ((uint32_t)(arg1[8]) << 13);
1347
+ x25 = ((uint32_t)(arg1[7]) << 5);
1348
+ x26 = ((uint32_t)(arg1[6]) << 22);
1349
+ x27 = ((uint32_t)(arg1[5]) << 14);
1350
+ x28 = ((uint32_t)(arg1[4]) << 6);
1351
+ x29 = ((uint32_t)(arg1[3]) << 24);
1352
+ x30 = ((uint32_t)(arg1[2]) << 16);
1353
+ x31 = ((uint32_t)(arg1[1]) << 8);
1354
+ x32 = (arg1[0]);
1355
+ x33 = (x31 + (uint32_t)x32);
1356
+ x34 = (x30 + x33);
1357
+ x35 = (x29 + x34);
1358
+ x36 = (x35 & UINT32_C(0x3ffffff));
1359
+ x37 = (uint8_t)(x35 >> 26);
1360
+ x38 = (x28 + (uint32_t)x37);
1361
+ x39 = (x27 + x38);
1362
+ x40 = (x26 + x39);
1363
+ x41 = (x40 & UINT32_C(0x1ffffff));
1364
+ x42 = (uint8_t)(x40 >> 25);
1365
+ x43 = (x25 + (uint32_t)x42);
1366
+ x44 = (x24 + x43);
1367
+ x45 = (x23 + x44);
1368
+ x46 = (x45 & UINT32_C(0x3ffffff));
1369
+ x47 = (uint8_t)(x45 >> 26);
1370
+ x48 = (x22 + (uint32_t)x47);
1371
+ x49 = (x21 + x48);
1372
+ x50 = (x20 + x49);
1373
+ x51 = (x50 & UINT32_C(0x1ffffff));
1374
+ x52 = (uint8_t)(x50 >> 25);
1375
+ x53 = (x19 + (uint32_t)x52);
1376
+ x54 = (x18 + x53);
1377
+ x55 = (x17 + x54);
1378
+ x56 = (x15 + (uint32_t)x16);
1379
+ x57 = (x14 + x56);
1380
+ x58 = (x13 + x57);
1381
+ x59 = (x58 & UINT32_C(0x1ffffff));
1382
+ x60 = (uint8_t)(x58 >> 25);
1383
+ x61 = (x12 + (uint32_t)x60);
1384
+ x62 = (x11 + x61);
1385
+ x63 = (x10 + x62);
1386
+ x64 = (x63 & UINT32_C(0x3ffffff));
1387
+ x65 = (uint8_t)(x63 >> 26);
1388
+ x66 = (x9 + (uint32_t)x65);
1389
+ x67 = (x8 + x66);
1390
+ x68 = (x7 + x67);
1391
+ x69 = (x68 & UINT32_C(0x1ffffff));
1392
+ x70 = (uint8_t)(x68 >> 25);
1393
+ x71 = (x6 + (uint32_t)x70);
1394
+ x72 = (x5 + x71);
1395
+ x73 = (x4 + x72);
1396
+ x74 = (x73 & UINT32_C(0x3ffffff));
1397
+ x75 = (uint8_t)(x73 >> 26);
1398
+ x76 = (x3 + (uint32_t)x75);
1399
+ x77 = (x2 + x76);
1400
+ x78 = (x1 + x77);
1401
+ out1[0] = x36;
1402
+ out1[1] = x41;
1403
+ out1[2] = x46;
1404
+ out1[3] = x51;
904
1405
  out1[4] = x55;
905
- out1[5] = x57;
906
- out1[6] = x60;
907
- out1[7] = x63;
908
- out1[8] = x66;
909
- out1[9] = x67;
1406
+ out1[5] = x59;
1407
+ out1[6] = x64;
1408
+ out1[7] = x69;
1409
+ out1[8] = x74;
1410
+ out1[9] = x78;
1411
+ }
1412
+
1413
+ /*
1414
+ * The function fiat_25519_relax is the identity function converting from tight field elements to loose field elements.
1415
+ *
1416
+ * Postconditions:
1417
+ * out1 = arg1
1418
+ *
1419
+ */
1420
+ static FIAT_25519_FIAT_INLINE void fiat_25519_relax(fiat_25519_loose_field_element out1, const fiat_25519_tight_field_element arg1) {
1421
+ uint32_t x1;
1422
+ uint32_t x2;
1423
+ uint32_t x3;
1424
+ uint32_t x4;
1425
+ uint32_t x5;
1426
+ uint32_t x6;
1427
+ uint32_t x7;
1428
+ uint32_t x8;
1429
+ uint32_t x9;
1430
+ uint32_t x10;
1431
+ x1 = (arg1[0]);
1432
+ x2 = (arg1[1]);
1433
+ x3 = (arg1[2]);
1434
+ x4 = (arg1[3]);
1435
+ x5 = (arg1[4]);
1436
+ x6 = (arg1[5]);
1437
+ x7 = (arg1[6]);
1438
+ x8 = (arg1[7]);
1439
+ x9 = (arg1[8]);
1440
+ x10 = (arg1[9]);
1441
+ out1[0] = x1;
1442
+ out1[1] = x2;
1443
+ out1[2] = x3;
1444
+ out1[3] = x4;
1445
+ out1[4] = x5;
1446
+ out1[5] = x6;
1447
+ out1[6] = x7;
1448
+ out1[7] = x8;
1449
+ out1[8] = x9;
1450
+ out1[9] = x10;
910
1451
  }
911
1452
 
912
1453
  /*
913
1454
  * The function fiat_25519_carry_scmul_121666 multiplies a field element by 121666 and reduces the result.
1455
+ *
914
1456
  * Postconditions:
915
1457
  * eval out1 mod m = (121666 * eval arg1) mod m
916
1458
  *
917
- * Input Bounds:
918
- * arg1: [[0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999], [0x0 ~> 0xd333332], [0x0 ~> 0x6999999]]
919
- * Output Bounds:
920
- * out1: [[0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333], [0x0 ~> 0x4666666], [0x0 ~> 0x2333333]]
921
1459
  */
922
- static void fiat_25519_carry_scmul_121666(uint32_t out1[10], const uint32_t arg1[10]) {
923
- uint64_t x1 = ((uint64_t)UINT32_C(0x1db42) * (arg1[9]));
924
- uint64_t x2 = ((uint64_t)UINT32_C(0x1db42) * (arg1[8]));
925
- uint64_t x3 = ((uint64_t)UINT32_C(0x1db42) * (arg1[7]));
926
- uint64_t x4 = ((uint64_t)UINT32_C(0x1db42) * (arg1[6]));
927
- uint64_t x5 = ((uint64_t)UINT32_C(0x1db42) * (arg1[5]));
928
- uint64_t x6 = ((uint64_t)UINT32_C(0x1db42) * (arg1[4]));
929
- uint64_t x7 = ((uint64_t)UINT32_C(0x1db42) * (arg1[3]));
930
- uint64_t x8 = ((uint64_t)UINT32_C(0x1db42) * (arg1[2]));
931
- uint64_t x9 = ((uint64_t)UINT32_C(0x1db42) * (arg1[1]));
932
- uint64_t x10 = ((uint64_t)UINT32_C(0x1db42) * (arg1[0]));
933
- uint32_t x11 = (uint32_t)(x10 >> 26);
934
- uint32_t x12 = (uint32_t)(x10 & UINT32_C(0x3ffffff));
935
- uint64_t x13 = (x11 + x9);
936
- uint32_t x14 = (uint32_t)(x13 >> 25);
937
- uint32_t x15 = (uint32_t)(x13 & UINT32_C(0x1ffffff));
938
- uint64_t x16 = (x14 + x8);
939
- uint32_t x17 = (uint32_t)(x16 >> 26);
940
- uint32_t x18 = (uint32_t)(x16 & UINT32_C(0x3ffffff));
941
- uint64_t x19 = (x17 + x7);
942
- uint32_t x20 = (uint32_t)(x19 >> 25);
943
- uint32_t x21 = (uint32_t)(x19 & UINT32_C(0x1ffffff));
944
- uint64_t x22 = (x20 + x6);
945
- uint32_t x23 = (uint32_t)(x22 >> 26);
946
- uint32_t x24 = (uint32_t)(x22 & UINT32_C(0x3ffffff));
947
- uint64_t x25 = (x23 + x5);
948
- uint32_t x26 = (uint32_t)(x25 >> 25);
949
- uint32_t x27 = (uint32_t)(x25 & UINT32_C(0x1ffffff));
950
- uint64_t x28 = (x26 + x4);
951
- uint32_t x29 = (uint32_t)(x28 >> 26);
952
- uint32_t x30 = (uint32_t)(x28 & UINT32_C(0x3ffffff));
953
- uint64_t x31 = (x29 + x3);
954
- uint32_t x32 = (uint32_t)(x31 >> 25);
955
- uint32_t x33 = (uint32_t)(x31 & UINT32_C(0x1ffffff));
956
- uint64_t x34 = (x32 + x2);
957
- uint32_t x35 = (uint32_t)(x34 >> 26);
958
- uint32_t x36 = (uint32_t)(x34 & UINT32_C(0x3ffffff));
959
- uint64_t x37 = (x35 + x1);
960
- uint32_t x38 = (uint32_t)(x37 >> 25);
961
- uint32_t x39 = (uint32_t)(x37 & UINT32_C(0x1ffffff));
962
- uint32_t x40 = (x38 * UINT8_C(0x13));
963
- uint32_t x41 = (x12 + x40);
964
- fiat_25519_uint1 x42 = (fiat_25519_uint1)(x41 >> 26);
965
- uint32_t x43 = (x41 & UINT32_C(0x3ffffff));
966
- uint32_t x44 = (x42 + x15);
967
- fiat_25519_uint1 x45 = (fiat_25519_uint1)(x44 >> 25);
968
- uint32_t x46 = (x44 & UINT32_C(0x1ffffff));
969
- uint32_t x47 = (x45 + x18);
1460
+ static FIAT_25519_FIAT_INLINE void fiat_25519_carry_scmul_121666(fiat_25519_tight_field_element out1, const fiat_25519_loose_field_element arg1) {
1461
+ uint64_t x1;
1462
+ uint64_t x2;
1463
+ uint64_t x3;
1464
+ uint64_t x4;
1465
+ uint64_t x5;
1466
+ uint64_t x6;
1467
+ uint64_t x7;
1468
+ uint64_t x8;
1469
+ uint64_t x9;
1470
+ uint64_t x10;
1471
+ uint32_t x11;
1472
+ uint32_t x12;
1473
+ uint64_t x13;
1474
+ uint32_t x14;
1475
+ uint32_t x15;
1476
+ uint64_t x16;
1477
+ uint32_t x17;
1478
+ uint32_t x18;
1479
+ uint64_t x19;
1480
+ uint32_t x20;
1481
+ uint32_t x21;
1482
+ uint64_t x22;
1483
+ uint32_t x23;
1484
+ uint32_t x24;
1485
+ uint64_t x25;
1486
+ uint32_t x26;
1487
+ uint32_t x27;
1488
+ uint64_t x28;
1489
+ uint32_t x29;
1490
+ uint32_t x30;
1491
+ uint64_t x31;
1492
+ uint32_t x32;
1493
+ uint32_t x33;
1494
+ uint64_t x34;
1495
+ uint32_t x35;
1496
+ uint32_t x36;
1497
+ uint64_t x37;
1498
+ uint32_t x38;
1499
+ uint32_t x39;
1500
+ uint32_t x40;
1501
+ uint32_t x41;
1502
+ fiat_25519_uint1 x42;
1503
+ uint32_t x43;
1504
+ uint32_t x44;
1505
+ fiat_25519_uint1 x45;
1506
+ uint32_t x46;
1507
+ uint32_t x47;
1508
+ x1 = ((uint64_t)UINT32_C(0x1db42) * (arg1[9]));
1509
+ x2 = ((uint64_t)UINT32_C(0x1db42) * (arg1[8]));
1510
+ x3 = ((uint64_t)UINT32_C(0x1db42) * (arg1[7]));
1511
+ x4 = ((uint64_t)UINT32_C(0x1db42) * (arg1[6]));
1512
+ x5 = ((uint64_t)UINT32_C(0x1db42) * (arg1[5]));
1513
+ x6 = ((uint64_t)UINT32_C(0x1db42) * (arg1[4]));
1514
+ x7 = ((uint64_t)UINT32_C(0x1db42) * (arg1[3]));
1515
+ x8 = ((uint64_t)UINT32_C(0x1db42) * (arg1[2]));
1516
+ x9 = ((uint64_t)UINT32_C(0x1db42) * (arg1[1]));
1517
+ x10 = ((uint64_t)UINT32_C(0x1db42) * (arg1[0]));
1518
+ x11 = (uint32_t)(x10 >> 26);
1519
+ x12 = (uint32_t)(x10 & UINT32_C(0x3ffffff));
1520
+ x13 = (x11 + x9);
1521
+ x14 = (uint32_t)(x13 >> 25);
1522
+ x15 = (uint32_t)(x13 & UINT32_C(0x1ffffff));
1523
+ x16 = (x14 + x8);
1524
+ x17 = (uint32_t)(x16 >> 26);
1525
+ x18 = (uint32_t)(x16 & UINT32_C(0x3ffffff));
1526
+ x19 = (x17 + x7);
1527
+ x20 = (uint32_t)(x19 >> 25);
1528
+ x21 = (uint32_t)(x19 & UINT32_C(0x1ffffff));
1529
+ x22 = (x20 + x6);
1530
+ x23 = (uint32_t)(x22 >> 26);
1531
+ x24 = (uint32_t)(x22 & UINT32_C(0x3ffffff));
1532
+ x25 = (x23 + x5);
1533
+ x26 = (uint32_t)(x25 >> 25);
1534
+ x27 = (uint32_t)(x25 & UINT32_C(0x1ffffff));
1535
+ x28 = (x26 + x4);
1536
+ x29 = (uint32_t)(x28 >> 26);
1537
+ x30 = (uint32_t)(x28 & UINT32_C(0x3ffffff));
1538
+ x31 = (x29 + x3);
1539
+ x32 = (uint32_t)(x31 >> 25);
1540
+ x33 = (uint32_t)(x31 & UINT32_C(0x1ffffff));
1541
+ x34 = (x32 + x2);
1542
+ x35 = (uint32_t)(x34 >> 26);
1543
+ x36 = (uint32_t)(x34 & UINT32_C(0x3ffffff));
1544
+ x37 = (x35 + x1);
1545
+ x38 = (uint32_t)(x37 >> 25);
1546
+ x39 = (uint32_t)(x37 & UINT32_C(0x1ffffff));
1547
+ x40 = (x38 * UINT8_C(0x13));
1548
+ x41 = (x12 + x40);
1549
+ x42 = (fiat_25519_uint1)(x41 >> 26);
1550
+ x43 = (x41 & UINT32_C(0x3ffffff));
1551
+ x44 = (x42 + x15);
1552
+ x45 = (fiat_25519_uint1)(x44 >> 25);
1553
+ x46 = (x44 & UINT32_C(0x1ffffff));
1554
+ x47 = (x45 + x18);
970
1555
  out1[0] = x43;
971
1556
  out1[1] = x46;
972
1557
  out1[2] = x47;
@@ -978,4 +1563,3 @@ static void fiat_25519_carry_scmul_121666(uint32_t out1[10], const uint32_t arg1
978
1563
  out1[8] = x36;
979
1564
  out1[9] = x39;
980
1565
  }
981
-