blob: 91854f02ea0dc6e06adb08b0b1a6fab90501b314 [file] [log] [blame]
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +03001/*
2 * replay-audio.c
3 *
4 * Copyright (c) 2010-2017 Institute for System Programming
5 * of the Russian Academy of Sciences.
6 *
7 * This work is licensed under the terms of the GNU GPL, version 2 or later.
8 * See the COPYING file in the top-level directory.
9 *
10 */
11
12#include "qemu/osdep.h"
13#include "qemu/error-report.h"
14#include "sysemu/replay.h"
15#include "replay-internal.h"
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030016#include "audio/audio.h"
17
Kővágó, Zoltán75204622019-08-19 01:06:58 +020018void replay_audio_out(size_t *played)
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030019{
20 if (replay_mode == REPLAY_MODE_RECORD) {
Alex Bennéed759c952018-02-27 12:52:48 +030021 g_assert(replay_mutex_locked());
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030022 replay_save_instructions();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030023 replay_put_event(EVENT_AUDIO_OUT);
Kővágó, Zoltán75204622019-08-19 01:06:58 +020024 replay_put_qword(*played);
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030025 } else if (replay_mode == REPLAY_MODE_PLAY) {
Alex Bennéed759c952018-02-27 12:52:48 +030026 g_assert(replay_mutex_locked());
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030027 replay_account_executed_instructions();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030028 if (replay_next_event_is(EVENT_AUDIO_OUT)) {
Kővágó, Zoltán75204622019-08-19 01:06:58 +020029 *played = replay_get_qword();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030030 replay_finish_event();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030031 } else {
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030032 error_report("Missing audio out event in the replay log");
33 abort();
34 }
35 }
36}
37
Kővágó, Zoltán75204622019-08-19 01:06:58 +020038void replay_audio_in(size_t *recorded, void *samples, size_t *wpos, size_t size)
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030039{
40 int pos;
41 uint64_t left, right;
42 if (replay_mode == REPLAY_MODE_RECORD) {
Alex Bennéed759c952018-02-27 12:52:48 +030043 g_assert(replay_mutex_locked());
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030044 replay_save_instructions();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030045 replay_put_event(EVENT_AUDIO_IN);
Kővágó, Zoltán75204622019-08-19 01:06:58 +020046 replay_put_qword(*recorded);
47 replay_put_qword(*wpos);
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030048 for (pos = (*wpos - *recorded + size) % size ; pos != *wpos
49 ; pos = (pos + 1) % size) {
50 audio_sample_to_uint64(samples, pos, &left, &right);
51 replay_put_qword(left);
52 replay_put_qword(right);
53 }
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030054 } else if (replay_mode == REPLAY_MODE_PLAY) {
Alex Bennéed759c952018-02-27 12:52:48 +030055 g_assert(replay_mutex_locked());
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030056 replay_account_executed_instructions();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030057 if (replay_next_event_is(EVENT_AUDIO_IN)) {
Kővágó, Zoltán75204622019-08-19 01:06:58 +020058 *recorded = replay_get_qword();
59 *wpos = replay_get_qword();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030060 for (pos = (*wpos - *recorded + size) % size ; pos != *wpos
61 ; pos = (pos + 1) % size) {
62 left = replay_get_qword();
63 right = replay_get_qword();
64 audio_sample_from_uint64(samples, pos, left, right);
65 }
66 replay_finish_event();
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030067 } else {
Pavel Dovgalyuk3d4d16f2017-02-02 08:50:54 +030068 error_report("Missing audio in event in the replay log");
69 abort();
70 }
71 }
72}