frames, (int)ret);
return -E_ALSA_WRITE;
}
- if (ret == -EAGAIN) { /* try again in 5ms */
- PARA_WARNING_LOG("EAGAIN\n");
- ms2tv(5, &tv);
- } else {
+ if (ret == -EAGAIN)
+ PARA_DEBUG_LOG("EAGAIN\n");
+ else
wn->written += ret * pad->bytes_per_frame;
- ms2tv(pad->buffer_time / 4000, &tv);
+ if (ret == frames) /* we wrote everything, try again immediately */
+ pad->next_chunk = *now;
+ else {
+ ms2tv(pad->buffer_time / pad->bytes_per_frame / 1000, &tv);
+ tv_add(now, &tv, &pad->next_chunk);
}
- tv_add(now, &tv, &pad->next_chunk);
return 1;
}