Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions vllm/core/scheduler.py
Original file line number Diff line number Diff line change
Expand Up @@ -646,6 +646,12 @@ def get_and_reset_finished_requests_ids(self) -> List[str]:
self._finished_requests_ids = list()
return finished_requests_ids

def get_async_stopped_request_ids(self):
if self._async_stopped:
return [seq_group.request_id for seq_group in self._async_stopped]
else:
return []

def _schedule_running(
self,
budget: SchedulingBudget,
Expand Down
3 changes: 3 additions & 0 deletions vllm/engine/async_llm_engine.py
Original file line number Diff line number Diff line change
Expand Up @@ -309,6 +309,9 @@ async def step_async(
finished_requests_ids = self.scheduler[
virtual_engine].get_and_reset_finished_requests_ids()

finished_requests_ids += self.scheduler[
virtual_engine].get_async_stopped_request_ids()

# Maybe switch from async mode to sync mode
if not allow_async_output_proc and len(ctx.output_queue) > 0:
self._process_model_outputs(ctx=ctx)
Expand Down
3 changes: 3 additions & 0 deletions vllm/engine/llm_engine.py
Original file line number Diff line number Diff line change
Expand Up @@ -1385,6 +1385,9 @@ def step(self) -> List[Union[RequestOutput, PoolingRequestOutput]]:
if finished_request_id in self.seq_id_to_seq_group:
del self.seq_id_to_seq_group[finished_request_id]

finished_requests_ids += self.scheduler[
virtual_engine].get_async_stopped_request_ids()

# Maybe switch from async mode to sync mode
if not allow_async_output_proc and len(ctx.output_queue) > 0:
self._process_model_outputs(ctx=ctx)
Expand Down