vllm-cpu-avx512vnni 0.13.0__cp313-cp313-manylinux_2_28_x86_64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of vllm-cpu-avx512vnni might be problematic. Click here for more details.

Files changed (1641) hide show
  1. vllm/_C.abi3.so +0 -0
  2. vllm/__init__.py +225 -0
  3. vllm/_aiter_ops.py +1260 -0
  4. vllm/_bc_linter.py +54 -0
  5. vllm/_custom_ops.py +3080 -0
  6. vllm/_ipex_ops.py +457 -0
  7. vllm/_version.py +34 -0
  8. vllm/assets/__init__.py +0 -0
  9. vllm/assets/audio.py +43 -0
  10. vllm/assets/base.py +40 -0
  11. vllm/assets/image.py +59 -0
  12. vllm/assets/video.py +149 -0
  13. vllm/attention/__init__.py +0 -0
  14. vllm/attention/backends/__init__.py +0 -0
  15. vllm/attention/backends/abstract.py +443 -0
  16. vllm/attention/backends/registry.py +254 -0
  17. vllm/attention/backends/utils.py +33 -0
  18. vllm/attention/layer.py +969 -0
  19. vllm/attention/layers/__init__.py +0 -0
  20. vllm/attention/layers/chunked_local_attention.py +120 -0
  21. vllm/attention/layers/cross_attention.py +178 -0
  22. vllm/attention/layers/encoder_only_attention.py +103 -0
  23. vllm/attention/layers/mm_encoder_attention.py +284 -0
  24. vllm/attention/ops/__init__.py +0 -0
  25. vllm/attention/ops/chunked_prefill_paged_decode.py +401 -0
  26. vllm/attention/ops/common.py +469 -0
  27. vllm/attention/ops/flashmla.py +251 -0
  28. vllm/attention/ops/merge_attn_states.py +47 -0
  29. vllm/attention/ops/paged_attn.py +51 -0
  30. vllm/attention/ops/pallas_kv_cache_update.py +130 -0
  31. vllm/attention/ops/prefix_prefill.py +814 -0
  32. vllm/attention/ops/rocm_aiter_mla_sparse.py +210 -0
  33. vllm/attention/ops/triton_decode_attention.py +712 -0
  34. vllm/attention/ops/triton_merge_attn_states.py +116 -0
  35. vllm/attention/ops/triton_reshape_and_cache_flash.py +184 -0
  36. vllm/attention/ops/triton_unified_attention.py +1047 -0
  37. vllm/attention/ops/vit_attn_wrappers.py +139 -0
  38. vllm/attention/selector.py +145 -0
  39. vllm/attention/utils/__init__.py +0 -0
  40. vllm/attention/utils/fa_utils.py +118 -0
  41. vllm/attention/utils/kv_sharing_utils.py +33 -0
  42. vllm/attention/utils/kv_transfer_utils.py +60 -0
  43. vllm/beam_search.py +88 -0
  44. vllm/benchmarks/__init__.py +0 -0
  45. vllm/benchmarks/datasets.py +3228 -0
  46. vllm/benchmarks/latency.py +170 -0
  47. vllm/benchmarks/lib/__init__.py +3 -0
  48. vllm/benchmarks/lib/endpoint_request_func.py +777 -0
  49. vllm/benchmarks/lib/ready_checker.py +72 -0
  50. vllm/benchmarks/lib/utils.py +79 -0
  51. vllm/benchmarks/serve.py +1538 -0
  52. vllm/benchmarks/startup.py +326 -0
  53. vllm/benchmarks/sweep/__init__.py +0 -0
  54. vllm/benchmarks/sweep/cli.py +41 -0
  55. vllm/benchmarks/sweep/param_sweep.py +158 -0
  56. vllm/benchmarks/sweep/plot.py +675 -0
  57. vllm/benchmarks/sweep/plot_pareto.py +393 -0
  58. vllm/benchmarks/sweep/serve.py +450 -0
  59. vllm/benchmarks/sweep/serve_sla.py +492 -0
  60. vllm/benchmarks/sweep/server.py +114 -0
  61. vllm/benchmarks/sweep/sla_sweep.py +132 -0
  62. vllm/benchmarks/sweep/utils.py +4 -0
  63. vllm/benchmarks/throughput.py +808 -0
  64. vllm/collect_env.py +857 -0
  65. vllm/compilation/__init__.py +0 -0
  66. vllm/compilation/activation_quant_fusion.py +209 -0
  67. vllm/compilation/backends.py +839 -0
  68. vllm/compilation/base_static_graph.py +57 -0
  69. vllm/compilation/caching.py +180 -0
  70. vllm/compilation/collective_fusion.py +1215 -0
  71. vllm/compilation/compiler_interface.py +639 -0
  72. vllm/compilation/counter.py +48 -0
  73. vllm/compilation/cuda_graph.py +302 -0
  74. vllm/compilation/decorators.py +626 -0
  75. vllm/compilation/fix_functionalization.py +266 -0
  76. vllm/compilation/fusion.py +550 -0
  77. vllm/compilation/fusion_attn.py +359 -0
  78. vllm/compilation/fx_utils.py +91 -0
  79. vllm/compilation/inductor_pass.py +138 -0
  80. vllm/compilation/matcher_utils.py +361 -0
  81. vllm/compilation/monitor.py +62 -0
  82. vllm/compilation/noop_elimination.py +130 -0
  83. vllm/compilation/partition_rules.py +72 -0
  84. vllm/compilation/pass_manager.py +155 -0
  85. vllm/compilation/piecewise_backend.py +178 -0
  86. vllm/compilation/post_cleanup.py +21 -0
  87. vllm/compilation/qk_norm_rope_fusion.py +238 -0
  88. vllm/compilation/rocm_aiter_fusion.py +242 -0
  89. vllm/compilation/sequence_parallelism.py +364 -0
  90. vllm/compilation/torch25_custom_graph_pass.py +44 -0
  91. vllm/compilation/vllm_inductor_pass.py +173 -0
  92. vllm/compilation/wrapper.py +319 -0
  93. vllm/config/__init__.py +108 -0
  94. vllm/config/attention.py +114 -0
  95. vllm/config/cache.py +232 -0
  96. vllm/config/compilation.py +1140 -0
  97. vllm/config/device.py +75 -0
  98. vllm/config/ec_transfer.py +110 -0
  99. vllm/config/kv_events.py +56 -0
  100. vllm/config/kv_transfer.py +119 -0
  101. vllm/config/load.py +124 -0
  102. vllm/config/lora.py +96 -0
  103. vllm/config/model.py +2190 -0
  104. vllm/config/multimodal.py +247 -0
  105. vllm/config/observability.py +140 -0
  106. vllm/config/parallel.py +660 -0
  107. vllm/config/pooler.py +126 -0
  108. vllm/config/profiler.py +199 -0
  109. vllm/config/scheduler.py +299 -0
  110. vllm/config/speculative.py +644 -0
  111. vllm/config/speech_to_text.py +38 -0
  112. vllm/config/structured_outputs.py +78 -0
  113. vllm/config/utils.py +370 -0
  114. vllm/config/vllm.py +1434 -0
  115. vllm/connections.py +189 -0
  116. vllm/device_allocator/__init__.py +0 -0
  117. vllm/device_allocator/cumem.py +327 -0
  118. vllm/distributed/__init__.py +6 -0
  119. vllm/distributed/communication_op.py +43 -0
  120. vllm/distributed/device_communicators/__init__.py +0 -0
  121. vllm/distributed/device_communicators/all2all.py +490 -0
  122. vllm/distributed/device_communicators/all_reduce_utils.py +344 -0
  123. vllm/distributed/device_communicators/base_device_communicator.py +297 -0
  124. vllm/distributed/device_communicators/cpu_communicator.py +209 -0
  125. vllm/distributed/device_communicators/cuda_communicator.py +340 -0
  126. vllm/distributed/device_communicators/cuda_wrapper.py +216 -0
  127. vllm/distributed/device_communicators/custom_all_reduce.py +326 -0
  128. vllm/distributed/device_communicators/mnnvl_compat.py +27 -0
  129. vllm/distributed/device_communicators/pynccl.py +386 -0
  130. vllm/distributed/device_communicators/pynccl_allocator.py +191 -0
  131. vllm/distributed/device_communicators/pynccl_wrapper.py +564 -0
  132. vllm/distributed/device_communicators/quick_all_reduce.py +290 -0
  133. vllm/distributed/device_communicators/ray_communicator.py +259 -0
  134. vllm/distributed/device_communicators/shm_broadcast.py +778 -0
  135. vllm/distributed/device_communicators/shm_object_storage.py +697 -0
  136. vllm/distributed/device_communicators/symm_mem.py +156 -0
  137. vllm/distributed/device_communicators/tpu_communicator.py +99 -0
  138. vllm/distributed/device_communicators/xpu_communicator.py +95 -0
  139. vllm/distributed/ec_transfer/__init__.py +14 -0
  140. vllm/distributed/ec_transfer/ec_connector/__init__.py +0 -0
  141. vllm/distributed/ec_transfer/ec_connector/base.py +247 -0
  142. vllm/distributed/ec_transfer/ec_connector/example_connector.py +201 -0
  143. vllm/distributed/ec_transfer/ec_connector/factory.py +85 -0
  144. vllm/distributed/ec_transfer/ec_transfer_state.py +42 -0
  145. vllm/distributed/eplb/__init__.py +3 -0
  146. vllm/distributed/eplb/async_worker.py +115 -0
  147. vllm/distributed/eplb/eplb_state.py +1164 -0
  148. vllm/distributed/eplb/policy/__init__.py +19 -0
  149. vllm/distributed/eplb/policy/abstract.py +40 -0
  150. vllm/distributed/eplb/policy/default.py +267 -0
  151. vllm/distributed/eplb/rebalance_execute.py +529 -0
  152. vllm/distributed/kv_events.py +499 -0
  153. vllm/distributed/kv_transfer/README.md +29 -0
  154. vllm/distributed/kv_transfer/__init__.py +20 -0
  155. vllm/distributed/kv_transfer/disagg_prefill_workflow.jpg +0 -0
  156. vllm/distributed/kv_transfer/kv_connector/__init__.py +0 -0
  157. vllm/distributed/kv_transfer/kv_connector/base.py +10 -0
  158. vllm/distributed/kv_transfer/kv_connector/factory.py +197 -0
  159. vllm/distributed/kv_transfer/kv_connector/utils.py +322 -0
  160. vllm/distributed/kv_transfer/kv_connector/v1/__init__.py +19 -0
  161. vllm/distributed/kv_transfer/kv_connector/v1/base.py +597 -0
  162. vllm/distributed/kv_transfer/kv_connector/v1/decode_bench_connector.py +419 -0
  163. vllm/distributed/kv_transfer/kv_connector/v1/example_connector.py +450 -0
  164. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_connector.py +327 -0
  165. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_integration/__init__.py +18 -0
  166. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_integration/multi_process_adapter.py +378 -0
  167. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_integration/utils.py +221 -0
  168. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_integration/vllm_v1_adapter.py +1418 -0
  169. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_mp_connector.py +895 -0
  170. vllm/distributed/kv_transfer/kv_connector/v1/metrics.py +186 -0
  171. vllm/distributed/kv_transfer/kv_connector/v1/mooncake_connector.py +914 -0
  172. vllm/distributed/kv_transfer/kv_connector/v1/multi_connector.py +464 -0
  173. vllm/distributed/kv_transfer/kv_connector/v1/nixl_connector.py +2526 -0
  174. vllm/distributed/kv_transfer/kv_connector/v1/offloading_connector.py +538 -0
  175. vllm/distributed/kv_transfer/kv_connector/v1/p2p/__init__.py +0 -0
  176. vllm/distributed/kv_transfer/kv_connector/v1/p2p/p2p_nccl_connector.py +531 -0
  177. vllm/distributed/kv_transfer/kv_connector/v1/p2p/p2p_nccl_engine.py +632 -0
  178. vllm/distributed/kv_transfer/kv_connector/v1/p2p/tensor_memory_pool.py +273 -0
  179. vllm/distributed/kv_transfer/kv_transfer_state.py +78 -0
  180. vllm/distributed/parallel_state.py +1795 -0
  181. vllm/distributed/tpu_distributed_utils.py +188 -0
  182. vllm/distributed/utils.py +545 -0
  183. vllm/engine/__init__.py +0 -0
  184. vllm/engine/arg_utils.py +2068 -0
  185. vllm/engine/async_llm_engine.py +6 -0
  186. vllm/engine/llm_engine.py +6 -0
  187. vllm/engine/protocol.py +190 -0
  188. vllm/entrypoints/__init__.py +0 -0
  189. vllm/entrypoints/anthropic/__init__.py +0 -0
  190. vllm/entrypoints/anthropic/protocol.py +162 -0
  191. vllm/entrypoints/anthropic/serving_messages.py +468 -0
  192. vllm/entrypoints/api_server.py +185 -0
  193. vllm/entrypoints/chat_utils.py +1903 -0
  194. vllm/entrypoints/cli/__init__.py +15 -0
  195. vllm/entrypoints/cli/benchmark/__init__.py +0 -0
  196. vllm/entrypoints/cli/benchmark/base.py +25 -0
  197. vllm/entrypoints/cli/benchmark/latency.py +21 -0
  198. vllm/entrypoints/cli/benchmark/main.py +56 -0
  199. vllm/entrypoints/cli/benchmark/serve.py +21 -0
  200. vllm/entrypoints/cli/benchmark/startup.py +21 -0
  201. vllm/entrypoints/cli/benchmark/sweep.py +21 -0
  202. vllm/entrypoints/cli/benchmark/throughput.py +21 -0
  203. vllm/entrypoints/cli/collect_env.py +38 -0
  204. vllm/entrypoints/cli/main.py +79 -0
  205. vllm/entrypoints/cli/openai.py +260 -0
  206. vllm/entrypoints/cli/run_batch.py +68 -0
  207. vllm/entrypoints/cli/serve.py +249 -0
  208. vllm/entrypoints/cli/types.py +29 -0
  209. vllm/entrypoints/constants.py +12 -0
  210. vllm/entrypoints/context.py +835 -0
  211. vllm/entrypoints/launcher.py +175 -0
  212. vllm/entrypoints/llm.py +1790 -0
  213. vllm/entrypoints/logger.py +84 -0
  214. vllm/entrypoints/openai/__init__.py +0 -0
  215. vllm/entrypoints/openai/api_server.py +1469 -0
  216. vllm/entrypoints/openai/cli_args.py +302 -0
  217. vllm/entrypoints/openai/orca_metrics.py +120 -0
  218. vllm/entrypoints/openai/parser/__init__.py +0 -0
  219. vllm/entrypoints/openai/parser/harmony_utils.py +825 -0
  220. vllm/entrypoints/openai/parser/responses_parser.py +135 -0
  221. vllm/entrypoints/openai/protocol.py +2496 -0
  222. vllm/entrypoints/openai/run_batch.py +631 -0
  223. vllm/entrypoints/openai/serving_chat.py +1822 -0
  224. vllm/entrypoints/openai/serving_completion.py +729 -0
  225. vllm/entrypoints/openai/serving_engine.py +1542 -0
  226. vllm/entrypoints/openai/serving_models.py +304 -0
  227. vllm/entrypoints/openai/serving_responses.py +2080 -0
  228. vllm/entrypoints/openai/serving_transcription.py +168 -0
  229. vllm/entrypoints/openai/speech_to_text.py +559 -0
  230. vllm/entrypoints/openai/tool_parsers/__init__.py +33 -0
  231. vllm/entrypoints/openai/utils.py +49 -0
  232. vllm/entrypoints/pooling/__init__.py +16 -0
  233. vllm/entrypoints/pooling/classify/__init__.py +0 -0
  234. vllm/entrypoints/pooling/classify/api_router.py +50 -0
  235. vllm/entrypoints/pooling/classify/protocol.py +181 -0
  236. vllm/entrypoints/pooling/classify/serving.py +233 -0
  237. vllm/entrypoints/pooling/embed/__init__.py +0 -0
  238. vllm/entrypoints/pooling/embed/api_router.py +67 -0
  239. vllm/entrypoints/pooling/embed/protocol.py +208 -0
  240. vllm/entrypoints/pooling/embed/serving.py +684 -0
  241. vllm/entrypoints/pooling/pooling/__init__.py +0 -0
  242. vllm/entrypoints/pooling/pooling/api_router.py +63 -0
  243. vllm/entrypoints/pooling/pooling/protocol.py +148 -0
  244. vllm/entrypoints/pooling/pooling/serving.py +354 -0
  245. vllm/entrypoints/pooling/score/__init__.py +0 -0
  246. vllm/entrypoints/pooling/score/api_router.py +149 -0
  247. vllm/entrypoints/pooling/score/protocol.py +146 -0
  248. vllm/entrypoints/pooling/score/serving.py +508 -0
  249. vllm/entrypoints/renderer.py +410 -0
  250. vllm/entrypoints/responses_utils.py +249 -0
  251. vllm/entrypoints/sagemaker/__init__.py +4 -0
  252. vllm/entrypoints/sagemaker/routes.py +118 -0
  253. vllm/entrypoints/score_utils.py +237 -0
  254. vllm/entrypoints/serve/__init__.py +60 -0
  255. vllm/entrypoints/serve/disagg/__init__.py +0 -0
  256. vllm/entrypoints/serve/disagg/api_router.py +110 -0
  257. vllm/entrypoints/serve/disagg/protocol.py +90 -0
  258. vllm/entrypoints/serve/disagg/serving.py +285 -0
  259. vllm/entrypoints/serve/elastic_ep/__init__.py +0 -0
  260. vllm/entrypoints/serve/elastic_ep/api_router.py +96 -0
  261. vllm/entrypoints/serve/elastic_ep/middleware.py +49 -0
  262. vllm/entrypoints/serve/instrumentator/__init__.py +0 -0
  263. vllm/entrypoints/serve/instrumentator/health.py +33 -0
  264. vllm/entrypoints/serve/instrumentator/metrics.py +45 -0
  265. vllm/entrypoints/serve/lora/__init__.py +0 -0
  266. vllm/entrypoints/serve/lora/api_router.py +70 -0
  267. vllm/entrypoints/serve/profile/__init__.py +0 -0
  268. vllm/entrypoints/serve/profile/api_router.py +46 -0
  269. vllm/entrypoints/serve/rlhf/__init__.py +0 -0
  270. vllm/entrypoints/serve/rlhf/api_router.py +102 -0
  271. vllm/entrypoints/serve/sleep/__init__.py +0 -0
  272. vllm/entrypoints/serve/sleep/api_router.py +60 -0
  273. vllm/entrypoints/serve/tokenize/__init__.py +0 -0
  274. vllm/entrypoints/serve/tokenize/api_router.py +118 -0
  275. vllm/entrypoints/serve/tokenize/serving.py +204 -0
  276. vllm/entrypoints/ssl.py +78 -0
  277. vllm/entrypoints/tool.py +187 -0
  278. vllm/entrypoints/tool_server.py +234 -0
  279. vllm/entrypoints/utils.py +319 -0
  280. vllm/env_override.py +378 -0
  281. vllm/envs.py +1744 -0
  282. vllm/forward_context.py +358 -0
  283. vllm/inputs/__init__.py +44 -0
  284. vllm/inputs/data.py +359 -0
  285. vllm/inputs/parse.py +146 -0
  286. vllm/inputs/preprocess.py +717 -0
  287. vllm/logger.py +303 -0
  288. vllm/logging_utils/__init__.py +13 -0
  289. vllm/logging_utils/dump_input.py +83 -0
  290. vllm/logging_utils/formatter.py +127 -0
  291. vllm/logging_utils/lazy.py +20 -0
  292. vllm/logging_utils/log_time.py +34 -0
  293. vllm/logits_process.py +121 -0
  294. vllm/logprobs.py +206 -0
  295. vllm/lora/__init__.py +0 -0
  296. vllm/lora/layers/__init__.py +42 -0
  297. vllm/lora/layers/base.py +66 -0
  298. vllm/lora/layers/base_linear.py +165 -0
  299. vllm/lora/layers/column_parallel_linear.py +577 -0
  300. vllm/lora/layers/fused_moe.py +747 -0
  301. vllm/lora/layers/logits_processor.py +203 -0
  302. vllm/lora/layers/replicated_linear.py +70 -0
  303. vllm/lora/layers/row_parallel_linear.py +176 -0
  304. vllm/lora/layers/utils.py +74 -0
  305. vllm/lora/layers/vocal_parallel_embedding.py +140 -0
  306. vllm/lora/lora_model.py +246 -0
  307. vllm/lora/lora_weights.py +227 -0
  308. vllm/lora/model_manager.py +690 -0
  309. vllm/lora/ops/__init__.py +0 -0
  310. vllm/lora/ops/ipex_ops/__init__.py +6 -0
  311. vllm/lora/ops/ipex_ops/lora_ops.py +57 -0
  312. vllm/lora/ops/torch_ops/__init__.py +20 -0
  313. vllm/lora/ops/torch_ops/lora_ops.py +128 -0
  314. vllm/lora/ops/triton_ops/README_TUNING.md +60 -0
  315. vllm/lora/ops/triton_ops/__init__.py +21 -0
  316. vllm/lora/ops/triton_ops/fused_moe_lora_op.py +665 -0
  317. vllm/lora/ops/triton_ops/kernel_utils.py +340 -0
  318. vllm/lora/ops/triton_ops/lora_expand_op.py +310 -0
  319. vllm/lora/ops/triton_ops/lora_kernel_metadata.py +154 -0
  320. vllm/lora/ops/triton_ops/lora_shrink_op.py +287 -0
  321. vllm/lora/ops/triton_ops/utils.py +295 -0
  322. vllm/lora/ops/xla_ops/__init__.py +6 -0
  323. vllm/lora/ops/xla_ops/lora_ops.py +141 -0
  324. vllm/lora/peft_helper.py +128 -0
  325. vllm/lora/punica_wrapper/__init__.py +10 -0
  326. vllm/lora/punica_wrapper/punica_base.py +493 -0
  327. vllm/lora/punica_wrapper/punica_cpu.py +351 -0
  328. vllm/lora/punica_wrapper/punica_gpu.py +412 -0
  329. vllm/lora/punica_wrapper/punica_selector.py +21 -0
  330. vllm/lora/punica_wrapper/punica_tpu.py +358 -0
  331. vllm/lora/punica_wrapper/punica_xpu.py +276 -0
  332. vllm/lora/punica_wrapper/utils.py +150 -0
  333. vllm/lora/request.py +100 -0
  334. vllm/lora/resolver.py +88 -0
  335. vllm/lora/utils.py +315 -0
  336. vllm/lora/worker_manager.py +268 -0
  337. vllm/model_executor/__init__.py +11 -0
  338. vllm/model_executor/custom_op.py +199 -0
  339. vllm/model_executor/layers/__init__.py +0 -0
  340. vllm/model_executor/layers/activation.py +595 -0
  341. vllm/model_executor/layers/attention_layer_base.py +32 -0
  342. vllm/model_executor/layers/batch_invariant.py +1067 -0
  343. vllm/model_executor/layers/conv.py +256 -0
  344. vllm/model_executor/layers/fla/__init__.py +8 -0
  345. vllm/model_executor/layers/fla/ops/__init__.py +17 -0
  346. vllm/model_executor/layers/fla/ops/chunk.py +240 -0
  347. vllm/model_executor/layers/fla/ops/chunk_delta_h.py +344 -0
  348. vllm/model_executor/layers/fla/ops/chunk_o.py +183 -0
  349. vllm/model_executor/layers/fla/ops/chunk_scaled_dot_kkt.py +154 -0
  350. vllm/model_executor/layers/fla/ops/cumsum.py +280 -0
  351. vllm/model_executor/layers/fla/ops/fused_recurrent.py +390 -0
  352. vllm/model_executor/layers/fla/ops/index.py +41 -0
  353. vllm/model_executor/layers/fla/ops/kda.py +1351 -0
  354. vllm/model_executor/layers/fla/ops/l2norm.py +146 -0
  355. vllm/model_executor/layers/fla/ops/layernorm_guard.py +396 -0
  356. vllm/model_executor/layers/fla/ops/op.py +60 -0
  357. vllm/model_executor/layers/fla/ops/solve_tril.py +556 -0
  358. vllm/model_executor/layers/fla/ops/utils.py +194 -0
  359. vllm/model_executor/layers/fla/ops/wy_fast.py +158 -0
  360. vllm/model_executor/layers/fused_moe/__init__.py +114 -0
  361. vllm/model_executor/layers/fused_moe/all2all_utils.py +171 -0
  362. vllm/model_executor/layers/fused_moe/batched_deep_gemm_moe.py +409 -0
  363. vllm/model_executor/layers/fused_moe/config.py +1043 -0
  364. vllm/model_executor/layers/fused_moe/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  365. vllm/model_executor/layers/fused_moe/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  366. vllm/model_executor/layers/fused_moe/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  367. vllm/model_executor/layers/fused_moe/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  368. vllm/model_executor/layers/fused_moe/configs/E=1,N=1792,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  369. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  370. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  371. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3.json +218 -0
  372. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_H200,dtype=int8_w8a16.json +146 -0
  373. vllm/model_executor/layers/fused_moe/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  374. vllm/model_executor/layers/fused_moe/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  375. vllm/model_executor/layers/fused_moe/configs/E=1,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  376. vllm/model_executor/layers/fused_moe/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  377. vllm/model_executor/layers/fused_moe/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  378. vllm/model_executor/layers/fused_moe/configs/E=1,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  379. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  380. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=AMD_Instinct_MI300X.json +200 -0
  381. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  382. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=NVIDIA_H100,dtype=fp8_w8a8.json +123 -0
  383. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  384. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=NVIDIA_H200.json +146 -0
  385. vllm/model_executor/layers/fused_moe/configs/E=128,N=1856,device_name=NVIDIA_H100_80GB_HBM3.json +147 -0
  386. vllm/model_executor/layers/fused_moe/configs/E=128,N=1856,device_name=NVIDIA_L40S.json +147 -0
  387. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  388. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  389. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H20-3e.json +146 -0
  390. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H20.json +146 -0
  391. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H200.json +146 -0
  392. vllm/model_executor/layers/fused_moe/configs/E=128,N=352,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +122 -0
  393. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  394. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  395. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  396. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  397. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20-3e,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  398. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20-3e.json +146 -0
  399. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20.json +146 -0
  400. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  401. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H200.json +146 -0
  402. vllm/model_executor/layers/fused_moe/configs/E=128,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  403. vllm/model_executor/layers/fused_moe/configs/E=128,N=512,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  404. vllm/model_executor/layers/fused_moe/configs/E=128,N=704,device_name=NVIDIA_B200,dtype=fp8_w8a8.json +146 -0
  405. vllm/model_executor/layers/fused_moe/configs/E=128,N=704,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +114 -0
  406. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  407. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=AMD_Instinct_MI308X.json +213 -0
  408. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  409. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  410. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  411. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H20-3e,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  412. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H20.json +146 -0
  413. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  414. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H200.json +146 -0
  415. vllm/model_executor/layers/fused_moe/configs/E=128,N=8960,device_name=NVIDIA_H100_80GB_HBM3,dtype=bf16.json +82 -0
  416. vllm/model_executor/layers/fused_moe/configs/E=128,N=8960,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +82 -0
  417. vllm/model_executor/layers/fused_moe/configs/E=128,N=928,device_name=NVIDIA_H100_80GB_HBM3.json +147 -0
  418. vllm/model_executor/layers/fused_moe/configs/E=128,N=928,device_name=NVIDIA_L40S.json +147 -0
  419. vllm/model_executor/layers/fused_moe/configs/E=128,N=96,device_name=NVIDIA_H20.json +146 -0
  420. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=AMD_Instinct_MI300X.json +200 -0
  421. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_B200,dtype=fp8_w8a8.json +147 -0
  422. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_B200.json +146 -0
  423. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_H100.json +146 -0
  424. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  425. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_H200.json +146 -0
  426. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  427. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  428. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  429. vllm/model_executor/layers/fused_moe/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  430. vllm/model_executor/layers/fused_moe/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  431. vllm/model_executor/layers/fused_moe/configs/E=16,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  432. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  433. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  434. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  435. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  436. vllm/model_executor/layers/fused_moe/configs/E=16,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  437. vllm/model_executor/layers/fused_moe/configs/E=16,N=2048,device_name=NVIDIA_H200.json +146 -0
  438. vllm/model_executor/layers/fused_moe/configs/E=16,N=2688,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  439. vllm/model_executor/layers/fused_moe/configs/E=16,N=2688,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  440. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  441. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=float8.json +146 -0
  442. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  443. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_H200,dtype=int8_w8a16.json +146 -0
  444. vllm/model_executor/layers/fused_moe/configs/E=16,N=3200,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  445. vllm/model_executor/layers/fused_moe/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  446. vllm/model_executor/layers/fused_moe/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  447. vllm/model_executor/layers/fused_moe/configs/E=16,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  448. vllm/model_executor/layers/fused_moe/configs/E=16,N=6400,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  449. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  450. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  451. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=float8.json +146 -0
  452. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  453. vllm/model_executor/layers/fused_moe/configs/E=16,N=800,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  454. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=AMD_Instinct_MI300X.json +201 -0
  455. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=AMD_Instinct_MI350_OAM,dtype=fp8_w8a8.json +164 -0
  456. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  457. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=NVIDIA_H20-3e.json +146 -0
  458. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +147 -0
  459. vllm/model_executor/layers/fused_moe/configs/E=160,N=320,device_name=NVIDIA_H20-3e.json +146 -0
  460. vllm/model_executor/layers/fused_moe/configs/E=160,N=384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  461. vllm/model_executor/layers/fused_moe/configs/E=160,N=384,device_name=AMD_Instinct_MI350_OAM,dtype=fp8_w8a8.json +164 -0
  462. vllm/model_executor/layers/fused_moe/configs/E=160,N=384,device_name=AMD_Instinct_MI355_OAM,dtype=fp8_w8a8.json +164 -0
  463. vllm/model_executor/layers/fused_moe/configs/E=160,N=640,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  464. vllm/model_executor/layers/fused_moe/configs/E=160,N=640,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  465. vllm/model_executor/layers/fused_moe/configs/E=160,N=640,device_name=NVIDIA_H100,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  466. vllm/model_executor/layers/fused_moe/configs/E=20,N=1536,device_name=NVIDIA_RTX_PRO_6000_Blackwell_Server_Edition,dtype=fp8_w8a8.json +147 -0
  467. vllm/model_executor/layers/fused_moe/configs/E=20,N=2560,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  468. vllm/model_executor/layers/fused_moe/configs/E=20,N=2560,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  469. vllm/model_executor/layers/fused_moe/configs/E=20,N=2560,device_name=NVIDIA_H100,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  470. vllm/model_executor/layers/fused_moe/configs/E=20,N=2560,device_name=NVIDIA_H20-3e,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  471. vllm/model_executor/layers/fused_moe/configs/E=256,N=1024,device_name=AMD_Instinct_MI325X,block_shape=[128,128].json +200 -0
  472. vllm/model_executor/layers/fused_moe/configs/E=256,N=1024,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  473. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  474. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8.json +146 -0
  475. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  476. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json +146 -0
  477. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  478. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  479. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  480. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  481. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  482. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  483. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  484. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  485. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  486. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H20-3e,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  487. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  488. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  489. vllm/model_executor/layers/fused_moe/configs/E=256,N=384,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +147 -0
  490. vllm/model_executor/layers/fused_moe/configs/E=256,N=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  491. vllm/model_executor/layers/fused_moe/configs/E=256,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  492. vllm/model_executor/layers/fused_moe/configs/E=256,N=64,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  493. vllm/model_executor/layers/fused_moe/configs/E=32,N=1408,device_name=NVIDIA_B200.json +147 -0
  494. vllm/model_executor/layers/fused_moe/configs/E=32,N=2048,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +147 -0
  495. vllm/model_executor/layers/fused_moe/configs/E=32,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +147 -0
  496. vllm/model_executor/layers/fused_moe/configs/E=384,N=128,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  497. vllm/model_executor/layers/fused_moe/configs/E=384,N=128,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  498. vllm/model_executor/layers/fused_moe/configs/E=384,N=128,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  499. vllm/model_executor/layers/fused_moe/configs/E=384,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  500. vllm/model_executor/layers/fused_moe/configs/E=384,N=256,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  501. vllm/model_executor/layers/fused_moe/configs/E=40,N=1536,device_name=NVIDIA_B200,dtype=fp8_w8a8.json +147 -0
  502. vllm/model_executor/layers/fused_moe/configs/E=40,N=2560,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  503. vllm/model_executor/layers/fused_moe/configs/E=40,N=2560,device_name=NVIDIA_GB200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  504. vllm/model_executor/layers/fused_moe/configs/E=40,N=2560,device_name=NVIDIA_H100,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  505. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_A100-SXM4-80GB.json +147 -0
  506. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_B200.json +146 -0
  507. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_GB200,dtype=fp8_w8a8.json +147 -0
  508. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  509. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_H20-3e.json +146 -0
  510. vllm/model_executor/layers/fused_moe/configs/E=512,N=128,device_name=NVIDIA_H200.json +146 -0
  511. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_B200.json +146 -0
  512. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_GB200,dtype=fp8_w8a8.json +146 -0
  513. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +147 -0
  514. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  515. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_H20-3e.json +146 -0
  516. vllm/model_executor/layers/fused_moe/configs/E=512,N=256,device_name=NVIDIA_H200.json +146 -0
  517. vllm/model_executor/layers/fused_moe/configs/E=512,N=512,device_name=NVIDIA_B200.json +146 -0
  518. vllm/model_executor/layers/fused_moe/configs/E=512,N=512,device_name=NVIDIA_GB200,dtype=fp8_w8a8.json +146 -0
  519. vllm/model_executor/layers/fused_moe/configs/E=512,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  520. vllm/model_executor/layers/fused_moe/configs/E=512,N=512,device_name=NVIDIA_H20-3e.json +146 -0
  521. vllm/model_executor/layers/fused_moe/configs/E=512,N=512,device_name=NVIDIA_H200.json +146 -0
  522. vllm/model_executor/layers/fused_moe/configs/E=512,N=64,device_name=NVIDIA_A100-SXM4-80GB.json +147 -0
  523. vllm/model_executor/layers/fused_moe/configs/E=512,N=64,device_name=NVIDIA_B200.json +146 -0
  524. vllm/model_executor/layers/fused_moe/configs/E=512,N=64,device_name=NVIDIA_H20-3e.json +146 -0
  525. vllm/model_executor/layers/fused_moe/configs/E=512,N=64,device_name=NVIDIA_H200.json +146 -0
  526. vllm/model_executor/layers/fused_moe/configs/E=60,N=1408,device_name=AMD_Instinct_MI300X.json +200 -0
  527. vllm/model_executor/layers/fused_moe/configs/E=60,N=176,device_name=AMD_Instinct_MI300X.json +200 -0
  528. vllm/model_executor/layers/fused_moe/configs/E=60,N=352,device_name=AMD_Instinct_MI300X.json +200 -0
  529. vllm/model_executor/layers/fused_moe/configs/E=60,N=704,device_name=AMD_Instinct_MI300X.json +200 -0
  530. vllm/model_executor/layers/fused_moe/configs/E=62,N=128,device_name=AMD_Instinct_MI300X.json +200 -0
  531. vllm/model_executor/layers/fused_moe/configs/E=62,N=256,device_name=AMD_Instinct_MI300X.json +200 -0
  532. vllm/model_executor/layers/fused_moe/configs/E=62,N=256,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  533. vllm/model_executor/layers/fused_moe/configs/E=62,N=512,device_name=AMD_Instinct_MI300X.json +200 -0
  534. vllm/model_executor/layers/fused_moe/configs/E=62,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  535. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  536. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  537. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  538. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  539. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  540. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H200.json +146 -0
  541. vllm/model_executor/layers/fused_moe/configs/E=64,N=1408,device_name=NVIDIA_B200.json +147 -0
  542. vllm/model_executor/layers/fused_moe/configs/E=64,N=1536,device_name=NVIDIA_H20,dtype=fp8_w8a8.json +146 -0
  543. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  544. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  545. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H200.json +146 -0
  546. vllm/model_executor/layers/fused_moe/configs/E=64,N=3072,device_name=NVIDIA_H20,dtype=fp8_w8a8.json +146 -0
  547. vllm/model_executor/layers/fused_moe/configs/E=64,N=3072,device_name=NVIDIA_H20.json +146 -0
  548. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  549. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  550. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  551. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H200.json +146 -0
  552. vllm/model_executor/layers/fused_moe/configs/E=64,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8.json +146 -0
  553. vllm/model_executor/layers/fused_moe/configs/E=64,N=384,device_name=NVIDIA_H20.json +146 -0
  554. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  555. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  556. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +146 -0
  557. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  558. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  559. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  560. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H200.json +146 -0
  561. vllm/model_executor/layers/fused_moe/configs/E=64,N=768,device_name=NVIDIA_H100_PCIe,dtype=fp8_w8a8,block_shape=[128,128].json +147 -0
  562. vllm/model_executor/layers/fused_moe/configs/E=64,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8.json +146 -0
  563. vllm/model_executor/layers/fused_moe/configs/E=64,N=768,device_name=NVIDIA_H20.json +146 -0
  564. vllm/model_executor/layers/fused_moe/configs/E=64,N=896,device_name=NVIDIA_H20.json +146 -0
  565. vllm/model_executor/layers/fused_moe/configs/E=64,N=8960,device_name=NVIDIA_H100_80GB_HBM3,dtype=bf16.json +82 -0
  566. vllm/model_executor/layers/fused_moe/configs/E=64,N=8960,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +82 -0
  567. vllm/model_executor/layers/fused_moe/configs/E=72,N=192,device_name=AMD_Instinct_MI300X.json +200 -0
  568. vllm/model_executor/layers/fused_moe/configs/E=72,N=384,device_name=AMD_Instinct_MI300X.json +200 -0
  569. vllm/model_executor/layers/fused_moe/configs/E=72,N=384,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  570. vllm/model_executor/layers/fused_moe/configs/E=72,N=768,device_name=AMD_Instinct_MI300X.json +200 -0
  571. vllm/model_executor/layers/fused_moe/configs/E=72,N=768,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  572. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  573. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI300X.json +200 -0
  574. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  575. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI325X.json +200 -0
  576. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +138 -0
  577. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  578. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H200.json +146 -0
  579. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  580. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI300X.json +200 -0
  581. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  582. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI325X.json +200 -0
  583. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  584. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI300X.json +200 -0
  585. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  586. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI325X.json +200 -0
  587. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  588. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  589. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  590. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  591. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H200.json +146 -0
  592. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  593. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI300X.json +200 -0
  594. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  595. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI325X.json +200 -0
  596. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  597. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  598. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  599. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +154 -0
  600. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  601. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H200.json +146 -0
  602. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  603. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI300X.json +200 -0
  604. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  605. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI325X.json +200 -0
  606. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  607. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  608. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +146 -0
  609. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  610. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  611. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  612. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H200.json +146 -0
  613. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_L40S.json +173 -0
  614. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  615. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI300X.json +200 -0
  616. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  617. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI325X.json +200 -0
  618. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  619. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  620. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  621. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  622. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H200.json +146 -0
  623. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  624. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI300X.json +200 -0
  625. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  626. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI325X.json +200 -0
  627. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  628. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  629. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  630. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  631. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H200.json +146 -0
  632. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  633. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI300X.json +200 -0
  634. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  635. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI325X.json +200 -0
  636. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  637. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  638. vllm/model_executor/layers/fused_moe/configs/README +12 -0
  639. vllm/model_executor/layers/fused_moe/cpu_fused_moe.py +292 -0
  640. vllm/model_executor/layers/fused_moe/cutlass_moe.py +1453 -0
  641. vllm/model_executor/layers/fused_moe/deep_gemm_moe.py +358 -0
  642. vllm/model_executor/layers/fused_moe/deep_gemm_utils.py +427 -0
  643. vllm/model_executor/layers/fused_moe/deepep_ht_prepare_finalize.py +420 -0
  644. vllm/model_executor/layers/fused_moe/deepep_ll_prepare_finalize.py +434 -0
  645. vllm/model_executor/layers/fused_moe/flashinfer_cutedsl_moe.py +376 -0
  646. vllm/model_executor/layers/fused_moe/flashinfer_cutlass_moe.py +307 -0
  647. vllm/model_executor/layers/fused_moe/flashinfer_cutlass_prepare_finalize.py +362 -0
  648. vllm/model_executor/layers/fused_moe/flashinfer_trtllm_moe.py +192 -0
  649. vllm/model_executor/layers/fused_moe/fused_batched_moe.py +1012 -0
  650. vllm/model_executor/layers/fused_moe/fused_marlin_moe.py +825 -0
  651. vllm/model_executor/layers/fused_moe/fused_moe.py +2223 -0
  652. vllm/model_executor/layers/fused_moe/fused_moe_method_base.py +103 -0
  653. vllm/model_executor/layers/fused_moe/fused_moe_modular_method.py +119 -0
  654. vllm/model_executor/layers/fused_moe/gpt_oss_triton_kernels_moe.py +524 -0
  655. vllm/model_executor/layers/fused_moe/layer.py +2133 -0
  656. vllm/model_executor/layers/fused_moe/modular_kernel.py +1302 -0
  657. vllm/model_executor/layers/fused_moe/moe_align_block_size.py +192 -0
  658. vllm/model_executor/layers/fused_moe/moe_pallas.py +83 -0
  659. vllm/model_executor/layers/fused_moe/moe_permute_unpermute.py +229 -0
  660. vllm/model_executor/layers/fused_moe/moe_torch_iterative.py +60 -0
  661. vllm/model_executor/layers/fused_moe/pplx_prepare_finalize.py +362 -0
  662. vllm/model_executor/layers/fused_moe/prepare_finalize.py +78 -0
  663. vllm/model_executor/layers/fused_moe/rocm_aiter_fused_moe.py +265 -0
  664. vllm/model_executor/layers/fused_moe/routing_simulator.py +310 -0
  665. vllm/model_executor/layers/fused_moe/shared_fused_moe.py +96 -0
  666. vllm/model_executor/layers/fused_moe/topk_weight_and_reduce.py +171 -0
  667. vllm/model_executor/layers/fused_moe/triton_deep_gemm_moe.py +163 -0
  668. vllm/model_executor/layers/fused_moe/trtllm_moe.py +143 -0
  669. vllm/model_executor/layers/fused_moe/unquantized_fused_moe_method.py +455 -0
  670. vllm/model_executor/layers/fused_moe/utils.py +332 -0
  671. vllm/model_executor/layers/kda.py +442 -0
  672. vllm/model_executor/layers/layernorm.py +442 -0
  673. vllm/model_executor/layers/lightning_attn.py +735 -0
  674. vllm/model_executor/layers/linear.py +1424 -0
  675. vllm/model_executor/layers/logits_processor.py +106 -0
  676. vllm/model_executor/layers/mamba/__init__.py +0 -0
  677. vllm/model_executor/layers/mamba/abstract.py +68 -0
  678. vllm/model_executor/layers/mamba/linear_attn.py +388 -0
  679. vllm/model_executor/layers/mamba/mamba_mixer.py +526 -0
  680. vllm/model_executor/layers/mamba/mamba_mixer2.py +930 -0
  681. vllm/model_executor/layers/mamba/mamba_utils.py +225 -0
  682. vllm/model_executor/layers/mamba/ops/__init__.py +0 -0
  683. vllm/model_executor/layers/mamba/ops/causal_conv1d.py +1240 -0
  684. vllm/model_executor/layers/mamba/ops/layernorm_gated.py +172 -0
  685. vllm/model_executor/layers/mamba/ops/mamba_ssm.py +586 -0
  686. vllm/model_executor/layers/mamba/ops/ssd_bmm.py +211 -0
  687. vllm/model_executor/layers/mamba/ops/ssd_chunk_scan.py +456 -0
  688. vllm/model_executor/layers/mamba/ops/ssd_chunk_state.py +700 -0
  689. vllm/model_executor/layers/mamba/ops/ssd_combined.py +230 -0
  690. vllm/model_executor/layers/mamba/ops/ssd_state_passing.py +157 -0
  691. vllm/model_executor/layers/mamba/short_conv.py +255 -0
  692. vllm/model_executor/layers/mla.py +176 -0
  693. vllm/model_executor/layers/pooler.py +830 -0
  694. vllm/model_executor/layers/quantization/__init__.py +179 -0
  695. vllm/model_executor/layers/quantization/auto_round.py +454 -0
  696. vllm/model_executor/layers/quantization/awq.py +277 -0
  697. vllm/model_executor/layers/quantization/awq_marlin.py +793 -0
  698. vllm/model_executor/layers/quantization/awq_triton.py +337 -0
  699. vllm/model_executor/layers/quantization/base_config.py +170 -0
  700. vllm/model_executor/layers/quantization/bitblas.py +502 -0
  701. vllm/model_executor/layers/quantization/bitsandbytes.py +626 -0
  702. vllm/model_executor/layers/quantization/compressed_tensors/__init__.py +3 -0
  703. vllm/model_executor/layers/quantization/compressed_tensors/compressed_tensors.py +986 -0
  704. vllm/model_executor/layers/quantization/compressed_tensors/compressed_tensors_moe.py +2645 -0
  705. vllm/model_executor/layers/quantization/compressed_tensors/schemes/__init__.py +35 -0
  706. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_24.py +392 -0
  707. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_scheme.py +55 -0
  708. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a16_24.py +176 -0
  709. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a16_nvfp4.py +124 -0
  710. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a4_nvfp4.py +218 -0
  711. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a8_fp8.py +176 -0
  712. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a8_int.py +153 -0
  713. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a16_fp8.py +138 -0
  714. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a8_fp8.py +200 -0
  715. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a8_int8.py +125 -0
  716. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_wNa16.py +230 -0
  717. vllm/model_executor/layers/quantization/compressed_tensors/transform/__init__.py +0 -0
  718. vllm/model_executor/layers/quantization/compressed_tensors/transform/linear.py +260 -0
  719. vllm/model_executor/layers/quantization/compressed_tensors/transform/module.py +173 -0
  720. vllm/model_executor/layers/quantization/compressed_tensors/transform/schemes/__init__.py +0 -0
  721. vllm/model_executor/layers/quantization/compressed_tensors/transform/schemes/linear_qutlass_nvfp4.py +64 -0
  722. vllm/model_executor/layers/quantization/compressed_tensors/transform/utils.py +13 -0
  723. vllm/model_executor/layers/quantization/compressed_tensors/triton_scaled_mm.py +224 -0
  724. vllm/model_executor/layers/quantization/compressed_tensors/utils.py +216 -0
  725. vllm/model_executor/layers/quantization/cpu_wna16.py +625 -0
  726. vllm/model_executor/layers/quantization/deepspeedfp.py +218 -0
  727. vllm/model_executor/layers/quantization/experts_int8.py +207 -0
  728. vllm/model_executor/layers/quantization/fbgemm_fp8.py +195 -0
  729. vllm/model_executor/layers/quantization/fp8.py +1461 -0
  730. vllm/model_executor/layers/quantization/fp_quant.py +420 -0
  731. vllm/model_executor/layers/quantization/gguf.py +677 -0
  732. vllm/model_executor/layers/quantization/gptq.py +393 -0
  733. vllm/model_executor/layers/quantization/gptq_bitblas.py +482 -0
  734. vllm/model_executor/layers/quantization/gptq_marlin.py +932 -0
  735. vllm/model_executor/layers/quantization/gptq_marlin_24.py +320 -0
  736. vllm/model_executor/layers/quantization/hqq_marlin.py +372 -0
  737. vllm/model_executor/layers/quantization/inc.py +65 -0
  738. vllm/model_executor/layers/quantization/input_quant_fp8.py +202 -0
  739. vllm/model_executor/layers/quantization/ipex_quant.py +487 -0
  740. vllm/model_executor/layers/quantization/kernels/__init__.py +0 -0
  741. vllm/model_executor/layers/quantization/kernels/mixed_precision/MPLinearKernel.py +94 -0
  742. vllm/model_executor/layers/quantization/kernels/mixed_precision/__init__.py +109 -0
  743. vllm/model_executor/layers/quantization/kernels/mixed_precision/allspark.py +115 -0
  744. vllm/model_executor/layers/quantization/kernels/mixed_precision/bitblas.py +323 -0
  745. vllm/model_executor/layers/quantization/kernels/mixed_precision/conch.py +98 -0
  746. vllm/model_executor/layers/quantization/kernels/mixed_precision/cutlass.py +130 -0
  747. vllm/model_executor/layers/quantization/kernels/mixed_precision/dynamic_4bit.py +111 -0
  748. vllm/model_executor/layers/quantization/kernels/mixed_precision/exllama.py +161 -0
  749. vllm/model_executor/layers/quantization/kernels/mixed_precision/machete.py +159 -0
  750. vllm/model_executor/layers/quantization/kernels/mixed_precision/marlin.py +200 -0
  751. vllm/model_executor/layers/quantization/kernels/mixed_precision/xpu.py +97 -0
  752. vllm/model_executor/layers/quantization/kernels/scaled_mm/ScaledMMLinearKernel.py +76 -0
  753. vllm/model_executor/layers/quantization/kernels/scaled_mm/__init__.py +81 -0
  754. vllm/model_executor/layers/quantization/kernels/scaled_mm/aiter.py +128 -0
  755. vllm/model_executor/layers/quantization/kernels/scaled_mm/cpu.py +220 -0
  756. vllm/model_executor/layers/quantization/kernels/scaled_mm/cutlass.py +147 -0
  757. vllm/model_executor/layers/quantization/kernels/scaled_mm/triton.py +71 -0
  758. vllm/model_executor/layers/quantization/kernels/scaled_mm/xla.py +106 -0
  759. vllm/model_executor/layers/quantization/kv_cache.py +153 -0
  760. vllm/model_executor/layers/quantization/modelopt.py +1684 -0
  761. vllm/model_executor/layers/quantization/moe_wna16.py +516 -0
  762. vllm/model_executor/layers/quantization/mxfp4.py +1140 -0
  763. vllm/model_executor/layers/quantization/petit.py +319 -0
  764. vllm/model_executor/layers/quantization/ptpc_fp8.py +136 -0
  765. vllm/model_executor/layers/quantization/quark/__init__.py +0 -0
  766. vllm/model_executor/layers/quantization/quark/quark.py +527 -0
  767. vllm/model_executor/layers/quantization/quark/quark_moe.py +622 -0
  768. vllm/model_executor/layers/quantization/quark/schemes/__init__.py +9 -0
  769. vllm/model_executor/layers/quantization/quark/schemes/quark_ocp_mx.py +343 -0
  770. vllm/model_executor/layers/quantization/quark/schemes/quark_scheme.py +55 -0
  771. vllm/model_executor/layers/quantization/quark/schemes/quark_w8a8_fp8.py +179 -0
  772. vllm/model_executor/layers/quantization/quark/schemes/quark_w8a8_int8.py +139 -0
  773. vllm/model_executor/layers/quantization/quark/utils.py +105 -0
  774. vllm/model_executor/layers/quantization/qutlass_utils.py +185 -0
  775. vllm/model_executor/layers/quantization/rtn.py +621 -0
  776. vllm/model_executor/layers/quantization/schema.py +90 -0
  777. vllm/model_executor/layers/quantization/torchao.py +380 -0
  778. vllm/model_executor/layers/quantization/tpu_int8.py +139 -0
  779. vllm/model_executor/layers/quantization/utils/__init__.py +6 -0
  780. vllm/model_executor/layers/quantization/utils/allspark_utils.py +67 -0
  781. vllm/model_executor/layers/quantization/utils/bitblas_utils.py +229 -0
  782. vllm/model_executor/layers/quantization/utils/configs/N=10240,K=5120,device_name=NVIDIA_L40S,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  783. vllm/model_executor/layers/quantization/utils/configs/N=12288,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  784. vllm/model_executor/layers/quantization/utils/configs/N=12288,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  785. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  786. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  787. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  788. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  789. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  790. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  791. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  792. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  793. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  794. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  795. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  796. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  797. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  798. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  799. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  800. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  801. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  802. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  803. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  804. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  805. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  806. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  807. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  808. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  809. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  810. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  811. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  812. vllm/model_executor/layers/quantization/utils/configs/N=2112,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  813. vllm/model_executor/layers/quantization/utils/configs/N=2112,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  814. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  815. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  816. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  817. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  818. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  819. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  820. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  821. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  822. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  823. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=1536,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  824. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=1536,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  825. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  826. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  827. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  828. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  829. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  830. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  831. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  832. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  833. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  834. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  835. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  836. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  837. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  838. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  839. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  840. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  841. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  842. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  843. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  844. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  845. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  846. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  847. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  848. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  849. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  850. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  851. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  852. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  853. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  854. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  855. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  856. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  857. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  858. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  859. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  860. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  861. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  862. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  863. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  864. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  865. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  866. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  867. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  868. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  869. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  870. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  871. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  872. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  873. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  874. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  875. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  876. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  877. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  878. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  879. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  880. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  881. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  882. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  883. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  884. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  885. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  886. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  887. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  888. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  889. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  890. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  891. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  892. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  893. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  894. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  895. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  896. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  897. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  898. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  899. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  900. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  901. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  902. vllm/model_executor/layers/quantization/utils/configs/N=5120,K=25600,device_name=NVIDIA_L40S,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  903. vllm/model_executor/layers/quantization/utils/configs/N=5120,K=8192,device_name=NVIDIA_L40S,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  904. vllm/model_executor/layers/quantization/utils/configs/N=51200,K=5120,device_name=NVIDIA_L40S,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  905. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  906. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  907. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  908. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  909. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  910. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  911. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  912. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  913. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  914. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  915. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +18 -0
  916. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  917. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  918. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  919. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  920. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  921. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  922. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  923. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  924. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  925. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  926. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  927. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  928. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  929. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  930. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  931. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  932. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  933. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  934. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  935. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  936. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  937. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  938. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  939. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  940. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  941. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  942. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  943. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  944. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  945. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  946. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  947. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  948. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  949. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  950. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  951. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  952. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  953. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  954. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  955. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  956. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  957. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  958. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  959. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  960. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  961. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  962. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  963. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  964. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  965. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  966. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  967. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  968. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  969. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  970. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  971. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  972. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  973. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  974. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  975. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  976. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  977. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  978. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  979. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  980. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  981. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  982. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  983. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  984. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  985. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  986. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  987. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  988. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  989. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  990. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  991. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  992. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  993. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  994. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  995. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  996. vllm/model_executor/layers/quantization/utils/configs/README.md +3 -0
  997. vllm/model_executor/layers/quantization/utils/flashinfer_fp4_moe.py +412 -0
  998. vllm/model_executor/layers/quantization/utils/flashinfer_utils.py +312 -0
  999. vllm/model_executor/layers/quantization/utils/fp8_utils.py +1453 -0
  1000. vllm/model_executor/layers/quantization/utils/gptq_utils.py +158 -0
  1001. vllm/model_executor/layers/quantization/utils/int8_utils.py +474 -0
  1002. vllm/model_executor/layers/quantization/utils/layer_utils.py +41 -0
  1003. vllm/model_executor/layers/quantization/utils/machete_utils.py +56 -0
  1004. vllm/model_executor/layers/quantization/utils/marlin_utils.py +678 -0
  1005. vllm/model_executor/layers/quantization/utils/marlin_utils_fp4.py +452 -0
  1006. vllm/model_executor/layers/quantization/utils/marlin_utils_fp8.py +381 -0
  1007. vllm/model_executor/layers/quantization/utils/marlin_utils_test.py +219 -0
  1008. vllm/model_executor/layers/quantization/utils/marlin_utils_test_24.py +467 -0
  1009. vllm/model_executor/layers/quantization/utils/mxfp4_utils.py +189 -0
  1010. vllm/model_executor/layers/quantization/utils/mxfp6_utils.py +142 -0
  1011. vllm/model_executor/layers/quantization/utils/mxfp8_utils.py +24 -0
  1012. vllm/model_executor/layers/quantization/utils/nvfp4_emulation_utils.py +142 -0
  1013. vllm/model_executor/layers/quantization/utils/nvfp4_moe_support.py +67 -0
  1014. vllm/model_executor/layers/quantization/utils/ocp_mx_utils.py +51 -0
  1015. vllm/model_executor/layers/quantization/utils/petit_utils.py +124 -0
  1016. vllm/model_executor/layers/quantization/utils/quant_utils.py +741 -0
  1017. vllm/model_executor/layers/quantization/utils/w8a8_utils.py +519 -0
  1018. vllm/model_executor/layers/resampler.py +283 -0
  1019. vllm/model_executor/layers/rotary_embedding/__init__.py +289 -0
  1020. vllm/model_executor/layers/rotary_embedding/base.py +254 -0
  1021. vllm/model_executor/layers/rotary_embedding/common.py +279 -0
  1022. vllm/model_executor/layers/rotary_embedding/deepseek_scaling_rope.py +165 -0
  1023. vllm/model_executor/layers/rotary_embedding/dual_chunk_rope.py +215 -0
  1024. vllm/model_executor/layers/rotary_embedding/dynamic_ntk_alpha_rope.py +43 -0
  1025. vllm/model_executor/layers/rotary_embedding/dynamic_ntk_scaling_rope.py +68 -0
  1026. vllm/model_executor/layers/rotary_embedding/ernie45_vl_rope.py +82 -0
  1027. vllm/model_executor/layers/rotary_embedding/linear_scaling_rope.py +115 -0
  1028. vllm/model_executor/layers/rotary_embedding/llama3_rope.py +54 -0
  1029. vllm/model_executor/layers/rotary_embedding/llama4_vision_rope.py +80 -0
  1030. vllm/model_executor/layers/rotary_embedding/mrope.py +412 -0
  1031. vllm/model_executor/layers/rotary_embedding/ntk_scaling_rope.py +47 -0
  1032. vllm/model_executor/layers/rotary_embedding/phi3_long_rope_scaled_rope.py +159 -0
  1033. vllm/model_executor/layers/rotary_embedding/xdrope.py +160 -0
  1034. vllm/model_executor/layers/rotary_embedding/yarn_scaling_rope.py +84 -0
  1035. vllm/model_executor/layers/utils.py +251 -0
  1036. vllm/model_executor/layers/vocab_parallel_embedding.py +558 -0
  1037. vllm/model_executor/model_loader/__init__.py +150 -0
  1038. vllm/model_executor/model_loader/base_loader.py +57 -0
  1039. vllm/model_executor/model_loader/bitsandbytes_loader.py +822 -0
  1040. vllm/model_executor/model_loader/default_loader.py +321 -0
  1041. vllm/model_executor/model_loader/dummy_loader.py +28 -0
  1042. vllm/model_executor/model_loader/gguf_loader.py +371 -0
  1043. vllm/model_executor/model_loader/online_quantization.py +275 -0
  1044. vllm/model_executor/model_loader/runai_streamer_loader.py +116 -0
  1045. vllm/model_executor/model_loader/sharded_state_loader.py +214 -0
  1046. vllm/model_executor/model_loader/tensorizer.py +790 -0
  1047. vllm/model_executor/model_loader/tensorizer_loader.py +151 -0
  1048. vllm/model_executor/model_loader/tpu.py +118 -0
  1049. vllm/model_executor/model_loader/utils.py +292 -0
  1050. vllm/model_executor/model_loader/weight_utils.py +1157 -0
  1051. vllm/model_executor/models/__init__.py +44 -0
  1052. vllm/model_executor/models/adapters.py +522 -0
  1053. vllm/model_executor/models/afmoe.py +696 -0
  1054. vllm/model_executor/models/aimv2.py +248 -0
  1055. vllm/model_executor/models/apertus.py +565 -0
  1056. vllm/model_executor/models/arcee.py +428 -0
  1057. vllm/model_executor/models/arctic.py +633 -0
  1058. vllm/model_executor/models/aria.py +653 -0
  1059. vllm/model_executor/models/audioflamingo3.py +639 -0
  1060. vllm/model_executor/models/aya_vision.py +448 -0
  1061. vllm/model_executor/models/bagel.py +584 -0
  1062. vllm/model_executor/models/baichuan.py +493 -0
  1063. vllm/model_executor/models/bailing_moe.py +642 -0
  1064. vllm/model_executor/models/bamba.py +511 -0
  1065. vllm/model_executor/models/bee.py +157 -0
  1066. vllm/model_executor/models/bert.py +925 -0
  1067. vllm/model_executor/models/bert_with_rope.py +732 -0
  1068. vllm/model_executor/models/blip.py +350 -0
  1069. vllm/model_executor/models/blip2.py +693 -0
  1070. vllm/model_executor/models/bloom.py +390 -0
  1071. vllm/model_executor/models/chameleon.py +1095 -0
  1072. vllm/model_executor/models/chatglm.py +502 -0
  1073. vllm/model_executor/models/clip.py +1004 -0
  1074. vllm/model_executor/models/cohere2_vision.py +470 -0
  1075. vllm/model_executor/models/commandr.py +469 -0
  1076. vllm/model_executor/models/config.py +531 -0
  1077. vllm/model_executor/models/dbrx.py +484 -0
  1078. vllm/model_executor/models/deepencoder.py +676 -0
  1079. vllm/model_executor/models/deepseek_eagle.py +252 -0
  1080. vllm/model_executor/models/deepseek_mtp.py +446 -0
  1081. vllm/model_executor/models/deepseek_ocr.py +591 -0
  1082. vllm/model_executor/models/deepseek_v2.py +1710 -0
  1083. vllm/model_executor/models/deepseek_vl2.py +642 -0
  1084. vllm/model_executor/models/dots1.py +565 -0
  1085. vllm/model_executor/models/dots_ocr.py +821 -0
  1086. vllm/model_executor/models/ernie45.py +53 -0
  1087. vllm/model_executor/models/ernie45_moe.py +754 -0
  1088. vllm/model_executor/models/ernie45_vl.py +1621 -0
  1089. vllm/model_executor/models/ernie45_vl_moe.py +800 -0
  1090. vllm/model_executor/models/ernie_mtp.py +279 -0
  1091. vllm/model_executor/models/exaone.py +524 -0
  1092. vllm/model_executor/models/exaone4.py +516 -0
  1093. vllm/model_executor/models/fairseq2_llama.py +154 -0
  1094. vllm/model_executor/models/falcon.py +543 -0
  1095. vllm/model_executor/models/falcon_h1.py +675 -0
  1096. vllm/model_executor/models/flex_olmo.py +155 -0
  1097. vllm/model_executor/models/fuyu.py +371 -0
  1098. vllm/model_executor/models/gemma.py +425 -0
  1099. vllm/model_executor/models/gemma2.py +435 -0
  1100. vllm/model_executor/models/gemma3.py +507 -0
  1101. vllm/model_executor/models/gemma3_mm.py +664 -0
  1102. vllm/model_executor/models/gemma3n.py +1166 -0
  1103. vllm/model_executor/models/gemma3n_mm.py +810 -0
  1104. vllm/model_executor/models/glm.py +24 -0
  1105. vllm/model_executor/models/glm4.py +295 -0
  1106. vllm/model_executor/models/glm4_1v.py +1808 -0
  1107. vllm/model_executor/models/glm4_moe.py +736 -0
  1108. vllm/model_executor/models/glm4_moe_mtp.py +359 -0
  1109. vllm/model_executor/models/glm4v.py +783 -0
  1110. vllm/model_executor/models/gpt2.py +397 -0
  1111. vllm/model_executor/models/gpt_bigcode.py +339 -0
  1112. vllm/model_executor/models/gpt_j.py +346 -0
  1113. vllm/model_executor/models/gpt_neox.py +340 -0
  1114. vllm/model_executor/models/gpt_oss.py +744 -0
  1115. vllm/model_executor/models/granite.py +475 -0
  1116. vllm/model_executor/models/granite_speech.py +912 -0
  1117. vllm/model_executor/models/granitemoe.py +560 -0
  1118. vllm/model_executor/models/granitemoehybrid.py +703 -0
  1119. vllm/model_executor/models/granitemoeshared.py +328 -0
  1120. vllm/model_executor/models/gritlm.py +243 -0
  1121. vllm/model_executor/models/grok1.py +554 -0
  1122. vllm/model_executor/models/h2ovl.py +554 -0
  1123. vllm/model_executor/models/hunyuan_v1.py +1040 -0
  1124. vllm/model_executor/models/hunyuan_vision.py +1034 -0
  1125. vllm/model_executor/models/hyperclovax_vision.py +1164 -0
  1126. vllm/model_executor/models/idefics2_vision_model.py +427 -0
  1127. vllm/model_executor/models/idefics3.py +716 -0
  1128. vllm/model_executor/models/interfaces.py +1179 -0
  1129. vllm/model_executor/models/interfaces_base.py +228 -0
  1130. vllm/model_executor/models/intern_vit.py +454 -0
  1131. vllm/model_executor/models/internlm2.py +453 -0
  1132. vllm/model_executor/models/internlm2_ve.py +139 -0
  1133. vllm/model_executor/models/interns1.py +828 -0
  1134. vllm/model_executor/models/interns1_vit.py +433 -0
  1135. vllm/model_executor/models/internvl.py +1450 -0
  1136. vllm/model_executor/models/jais.py +397 -0
  1137. vllm/model_executor/models/jais2.py +529 -0
  1138. vllm/model_executor/models/jamba.py +609 -0
  1139. vllm/model_executor/models/jina_vl.py +147 -0
  1140. vllm/model_executor/models/keye.py +1706 -0
  1141. vllm/model_executor/models/keye_vl1_5.py +726 -0
  1142. vllm/model_executor/models/kimi_linear.py +658 -0
  1143. vllm/model_executor/models/kimi_vl.py +576 -0
  1144. vllm/model_executor/models/lfm2.py +515 -0
  1145. vllm/model_executor/models/lfm2_moe.py +745 -0
  1146. vllm/model_executor/models/lightonocr.py +195 -0
  1147. vllm/model_executor/models/llama.py +700 -0
  1148. vllm/model_executor/models/llama4.py +856 -0
  1149. vllm/model_executor/models/llama4_eagle.py +225 -0
  1150. vllm/model_executor/models/llama_eagle.py +213 -0
  1151. vllm/model_executor/models/llama_eagle3.py +375 -0
  1152. vllm/model_executor/models/llava.py +840 -0
  1153. vllm/model_executor/models/llava_next.py +581 -0
  1154. vllm/model_executor/models/llava_next_video.py +465 -0
  1155. vllm/model_executor/models/llava_onevision.py +921 -0
  1156. vllm/model_executor/models/longcat_flash.py +743 -0
  1157. vllm/model_executor/models/longcat_flash_mtp.py +349 -0
  1158. vllm/model_executor/models/mamba.py +276 -0
  1159. vllm/model_executor/models/mamba2.py +288 -0
  1160. vllm/model_executor/models/medusa.py +179 -0
  1161. vllm/model_executor/models/midashenglm.py +826 -0
  1162. vllm/model_executor/models/mimo.py +188 -0
  1163. vllm/model_executor/models/mimo_mtp.py +294 -0
  1164. vllm/model_executor/models/minicpm.py +656 -0
  1165. vllm/model_executor/models/minicpm3.py +233 -0
  1166. vllm/model_executor/models/minicpm_eagle.py +385 -0
  1167. vllm/model_executor/models/minicpmo.py +768 -0
  1168. vllm/model_executor/models/minicpmv.py +1742 -0
  1169. vllm/model_executor/models/minimax_m2.py +550 -0
  1170. vllm/model_executor/models/minimax_text_01.py +1007 -0
  1171. vllm/model_executor/models/minimax_vl_01.py +394 -0
  1172. vllm/model_executor/models/mistral3.py +635 -0
  1173. vllm/model_executor/models/mistral_large_3.py +63 -0
  1174. vllm/model_executor/models/mistral_large_3_eagle.py +136 -0
  1175. vllm/model_executor/models/mixtral.py +598 -0
  1176. vllm/model_executor/models/mllama4.py +1149 -0
  1177. vllm/model_executor/models/mlp_speculator.py +235 -0
  1178. vllm/model_executor/models/modernbert.py +451 -0
  1179. vllm/model_executor/models/module_mapping.py +74 -0
  1180. vllm/model_executor/models/molmo.py +1550 -0
  1181. vllm/model_executor/models/moonvit.py +686 -0
  1182. vllm/model_executor/models/mpt.py +335 -0
  1183. vllm/model_executor/models/nano_nemotron_vl.py +1730 -0
  1184. vllm/model_executor/models/nemotron.py +499 -0
  1185. vllm/model_executor/models/nemotron_h.py +900 -0
  1186. vllm/model_executor/models/nemotron_nas.py +471 -0
  1187. vllm/model_executor/models/nemotron_vl.py +651 -0
  1188. vllm/model_executor/models/nvlm_d.py +216 -0
  1189. vllm/model_executor/models/olmo.py +412 -0
  1190. vllm/model_executor/models/olmo2.py +454 -0
  1191. vllm/model_executor/models/olmoe.py +493 -0
  1192. vllm/model_executor/models/opencua.py +262 -0
  1193. vllm/model_executor/models/openpangu.py +1049 -0
  1194. vllm/model_executor/models/openpangu_mtp.py +265 -0
  1195. vllm/model_executor/models/opt.py +426 -0
  1196. vllm/model_executor/models/orion.py +365 -0
  1197. vllm/model_executor/models/ouro.py +507 -0
  1198. vllm/model_executor/models/ovis.py +557 -0
  1199. vllm/model_executor/models/ovis2_5.py +661 -0
  1200. vllm/model_executor/models/paddleocr_vl.py +1300 -0
  1201. vllm/model_executor/models/paligemma.py +408 -0
  1202. vllm/model_executor/models/persimmon.py +373 -0
  1203. vllm/model_executor/models/phi.py +363 -0
  1204. vllm/model_executor/models/phi3.py +18 -0
  1205. vllm/model_executor/models/phi3v.py +729 -0
  1206. vllm/model_executor/models/phi4mm.py +1251 -0
  1207. vllm/model_executor/models/phi4mm_audio.py +1296 -0
  1208. vllm/model_executor/models/phi4mm_utils.py +1907 -0
  1209. vllm/model_executor/models/phimoe.py +669 -0
  1210. vllm/model_executor/models/pixtral.py +1379 -0
  1211. vllm/model_executor/models/plamo2.py +965 -0
  1212. vllm/model_executor/models/plamo3.py +440 -0
  1213. vllm/model_executor/models/qwen.py +365 -0
  1214. vllm/model_executor/models/qwen2.py +600 -0
  1215. vllm/model_executor/models/qwen2_5_omni_thinker.py +1219 -0
  1216. vllm/model_executor/models/qwen2_5_vl.py +1569 -0
  1217. vllm/model_executor/models/qwen2_audio.py +471 -0
  1218. vllm/model_executor/models/qwen2_moe.py +597 -0
  1219. vllm/model_executor/models/qwen2_rm.py +123 -0
  1220. vllm/model_executor/models/qwen2_vl.py +1568 -0
  1221. vllm/model_executor/models/qwen3.py +331 -0
  1222. vllm/model_executor/models/qwen3_moe.py +751 -0
  1223. vllm/model_executor/models/qwen3_next.py +1395 -0
  1224. vllm/model_executor/models/qwen3_next_mtp.py +296 -0
  1225. vllm/model_executor/models/qwen3_omni_moe_thinker.py +1793 -0
  1226. vllm/model_executor/models/qwen3_vl.py +2092 -0
  1227. vllm/model_executor/models/qwen3_vl_moe.py +474 -0
  1228. vllm/model_executor/models/qwen_vl.py +801 -0
  1229. vllm/model_executor/models/radio.py +555 -0
  1230. vllm/model_executor/models/registry.py +1189 -0
  1231. vllm/model_executor/models/roberta.py +259 -0
  1232. vllm/model_executor/models/rvl.py +107 -0
  1233. vllm/model_executor/models/seed_oss.py +492 -0
  1234. vllm/model_executor/models/siglip.py +1244 -0
  1235. vllm/model_executor/models/siglip2navit.py +658 -0
  1236. vllm/model_executor/models/skyworkr1v.py +951 -0
  1237. vllm/model_executor/models/smolvlm.py +38 -0
  1238. vllm/model_executor/models/solar.py +484 -0
  1239. vllm/model_executor/models/stablelm.py +354 -0
  1240. vllm/model_executor/models/starcoder2.py +365 -0
  1241. vllm/model_executor/models/step3_text.py +554 -0
  1242. vllm/model_executor/models/step3_vl.py +1147 -0
  1243. vllm/model_executor/models/swin.py +514 -0
  1244. vllm/model_executor/models/tarsier.py +617 -0
  1245. vllm/model_executor/models/telechat2.py +153 -0
  1246. vllm/model_executor/models/teleflm.py +78 -0
  1247. vllm/model_executor/models/terratorch.py +318 -0
  1248. vllm/model_executor/models/transformers/__init__.py +127 -0
  1249. vllm/model_executor/models/transformers/base.py +518 -0
  1250. vllm/model_executor/models/transformers/causal.py +65 -0
  1251. vllm/model_executor/models/transformers/legacy.py +90 -0
  1252. vllm/model_executor/models/transformers/moe.py +325 -0
  1253. vllm/model_executor/models/transformers/multimodal.py +411 -0
  1254. vllm/model_executor/models/transformers/pooling.py +119 -0
  1255. vllm/model_executor/models/transformers/utils.py +213 -0
  1256. vllm/model_executor/models/ultravox.py +766 -0
  1257. vllm/model_executor/models/utils.py +832 -0
  1258. vllm/model_executor/models/vision.py +546 -0
  1259. vllm/model_executor/models/voxtral.py +841 -0
  1260. vllm/model_executor/models/whisper.py +971 -0
  1261. vllm/model_executor/models/zamba2.py +979 -0
  1262. vllm/model_executor/parameter.py +642 -0
  1263. vllm/model_executor/utils.py +119 -0
  1264. vllm/model_executor/warmup/__init__.py +0 -0
  1265. vllm/model_executor/warmup/deep_gemm_warmup.py +314 -0
  1266. vllm/model_executor/warmup/kernel_warmup.py +98 -0
  1267. vllm/multimodal/__init__.py +40 -0
  1268. vllm/multimodal/audio.py +147 -0
  1269. vllm/multimodal/base.py +56 -0
  1270. vllm/multimodal/cache.py +823 -0
  1271. vllm/multimodal/evs.py +294 -0
  1272. vllm/multimodal/hasher.py +120 -0
  1273. vllm/multimodal/image.py +142 -0
  1274. vllm/multimodal/inputs.py +1089 -0
  1275. vllm/multimodal/parse.py +565 -0
  1276. vllm/multimodal/processing.py +2240 -0
  1277. vllm/multimodal/profiling.py +351 -0
  1278. vllm/multimodal/registry.py +357 -0
  1279. vllm/multimodal/utils.py +513 -0
  1280. vllm/multimodal/video.py +340 -0
  1281. vllm/outputs.py +345 -0
  1282. vllm/platforms/__init__.py +277 -0
  1283. vllm/platforms/cpu.py +421 -0
  1284. vllm/platforms/cuda.py +618 -0
  1285. vllm/platforms/interface.py +695 -0
  1286. vllm/platforms/rocm.py +564 -0
  1287. vllm/platforms/tpu.py +295 -0
  1288. vllm/platforms/xpu.py +277 -0
  1289. vllm/plugins/__init__.py +81 -0
  1290. vllm/plugins/io_processors/__init__.py +68 -0
  1291. vllm/plugins/io_processors/interface.py +77 -0
  1292. vllm/plugins/lora_resolvers/__init__.py +0 -0
  1293. vllm/plugins/lora_resolvers/filesystem_resolver.py +52 -0
  1294. vllm/pooling_params.py +230 -0
  1295. vllm/profiler/__init__.py +0 -0
  1296. vllm/profiler/layerwise_profile.py +392 -0
  1297. vllm/profiler/utils.py +151 -0
  1298. vllm/profiler/wrapper.py +241 -0
  1299. vllm/py.typed +2 -0
  1300. vllm/ray/__init__.py +0 -0
  1301. vllm/ray/lazy_utils.py +30 -0
  1302. vllm/ray/ray_env.py +79 -0
  1303. vllm/reasoning/__init__.py +96 -0
  1304. vllm/reasoning/abs_reasoning_parsers.py +318 -0
  1305. vllm/reasoning/basic_parsers.py +175 -0
  1306. vllm/reasoning/deepseek_r1_reasoning_parser.py +67 -0
  1307. vllm/reasoning/deepseek_v3_reasoning_parser.py +67 -0
  1308. vllm/reasoning/ernie45_reasoning_parser.py +165 -0
  1309. vllm/reasoning/glm4_moe_reasoning_parser.py +171 -0
  1310. vllm/reasoning/gptoss_reasoning_parser.py +173 -0
  1311. vllm/reasoning/granite_reasoning_parser.py +363 -0
  1312. vllm/reasoning/holo2_reasoning_parser.py +88 -0
  1313. vllm/reasoning/hunyuan_a13b_reasoning_parser.py +237 -0
  1314. vllm/reasoning/identity_reasoning_parser.py +63 -0
  1315. vllm/reasoning/minimax_m2_reasoning_parser.py +110 -0
  1316. vllm/reasoning/mistral_reasoning_parser.py +154 -0
  1317. vllm/reasoning/olmo3_reasoning_parser.py +302 -0
  1318. vllm/reasoning/qwen3_reasoning_parser.py +67 -0
  1319. vllm/reasoning/seedoss_reasoning_parser.py +27 -0
  1320. vllm/reasoning/step3_reasoning_parser.py +107 -0
  1321. vllm/sampling_params.py +597 -0
  1322. vllm/scalar_type.py +355 -0
  1323. vllm/scripts.py +17 -0
  1324. vllm/sequence.py +98 -0
  1325. vllm/tasks.py +13 -0
  1326. vllm/third_party/__init__.py +0 -0
  1327. vllm/third_party/pynvml.py +6140 -0
  1328. vllm/tokenizers/__init__.py +20 -0
  1329. vllm/tokenizers/deepseek_v32.py +175 -0
  1330. vllm/tokenizers/deepseek_v32_encoding.py +459 -0
  1331. vllm/tokenizers/detokenizer_utils.py +198 -0
  1332. vllm/tokenizers/hf.py +119 -0
  1333. vllm/tokenizers/mistral.py +567 -0
  1334. vllm/tokenizers/protocol.py +114 -0
  1335. vllm/tokenizers/registry.py +233 -0
  1336. vllm/tool_parsers/__init__.py +150 -0
  1337. vllm/tool_parsers/abstract_tool_parser.py +273 -0
  1338. vllm/tool_parsers/deepseekv31_tool_parser.py +388 -0
  1339. vllm/tool_parsers/deepseekv32_tool_parser.py +591 -0
  1340. vllm/tool_parsers/deepseekv3_tool_parser.py +390 -0
  1341. vllm/tool_parsers/ernie45_tool_parser.py +210 -0
  1342. vllm/tool_parsers/gigachat3_tool_parser.py +190 -0
  1343. vllm/tool_parsers/glm4_moe_tool_parser.py +200 -0
  1344. vllm/tool_parsers/granite_20b_fc_tool_parser.py +273 -0
  1345. vllm/tool_parsers/granite_tool_parser.py +253 -0
  1346. vllm/tool_parsers/hermes_tool_parser.py +495 -0
  1347. vllm/tool_parsers/hunyuan_a13b_tool_parser.py +420 -0
  1348. vllm/tool_parsers/internlm2_tool_parser.py +227 -0
  1349. vllm/tool_parsers/jamba_tool_parser.py +323 -0
  1350. vllm/tool_parsers/kimi_k2_tool_parser.py +590 -0
  1351. vllm/tool_parsers/llama4_pythonic_tool_parser.py +341 -0
  1352. vllm/tool_parsers/llama_tool_parser.py +324 -0
  1353. vllm/tool_parsers/longcat_tool_parser.py +37 -0
  1354. vllm/tool_parsers/minimax_m2_tool_parser.py +643 -0
  1355. vllm/tool_parsers/minimax_tool_parser.py +849 -0
  1356. vllm/tool_parsers/mistral_tool_parser.py +585 -0
  1357. vllm/tool_parsers/olmo3_tool_parser.py +366 -0
  1358. vllm/tool_parsers/openai_tool_parser.py +102 -0
  1359. vllm/tool_parsers/phi4mini_tool_parser.py +120 -0
  1360. vllm/tool_parsers/pythonic_tool_parser.py +332 -0
  1361. vllm/tool_parsers/qwen3coder_tool_parser.py +781 -0
  1362. vllm/tool_parsers/qwen3xml_tool_parser.py +1316 -0
  1363. vllm/tool_parsers/seed_oss_tool_parser.py +744 -0
  1364. vllm/tool_parsers/step3_tool_parser.py +303 -0
  1365. vllm/tool_parsers/utils.py +229 -0
  1366. vllm/tool_parsers/xlam_tool_parser.py +556 -0
  1367. vllm/tracing.py +135 -0
  1368. vllm/transformers_utils/__init__.py +26 -0
  1369. vllm/transformers_utils/chat_templates/__init__.py +5 -0
  1370. vllm/transformers_utils/chat_templates/registry.py +73 -0
  1371. vllm/transformers_utils/chat_templates/template_basic.jinja +3 -0
  1372. vllm/transformers_utils/chat_templates/template_blip2.jinja +11 -0
  1373. vllm/transformers_utils/chat_templates/template_chatml.jinja +10 -0
  1374. vllm/transformers_utils/chat_templates/template_deepseek_ocr.jinja +14 -0
  1375. vllm/transformers_utils/chat_templates/template_deepseek_vl2.jinja +23 -0
  1376. vllm/transformers_utils/chat_templates/template_fuyu.jinja +3 -0
  1377. vllm/transformers_utils/chat_templates/template_minicpmv45.jinja +93 -0
  1378. vllm/transformers_utils/config.py +1144 -0
  1379. vllm/transformers_utils/config_parser_base.py +20 -0
  1380. vllm/transformers_utils/configs/__init__.py +102 -0
  1381. vllm/transformers_utils/configs/afmoe.py +87 -0
  1382. vllm/transformers_utils/configs/arctic.py +216 -0
  1383. vllm/transformers_utils/configs/bagel.py +53 -0
  1384. vllm/transformers_utils/configs/chatglm.py +75 -0
  1385. vllm/transformers_utils/configs/deepseek_vl2.py +126 -0
  1386. vllm/transformers_utils/configs/dotsocr.py +71 -0
  1387. vllm/transformers_utils/configs/eagle.py +90 -0
  1388. vllm/transformers_utils/configs/falcon.py +89 -0
  1389. vllm/transformers_utils/configs/flex_olmo.py +82 -0
  1390. vllm/transformers_utils/configs/hunyuan_vl.py +322 -0
  1391. vllm/transformers_utils/configs/jais.py +243 -0
  1392. vllm/transformers_utils/configs/kimi_linear.py +148 -0
  1393. vllm/transformers_utils/configs/kimi_vl.py +38 -0
  1394. vllm/transformers_utils/configs/lfm2_moe.py +163 -0
  1395. vllm/transformers_utils/configs/medusa.py +65 -0
  1396. vllm/transformers_utils/configs/midashenglm.py +103 -0
  1397. vllm/transformers_utils/configs/mistral.py +235 -0
  1398. vllm/transformers_utils/configs/mlp_speculator.py +69 -0
  1399. vllm/transformers_utils/configs/moonvit.py +33 -0
  1400. vllm/transformers_utils/configs/nemotron.py +220 -0
  1401. vllm/transformers_utils/configs/nemotron_h.py +284 -0
  1402. vllm/transformers_utils/configs/olmo3.py +83 -0
  1403. vllm/transformers_utils/configs/ovis.py +182 -0
  1404. vllm/transformers_utils/configs/qwen3_next.py +277 -0
  1405. vllm/transformers_utils/configs/radio.py +89 -0
  1406. vllm/transformers_utils/configs/speculators/__init__.py +2 -0
  1407. vllm/transformers_utils/configs/speculators/algos.py +38 -0
  1408. vllm/transformers_utils/configs/speculators/base.py +114 -0
  1409. vllm/transformers_utils/configs/step3_vl.py +178 -0
  1410. vllm/transformers_utils/configs/tarsier2.py +24 -0
  1411. vllm/transformers_utils/configs/ultravox.py +120 -0
  1412. vllm/transformers_utils/dynamic_module.py +59 -0
  1413. vllm/transformers_utils/gguf_utils.py +280 -0
  1414. vllm/transformers_utils/processor.py +424 -0
  1415. vllm/transformers_utils/processors/__init__.py +25 -0
  1416. vllm/transformers_utils/processors/bagel.py +73 -0
  1417. vllm/transformers_utils/processors/deepseek_ocr.py +438 -0
  1418. vllm/transformers_utils/processors/deepseek_vl2.py +406 -0
  1419. vllm/transformers_utils/processors/hunyuan_vl.py +233 -0
  1420. vllm/transformers_utils/processors/hunyuan_vl_image.py +477 -0
  1421. vllm/transformers_utils/processors/ovis.py +453 -0
  1422. vllm/transformers_utils/processors/ovis2_5.py +468 -0
  1423. vllm/transformers_utils/repo_utils.py +287 -0
  1424. vllm/transformers_utils/runai_utils.py +102 -0
  1425. vllm/transformers_utils/s3_utils.py +95 -0
  1426. vllm/transformers_utils/tokenizer.py +127 -0
  1427. vllm/transformers_utils/tokenizer_base.py +33 -0
  1428. vllm/transformers_utils/utils.py +112 -0
  1429. vllm/triton_utils/__init__.py +20 -0
  1430. vllm/triton_utils/importing.py +103 -0
  1431. vllm/usage/__init__.py +0 -0
  1432. vllm/usage/usage_lib.py +294 -0
  1433. vllm/utils/__init__.py +66 -0
  1434. vllm/utils/argparse_utils.py +492 -0
  1435. vllm/utils/async_utils.py +310 -0
  1436. vllm/utils/cache.py +214 -0
  1437. vllm/utils/collection_utils.py +112 -0
  1438. vllm/utils/counter.py +45 -0
  1439. vllm/utils/deep_gemm.py +400 -0
  1440. vllm/utils/flashinfer.py +528 -0
  1441. vllm/utils/func_utils.py +236 -0
  1442. vllm/utils/gc_utils.py +151 -0
  1443. vllm/utils/hashing.py +117 -0
  1444. vllm/utils/import_utils.py +449 -0
  1445. vllm/utils/jsontree.py +158 -0
  1446. vllm/utils/math_utils.py +32 -0
  1447. vllm/utils/mem_constants.py +13 -0
  1448. vllm/utils/mem_utils.py +232 -0
  1449. vllm/utils/nccl.py +64 -0
  1450. vllm/utils/network_utils.py +331 -0
  1451. vllm/utils/nvtx_pytorch_hooks.py +286 -0
  1452. vllm/utils/platform_utils.py +59 -0
  1453. vllm/utils/profiling.py +56 -0
  1454. vllm/utils/registry.py +51 -0
  1455. vllm/utils/serial_utils.py +214 -0
  1456. vllm/utils/system_utils.py +269 -0
  1457. vllm/utils/tensor_schema.py +255 -0
  1458. vllm/utils/torch_utils.py +648 -0
  1459. vllm/v1/__init__.py +0 -0
  1460. vllm/v1/attention/__init__.py +0 -0
  1461. vllm/v1/attention/backends/__init__.py +0 -0
  1462. vllm/v1/attention/backends/cpu_attn.py +497 -0
  1463. vllm/v1/attention/backends/flash_attn.py +1051 -0
  1464. vllm/v1/attention/backends/flashinfer.py +1575 -0
  1465. vllm/v1/attention/backends/flex_attention.py +1028 -0
  1466. vllm/v1/attention/backends/gdn_attn.py +375 -0
  1467. vllm/v1/attention/backends/linear_attn.py +77 -0
  1468. vllm/v1/attention/backends/mamba1_attn.py +159 -0
  1469. vllm/v1/attention/backends/mamba2_attn.py +348 -0
  1470. vllm/v1/attention/backends/mamba_attn.py +117 -0
  1471. vllm/v1/attention/backends/mla/__init__.py +0 -0
  1472. vllm/v1/attention/backends/mla/aiter_triton_mla.py +74 -0
  1473. vllm/v1/attention/backends/mla/common.py +2114 -0
  1474. vllm/v1/attention/backends/mla/cutlass_mla.py +278 -0
  1475. vllm/v1/attention/backends/mla/flashattn_mla.py +342 -0
  1476. vllm/v1/attention/backends/mla/flashinfer_mla.py +174 -0
  1477. vllm/v1/attention/backends/mla/flashmla.py +317 -0
  1478. vllm/v1/attention/backends/mla/flashmla_sparse.py +1020 -0
  1479. vllm/v1/attention/backends/mla/indexer.py +345 -0
  1480. vllm/v1/attention/backends/mla/rocm_aiter_mla.py +275 -0
  1481. vllm/v1/attention/backends/mla/rocm_aiter_mla_sparse.py +325 -0
  1482. vllm/v1/attention/backends/mla/triton_mla.py +171 -0
  1483. vllm/v1/attention/backends/pallas.py +436 -0
  1484. vllm/v1/attention/backends/rocm_aiter_fa.py +1000 -0
  1485. vllm/v1/attention/backends/rocm_aiter_unified_attn.py +206 -0
  1486. vllm/v1/attention/backends/rocm_attn.py +359 -0
  1487. vllm/v1/attention/backends/short_conv_attn.py +104 -0
  1488. vllm/v1/attention/backends/tree_attn.py +428 -0
  1489. vllm/v1/attention/backends/triton_attn.py +497 -0
  1490. vllm/v1/attention/backends/utils.py +1212 -0
  1491. vllm/v1/core/__init__.py +0 -0
  1492. vllm/v1/core/block_pool.py +485 -0
  1493. vllm/v1/core/encoder_cache_manager.py +402 -0
  1494. vllm/v1/core/kv_cache_coordinator.py +570 -0
  1495. vllm/v1/core/kv_cache_manager.py +419 -0
  1496. vllm/v1/core/kv_cache_metrics.py +96 -0
  1497. vllm/v1/core/kv_cache_utils.py +1476 -0
  1498. vllm/v1/core/sched/__init__.py +0 -0
  1499. vllm/v1/core/sched/async_scheduler.py +68 -0
  1500. vllm/v1/core/sched/interface.py +189 -0
  1501. vllm/v1/core/sched/output.py +230 -0
  1502. vllm/v1/core/sched/request_queue.py +217 -0
  1503. vllm/v1/core/sched/scheduler.py +1826 -0
  1504. vllm/v1/core/sched/utils.py +64 -0
  1505. vllm/v1/core/single_type_kv_cache_manager.py +801 -0
  1506. vllm/v1/cudagraph_dispatcher.py +183 -0
  1507. vllm/v1/engine/__init__.py +217 -0
  1508. vllm/v1/engine/async_llm.py +866 -0
  1509. vllm/v1/engine/coordinator.py +377 -0
  1510. vllm/v1/engine/core.py +1455 -0
  1511. vllm/v1/engine/core_client.py +1416 -0
  1512. vllm/v1/engine/detokenizer.py +351 -0
  1513. vllm/v1/engine/exceptions.py +18 -0
  1514. vllm/v1/engine/input_processor.py +643 -0
  1515. vllm/v1/engine/llm_engine.py +414 -0
  1516. vllm/v1/engine/logprobs.py +189 -0
  1517. vllm/v1/engine/output_processor.py +659 -0
  1518. vllm/v1/engine/parallel_sampling.py +145 -0
  1519. vllm/v1/engine/processor.py +20 -0
  1520. vllm/v1/engine/utils.py +1068 -0
  1521. vllm/v1/executor/__init__.py +6 -0
  1522. vllm/v1/executor/abstract.py +352 -0
  1523. vllm/v1/executor/multiproc_executor.py +890 -0
  1524. vllm/v1/executor/ray_distributed_executor.py +8 -0
  1525. vllm/v1/executor/ray_executor.py +626 -0
  1526. vllm/v1/executor/ray_utils.py +465 -0
  1527. vllm/v1/executor/uniproc_executor.py +186 -0
  1528. vllm/v1/kv_cache_interface.py +404 -0
  1529. vllm/v1/kv_offload/__init__.py +0 -0
  1530. vllm/v1/kv_offload/abstract.py +161 -0
  1531. vllm/v1/kv_offload/arc_manager.py +237 -0
  1532. vllm/v1/kv_offload/backend.py +97 -0
  1533. vllm/v1/kv_offload/backends/__init__.py +0 -0
  1534. vllm/v1/kv_offload/backends/cpu.py +62 -0
  1535. vllm/v1/kv_offload/cpu.py +86 -0
  1536. vllm/v1/kv_offload/factory.py +56 -0
  1537. vllm/v1/kv_offload/lru_manager.py +139 -0
  1538. vllm/v1/kv_offload/mediums.py +39 -0
  1539. vllm/v1/kv_offload/spec.py +66 -0
  1540. vllm/v1/kv_offload/worker/__init__.py +0 -0
  1541. vllm/v1/kv_offload/worker/cpu_gpu.py +280 -0
  1542. vllm/v1/kv_offload/worker/worker.py +144 -0
  1543. vllm/v1/metrics/__init__.py +0 -0
  1544. vllm/v1/metrics/loggers.py +1305 -0
  1545. vllm/v1/metrics/prometheus.py +82 -0
  1546. vllm/v1/metrics/ray_wrappers.py +194 -0
  1547. vllm/v1/metrics/reader.py +257 -0
  1548. vllm/v1/metrics/stats.py +437 -0
  1549. vllm/v1/outputs.py +245 -0
  1550. vllm/v1/pool/__init__.py +0 -0
  1551. vllm/v1/pool/metadata.py +126 -0
  1552. vllm/v1/request.py +282 -0
  1553. vllm/v1/sample/__init__.py +0 -0
  1554. vllm/v1/sample/logits_processor/__init__.py +352 -0
  1555. vllm/v1/sample/logits_processor/builtin.py +278 -0
  1556. vllm/v1/sample/logits_processor/interface.py +106 -0
  1557. vllm/v1/sample/logits_processor/state.py +165 -0
  1558. vllm/v1/sample/metadata.py +44 -0
  1559. vllm/v1/sample/ops/__init__.py +0 -0
  1560. vllm/v1/sample/ops/bad_words.py +52 -0
  1561. vllm/v1/sample/ops/logprobs.py +25 -0
  1562. vllm/v1/sample/ops/penalties.py +57 -0
  1563. vllm/v1/sample/ops/topk_topp_sampler.py +384 -0
  1564. vllm/v1/sample/rejection_sampler.py +805 -0
  1565. vllm/v1/sample/sampler.py +319 -0
  1566. vllm/v1/sample/tpu/__init__.py +0 -0
  1567. vllm/v1/sample/tpu/metadata.py +120 -0
  1568. vllm/v1/sample/tpu/sampler.py +215 -0
  1569. vllm/v1/serial_utils.py +514 -0
  1570. vllm/v1/spec_decode/__init__.py +0 -0
  1571. vllm/v1/spec_decode/eagle.py +1331 -0
  1572. vllm/v1/spec_decode/medusa.py +73 -0
  1573. vllm/v1/spec_decode/metadata.py +66 -0
  1574. vllm/v1/spec_decode/metrics.py +225 -0
  1575. vllm/v1/spec_decode/ngram_proposer.py +291 -0
  1576. vllm/v1/spec_decode/suffix_decoding.py +101 -0
  1577. vllm/v1/spec_decode/utils.py +121 -0
  1578. vllm/v1/structured_output/__init__.py +353 -0
  1579. vllm/v1/structured_output/backend_guidance.py +265 -0
  1580. vllm/v1/structured_output/backend_lm_format_enforcer.py +177 -0
  1581. vllm/v1/structured_output/backend_outlines.py +324 -0
  1582. vllm/v1/structured_output/backend_types.py +136 -0
  1583. vllm/v1/structured_output/backend_xgrammar.py +378 -0
  1584. vllm/v1/structured_output/request.py +94 -0
  1585. vllm/v1/structured_output/utils.py +469 -0
  1586. vllm/v1/utils.py +414 -0
  1587. vllm/v1/worker/__init__.py +0 -0
  1588. vllm/v1/worker/block_table.py +343 -0
  1589. vllm/v1/worker/cp_utils.py +42 -0
  1590. vllm/v1/worker/cpu_model_runner.py +122 -0
  1591. vllm/v1/worker/cpu_worker.py +192 -0
  1592. vllm/v1/worker/dp_utils.py +240 -0
  1593. vllm/v1/worker/ec_connector_model_runner_mixin.py +87 -0
  1594. vllm/v1/worker/gpu/README.md +4 -0
  1595. vllm/v1/worker/gpu/__init__.py +0 -0
  1596. vllm/v1/worker/gpu/async_utils.py +98 -0
  1597. vllm/v1/worker/gpu/attn_utils.py +189 -0
  1598. vllm/v1/worker/gpu/block_table.py +314 -0
  1599. vllm/v1/worker/gpu/cudagraph_utils.py +259 -0
  1600. vllm/v1/worker/gpu/dp_utils.py +31 -0
  1601. vllm/v1/worker/gpu/input_batch.py +479 -0
  1602. vllm/v1/worker/gpu/metrics/__init__.py +0 -0
  1603. vllm/v1/worker/gpu/metrics/logits.py +42 -0
  1604. vllm/v1/worker/gpu/model_runner.py +1006 -0
  1605. vllm/v1/worker/gpu/sample/__init__.py +0 -0
  1606. vllm/v1/worker/gpu/sample/gumbel.py +101 -0
  1607. vllm/v1/worker/gpu/sample/logprob.py +167 -0
  1608. vllm/v1/worker/gpu/sample/metadata.py +192 -0
  1609. vllm/v1/worker/gpu/sample/min_p.py +51 -0
  1610. vllm/v1/worker/gpu/sample/output.py +14 -0
  1611. vllm/v1/worker/gpu/sample/penalties.py +155 -0
  1612. vllm/v1/worker/gpu/sample/sampler.py +87 -0
  1613. vllm/v1/worker/gpu/spec_decode/__init__.py +18 -0
  1614. vllm/v1/worker/gpu/spec_decode/eagle.py +565 -0
  1615. vllm/v1/worker/gpu/spec_decode/eagle_cudagraph.py +115 -0
  1616. vllm/v1/worker/gpu/spec_decode/rejection_sample.py +71 -0
  1617. vllm/v1/worker/gpu/states.py +316 -0
  1618. vllm/v1/worker/gpu/structured_outputs.py +76 -0
  1619. vllm/v1/worker/gpu_input_batch.py +990 -0
  1620. vllm/v1/worker/gpu_model_runner.py +5470 -0
  1621. vllm/v1/worker/gpu_ubatch_wrapper.py +472 -0
  1622. vllm/v1/worker/gpu_worker.py +955 -0
  1623. vllm/v1/worker/kv_connector_model_runner_mixin.py +302 -0
  1624. vllm/v1/worker/lora_model_runner_mixin.py +212 -0
  1625. vllm/v1/worker/tpu_input_batch.py +583 -0
  1626. vllm/v1/worker/tpu_model_runner.py +2191 -0
  1627. vllm/v1/worker/tpu_worker.py +352 -0
  1628. vllm/v1/worker/ubatch_utils.py +109 -0
  1629. vllm/v1/worker/ubatching.py +231 -0
  1630. vllm/v1/worker/utils.py +375 -0
  1631. vllm/v1/worker/worker_base.py +377 -0
  1632. vllm/v1/worker/workspace.py +253 -0
  1633. vllm/v1/worker/xpu_model_runner.py +48 -0
  1634. vllm/v1/worker/xpu_worker.py +174 -0
  1635. vllm/version.py +39 -0
  1636. vllm/vllm_flash_attn/.gitkeep +0 -0
  1637. vllm_cpu_avx512vnni-0.13.0.dist-info/METADATA +339 -0
  1638. vllm_cpu_avx512vnni-0.13.0.dist-info/RECORD +1641 -0
  1639. vllm_cpu_avx512vnni-0.13.0.dist-info/WHEEL +5 -0
  1640. vllm_cpu_avx512vnni-0.13.0.dist-info/entry_points.txt +5 -0
  1641. vllm_cpu_avx512vnni-0.13.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1826 @@
1
+ # SPDX-License-Identifier: Apache-2.0
2
+ # SPDX-FileCopyrightText: Copyright contributors to the vLLM project
3
+ import itertools
4
+ import time
5
+ from collections import defaultdict
6
+ from collections.abc import Iterable
7
+ from typing import Any
8
+
9
+ from vllm import envs
10
+ from vllm.compilation.cuda_graph import CUDAGraphStat
11
+ from vllm.config import VllmConfig
12
+ from vllm.distributed.ec_transfer.ec_connector.base import (
13
+ ECConnectorMetadata,
14
+ ECConnectorRole,
15
+ )
16
+ from vllm.distributed.ec_transfer.ec_connector.factory import ECConnectorFactory
17
+ from vllm.distributed.kv_events import EventPublisherFactory, KVEventBatch
18
+ from vllm.distributed.kv_transfer.kv_connector.factory import KVConnectorFactory
19
+ from vllm.distributed.kv_transfer.kv_connector.v1 import (
20
+ KVConnectorBase_V1,
21
+ KVConnectorRole,
22
+ SupportsHMA,
23
+ )
24
+ from vllm.distributed.kv_transfer.kv_connector.v1.base import KVConnectorMetadata
25
+ from vllm.distributed.kv_transfer.kv_connector.v1.metrics import KVConnectorStats
26
+ from vllm.logger import init_logger
27
+ from vllm.multimodal import MULTIMODAL_REGISTRY, MultiModalRegistry
28
+ from vllm.v1.core.encoder_cache_manager import (
29
+ EncoderCacheManager,
30
+ EncoderDecoderCacheManager,
31
+ compute_encoder_budget,
32
+ )
33
+ from vllm.v1.core.kv_cache_manager import KVCacheBlocks, KVCacheManager
34
+ from vllm.v1.core.kv_cache_metrics import KVCacheMetricsCollector
35
+ from vllm.v1.core.sched.interface import SchedulerInterface
36
+ from vllm.v1.core.sched.output import (
37
+ CachedRequestData,
38
+ GrammarOutput,
39
+ NewRequestData,
40
+ SchedulerOutput,
41
+ )
42
+ from vllm.v1.core.sched.request_queue import SchedulingPolicy, create_request_queue
43
+ from vllm.v1.core.sched.utils import check_stop, remove_all
44
+ from vllm.v1.engine import EngineCoreEventType, EngineCoreOutput, EngineCoreOutputs
45
+ from vllm.v1.kv_cache_interface import KVCacheConfig
46
+ from vllm.v1.metrics.stats import (
47
+ PrefixCacheStats,
48
+ SchedulerStats,
49
+ )
50
+ from vllm.v1.outputs import DraftTokenIds, KVConnectorOutput, ModelRunnerOutput
51
+ from vllm.v1.request import Request, RequestStatus
52
+ from vllm.v1.spec_decode.metrics import SpecDecodingStats
53
+ from vllm.v1.structured_output import StructuredOutputManager
54
+ from vllm.v1.utils import record_function_or_nullcontext
55
+
56
+ logger = init_logger(__name__)
57
+
58
+
59
+ class Scheduler(SchedulerInterface):
60
+ def __init__(
61
+ self,
62
+ vllm_config: VllmConfig,
63
+ kv_cache_config: KVCacheConfig,
64
+ structured_output_manager: StructuredOutputManager,
65
+ block_size: int,
66
+ mm_registry: MultiModalRegistry = MULTIMODAL_REGISTRY,
67
+ include_finished_set: bool = False,
68
+ log_stats: bool = False,
69
+ ) -> None:
70
+ self.vllm_config = vllm_config
71
+ self.scheduler_config = vllm_config.scheduler_config
72
+ self.cache_config = vllm_config.cache_config
73
+ self.lora_config = vllm_config.lora_config
74
+ self.kv_cache_config = kv_cache_config
75
+ self.kv_events_config = vllm_config.kv_events_config
76
+ self.parallel_config = vllm_config.parallel_config
77
+ self.log_stats = log_stats
78
+ self.observability_config = vllm_config.observability_config
79
+ self.kv_metrics_collector: KVCacheMetricsCollector | None = None
80
+ if self.observability_config.kv_cache_metrics:
81
+ self.kv_metrics_collector = KVCacheMetricsCollector(
82
+ self.observability_config.kv_cache_metrics_sample,
83
+ )
84
+ self.structured_output_manager = structured_output_manager
85
+ self.is_encoder_decoder = vllm_config.model_config.is_encoder_decoder
86
+
87
+ # include_finished_set controls whether a separate set of finished
88
+ # request ids should be included in the EngineCoreOutputs returned
89
+ # by update_from_outputs(). This is currently used in the multi-engine
90
+ # case to track request lifetimes efficiently.
91
+ self.finished_req_ids_dict: dict[int, set[str]] | None = (
92
+ defaultdict(set) if include_finished_set else None
93
+ )
94
+ self.prev_step_scheduled_req_ids: set[str] = set()
95
+
96
+ # Scheduling constraints.
97
+ self.max_num_running_reqs = self.scheduler_config.max_num_seqs
98
+ self.max_num_scheduled_tokens = self.scheduler_config.max_num_batched_tokens
99
+ self.max_model_len = vllm_config.model_config.max_model_len
100
+ self.enable_kv_cache_events = (
101
+ self.kv_events_config is not None
102
+ and self.kv_events_config.enable_kv_cache_events
103
+ )
104
+
105
+ # Create KVConnector for the Scheduler. Note that each Worker
106
+ # will have a corresponding KVConnector with Role=WORKER.
107
+ # KV Connector pushes/pull of remote KVs for P/D and offloading.
108
+ self.connector = None
109
+ self.connector_prefix_cache_stats: PrefixCacheStats | None = None
110
+ self.recompute_kv_load_failures = True
111
+ if self.vllm_config.kv_transfer_config is not None:
112
+ assert not self.is_encoder_decoder, (
113
+ "Encoder-decoder models are not currently supported with KV connectors"
114
+ )
115
+ self.connector = KVConnectorFactory.create_connector(
116
+ config=self.vllm_config,
117
+ role=KVConnectorRole.SCHEDULER,
118
+ kv_cache_config=self.kv_cache_config,
119
+ )
120
+ if self.log_stats:
121
+ self.connector_prefix_cache_stats = PrefixCacheStats()
122
+ kv_load_failure_policy = (
123
+ self.vllm_config.kv_transfer_config.kv_load_failure_policy
124
+ )
125
+ self.recompute_kv_load_failures = kv_load_failure_policy == "recompute"
126
+
127
+ self.kv_event_publisher = EventPublisherFactory.create(
128
+ self.kv_events_config,
129
+ self.parallel_config.data_parallel_rank,
130
+ )
131
+ self.ec_connector = None
132
+ if self.vllm_config.ec_transfer_config is not None:
133
+ self.ec_connector = ECConnectorFactory.create_connector(
134
+ config=self.vllm_config, role=ECConnectorRole.SCHEDULER
135
+ )
136
+
137
+ num_gpu_blocks = self.cache_config.num_gpu_blocks
138
+ assert num_gpu_blocks is not None and num_gpu_blocks > 0
139
+
140
+ self.block_size = block_size
141
+ self.dcp_world_size = vllm_config.parallel_config.decode_context_parallel_size
142
+ self.pcp_world_size = vllm_config.parallel_config.prefill_context_parallel_size
143
+
144
+ # req_id -> Request
145
+ self.requests: dict[str, Request] = {}
146
+ # Scheduling policy
147
+ try:
148
+ self.policy = SchedulingPolicy(self.scheduler_config.policy)
149
+ except ValueError as e:
150
+ raise ValueError(
151
+ f"Unknown scheduling policy: {self.scheduler_config.policy}"
152
+ ) from e
153
+ # Priority queues for requests.
154
+ self.waiting = create_request_queue(self.policy)
155
+ self.running: list[Request] = []
156
+
157
+ # The request IDs that are finished in between the previous and the
158
+ # current steps. This is used to notify the workers about the finished
159
+ # requests so that they can free the cached states for those requests.
160
+ # This is flushed at the end of each scheduling step.
161
+ self.finished_req_ids: set[str] = set()
162
+
163
+ # KV Connector: requests in process of async KV loading or recving
164
+ self.finished_recving_kv_req_ids: set[str] = set()
165
+ self.failed_recving_kv_req_ids: set[str] = set()
166
+
167
+ # Encoder-related.
168
+ # Calculate encoder cache size if applicable
169
+ # NOTE: For now we use the same budget for both compute and space.
170
+ # This can be changed when we make encoder cache for embedding caching
171
+ # across requests.
172
+ encoder_compute_budget, encoder_cache_size = compute_encoder_budget(
173
+ model_config=vllm_config.model_config,
174
+ scheduler_config=vllm_config.scheduler_config,
175
+ mm_registry=mm_registry,
176
+ )
177
+
178
+ # NOTE(woosuk): Here, "encoder" includes the vision encoder (and
179
+ # projector if needed) for MM models as well as encoder-decoder
180
+ # transformers.
181
+ self.max_num_encoder_input_tokens = encoder_compute_budget
182
+ # NOTE: For the models without encoder (e.g., text-only models),
183
+ # the encoder cache will not be initialized because cache size is 0
184
+ # for these models.
185
+ self.encoder_cache_manager = (
186
+ EncoderDecoderCacheManager(cache_size=encoder_cache_size)
187
+ if self.is_encoder_decoder
188
+ else EncoderCacheManager(cache_size=encoder_cache_size)
189
+ )
190
+
191
+ speculative_config = vllm_config.speculative_config
192
+ self.use_eagle = False
193
+ self.num_spec_tokens = self.num_lookahead_tokens = 0
194
+ if speculative_config:
195
+ self.num_spec_tokens = speculative_config.num_speculative_tokens
196
+ if speculative_config.use_eagle():
197
+ self.use_eagle = True
198
+ self.num_lookahead_tokens = self.num_spec_tokens
199
+
200
+ # Create the KV cache manager.
201
+ self.kv_cache_manager = KVCacheManager(
202
+ kv_cache_config=kv_cache_config,
203
+ max_model_len=self.max_model_len,
204
+ enable_caching=self.cache_config.enable_prefix_caching,
205
+ use_eagle=self.use_eagle,
206
+ log_stats=self.log_stats,
207
+ enable_kv_cache_events=self.enable_kv_cache_events,
208
+ dcp_world_size=self.dcp_world_size,
209
+ pcp_world_size=self.pcp_world_size,
210
+ hash_block_size=self.block_size,
211
+ metrics_collector=self.kv_metrics_collector,
212
+ )
213
+ self.use_pp = self.parallel_config.pipeline_parallel_size > 1
214
+ self.use_v2_model_runner = envs.VLLM_USE_V2_MODEL_RUNNER
215
+
216
+ def schedule(self) -> SchedulerOutput:
217
+ # NOTE(woosuk) on the scheduling algorithm:
218
+ # There's no "decoding phase" nor "prefill phase" in the scheduler.
219
+ # Each request just has the num_computed_tokens and
220
+ # num_tokens_with_spec. num_tokens_with_spec =
221
+ # len(prompt_token_ids) + len(output_token_ids) + len(spec_token_ids).
222
+ # At each step, the scheduler tries to assign tokens to the requests
223
+ # so that each request's num_computed_tokens can catch up its
224
+ # num_tokens_with_spec. This is general enough to cover
225
+ # chunked prefills, prefix caching, speculative decoding,
226
+ # and the "jump decoding" optimization in the future.
227
+
228
+ scheduled_new_reqs: list[Request] = []
229
+ scheduled_resumed_reqs: list[Request] = []
230
+ scheduled_running_reqs: list[Request] = []
231
+ preempted_reqs: list[Request] = []
232
+
233
+ req_to_new_blocks: dict[str, KVCacheBlocks] = {}
234
+ num_scheduled_tokens: dict[str, int] = {}
235
+ token_budget = self.max_num_scheduled_tokens
236
+ # Encoder-related.
237
+ scheduled_encoder_inputs: dict[str, list[int]] = {}
238
+ encoder_compute_budget = self.max_num_encoder_input_tokens
239
+ # Spec decode-related.
240
+ scheduled_spec_decode_tokens: dict[str, list[int]] = {}
241
+
242
+ # For logging.
243
+ scheduled_timestamp = time.monotonic()
244
+
245
+ # First, schedule the RUNNING requests.
246
+ req_index = 0
247
+ while req_index < len(self.running) and token_budget > 0:
248
+ request = self.running[req_index]
249
+
250
+ if (
251
+ request.num_output_placeholders > 0
252
+ # This is (num_computed_tokens + 1) - (num_output_placeholders - 1).
253
+ # Since output placeholders are also included in the computed tokens
254
+ # count, we subtract (num_output_placeholders - 1) to remove any draft
255
+ # tokens, so that we can be sure no further steps are needed even if
256
+ # they are all rejected.
257
+ and request.num_computed_tokens + 2 - request.num_output_placeholders
258
+ >= request.num_prompt_tokens + request.max_tokens
259
+ ):
260
+ # Async scheduling: Avoid scheduling an extra step when we are sure that
261
+ # the previous step has reached request.max_tokens. We don't schedule
262
+ # partial draft tokens since this prevents uniform decode optimizations.
263
+ req_index += 1
264
+ continue
265
+
266
+ num_new_tokens = (
267
+ request.num_tokens_with_spec
268
+ + request.num_output_placeholders
269
+ - request.num_computed_tokens
270
+ )
271
+ if 0 < self.scheduler_config.long_prefill_token_threshold < num_new_tokens:
272
+ num_new_tokens = self.scheduler_config.long_prefill_token_threshold
273
+ num_new_tokens = min(num_new_tokens, token_budget)
274
+
275
+ # Make sure the input position does not exceed the max model len.
276
+ # This is necessary when using spec decoding.
277
+ num_new_tokens = min(
278
+ num_new_tokens, self.max_model_len - 1 - request.num_computed_tokens
279
+ )
280
+
281
+ # Schedule encoder inputs.
282
+ encoder_inputs_to_schedule = None
283
+ external_load_encoder_input: list[int] = []
284
+ new_encoder_compute_budget = encoder_compute_budget
285
+ if request.has_encoder_inputs:
286
+ (
287
+ encoder_inputs_to_schedule,
288
+ num_new_tokens,
289
+ new_encoder_compute_budget,
290
+ external_load_encoder_input,
291
+ ) = self._try_schedule_encoder_inputs(
292
+ request,
293
+ request.num_computed_tokens,
294
+ num_new_tokens,
295
+ encoder_compute_budget,
296
+ shift_computed_tokens=1 if self.use_eagle else 0,
297
+ )
298
+
299
+ if num_new_tokens == 0:
300
+ # The request cannot be scheduled because one of the following
301
+ # reasons:
302
+ # 1. No new tokens to schedule. This may happen when
303
+ # (1) PP>1 and we have already scheduled all prompt tokens
304
+ # but they are not finished yet.
305
+ # (2) Async scheduling and the request has reached to either
306
+ # its max_total_tokens or max_model_len.
307
+ # 2. The encoder budget is exhausted.
308
+ # 3. The encoder cache is exhausted.
309
+ # NOTE(woosuk): Here, by doing `continue` instead of `break`,
310
+ # we do not strictly follow the FCFS scheduling policy and
311
+ # allow the lower-priority requests to be scheduled.
312
+ req_index += 1
313
+ continue
314
+
315
+ # Schedule newly needed KV blocks for the request.
316
+ with record_function_or_nullcontext("schedule: allocate_slots"):
317
+ while True:
318
+ new_blocks = self.kv_cache_manager.allocate_slots(
319
+ request,
320
+ num_new_tokens,
321
+ num_lookahead_tokens=self.num_lookahead_tokens,
322
+ )
323
+
324
+ if new_blocks is not None:
325
+ # The request can be scheduled.
326
+ break
327
+
328
+ # The request cannot be scheduled.
329
+ # Preempt the lowest-priority request.
330
+ if self.policy == SchedulingPolicy.PRIORITY:
331
+ preempted_req = max(
332
+ self.running,
333
+ key=lambda r: (r.priority, r.arrival_time),
334
+ )
335
+ self.running.remove(preempted_req)
336
+ if preempted_req in scheduled_running_reqs:
337
+ scheduled_running_reqs.remove(preempted_req)
338
+ token_budget += num_scheduled_tokens[
339
+ preempted_req.request_id
340
+ ]
341
+ req_to_new_blocks.pop(preempted_req.request_id)
342
+ num_scheduled_tokens.pop(preempted_req.request_id)
343
+ scheduled_spec_decode_tokens.pop(
344
+ preempted_req.request_id, None
345
+ )
346
+ preempted_encoder_inputs = scheduled_encoder_inputs.pop(
347
+ preempted_req.request_id, None
348
+ )
349
+ if preempted_encoder_inputs:
350
+ # Restore encoder compute budget if the preempted
351
+ # request had encoder inputs scheduled in this step.
352
+ num_embeds_to_restore = sum(
353
+ preempted_req.get_num_encoder_embeds(i)
354
+ for i in preempted_encoder_inputs
355
+ )
356
+ encoder_compute_budget += num_embeds_to_restore
357
+ req_index -= 1
358
+ else:
359
+ preempted_req = self.running.pop()
360
+
361
+ self._preempt_request(preempted_req, scheduled_timestamp)
362
+ preempted_reqs.append(preempted_req)
363
+ if preempted_req == request:
364
+ # No more request to preempt. Cannot schedule this request.
365
+ break
366
+
367
+ if new_blocks is None:
368
+ # Cannot schedule this request.
369
+ break
370
+
371
+ # Schedule the request.
372
+ scheduled_running_reqs.append(request)
373
+ req_to_new_blocks[request.request_id] = new_blocks
374
+ num_scheduled_tokens[request.request_id] = num_new_tokens
375
+ token_budget -= num_new_tokens
376
+ req_index += 1
377
+
378
+ # Speculative decode related.
379
+ if request.spec_token_ids:
380
+ num_scheduled_spec_tokens = (
381
+ num_new_tokens
382
+ + request.num_computed_tokens
383
+ - request.num_tokens
384
+ - request.num_output_placeholders
385
+ )
386
+ if num_scheduled_spec_tokens > 0:
387
+ # Trim spec_token_ids list to num_scheduled_spec_tokens.
388
+ del request.spec_token_ids[num_scheduled_spec_tokens:]
389
+ scheduled_spec_decode_tokens[request.request_id] = (
390
+ request.spec_token_ids
391
+ )
392
+ # New spec tokens will be set in `update_draft_token_ids` before the
393
+ # next step when applicable.
394
+ request.spec_token_ids = []
395
+
396
+ # Encoder-related.
397
+ if encoder_inputs_to_schedule:
398
+ scheduled_encoder_inputs[request.request_id] = (
399
+ encoder_inputs_to_schedule
400
+ )
401
+ # Allocate the encoder cache.
402
+ for i in encoder_inputs_to_schedule:
403
+ self.encoder_cache_manager.allocate(request, i)
404
+ encoder_compute_budget = new_encoder_compute_budget
405
+ if external_load_encoder_input:
406
+ for i in external_load_encoder_input:
407
+ self.encoder_cache_manager.allocate(request, i)
408
+ if self.ec_connector is not None:
409
+ self.ec_connector.update_state_after_alloc(request, i)
410
+
411
+ # Record the LoRAs in scheduled_running_reqs
412
+ scheduled_loras: set[int] = set()
413
+ if self.lora_config:
414
+ scheduled_loras = set(
415
+ req.lora_request.lora_int_id
416
+ for req in scheduled_running_reqs
417
+ if req.lora_request and req.lora_request.lora_int_id > 0
418
+ )
419
+ assert len(scheduled_loras) <= self.lora_config.max_loras
420
+
421
+ # Use a temporary RequestQueue to collect requests that need to be
422
+ # skipped and put back at the head of the waiting queue later
423
+ skipped_waiting_requests = create_request_queue(self.policy)
424
+
425
+ # Next, schedule the WAITING requests.
426
+ if not preempted_reqs:
427
+ while self.waiting and token_budget > 0:
428
+ if len(self.running) == self.max_num_running_reqs:
429
+ break
430
+
431
+ request = self.waiting.peek_request()
432
+
433
+ # KVTransfer: skip request if still waiting for remote kvs.
434
+ if request.status == RequestStatus.WAITING_FOR_REMOTE_KVS:
435
+ is_ready = self._update_waiting_for_remote_kv(request)
436
+ if is_ready:
437
+ request.status = RequestStatus.WAITING
438
+ else:
439
+ logger.debug(
440
+ "%s is still in WAITING_FOR_REMOTE_KVS state.",
441
+ request.request_id,
442
+ )
443
+ self.waiting.pop_request()
444
+ skipped_waiting_requests.prepend_request(request)
445
+ continue
446
+
447
+ # Skip request if the structured output request is still waiting
448
+ # for FSM compilation.
449
+ if request.status == RequestStatus.WAITING_FOR_FSM:
450
+ structured_output_req = request.structured_output_request
451
+ if structured_output_req and structured_output_req.grammar:
452
+ request.status = RequestStatus.WAITING
453
+ else:
454
+ self.waiting.pop_request()
455
+ skipped_waiting_requests.prepend_request(request)
456
+ continue
457
+
458
+ # Check that adding the request still respects the max_loras
459
+ # constraint.
460
+ if (
461
+ self.lora_config
462
+ and request.lora_request
463
+ and (
464
+ len(scheduled_loras) == self.lora_config.max_loras
465
+ and request.lora_request.lora_int_id not in scheduled_loras
466
+ )
467
+ ):
468
+ # Scheduling would exceed max_loras, skip.
469
+ self.waiting.pop_request()
470
+ skipped_waiting_requests.prepend_request(request)
471
+ continue
472
+
473
+ num_external_computed_tokens = 0
474
+ load_kv_async = False
475
+
476
+ # Get already-cached tokens.
477
+ if request.num_computed_tokens == 0:
478
+ # Get locally-cached tokens.
479
+ new_computed_blocks, num_new_local_computed_tokens = (
480
+ self.kv_cache_manager.get_computed_blocks(request)
481
+ )
482
+
483
+ # Get externally-cached tokens if using a KVConnector.
484
+ if self.connector is not None:
485
+ ext_tokens, load_kv_async = (
486
+ self.connector.get_num_new_matched_tokens(
487
+ request, num_new_local_computed_tokens
488
+ )
489
+ )
490
+
491
+ if ext_tokens is None:
492
+ # The request cannot be scheduled because
493
+ # the KVConnector couldn't determine
494
+ # the number of matched tokens.
495
+ self.waiting.pop_request()
496
+ skipped_waiting_requests.prepend_request(request)
497
+ continue
498
+
499
+ request.num_external_computed_tokens = ext_tokens
500
+ num_external_computed_tokens = ext_tokens
501
+
502
+ # Total computed tokens (local + external).
503
+ num_computed_tokens = (
504
+ num_new_local_computed_tokens + num_external_computed_tokens
505
+ )
506
+ else:
507
+ # KVTransfer: WAITING reqs have num_computed_tokens > 0
508
+ # after async KV recvs are completed.
509
+ new_computed_blocks = self.kv_cache_manager.empty_kv_cache_blocks
510
+ num_new_local_computed_tokens = 0
511
+ num_computed_tokens = request.num_computed_tokens
512
+
513
+ encoder_inputs_to_schedule = None
514
+ external_load_encoder_input = []
515
+ new_encoder_compute_budget = encoder_compute_budget
516
+
517
+ if load_kv_async:
518
+ # KVTransfer: loading remote KV, do not allocate for new work.
519
+ assert num_external_computed_tokens > 0
520
+ num_new_tokens = 0
521
+ else:
522
+ # Number of tokens to be scheduled.
523
+ # We use `request.num_tokens` instead of
524
+ # `request.num_prompt_tokens` to consider the resumed
525
+ # requests, which have output tokens.
526
+ num_new_tokens = request.num_tokens - num_computed_tokens
527
+ threshold = self.scheduler_config.long_prefill_token_threshold
528
+ if 0 < threshold < num_new_tokens:
529
+ num_new_tokens = threshold
530
+
531
+ # chunked prefill has to be enabled explicitly to allow
532
+ # pooling requests to be chunked
533
+ if (
534
+ not self.scheduler_config.enable_chunked_prefill
535
+ and num_new_tokens > token_budget
536
+ ):
537
+ # If chunked_prefill is disabled,
538
+ # we can stop the scheduling here.
539
+ break
540
+
541
+ num_new_tokens = min(num_new_tokens, token_budget)
542
+ assert num_new_tokens > 0
543
+
544
+ # Schedule encoder inputs.
545
+ if request.has_encoder_inputs:
546
+ (
547
+ encoder_inputs_to_schedule,
548
+ num_new_tokens,
549
+ new_encoder_compute_budget,
550
+ external_load_encoder_input,
551
+ ) = self._try_schedule_encoder_inputs(
552
+ request,
553
+ num_computed_tokens,
554
+ num_new_tokens,
555
+ encoder_compute_budget,
556
+ shift_computed_tokens=1 if self.use_eagle else 0,
557
+ )
558
+ if num_new_tokens == 0:
559
+ # The request cannot be scheduled.
560
+ break
561
+
562
+ # Handles an edge case when P/D Disaggregation
563
+ # is used with Spec Decoding where an
564
+ # extra block gets allocated which
565
+ # creates a mismatch between the number
566
+ # of local and remote blocks.
567
+ effective_lookahead_tokens = (
568
+ 0 if request.num_computed_tokens == 0 else self.num_lookahead_tokens
569
+ )
570
+
571
+ # Determine if we need to allocate cross-attention blocks.
572
+ if self.is_encoder_decoder and request.has_encoder_inputs:
573
+ # TODO(russellb): For Whisper, we know that the input is
574
+ # always padded to the maximum length. If we support other
575
+ # encoder-decoder models, this will need to be updated if we
576
+ # want to only allocate what is needed.
577
+ num_encoder_tokens = (
578
+ self.scheduler_config.max_num_encoder_input_tokens
579
+ )
580
+ else:
581
+ num_encoder_tokens = 0
582
+
583
+ new_blocks = self.kv_cache_manager.allocate_slots(
584
+ request,
585
+ num_new_tokens + num_external_computed_tokens,
586
+ num_new_local_computed_tokens,
587
+ new_computed_blocks,
588
+ num_lookahead_tokens=effective_lookahead_tokens,
589
+ delay_cache_blocks=load_kv_async,
590
+ num_encoder_tokens=num_encoder_tokens,
591
+ )
592
+
593
+ if new_blocks is None:
594
+ # The request cannot be scheduled.
595
+ break
596
+
597
+ # KVTransfer: the connector uses this info to determine
598
+ # if a load is needed. Note that
599
+ # This information is used to determine if a load is
600
+ # needed for this request.
601
+ if self.connector is not None:
602
+ self.connector.update_state_after_alloc(
603
+ request,
604
+ new_computed_blocks + new_blocks,
605
+ num_external_computed_tokens,
606
+ )
607
+
608
+ # Request was already popped from self.waiting
609
+ # unless it was re-added above due to new_blocks being None.
610
+ request = self.waiting.pop_request()
611
+ if load_kv_async:
612
+ # If loading async, allocate memory and put request
613
+ # into the WAITING_FOR_REMOTE_KV state.
614
+ skipped_waiting_requests.prepend_request(request)
615
+ request.status = RequestStatus.WAITING_FOR_REMOTE_KVS
616
+ continue
617
+
618
+ self._update_connector_prefix_cache_stats(request)
619
+
620
+ self.running.append(request)
621
+ if self.log_stats:
622
+ request.record_event(
623
+ EngineCoreEventType.SCHEDULED, scheduled_timestamp
624
+ )
625
+ if request.status == RequestStatus.WAITING:
626
+ scheduled_new_reqs.append(request)
627
+ elif request.status == RequestStatus.PREEMPTED:
628
+ scheduled_resumed_reqs.append(request)
629
+ else:
630
+ raise RuntimeError(f"Invalid request status: {request.status}")
631
+
632
+ if self.lora_config and request.lora_request:
633
+ scheduled_loras.add(request.lora_request.lora_int_id)
634
+ req_to_new_blocks[request.request_id] = (
635
+ self.kv_cache_manager.get_blocks(request.request_id)
636
+ )
637
+ num_scheduled_tokens[request.request_id] = num_new_tokens
638
+ token_budget -= num_new_tokens
639
+ request.status = RequestStatus.RUNNING
640
+ request.num_computed_tokens = num_computed_tokens
641
+ # Count the number of prefix cached tokens.
642
+ if request.num_cached_tokens < 0:
643
+ request.num_cached_tokens = num_computed_tokens
644
+ # Encoder-related.
645
+ if encoder_inputs_to_schedule:
646
+ scheduled_encoder_inputs[request.request_id] = (
647
+ encoder_inputs_to_schedule
648
+ )
649
+ # Allocate the encoder cache.
650
+ for i in encoder_inputs_to_schedule:
651
+ self.encoder_cache_manager.allocate(request, i)
652
+ encoder_compute_budget = new_encoder_compute_budget
653
+ # Allocate for external load encoder cache
654
+ if external_load_encoder_input:
655
+ for i in external_load_encoder_input:
656
+ self.encoder_cache_manager.allocate(request, i)
657
+ if self.ec_connector is not None:
658
+ self.ec_connector.update_state_after_alloc(request, i)
659
+ # Put back any skipped requests at the head of the waiting queue
660
+ if skipped_waiting_requests:
661
+ self.waiting.prepend_requests(skipped_waiting_requests)
662
+
663
+ # Check if the scheduling constraints are satisfied.
664
+ total_num_scheduled_tokens = sum(num_scheduled_tokens.values())
665
+ assert total_num_scheduled_tokens <= self.max_num_scheduled_tokens
666
+
667
+ assert token_budget >= 0
668
+ assert len(self.running) <= self.max_num_running_reqs
669
+ # Since some requests in the RUNNING queue may not be scheduled in
670
+ # this step, the total number of scheduled requests can be smaller than
671
+ # len(self.running).
672
+ assert len(scheduled_new_reqs) + len(scheduled_resumed_reqs) + len(
673
+ scheduled_running_reqs
674
+ ) <= len(self.running)
675
+
676
+ # Get the longest common prefix among all requests in the running queue.
677
+ # This can be potentially used for cascade attention.
678
+ num_common_prefix_blocks = [0] * len(self.kv_cache_config.kv_cache_groups)
679
+ with record_function_or_nullcontext("schedule: get_num_common_prefix_blocks"):
680
+ if self.running:
681
+ any_request = self.running[0]
682
+ num_common_prefix_blocks = (
683
+ self.kv_cache_manager.get_num_common_prefix_blocks(
684
+ any_request.request_id
685
+ )
686
+ )
687
+
688
+ # Construct the scheduler output.
689
+ if self.use_v2_model_runner:
690
+ scheduled_new_reqs = scheduled_new_reqs + scheduled_resumed_reqs
691
+ scheduled_resumed_reqs = []
692
+ new_reqs_data = [
693
+ NewRequestData.from_request(
694
+ req,
695
+ req_to_new_blocks[req.request_id].get_block_ids(),
696
+ req._all_token_ids,
697
+ )
698
+ for req in scheduled_new_reqs
699
+ ]
700
+ else:
701
+ new_reqs_data = [
702
+ NewRequestData.from_request(
703
+ req, req_to_new_blocks[req.request_id].get_block_ids()
704
+ )
705
+ for req in scheduled_new_reqs
706
+ ]
707
+
708
+ with record_function_or_nullcontext("schedule: make_cached_request_data"):
709
+ cached_reqs_data = self._make_cached_request_data(
710
+ scheduled_running_reqs,
711
+ scheduled_resumed_reqs,
712
+ num_scheduled_tokens,
713
+ scheduled_spec_decode_tokens,
714
+ req_to_new_blocks,
715
+ )
716
+
717
+ # Record the request ids that were scheduled in this step.
718
+ self.prev_step_scheduled_req_ids.clear()
719
+ self.prev_step_scheduled_req_ids.update(num_scheduled_tokens.keys())
720
+
721
+ scheduler_output = SchedulerOutput(
722
+ scheduled_new_reqs=new_reqs_data,
723
+ scheduled_cached_reqs=cached_reqs_data,
724
+ num_scheduled_tokens=num_scheduled_tokens,
725
+ total_num_scheduled_tokens=total_num_scheduled_tokens,
726
+ scheduled_spec_decode_tokens=scheduled_spec_decode_tokens,
727
+ scheduled_encoder_inputs=scheduled_encoder_inputs,
728
+ num_common_prefix_blocks=num_common_prefix_blocks,
729
+ preempted_req_ids={req.request_id for req in preempted_reqs},
730
+ # finished_req_ids is an existing state in the scheduler,
731
+ # instead of being newly scheduled in this step.
732
+ # It contains the request IDs that are finished in between
733
+ # the previous and the current steps.
734
+ finished_req_ids=self.finished_req_ids,
735
+ free_encoder_mm_hashes=self.encoder_cache_manager.get_freed_mm_hashes(),
736
+ )
737
+
738
+ # NOTE(Kuntai): this function is designed for multiple purposes:
739
+ # 1. Plan the KV cache store
740
+ # 2. Wrap up all the KV cache load / save ops into an opaque object
741
+ # 3. Clear the internal states of the connector
742
+ if self.connector is not None:
743
+ meta: KVConnectorMetadata = self.connector.build_connector_meta(
744
+ scheduler_output
745
+ )
746
+ scheduler_output.kv_connector_metadata = meta
747
+
748
+ # Build the connector meta for ECConnector
749
+ if self.ec_connector is not None:
750
+ ec_meta: ECConnectorMetadata = self.ec_connector.build_connector_meta(
751
+ scheduler_output
752
+ )
753
+ scheduler_output.ec_connector_metadata = ec_meta
754
+
755
+ with record_function_or_nullcontext("schedule: update_after_schedule"):
756
+ self._update_after_schedule(scheduler_output)
757
+ return scheduler_output
758
+
759
+ def _preempt_request(
760
+ self,
761
+ request: Request,
762
+ timestamp: float,
763
+ ) -> None:
764
+ """Preempt a request and put it back to the waiting queue.
765
+
766
+ NOTE: The request should be popped from the running queue outside of this
767
+ method.
768
+ """
769
+ assert request.status == RequestStatus.RUNNING, (
770
+ "Only running requests can be preempted"
771
+ )
772
+ self.kv_cache_manager.free(request)
773
+ self.encoder_cache_manager.free(request)
774
+ request.status = RequestStatus.PREEMPTED
775
+ request.num_computed_tokens = 0
776
+ request.num_preemptions += 1
777
+ if self.log_stats:
778
+ request.record_event(EngineCoreEventType.PREEMPTED, timestamp)
779
+
780
+ # Put the request back to the waiting queue.
781
+ self.waiting.prepend_request(request)
782
+
783
+ def _update_after_schedule(
784
+ self,
785
+ scheduler_output: SchedulerOutput,
786
+ ) -> None:
787
+ # Advance the number of computed tokens for the request AFTER
788
+ # the request is scheduled.
789
+ # 1. The scheduler_output of the current step has to include the
790
+ # original number of scheduled tokens to determine input IDs.
791
+ # 2. Advance the number of computed tokens here allowing us to
792
+ # schedule the prefill request again immediately in the next
793
+ # scheduling step.
794
+ # 3. If some tokens (e.g. spec tokens) are rejected later, the number of
795
+ # computed tokens will be adjusted in update_from_output.
796
+ num_scheduled_tokens = scheduler_output.num_scheduled_tokens
797
+ for req_id, num_scheduled_token in num_scheduled_tokens.items():
798
+ request = self.requests[req_id]
799
+ request.num_computed_tokens += num_scheduled_token
800
+
801
+ # NOTE: _free_encoder_inputs relies on num_computed_tokens, which
802
+ # may be updated again in _update_from_output for speculative
803
+ # decoding. However, it is safe to call the method here because
804
+ # encoder inputs are always part of the prompt, not the output,
805
+ # and thus are unaffected by speculative decoding.
806
+ if request.has_encoder_inputs:
807
+ self._free_encoder_inputs(request)
808
+
809
+ # Clear the finished request IDs.
810
+ # NOTE: We shouldn't do self.finished_req_ids.clear() here because
811
+ # it will also affect the scheduler output.
812
+ self.finished_req_ids = set()
813
+
814
+ def _make_cached_request_data(
815
+ self,
816
+ running_reqs: list[Request],
817
+ resumed_reqs: list[Request],
818
+ num_scheduled_tokens: dict[str, int],
819
+ spec_decode_tokens: dict[str, list[int]],
820
+ req_to_new_blocks: dict[str, KVCacheBlocks],
821
+ ) -> CachedRequestData:
822
+ req_ids: list[str] = []
823
+ new_token_ids: list[list[int]] = []
824
+ new_block_ids: list[tuple[list[int], ...] | None] = []
825
+ all_token_ids: dict[str, list[int]] = {}
826
+ num_computed_tokens: list[int] = []
827
+ num_output_tokens: list[int] = []
828
+ resumed_req_ids = set()
829
+
830
+ num_running_reqs = len(running_reqs)
831
+ for idx, req in enumerate(itertools.chain(running_reqs, resumed_reqs)):
832
+ req_id = req.request_id
833
+ req_ids.append(req_id)
834
+ if self.use_pp:
835
+ # When using PP, the scheduler sends the sampled tokens back,
836
+ # because there's no direct communication between the first-
837
+ # stage worker and the last-stage worker. Otherwise, we don't
838
+ # need to send the sampled tokens back because the model runner
839
+ # will cache them.
840
+ num_tokens = num_scheduled_tokens[req_id] - len(
841
+ spec_decode_tokens.get(req_id, ())
842
+ )
843
+ token_ids = req.all_token_ids[
844
+ req.num_computed_tokens : req.num_computed_tokens + num_tokens
845
+ ]
846
+ new_token_ids.append(token_ids)
847
+ scheduled_in_prev_step = req_id in self.prev_step_scheduled_req_ids
848
+ if idx >= num_running_reqs:
849
+ assert not scheduled_in_prev_step
850
+ resumed_req_ids.add(req_id)
851
+ if not scheduled_in_prev_step:
852
+ all_token_ids[req_id] = req.all_token_ids.copy()
853
+ new_block_ids.append(
854
+ req_to_new_blocks[req_id].get_block_ids(allow_none=True)
855
+ )
856
+ num_computed_tokens.append(req.num_computed_tokens)
857
+ num_output_tokens.append(
858
+ req.num_output_tokens + req.num_output_placeholders
859
+ )
860
+
861
+ return CachedRequestData(
862
+ req_ids=req_ids,
863
+ resumed_req_ids=resumed_req_ids,
864
+ new_token_ids=new_token_ids,
865
+ all_token_ids=all_token_ids,
866
+ new_block_ids=new_block_ids,
867
+ num_computed_tokens=num_computed_tokens,
868
+ num_output_tokens=num_output_tokens,
869
+ )
870
+
871
+ def _try_schedule_encoder_inputs(
872
+ self,
873
+ request: Request,
874
+ num_computed_tokens: int,
875
+ num_new_tokens: int,
876
+ encoder_compute_budget: int,
877
+ shift_computed_tokens: int = 0,
878
+ ) -> tuple[list[int], int, int, list[int]]:
879
+ """
880
+ Determine which encoder inputs need to be scheduled in the current step,
881
+ and update `num_new_tokens` and encoder token budget accordingly.
882
+
883
+ An encoder input will be scheduled if:
884
+ - Its output tokens overlap with the range of tokens being computed
885
+ in this step, i.e.,
886
+ [num_computed_tokens, num_computed_tokens + num_new_tokens).
887
+ - It is not already computed and stored in the encoder cache.
888
+ - It is not exist on remote encoder cache (via ECConnector)
889
+ - There is sufficient encoder token budget to process it.
890
+ - The encoder cache has space to store it.
891
+
892
+ If an encoder input cannot be scheduled due to cache or budget
893
+ limitations, the method adjusts `num_new_tokens` to schedule only the
894
+ decoder tokens up to just before the unschedulable encoder input.
895
+
896
+ Note that num_computed_tokens includes both locally cached
897
+ blocks and externally cached blocks (via KVConnector).
898
+ """
899
+ if num_new_tokens == 0 or not request.has_encoder_inputs:
900
+ return [], num_new_tokens, encoder_compute_budget, []
901
+ encoder_inputs_to_schedule: list[int] = []
902
+ mm_features = request.mm_features
903
+ assert mm_features is not None
904
+ assert len(mm_features) > 0
905
+ external_load_encoder_input = []
906
+
907
+ # Check remote cache first
908
+ if self.ec_connector is not None:
909
+ remote_cache_has_item = self.ec_connector.has_caches(request)
910
+ # NOTE: since scheduler operates on the request level (possibly with
911
+ # multiple encoder inputs per request), we need to create temporary
912
+ # trackers for accounting at the encoder input level.
913
+ mm_hashes_to_schedule = set()
914
+ num_embeds_to_schedule = 0
915
+ for i, mm_feature in enumerate(mm_features):
916
+ start_pos = mm_feature.mm_position.offset
917
+ num_encoder_tokens = mm_feature.mm_position.length
918
+ num_encoder_embeds = mm_feature.mm_position.get_num_embeds
919
+
920
+ # The encoder output is needed if the two ranges overlap:
921
+ # [num_computed_tokens, num_computed_tokens + num_new_tokens) and
922
+ # [start_pos, start_pos + num_encoder_tokens)
923
+ if (
924
+ start_pos
925
+ >= num_computed_tokens + num_new_tokens + shift_computed_tokens
926
+ ):
927
+ # The encoder input is not needed in this step.
928
+ break
929
+
930
+ if self.is_encoder_decoder and num_computed_tokens > 0:
931
+ assert start_pos == 0, (
932
+ "Encoder input should be processed at the beginning of "
933
+ "the sequence when encoder-decoder models are used."
934
+ )
935
+ # Encoder input has already been computed
936
+ # The calculation here is a bit different. We don't turn encoder
937
+ # output into tokens that get processed by the decoder and
938
+ # reflected in num_computed_tokens. Instead, start_pos reflects
939
+ # the position where we need to ensure we calculate encoder
940
+ # inputs. This should always be 0 to ensure we calculate encoder
941
+ # inputs before running the decoder. Once we've calculated some
942
+ # decoder tokens (num_computed_tokens > 0), then we know we
943
+ # already calculated encoder inputs and can skip here.
944
+ continue
945
+ elif start_pos + num_encoder_tokens <= num_computed_tokens:
946
+ # The encoder input is already computed and stored
947
+ # in the decoder's KV cache.
948
+ continue
949
+
950
+ if not self.is_encoder_decoder:
951
+ # We are not using the encoder cache for encoder-decoder models,
952
+ # yet.
953
+ if request.mm_features[i].identifier in mm_hashes_to_schedule:
954
+ # The same encoder input has already been scheduled in the
955
+ # current step.
956
+ continue
957
+
958
+ if self.encoder_cache_manager.check_and_update_cache(request, i):
959
+ # The encoder input is already computed and cached from a
960
+ # previous step.
961
+ continue
962
+
963
+ # If no encoder input chunking is allowed, we do not want to
964
+ # partially schedule a multimodal item. If the scheduled range would
965
+ # only cover part of the mm input, roll back to before the mm item.
966
+ if (
967
+ self.scheduler_config.disable_chunked_mm_input
968
+ and num_computed_tokens < start_pos
969
+ and (num_computed_tokens + num_new_tokens)
970
+ < (start_pos + num_encoder_tokens)
971
+ ):
972
+ num_new_tokens = start_pos - num_computed_tokens
973
+ break
974
+ if not self.encoder_cache_manager.can_allocate(
975
+ request, i, encoder_compute_budget, num_embeds_to_schedule
976
+ ):
977
+ # The encoder cache is full or the encoder budget is exhausted.
978
+ # NOTE(woosuk): We assume that the encoder input tokens should
979
+ # be processed altogether, as the encoder usually uses
980
+ # bidirectional attention.
981
+ if num_computed_tokens + shift_computed_tokens < start_pos:
982
+ # We only schedule the decoder tokens just before the
983
+ # encoder input.
984
+ num_new_tokens = start_pos - (
985
+ num_computed_tokens + shift_computed_tokens
986
+ )
987
+ else:
988
+ # Because of prefix caching, num_computed_tokens is greater
989
+ # than start_pos even though its encoder input is not
990
+ # available. In this case, we can't schedule any token for
991
+ # the request in this step.
992
+ num_new_tokens = 0
993
+ break
994
+
995
+ # Calculate the number of embeddings to schedule in the current range
996
+ # of scheduled encoder placholder tokens.
997
+ start_idx_rel = max(0, num_computed_tokens - start_pos)
998
+ end_idx_rel = min(
999
+ num_encoder_tokens, num_computed_tokens + num_new_tokens - start_pos
1000
+ )
1001
+ curr_embeds_start, curr_embeds_end = (
1002
+ mm_feature.mm_position.get_embeds_indices_in_range(
1003
+ start_idx_rel,
1004
+ end_idx_rel,
1005
+ )
1006
+ )
1007
+ # There's no embeddings in the current range of encoder placeholder tokens
1008
+ # so we can skip the encoder input.
1009
+ if curr_embeds_end - curr_embeds_start == 0:
1010
+ continue
1011
+
1012
+ if self.ec_connector is not None and remote_cache_has_item[i]:
1013
+ mm_hashes_to_schedule.add(request.mm_features[i].identifier)
1014
+ external_load_encoder_input.append(i)
1015
+ num_embeds_to_schedule += num_encoder_embeds
1016
+ continue
1017
+
1018
+ num_embeds_to_schedule += num_encoder_embeds
1019
+ encoder_compute_budget -= num_encoder_embeds
1020
+ mm_hashes_to_schedule.add(request.mm_features[i].identifier)
1021
+ encoder_inputs_to_schedule.append(i)
1022
+
1023
+ return (
1024
+ encoder_inputs_to_schedule,
1025
+ num_new_tokens,
1026
+ encoder_compute_budget,
1027
+ external_load_encoder_input,
1028
+ )
1029
+
1030
+ def get_grammar_bitmask(
1031
+ self,
1032
+ scheduler_output: SchedulerOutput,
1033
+ ) -> GrammarOutput | None:
1034
+ # Collect list of scheduled request ids that use structured output.
1035
+ # The corresponding rows of the bitmask will be in this order.
1036
+ # PERF: in case of chunked prefill,
1037
+ # request might not include any new tokens.
1038
+ # Therefore, we might introduce some additional
1039
+ # cycle to fill in the bitmask, which could be a big no-op.
1040
+ structured_output_request_ids = [
1041
+ req_id
1042
+ for req_id in scheduler_output.num_scheduled_tokens
1043
+ if (req := self.requests.get(req_id)) and req.use_structured_output
1044
+ ]
1045
+ if not structured_output_request_ids:
1046
+ return None
1047
+
1048
+ bitmask = self.structured_output_manager.grammar_bitmask(
1049
+ self.requests,
1050
+ structured_output_request_ids,
1051
+ scheduler_output.scheduled_spec_decode_tokens,
1052
+ )
1053
+ return GrammarOutput(structured_output_request_ids, bitmask)
1054
+
1055
+ def update_from_output(
1056
+ self,
1057
+ scheduler_output: SchedulerOutput,
1058
+ model_runner_output: ModelRunnerOutput,
1059
+ ) -> dict[int, EngineCoreOutputs]:
1060
+ sampled_token_ids = model_runner_output.sampled_token_ids
1061
+ logprobs = model_runner_output.logprobs
1062
+ prompt_logprobs_dict = model_runner_output.prompt_logprobs_dict
1063
+ num_scheduled_tokens = scheduler_output.num_scheduled_tokens
1064
+ pooler_outputs = model_runner_output.pooler_output
1065
+ num_nans_in_logits = model_runner_output.num_nans_in_logits
1066
+ kv_connector_output = model_runner_output.kv_connector_output
1067
+ cudagraph_stats = model_runner_output.cudagraph_stats
1068
+
1069
+ outputs: dict[int, list[EngineCoreOutput]] = defaultdict(list)
1070
+ spec_decoding_stats: SpecDecodingStats | None = None
1071
+ kv_connector_stats: KVConnectorStats | None = (
1072
+ kv_connector_output.kv_connector_stats if kv_connector_output else None
1073
+ )
1074
+ if kv_connector_stats and self.connector:
1075
+ kv_stats = self.connector.get_kv_connector_stats()
1076
+ if kv_stats:
1077
+ kv_connector_stats = kv_connector_stats.aggregate(kv_stats)
1078
+
1079
+ failed_kv_load_req_ids = None
1080
+ if kv_connector_output and kv_connector_output.invalid_block_ids:
1081
+ # These blocks contain externally computed tokens that failed to
1082
+ # load. Identify affected requests and adjust their computed token
1083
+ # count to trigger recomputation of the invalid blocks.
1084
+ failed_kv_load_req_ids = self._handle_invalid_blocks(
1085
+ kv_connector_output.invalid_block_ids
1086
+ )
1087
+
1088
+ # NOTE(woosuk): As len(num_scheduled_tokens) can be up to 1K or more,
1089
+ # the below loop can be a performance bottleneck. We should do our best
1090
+ # to avoid expensive operations inside the loop.
1091
+ stopped_running_reqs: set[Request] = set()
1092
+ stopped_preempted_reqs: set[Request] = set()
1093
+ for req_id, num_tokens_scheduled in num_scheduled_tokens.items():
1094
+ assert num_tokens_scheduled > 0
1095
+ if failed_kv_load_req_ids and req_id in failed_kv_load_req_ids:
1096
+ # skip failed or rescheduled requests from KV load failure
1097
+ continue
1098
+ request = self.requests.get(req_id)
1099
+ if request is None:
1100
+ # The request is already finished. This can happen if the
1101
+ # request is aborted while the model is executing it (e.g.,
1102
+ # in pipeline parallelism).
1103
+ continue
1104
+
1105
+ req_index = model_runner_output.req_id_to_index[req_id]
1106
+ generated_token_ids = (
1107
+ sampled_token_ids[req_index] if sampled_token_ids else []
1108
+ )
1109
+
1110
+ scheduled_spec_token_ids = (
1111
+ scheduler_output.scheduled_spec_decode_tokens.get(req_id)
1112
+ )
1113
+ if scheduled_spec_token_ids:
1114
+ num_draft_tokens = len(scheduled_spec_token_ids)
1115
+ num_accepted = len(generated_token_ids) - 1
1116
+ num_rejected = num_draft_tokens - num_accepted
1117
+ # num_computed_tokens represents the number of tokens
1118
+ # processed in the current step, considering scheduled
1119
+ # tokens and rejections. If some tokens are rejected,
1120
+ # num_computed_tokens is decreased by the number of rejected
1121
+ # tokens.
1122
+ if request.num_computed_tokens > 0:
1123
+ request.num_computed_tokens -= num_rejected
1124
+ # If async scheduling, num_output_placeholders also includes
1125
+ # the scheduled spec tokens count and so is similarly adjusted.
1126
+ if request.num_output_placeholders > 0:
1127
+ request.num_output_placeholders -= num_rejected
1128
+ spec_decoding_stats = self.make_spec_decoding_stats(
1129
+ spec_decoding_stats,
1130
+ num_draft_tokens=num_draft_tokens,
1131
+ num_accepted_tokens=num_accepted,
1132
+ )
1133
+
1134
+ stopped = False
1135
+ new_logprobs = None
1136
+ new_token_ids = generated_token_ids
1137
+ pooler_output = pooler_outputs[req_index] if pooler_outputs else None
1138
+ kv_transfer_params = None
1139
+ status_before_stop = request.status
1140
+
1141
+ # Check for stop and update request status.
1142
+ if new_token_ids:
1143
+ new_token_ids, stopped = self._update_request_with_output(
1144
+ request, new_token_ids
1145
+ )
1146
+ elif request.pooling_params and pooler_output is not None:
1147
+ # Pooling stops as soon as there is output.
1148
+ request.status = RequestStatus.FINISHED_STOPPED
1149
+ stopped = True
1150
+
1151
+ if stopped:
1152
+ kv_transfer_params = self._free_request(request)
1153
+ if status_before_stop == RequestStatus.RUNNING:
1154
+ stopped_running_reqs.add(request)
1155
+ else:
1156
+ stopped_preempted_reqs.add(request)
1157
+
1158
+ # Extract sample logprobs if needed.
1159
+ if (
1160
+ request.sampling_params is not None
1161
+ and request.sampling_params.logprobs is not None
1162
+ and logprobs
1163
+ ):
1164
+ new_logprobs = logprobs.slice_request(req_index, len(new_token_ids))
1165
+
1166
+ if new_token_ids and self.structured_output_manager.should_advance(request):
1167
+ struct_output_request = request.structured_output_request
1168
+ assert struct_output_request is not None
1169
+ assert struct_output_request.grammar is not None
1170
+ struct_output_request.grammar.accept_tokens(req_id, new_token_ids)
1171
+
1172
+ if num_nans_in_logits is not None and req_id in num_nans_in_logits:
1173
+ request.num_nans_in_logits = num_nans_in_logits[req_id]
1174
+
1175
+ # Get prompt logprobs for this request.
1176
+ prompt_logprobs_tensors = prompt_logprobs_dict.get(req_id)
1177
+ if new_token_ids or pooler_output is not None or kv_transfer_params:
1178
+ # Add EngineCoreOutput for this Request.
1179
+ outputs[request.client_index].append(
1180
+ EngineCoreOutput(
1181
+ request_id=req_id,
1182
+ new_token_ids=new_token_ids,
1183
+ finish_reason=request.get_finished_reason(),
1184
+ new_logprobs=new_logprobs,
1185
+ new_prompt_logprobs_tensors=prompt_logprobs_tensors,
1186
+ pooling_output=pooler_output,
1187
+ stop_reason=request.stop_reason,
1188
+ events=request.take_events(),
1189
+ kv_transfer_params=kv_transfer_params,
1190
+ trace_headers=request.trace_headers,
1191
+ num_cached_tokens=request.num_cached_tokens,
1192
+ num_nans_in_logits=request.num_nans_in_logits,
1193
+ )
1194
+ )
1195
+ else:
1196
+ # Invariant: EngineCore returns no partial prefill outputs.
1197
+ assert not prompt_logprobs_tensors
1198
+
1199
+ # Remove the stopped requests from the running and waiting queues.
1200
+ if stopped_running_reqs:
1201
+ self.running = remove_all(self.running, stopped_running_reqs)
1202
+ if stopped_preempted_reqs:
1203
+ # This is a rare case and unlikely to impact performance.
1204
+ self.waiting.remove_requests(stopped_preempted_reqs)
1205
+
1206
+ if failed_kv_load_req_ids and not self.recompute_kv_load_failures:
1207
+ requests = [self.requests[req_id] for req_id in failed_kv_load_req_ids]
1208
+ self.finish_requests(failed_kv_load_req_ids, RequestStatus.FINISHED_ERROR)
1209
+ for request in requests:
1210
+ outputs[request.client_index].append(
1211
+ EngineCoreOutput(
1212
+ request_id=request.request_id,
1213
+ new_token_ids=[],
1214
+ finish_reason=request.get_finished_reason(),
1215
+ events=request.take_events(),
1216
+ trace_headers=request.trace_headers,
1217
+ num_cached_tokens=request.num_cached_tokens,
1218
+ )
1219
+ )
1220
+
1221
+ # KV Connector: update state for finished KV Transfers.
1222
+ if kv_connector_output:
1223
+ self._update_from_kv_xfer_finished(kv_connector_output)
1224
+
1225
+ # collect KV cache events from KV cache manager
1226
+ events = self.kv_cache_manager.take_events()
1227
+
1228
+ # collect KV cache events from connector
1229
+ if self.connector is not None:
1230
+ connector_events = self.connector.take_events()
1231
+ if connector_events:
1232
+ if events is None:
1233
+ events = list(connector_events)
1234
+ else:
1235
+ events.extend(connector_events)
1236
+
1237
+ # publish collected KV cache events
1238
+ if events:
1239
+ batch = KVEventBatch(ts=time.time(), events=events)
1240
+ self.kv_event_publisher.publish(batch)
1241
+
1242
+ # Create EngineCoreOutputs for all clients that have requests with
1243
+ # outputs in this step.
1244
+ engine_core_outputs = {
1245
+ client_index: EngineCoreOutputs(outputs=outs)
1246
+ for client_index, outs in outputs.items()
1247
+ }
1248
+
1249
+ finished_req_ids = self.finished_req_ids_dict
1250
+ if finished_req_ids:
1251
+ # Include ids of requests that finished since last outputs
1252
+ # were sent.
1253
+ for client_index, finished_set in finished_req_ids.items():
1254
+ # Set finished request set in EngineCoreOutputs for this client.
1255
+ if (eco := engine_core_outputs.get(client_index)) is not None:
1256
+ eco.finished_requests = finished_set
1257
+ else:
1258
+ engine_core_outputs[client_index] = EngineCoreOutputs(
1259
+ finished_requests=finished_set
1260
+ )
1261
+ finished_req_ids.clear()
1262
+
1263
+ if (
1264
+ stats := self.make_stats(
1265
+ spec_decoding_stats, kv_connector_stats, cudagraph_stats
1266
+ )
1267
+ ) is not None:
1268
+ # Return stats to only one of the front-ends.
1269
+ if (eco := next(iter(engine_core_outputs.values()), None)) is None:
1270
+ # We must return the stats even if there are no request
1271
+ # outputs this step.
1272
+ engine_core_outputs[0] = eco = EngineCoreOutputs()
1273
+ eco.scheduler_stats = stats
1274
+
1275
+ return engine_core_outputs
1276
+
1277
+ def _update_request_with_output(
1278
+ self,
1279
+ request: Request,
1280
+ new_token_ids: list[int],
1281
+ ) -> tuple[list[int], bool]:
1282
+ # Append generated tokens and check for stop. Note that if
1283
+ # a request is still being prefilled, we expect the model runner
1284
+ # to return empty token ids for the request.
1285
+ stopped = False
1286
+ for num_new, output_token_id in enumerate(new_token_ids, 1):
1287
+ request.append_output_token_ids(output_token_id)
1288
+
1289
+ # Check for stop and update request state.
1290
+ # This must be called before we make the EngineCoreOutput.
1291
+ stopped = check_stop(request, self.max_model_len)
1292
+ if stopped:
1293
+ del new_token_ids[num_new:] # Trim new tokens if needed.
1294
+ break
1295
+ return new_token_ids, stopped
1296
+
1297
+ def _free_encoder_inputs(self, request: Request) -> None:
1298
+ cached_encoder_input_ids = self.encoder_cache_manager.get_cached_input_ids(
1299
+ request
1300
+ )
1301
+ # OPTIMIZATION: Avoid list(set) if the set is empty.
1302
+ if not cached_encoder_input_ids:
1303
+ return
1304
+
1305
+ # Here, we use list(set) to avoid modifying the set while iterating
1306
+ # over it.
1307
+ for input_id in list(cached_encoder_input_ids):
1308
+ mm_feature = request.mm_features[input_id]
1309
+ start_pos = mm_feature.mm_position.offset
1310
+ num_tokens = mm_feature.mm_position.length
1311
+ if self.is_encoder_decoder and request.num_computed_tokens > 0:
1312
+ # With Whisper, as soon as we've generated a single token,
1313
+ # we know we're done with the encoder input. Cross Attention
1314
+ # KVs have been calculated and cached already.
1315
+ self.encoder_cache_manager.free_encoder_input(request, input_id)
1316
+ elif start_pos + num_tokens <= request.num_computed_tokens:
1317
+ # The encoder output is already processed and stored
1318
+ # in the decoder's KV cache.
1319
+ self.encoder_cache_manager.free_encoder_input(request, input_id)
1320
+
1321
+ def update_draft_token_ids(
1322
+ self,
1323
+ draft_token_ids: DraftTokenIds,
1324
+ ) -> None:
1325
+ for req_id, spec_token_ids in zip(
1326
+ draft_token_ids.req_ids,
1327
+ draft_token_ids.draft_token_ids,
1328
+ ):
1329
+ request = self.requests.get(req_id)
1330
+ if request is None or request.is_finished():
1331
+ # The request may have been finished. Skip.
1332
+ continue
1333
+
1334
+ # Add newly generated spec token ids to the request.
1335
+ if self.structured_output_manager.should_advance(request):
1336
+ metadata = request.structured_output_request
1337
+ request.spec_token_ids = metadata.grammar.validate_tokens( # type: ignore[union-attr]
1338
+ spec_token_ids
1339
+ )
1340
+ else:
1341
+ request.spec_token_ids = spec_token_ids
1342
+
1343
+ def get_request_counts(self) -> tuple[int, int]:
1344
+ """Returns (num_running_reqs, num_waiting_reqs)."""
1345
+ return len(self.running), len(self.waiting)
1346
+
1347
+ def add_request(self, request: Request) -> None:
1348
+ self.waiting.add_request(request)
1349
+ self.requests[request.request_id] = request
1350
+ if self.log_stats:
1351
+ request.record_event(EngineCoreEventType.QUEUED)
1352
+
1353
+ def finish_requests(
1354
+ self,
1355
+ request_ids: str | Iterable[str],
1356
+ finished_status: RequestStatus,
1357
+ ) -> None:
1358
+ """Handles the finish signal from outside the scheduler.
1359
+
1360
+ For example, the API server can abort a request when the client
1361
+ disconnects.
1362
+ """
1363
+ assert RequestStatus.is_finished(finished_status)
1364
+ if isinstance(request_ids, str):
1365
+ request_ids = (request_ids,)
1366
+ else:
1367
+ request_ids = set(request_ids)
1368
+
1369
+ running_requests_to_remove = set()
1370
+ waiting_requests_to_remove = []
1371
+ valid_requests = []
1372
+
1373
+ # First pass: collect requests to remove from queues
1374
+ for req_id in request_ids:
1375
+ request = self.requests.get(req_id)
1376
+ if request is None or request.is_finished():
1377
+ # Invalid request ID.
1378
+ continue
1379
+
1380
+ valid_requests.append(request)
1381
+ if request.status == RequestStatus.RUNNING:
1382
+ running_requests_to_remove.add(request)
1383
+ else:
1384
+ waiting_requests_to_remove.append(request)
1385
+
1386
+ # Remove all requests from queues at once for better efficiency
1387
+ if running_requests_to_remove:
1388
+ self.running = remove_all(self.running, running_requests_to_remove)
1389
+ if waiting_requests_to_remove:
1390
+ self.waiting.remove_requests(waiting_requests_to_remove)
1391
+
1392
+ # Second pass: set status and free requests
1393
+ for request in valid_requests:
1394
+ request.status = finished_status
1395
+ self._free_request(request)
1396
+
1397
+ def _free_request(self, request: Request) -> dict[str, Any] | None:
1398
+ assert request.is_finished()
1399
+
1400
+ delay_free_blocks, kv_xfer_params = self._connector_finished(request)
1401
+ self.encoder_cache_manager.free(request)
1402
+ request_id = request.request_id
1403
+ self.finished_req_ids.add(request_id)
1404
+ if self.finished_req_ids_dict is not None:
1405
+ self.finished_req_ids_dict[request.client_index].add(request_id)
1406
+
1407
+ if not delay_free_blocks:
1408
+ self._free_blocks(request)
1409
+
1410
+ return kv_xfer_params
1411
+
1412
+ def _free_blocks(self, request: Request):
1413
+ assert request.is_finished()
1414
+ self.kv_cache_manager.free(request)
1415
+ del self.requests[request.request_id]
1416
+
1417
+ def get_num_unfinished_requests(self) -> int:
1418
+ return len(self.waiting) + len(self.running)
1419
+
1420
+ def has_finished_requests(self) -> bool:
1421
+ return len(self.finished_req_ids) > 0
1422
+
1423
+ def reset_prefix_cache(
1424
+ self, reset_running_requests: bool = False, reset_connector: bool = False
1425
+ ) -> bool:
1426
+ """Reset the KV prefix cache.
1427
+
1428
+ If reset_running_requests is True, all the running requests will be
1429
+ preempted and moved to the waiting queue.
1430
+ Otherwise, this method will only reset the KV prefix cache when there
1431
+ is no running requests taking KV cache.
1432
+ """
1433
+ if reset_running_requests:
1434
+ # For logging.
1435
+ timestamp = time.monotonic()
1436
+ # Invalidate all the current running requests KV's by pushing them to
1437
+ # the waiting queue. In this case, we can reduce the ref count of all
1438
+ # the kv blocks to 0 and thus we can make sure the reset is successful.
1439
+ # Preempt in reverse order so the requests will be added back to the
1440
+ # running queue in FIFO order.
1441
+ while self.running:
1442
+ request = self.running.pop()
1443
+ self._preempt_request(request, timestamp)
1444
+ # NOTE(zhuohan): For async scheduling, we need to discard the latest
1445
+ # output token on the fly to avoid a redundant repetitive output token.
1446
+ request.num_output_placeholders = 0
1447
+ request.discard_latest_async_tokens = True
1448
+
1449
+ # Clear scheduled request ids cache. Since we are forcing preemption
1450
+ # + resumption in the same step, we must act as if these requests were
1451
+ # not scheduled in the prior step. They will be flushed from the
1452
+ # persistent batch in the model runner.
1453
+ self.prev_step_scheduled_req_ids.clear()
1454
+
1455
+ reset_successful = self.kv_cache_manager.reset_prefix_cache()
1456
+ if reset_running_requests and not reset_successful:
1457
+ raise RuntimeError(
1458
+ "Failed to reset KV cache even when all the running requests are "
1459
+ "preempted and moved to the waiting queue. This is likely due to "
1460
+ "the presence of running requests waiting for remote KV transfer, "
1461
+ "which is not supported yet."
1462
+ )
1463
+
1464
+ if reset_connector:
1465
+ reset_successful = self.reset_connector_cache() and reset_successful
1466
+
1467
+ return reset_successful
1468
+
1469
+ def reset_connector_cache(self) -> bool:
1470
+ if self.connector is None:
1471
+ logger.warning("reset_connector called but no KV connector is configured.")
1472
+ return False
1473
+
1474
+ if self.connector.reset_cache() is False:
1475
+ return False
1476
+
1477
+ if self.log_stats:
1478
+ assert self.connector_prefix_cache_stats is not None
1479
+ self.connector_prefix_cache_stats.reset = True
1480
+
1481
+ return True
1482
+
1483
+ def make_stats(
1484
+ self,
1485
+ spec_decoding_stats: SpecDecodingStats | None = None,
1486
+ kv_connector_stats: KVConnectorStats | None = None,
1487
+ cudagraph_stats: CUDAGraphStat | None = None,
1488
+ ) -> SchedulerStats | None:
1489
+ if not self.log_stats:
1490
+ return None
1491
+ prefix_cache_stats = self.kv_cache_manager.make_prefix_cache_stats()
1492
+ assert prefix_cache_stats is not None
1493
+ connector_prefix_cache_stats = self._make_connector_prefix_cache_stats()
1494
+ eviction_events = (
1495
+ self.kv_metrics_collector.drain_events()
1496
+ if self.kv_metrics_collector is not None
1497
+ else []
1498
+ )
1499
+ spec_stats = spec_decoding_stats
1500
+ connector_stats_payload = (
1501
+ kv_connector_stats.data if kv_connector_stats else None
1502
+ )
1503
+ return SchedulerStats(
1504
+ num_running_reqs=len(self.running),
1505
+ num_waiting_reqs=len(self.waiting),
1506
+ kv_cache_usage=self.kv_cache_manager.usage,
1507
+ prefix_cache_stats=prefix_cache_stats,
1508
+ connector_prefix_cache_stats=connector_prefix_cache_stats,
1509
+ kv_cache_eviction_events=eviction_events,
1510
+ spec_decoding_stats=spec_stats,
1511
+ kv_connector_stats=connector_stats_payload,
1512
+ cudagraph_stats=cudagraph_stats,
1513
+ )
1514
+
1515
+ def make_spec_decoding_stats(
1516
+ self,
1517
+ spec_decoding_stats: SpecDecodingStats | None,
1518
+ num_draft_tokens: int,
1519
+ num_accepted_tokens: int,
1520
+ ) -> SpecDecodingStats | None:
1521
+ if not self.log_stats:
1522
+ return None
1523
+ if spec_decoding_stats is None:
1524
+ spec_decoding_stats = SpecDecodingStats.new(self.num_spec_tokens)
1525
+ spec_decoding_stats.observe_draft(
1526
+ num_draft_tokens=num_draft_tokens, num_accepted_tokens=num_accepted_tokens
1527
+ )
1528
+ return spec_decoding_stats
1529
+
1530
+ def shutdown(self) -> None:
1531
+ if self.kv_event_publisher:
1532
+ self.kv_event_publisher.shutdown()
1533
+ if self.connector is not None:
1534
+ self.connector.shutdown()
1535
+
1536
+ ########################################################################
1537
+ # KV Connector Related Methods
1538
+ ########################################################################
1539
+
1540
+ def _update_connector_prefix_cache_stats(self, request: Request) -> None:
1541
+ if self.connector_prefix_cache_stats is None:
1542
+ return
1543
+
1544
+ self.connector_prefix_cache_stats.record(
1545
+ num_tokens=request.num_tokens,
1546
+ num_hits=request.num_external_computed_tokens,
1547
+ preempted=request.num_preemptions > 0,
1548
+ )
1549
+
1550
+ def _make_connector_prefix_cache_stats(self) -> PrefixCacheStats | None:
1551
+ if self.connector_prefix_cache_stats is None:
1552
+ return None
1553
+ stats = self.connector_prefix_cache_stats
1554
+ self.connector_prefix_cache_stats = PrefixCacheStats()
1555
+ return stats
1556
+
1557
+ def get_kv_connector(self) -> KVConnectorBase_V1 | None:
1558
+ return self.connector
1559
+
1560
+ def _connector_finished(
1561
+ self, request: Request
1562
+ ) -> tuple[bool, dict[str, Any] | None]:
1563
+ """
1564
+ Invoke the KV connector request_finished() method if applicable.
1565
+
1566
+ Returns optional kv transfer parameters to be included with the
1567
+ request outputs.
1568
+ """
1569
+ if self.connector is None:
1570
+ return False, None
1571
+
1572
+ block_ids = self.kv_cache_manager.get_block_ids(request.request_id)
1573
+
1574
+ if not isinstance(self.connector, SupportsHMA):
1575
+ # NOTE(Kuntai): We should deprecate this code path after we enforce
1576
+ # all connectors to support HMA.
1577
+ # Hybrid memory allocator should be already turned off for this
1578
+ # code path, but let's double-check here.
1579
+ assert len(self.kv_cache_config.kv_cache_groups) == 1
1580
+ return self.connector.request_finished(request, block_ids[0])
1581
+
1582
+ return self.connector.request_finished_all_groups(request, block_ids)
1583
+
1584
+ def _update_waiting_for_remote_kv(self, request: Request) -> bool:
1585
+ """
1586
+ KV Connector: check if the request_id is finished_recving.
1587
+
1588
+ The finished_recving_kv_req_ids list is populated
1589
+ on the previous steps()'s update_from_output based
1590
+ on the worker side connector.
1591
+
1592
+ When the kv transfer is ready, we cache the blocks
1593
+ and the request state will be moved back to WAITING from
1594
+ WAITING_FOR_REMOTE_KV.
1595
+ """
1596
+ assert self.connector is not None
1597
+ if request.request_id not in self.finished_recving_kv_req_ids:
1598
+ return False
1599
+
1600
+ if request.request_id in self.failed_recving_kv_req_ids:
1601
+ # Request had KV load failures; num_computed_tokens was already
1602
+ # updated in _update_requests_with_invalid_blocks
1603
+ if request.num_computed_tokens:
1604
+ # Cache any valid computed tokens.
1605
+ self.kv_cache_manager.cache_blocks(request, request.num_computed_tokens)
1606
+ else:
1607
+ # No valid computed tokens, release allocated blocks.
1608
+ # There may be a local cache hit on retry.
1609
+ self.kv_cache_manager.free(request)
1610
+
1611
+ self.failed_recving_kv_req_ids.remove(request.request_id)
1612
+ else:
1613
+ # Now that the blocks are ready, actually cache them.
1614
+ (block_ids,) = self.kv_cache_manager.get_block_ids(request.request_id)
1615
+ num_computed_tokens = len(block_ids) * self.block_size
1616
+ # Handle the case where num request tokens less than one block.
1617
+ num_computed_tokens = min(num_computed_tokens, request.num_tokens)
1618
+ if num_computed_tokens == request.num_tokens:
1619
+ num_computed_tokens -= 1
1620
+ # This will cache the blocks iff caching is enabled.
1621
+ self.kv_cache_manager.cache_blocks(request, num_computed_tokens)
1622
+
1623
+ # Update the request state for scheduling.
1624
+ request.num_computed_tokens = num_computed_tokens
1625
+
1626
+ # Return that we are ready.
1627
+ self.finished_recving_kv_req_ids.remove(request.request_id)
1628
+ return True
1629
+
1630
+ def _update_from_kv_xfer_finished(self, kv_connector_output: KVConnectorOutput):
1631
+ """
1632
+ KV Connector: update the scheduler state based on the output.
1633
+
1634
+ The Worker side connectors add finished_recving and
1635
+ finished_sending reqs to the output.
1636
+ * if finished_sending: free the blocks
1637
+ # if finished_recving: add to state so we can
1638
+ schedule the request during the next step.
1639
+ """
1640
+
1641
+ if self.connector is not None:
1642
+ self.connector.update_connector_output(kv_connector_output)
1643
+
1644
+ # KV Connector:: update recv and send status from last step.
1645
+ for req_id in kv_connector_output.finished_recving or ():
1646
+ logger.debug("Finished recving KV transfer for request %s", req_id)
1647
+ self.finished_recving_kv_req_ids.add(req_id)
1648
+ for req_id in kv_connector_output.finished_sending or ():
1649
+ logger.debug("Finished sending KV transfer for request %s", req_id)
1650
+ assert req_id in self.requests
1651
+ self._free_blocks(self.requests[req_id])
1652
+
1653
+ def _update_requests_with_invalid_blocks(
1654
+ self,
1655
+ requests: Iterable[Request],
1656
+ invalid_block_ids: set[int],
1657
+ evict_blocks: bool = True,
1658
+ ) -> tuple[set[str], int, set[int]]:
1659
+ """
1660
+ Identify and update requests affected by invalid KV cache blocks.
1661
+
1662
+ This method scans the given requests, detects those with invalid blocks
1663
+ and adjusts their `num_computed_tokens` to the longest valid prefix.
1664
+ For observability, it also accumulates the total number of tokens that
1665
+ will need to be recomputed across all affected requests.
1666
+
1667
+ Args:
1668
+ requests: The set of requests to scan for invalid blocks.
1669
+ invalid_block_ids: IDs of invalid blocks.
1670
+ evict_blocks: Whether to collect blocks for eviction (False for
1671
+ async requests which aren't cached yet).
1672
+
1673
+ Returns:
1674
+ tuple:
1675
+ - affected_req_ids (set[str]): IDs of requests impacted by
1676
+ invalid blocks.
1677
+ - total_affected_tokens (int): Total number of tokens that must
1678
+ be recomputed across all affected requests.
1679
+ - blocks_to_evict (set[int]): Block IDs to evict from cache,
1680
+ including invalid blocks and downstream dependent blocks.
1681
+ """
1682
+ affected_req_ids: set[str] = set()
1683
+ total_affected_tokens = 0
1684
+ blocks_to_evict: set[int] = set()
1685
+ # If a block is invalid and shared by multiple requests in the batch,
1686
+ # these requests must be rescheduled, but only the first will recompute
1687
+ # it. This set tracks blocks already marked for recomputation.
1688
+ marked_invalid_block_ids: set[int] = set()
1689
+ for request in requests:
1690
+ is_affected = False
1691
+ marked_invalid_block = False
1692
+ req_id = request.request_id
1693
+ # TODO (davidb): add support for hybrid memory allocator
1694
+ (req_block_ids,) = self.kv_cache_manager.get_block_ids(req_id)
1695
+ # We iterate only over blocks that may contain externally computed
1696
+ # tokens
1697
+ if request.status == RequestStatus.WAITING_FOR_REMOTE_KVS:
1698
+ # Async loading. If num_computed_tokens is set it implies we
1699
+ # already processed some block failures for it in a prior step
1700
+ req_num_computed_tokens = (
1701
+ request.num_computed_tokens
1702
+ if req_id in self.failed_recving_kv_req_ids
1703
+ else len(req_block_ids) * self.block_size
1704
+ )
1705
+ else:
1706
+ # Sync loading. num_computed_tokens includes new tokens
1707
+ req_num_computed_tokens = request.num_cached_tokens
1708
+
1709
+ req_num_computed_blocks = (
1710
+ req_num_computed_tokens + self.block_size - 1
1711
+ ) // self.block_size
1712
+ for idx, block_id in zip(range(req_num_computed_blocks), req_block_ids):
1713
+ if block_id not in invalid_block_ids:
1714
+ continue
1715
+
1716
+ is_affected = True
1717
+
1718
+ if block_id in marked_invalid_block_ids:
1719
+ # This invalid block is shared with a previous request
1720
+ # and was already marked for recomputation.
1721
+ # This means this request can still consider this block
1722
+ # as computed when rescheduled.
1723
+ # Currently this only applies to sync loading; Async
1724
+ # loading does not yet support block sharing
1725
+ continue
1726
+
1727
+ marked_invalid_block_ids.add(block_id)
1728
+
1729
+ if marked_invalid_block:
1730
+ # This request has already marked an invalid block for
1731
+ # recomputation and updated its num_computed_tokens.
1732
+ continue
1733
+
1734
+ marked_invalid_block = True
1735
+ # Truncate the computed tokens at the first failed block
1736
+ request.num_computed_tokens = idx * self.block_size
1737
+ num_affected_tokens = (
1738
+ req_num_computed_tokens - request.num_computed_tokens
1739
+ )
1740
+ total_affected_tokens += num_affected_tokens
1741
+ request.num_external_computed_tokens -= num_affected_tokens
1742
+ # collect invalid block and all downstream dependent blocks
1743
+ if evict_blocks:
1744
+ blocks_to_evict.update(req_block_ids[idx:])
1745
+
1746
+ if is_affected:
1747
+ if not marked_invalid_block:
1748
+ # All invalid blocks of this request are shared with
1749
+ # previous requests and will be recomputed by them.
1750
+ # Revert to considering only cached tokens as computed.
1751
+ # Currently this only applies to sync loading; Async
1752
+ # loading does not yet support block sharing
1753
+ total_affected_tokens += (
1754
+ request.num_computed_tokens - request.num_cached_tokens
1755
+ )
1756
+ request.num_computed_tokens = request.num_cached_tokens
1757
+
1758
+ affected_req_ids.add(request.request_id)
1759
+
1760
+ return affected_req_ids, total_affected_tokens, blocks_to_evict
1761
+
1762
+ def _handle_invalid_blocks(self, invalid_block_ids: set[int]) -> set[str]:
1763
+ """
1764
+ Handle requests affected by invalid KV cache blocks.
1765
+
1766
+ Returns:
1767
+ Set of affected request IDs to skip in update_from_output main loop.
1768
+ """
1769
+ should_fail = not self.recompute_kv_load_failures
1770
+
1771
+ # handle async KV loads (not cached yet, evict_blocks=False)
1772
+ async_load_reqs = (
1773
+ req
1774
+ for req in self.waiting
1775
+ if req.status == RequestStatus.WAITING_FOR_REMOTE_KVS
1776
+ )
1777
+ async_failed_req_ids, num_failed_tokens, _ = (
1778
+ self._update_requests_with_invalid_blocks(
1779
+ async_load_reqs, invalid_block_ids, evict_blocks=False
1780
+ )
1781
+ )
1782
+
1783
+ total_failed_requests = len(async_failed_req_ids)
1784
+ total_failed_tokens = num_failed_tokens
1785
+
1786
+ # handle sync loads (may be cached, collect blocks for eviction)
1787
+ sync_failed_req_ids, num_failed_tokens, sync_blocks_to_evict = (
1788
+ self._update_requests_with_invalid_blocks(
1789
+ self.running, invalid_block_ids, evict_blocks=True
1790
+ )
1791
+ )
1792
+
1793
+ total_failed_requests += len(sync_failed_req_ids)
1794
+ total_failed_tokens += num_failed_tokens
1795
+
1796
+ if not total_failed_requests:
1797
+ return set()
1798
+
1799
+ # evict invalid blocks and downstream dependent blocks from cache
1800
+ # only when not using recompute policy (where blocks will be recomputed
1801
+ # and reused by other requests sharing them)
1802
+ if sync_blocks_to_evict and not self.recompute_kv_load_failures:
1803
+ self.kv_cache_manager.evict_blocks(sync_blocks_to_evict)
1804
+
1805
+ if should_fail:
1806
+ all_failed_req_ids = async_failed_req_ids | sync_failed_req_ids
1807
+ logger.error(
1808
+ "Failing %d request(s) due to KV load failure "
1809
+ "(failure_policy=fail, %d tokens affected). Request IDs: %s",
1810
+ total_failed_requests,
1811
+ total_failed_tokens,
1812
+ all_failed_req_ids,
1813
+ )
1814
+ return all_failed_req_ids
1815
+
1816
+ logger.warning(
1817
+ "Recovered from KV load failure: "
1818
+ "%d request(s) rescheduled (%d tokens affected).",
1819
+ total_failed_requests,
1820
+ total_failed_tokens,
1821
+ )
1822
+
1823
+ # Mark async requests with KV load failures for retry once loading completes
1824
+ self.failed_recving_kv_req_ids |= async_failed_req_ids
1825
+ # Return sync affected IDs to skip in update_from_output
1826
+ return sync_failed_req_ids