summaryrefslogtreecommitdiff
path: root/reduced_system_layer.c
diff options
context:
space:
mode:
authorMitya Selivanov <automainint@guattari.tech>2024-11-22 16:30:19 +0100
committerMitya Selivanov <automainint@guattari.tech>2024-11-22 16:30:19 +0100
commit533aa1816b2c90b3935504b489e03e6ef87038a6 (patch)
tree09140f39264c2939a5eb2683d05827894f62dac3 /reduced_system_layer.c
parenteda1d8c0bf70fc582a02b32df82d600b8b1cbe25 (diff)
downloadreduced_system_layer-533aa1816b2c90b3935504b489e03e6ef87038a6.zip
Update audio
Diffstat (limited to 'reduced_system_layer.c')
-rwxr-xr-xreduced_system_layer.c59
1 files changed, 38 insertions, 21 deletions
diff --git a/reduced_system_layer.c b/reduced_system_layer.c
index e65653e..c272711 100755
--- a/reduced_system_layer.c
+++ b/reduced_system_layer.c
@@ -163,7 +163,7 @@ enum {
AUDIO_NUM_CHANNELS = 2,
AUDIO_SAMPLE_RATE = 44100,
- AUDIO_AVAIL_MIN = 64,
+ AUDIO_AVAIL_MIN = 256,
MAX_NUM_AUDIO_FRAMES = 10 * AUDIO_SAMPLE_RATE * AUDIO_NUM_CHANNELS, // 10 seconds
@@ -940,25 +940,25 @@ void p_handle_audio(i64 samples_elapsed) {
i32 s;
if (num_frames <= MAX_NUM_AUDIO_FRAMES - _sound_position) {
- s = snd_pcm_writei(_sound_out, _sound_ring + _sound_position, num_frames);
+ s = snd_pcm_writei(_sound_out, _sound_ring + _sound_position, num_frames / AUDIO_NUM_CHANNELS);
if (s < 0)
fprintf(stderr, "%s:%d, %s: snd_pcm_writei failed: %s\n", __FILE__, __LINE__, __func__, snd_strerror(s));
- memset(_sound_ring + _sound_position, 0, num_frames);
+ memset(_sound_ring + _sound_position, 0, num_frames * sizeof *_sound_ring);
} else {
i64 part_one = MAX_NUM_AUDIO_FRAMES - _sound_position;
- i64 part_two = num_frames - part_one;
+ i64 part_two = num_frames - part_one;
- s = snd_pcm_writei(_sound_out, _sound_ring + _sound_position, part_one);
+ s = snd_pcm_writei(_sound_out, _sound_ring + _sound_position, part_one / AUDIO_NUM_CHANNELS);
if (s < 0)
fprintf(stderr, "%s:%d, %s: snd_pcm_writei failed: %s\n", __FILE__, __LINE__, __func__, snd_strerror(s));
- s = snd_pcm_writei(_sound_out, _sound_ring, part_two);
+ s = snd_pcm_writei(_sound_out, _sound_ring, part_two / AUDIO_NUM_CHANNELS);
if (s < 0)
fprintf(stderr, "%s:%d, %s: snd_pcm_writei failed: %s\n", __FILE__, __LINE__, __func__, snd_strerror(s));
- memset(_sound_ring + _sound_position, 0, part_one);
- memset(_sound_ring, 0, part_two);
+ memset(_sound_ring + _sound_position, 0, part_one * sizeof *_sound_ring);
+ memset(_sound_ring, 0, part_two * sizeof *_sound_ring);
}
_sound_position = (_sound_position + num_frames) % MAX_NUM_AUDIO_FRAMES;
@@ -971,6 +971,7 @@ void p_queue_sound(i64 delay_in_samples, i64 num_samples, f32 *frames) {
return;
if (delay_in_samples < 0) {
+ frames += -delay_in_samples * AUDIO_NUM_CHANNELS;
num_samples -= delay_in_samples;
delay_in_samples = 0;
}
@@ -990,13 +991,16 @@ void p_queue_sound(i64 delay_in_samples, i64 num_samples, f32 *frames) {
i64 begin = (_sound_position + delay_in_samples) % MAX_NUM_AUDIO_FRAMES;
if (num_frames <= MAX_NUM_AUDIO_FRAMES - begin)
- memcpy(_sound_ring + begin, frames, num_frames * sizeof *frames);
+ for (i64 i = 0; i < num_frames; ++i)
+ _sound_ring[begin + i] += frames[i];
else {
i64 part_one = MAX_NUM_AUDIO_FRAMES - begin;
i64 part_two = num_frames - part_one;
- memcpy(_sound_ring + begin, frames, part_one * sizeof *frames);
- memcpy(_sound_ring, frames + part_one, part_two * sizeof *frames);
+ for (i64 i = 0; i < part_one; ++i)
+ _sound_ring[begin + i] += frames[i];
+ for (i64 i = 0; i < part_two; ++i)
+ _sound_ring[i] += frames[part_one + i];
}
}
@@ -1563,6 +1567,18 @@ static i32 _num_events = 0;
static i32 _input_size = 0;
static b8 _key_pressed[MAX_NUM_KEYS] = {0};
+i32 p_time_impl(void);
+
+i64 p_time(void) {
+ return p_time_impl();
+}
+
+void p_sleep_for_impl(i32 duration);
+
+void p_sleep_for(i64 duration) {
+ p_sleep_for_impl((i32) duration);
+}
+
i32 p_handle_events(void) {
platform.input_size = _input_size;
_input_size = 0;
@@ -1689,15 +1705,15 @@ __attribute__((export_name("js_keyup"))) void js_keyup(u32 key, u32 mod) {
i64 _sound_position = 0;
f32 _sound_ring[MAX_NUM_AUDIO_FRAMES] = {0};
-void p_handle_audio_impl(i64 samples_elapsed);
+void p_handle_audio_impl(i32 samples_elapsed);
void p_handle_audio(i64 samples_elapsed) {
if (samples_elapsed <= 0)
return;
- _sound_position = (_sound_position + samples_elapsed * AUDIO_NUM_CHANNELS) % MAX_NUM_AUDIO_FRAMES;
-
p_handle_audio_impl(samples_elapsed);
+
+ _sound_position = (_sound_position + samples_elapsed * AUDIO_NUM_CHANNELS) % MAX_NUM_AUDIO_FRAMES;
}
void p_queue_sound(i64 delay_in_samples, i64 num_samples, f32 *frames) {
@@ -1705,6 +1721,7 @@ void p_queue_sound(i64 delay_in_samples, i64 num_samples, f32 *frames) {
return;
if (delay_in_samples < 0) {
+ frames += -delay_in_samples * AUDIO_NUM_CHANNELS;
num_samples -= delay_in_samples;
delay_in_samples = 0;
}
@@ -1716,19 +1733,19 @@ void p_queue_sound(i64 delay_in_samples, i64 num_samples, f32 *frames) {
if (num_frames > MAX_NUM_AUDIO_FRAMES)
return;
- i64 begin = (_sound_position + delay_in_samples) % MAX_NUM_AUDIO_FRAMES;
+ i64 begin = (_sound_position + AUDIO_AVAIL_MIN + delay_in_samples * AUDIO_NUM_CHANNELS) % MAX_NUM_AUDIO_FRAMES;
if (num_frames <= MAX_NUM_AUDIO_FRAMES - begin)
for (i64 i = 0; i < num_frames; ++i)
- _sound_ring[begin + i] = frames[i];
+ _sound_ring[begin + i] += frames[i];
else {
i64 part_one = MAX_NUM_AUDIO_FRAMES - begin;
- i64 part_two = num_frames - part_one;
+ i64 part_two = num_frames - part_one;
for (i64 i = 0; i < part_one; ++i)
- _sound_ring[begin + i] = frames[i];
+ _sound_ring[begin + i] += frames[i];
for (i64 i = 0; i < part_two; ++i)
- _sound_ring[i] = frames[part_one + i];
+ _sound_ring[i] += frames[part_one + i];
}
}
@@ -1748,8 +1765,8 @@ __attribute__((export_name("js_sound_buffer"))) void *js_sound_buffer(void) {
return _sound_ring;
}
-__attribute__((export_name("js_sound_sync"))) i64 js_sound_sync(void) {
- _sound_position = AUDIO_AVAIL_MIN % MAX_NUM_AUDIO_FRAMES;
+__attribute__((export_name("js_sound_sync"))) void js_sound_sync(void) {
+ _sound_position = 0;
for (i64 i = 0; i < MAX_NUM_AUDIO_FRAMES; ++i)
_sound_ring[i] = 0.f;
}