+ return;
+ }
+ if (st->ct->status != CL_RECEIVING)
+ return;
+ bytes_left = for_each_line(st->ct->buf, st->ct->loaded,
+ &check_stat_line, NULL);
+ if (st->ct->loaded != bytes_left) {
+ st->last_status_read = *now;
+ st->ct->loaded = bytes_left;
+ } else {
+ struct timeval diff;
+ tv_diff(now, &st->last_status_read, &diff);
+ if (diff.tv_sec > 61)
+ st->ct->task.error = -E_STATUS_TIMEOUT;
+ }
+ return;
+ }
+ if (tv_diff(now, &st->restart_barrier, NULL) < 0)
+ return;
+ if (st->clock_diff_count) { /* get status only one time */
+ char *argv[] = {"audiod", "stat", "1", NULL};
+ int argc = 3;
+ PARA_INFO_LOG("clock diff count: %d\n", st->clock_diff_count);
+ st->clock_diff_count--;
+ client_open(argc, argv, &st->ct);
+ set_stat_task_restart_barrier(2);
+
+ } else {
+ char *argv[] = {"audiod", "stat", NULL};
+ int argc = 2;
+ client_open(argc, argv, &st->ct);
+ set_stat_task_restart_barrier(5);