ehci: rework frame skipping
Move the framecount check out of the loop and use the new ehci_update_frindex function to skip frames if needed. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
3a21532626
commit
f020ed36fe
@ -2315,9 +2315,8 @@ static void ehci_frame_timer(void *opaque)
|
||||
int schedules = 0;
|
||||
int64_t expire_time, t_now;
|
||||
uint64_t ns_elapsed;
|
||||
int frames;
|
||||
int frames, skipped_frames;
|
||||
int i;
|
||||
int skipped_frames = 0;
|
||||
|
||||
t_now = qemu_get_clock_ns(vm_clock);
|
||||
ns_elapsed = t_now - ehci->last_run_ns;
|
||||
@ -2327,15 +2326,17 @@ static void ehci_frame_timer(void *opaque)
|
||||
schedules++;
|
||||
expire_time = t_now + (get_ticks_per_sec() / FRAME_TIMER_FREQ);
|
||||
|
||||
if (frames > ehci->maxframes) {
|
||||
skipped_frames = frames - ehci->maxframes;
|
||||
ehci_update_frindex(ehci, skipped_frames);
|
||||
ehci->last_run_ns += FRAME_TIMER_NS * skipped_frames;
|
||||
frames -= skipped_frames;
|
||||
DPRINTF("WARNING - EHCI skipped %d frames\n", skipped_frames);
|
||||
}
|
||||
|
||||
for (i = 0; i < frames; i++) {
|
||||
ehci_update_frindex(ehci, 1);
|
||||
|
||||
if (frames - i > ehci->maxframes) {
|
||||
skipped_frames++;
|
||||
} else {
|
||||
ehci_advance_periodic_state(ehci);
|
||||
}
|
||||
|
||||
ehci_advance_periodic_state(ehci);
|
||||
ehci->last_run_ns += FRAME_TIMER_NS;
|
||||
}
|
||||
} else {
|
||||
@ -2348,12 +2349,6 @@ static void ehci_frame_timer(void *opaque)
|
||||
ehci->last_run_ns += FRAME_TIMER_NS * frames;
|
||||
}
|
||||
|
||||
#if 0
|
||||
if (skipped_frames) {
|
||||
DPRINTF("WARNING - EHCI skipped %d frames\n", skipped_frames);
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Async is not inside loop since it executes everything it can once
|
||||
* called
|
||||
*/
|
||||
|
Loading…
Reference in New Issue
Block a user