mirror of
https://github.com/Ryujinx/libsoundio.git
synced 2025-01-22 03:11:09 +00:00
no longer depend on or link against libm
This commit is contained in:
parent
8406dcd0ad
commit
e2e483a4d5
|
@ -190,7 +190,6 @@ set(LIBSOUNDIO_LIBS
|
|||
${COREAUDIO_LIBRARY}
|
||||
${COREFOUNDATION_LIBRARY}
|
||||
${AUDIOUNIT_LIBRARY}
|
||||
m
|
||||
${CMAKE_THREAD_LIBS_INIT}
|
||||
)
|
||||
|
||||
|
@ -261,7 +260,7 @@ if(BUILD_EXAMPLE_PROGRAMS)
|
|||
set_target_properties(sio_sine PROPERTIES
|
||||
LINKER_LANGUAGE C
|
||||
COMPILE_FLAGS ${EXAMPLE_CFLAGS})
|
||||
target_link_libraries(sio_sine libsoundio_shared)
|
||||
target_link_libraries(sio_sine libsoundio_shared m)
|
||||
install(TARGETS sio_sine DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||
|
||||
add_executable(sio_list_devices example/sio_list_devices.c)
|
||||
|
@ -296,7 +295,7 @@ if(BUILD_TESTS)
|
|||
)
|
||||
|
||||
add_executable(latency "${CMAKE_SOURCE_DIR}/test/latency.cpp" ${LIBSOUNDIO_SOURCES})
|
||||
target_link_libraries(latency LINK_PUBLIC ${LIBSOUNDIO_LIBS})
|
||||
target_link_libraries(latency LINK_PUBLIC ${LIBSOUNDIO_LIBS} m)
|
||||
set_target_properties(latency PROPERTIES
|
||||
LINKER_LANGUAGE C
|
||||
COMPILE_FLAGS ${LIB_CFLAGS}
|
||||
|
@ -306,7 +305,7 @@ if(BUILD_TESTS)
|
|||
set_target_properties(underflow PROPERTIES
|
||||
LINKER_LANGUAGE C
|
||||
COMPILE_FLAGS ${EXAMPLE_CFLAGS})
|
||||
target_link_libraries(underflow libsoundio_shared)
|
||||
target_link_libraries(underflow libsoundio_shared m)
|
||||
|
||||
add_executable(backend_disconnect_recover test/backend_disconnect_recover.c)
|
||||
set_target_properties(backend_disconnect_recover PROPERTIES
|
||||
|
|
12
src/alsa.cpp
12
src/alsa.cpp
|
@ -59,6 +59,11 @@ static void destroy_alsa(SoundIoPrivate *si) {
|
|||
close(sia->notify_fd);
|
||||
}
|
||||
|
||||
static inline snd_pcm_uframes_t ceil_dbl_to_uframes(double x) {
|
||||
const double truncation = (snd_pcm_uframes_t)x;
|
||||
return truncation + (truncation < x);
|
||||
}
|
||||
|
||||
static char * str_partition_on_char(char *str, char c) {
|
||||
while (*str) {
|
||||
if (*str == c) {
|
||||
|
@ -1253,7 +1258,7 @@ static int outstream_open_alsa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os)
|
|||
return SoundIoErrorOpeningDevice;
|
||||
}
|
||||
|
||||
osa->buffer_size_frames = ceil(outstream->software_latency * (double)outstream->sample_rate);
|
||||
osa->buffer_size_frames = ceil_dbl_to_int(outstream->software_latency * (double)outstream->sample_rate);
|
||||
|
||||
if ((err = snd_pcm_hw_params_set_buffer_size_near(osa->handle, hwparams, &osa->buffer_size_frames)) < 0) {
|
||||
outstream_destroy_alsa(si, os);
|
||||
|
@ -1269,7 +1274,8 @@ static int outstream_open_alsa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os)
|
|||
}
|
||||
} else {
|
||||
double period_duration = outstream->software_latency / 2.0;
|
||||
snd_pcm_uframes_t period_frames = ceil(period_duration * (double)outstream->sample_rate);
|
||||
snd_pcm_uframes_t period_frames =
|
||||
ceil_dbl_to_uframes(period_duration * (double)outstream->sample_rate);
|
||||
|
||||
if ((err = snd_pcm_hw_params_set_period_size_near(osa->handle, hwparams, &period_frames, nullptr)) < 0) {
|
||||
outstream_destroy_alsa(si, os);
|
||||
|
@ -1567,7 +1573,7 @@ static int instream_open_alsa(SoundIoPrivate *si, SoundIoInStreamPrivate *is) {
|
|||
return SoundIoErrorOpeningDevice;
|
||||
}
|
||||
|
||||
snd_pcm_uframes_t period_frames = ceil(0.5 * instream->software_latency * (double)instream->sample_rate);
|
||||
snd_pcm_uframes_t period_frames = ceil_dbl_to_uframes(0.5 * instream->software_latency * (double)instream->sample_rate);
|
||||
if ((err = snd_pcm_hw_params_set_period_size_near(isa->handle, hwparams, &period_frames, nullptr)) < 0) {
|
||||
instream_destroy_alsa(si, is);
|
||||
return SoundIoErrorOpeningDevice;
|
||||
|
|
|
@ -683,8 +683,8 @@ static int refresh_devices(struct SoundIoPrivate *si) {
|
|||
if (avr_array_len == 1) {
|
||||
rd.device->sample_rate_count = 1;
|
||||
rd.device->sample_rates = &dev->prealloc_sample_rate_range;
|
||||
rd.device->sample_rates[0].min = ceil(rd.avr_array[0].mMinimum);
|
||||
rd.device->sample_rates[0].max = floor(rd.avr_array[0].mMaximum);
|
||||
rd.device->sample_rates[0].min = ceil_dbl_to_int(rd.avr_array[0].mMinimum);
|
||||
rd.device->sample_rates[0].max = (int)(rd.avr_array[0].mMaximum);
|
||||
} else {
|
||||
rd.device->sample_rate_count = avr_array_len;
|
||||
rd.device->sample_rates = allocate<SoundIoSampleRateRange>(avr_array_len);
|
||||
|
@ -694,8 +694,8 @@ static int refresh_devices(struct SoundIoPrivate *si) {
|
|||
}
|
||||
for (int i = 0; i < avr_array_len; i += 1) {
|
||||
AudioValueRange *avr = &rd.avr_array[i];
|
||||
int min_val = ceil(avr->mMinimum);
|
||||
int max_val = floor(avr->mMaximum);
|
||||
int min_val = ceil_dbl_to_int(avr->mMinimum);
|
||||
int max_val = (int)(avr->mMaximum);
|
||||
rd.device->sample_rates[i].min = min_val;
|
||||
rd.device->sample_rates[i].max = max_val;
|
||||
}
|
||||
|
|
|
@ -29,7 +29,7 @@ static void playback_thread_run(void *arg) {
|
|||
double now = soundio_os_get_time();
|
||||
double time_passed = now - start_time;
|
||||
double next_period = start_time +
|
||||
ceil(time_passed / osd->period_duration) * osd->period_duration;
|
||||
ceil_dbl(time_passed / osd->period_duration) * osd->period_duration;
|
||||
double relative_time = next_period - now;
|
||||
soundio_os_cond_timed_wait(osd->cond, nullptr, relative_time);
|
||||
if (!osd->clear_buffer_flag.test_and_set()) {
|
||||
|
@ -80,7 +80,7 @@ static void capture_thread_run(void *arg) {
|
|||
double now = soundio_os_get_time();
|
||||
double time_passed = now - start_time;
|
||||
double next_period = start_time +
|
||||
ceil(time_passed / isd->period_duration) * isd->period_duration;
|
||||
ceil_dbl(time_passed / isd->period_duration) * isd->period_duration;
|
||||
double relative_time = next_period - now;
|
||||
soundio_os_cond_timed_wait(isd->cond, nullptr, relative_time);
|
||||
|
||||
|
|
|
@ -604,8 +604,13 @@ int soundio_os_page_size(void) {
|
|||
return page_size;
|
||||
}
|
||||
|
||||
static inline size_t ceil_dbl_to_size_t(double x) {
|
||||
const double truncation = (size_t)x;
|
||||
return truncation + (truncation < x);
|
||||
}
|
||||
|
||||
int soundio_os_init_mirrored_memory(struct SoundIoOsMirroredMemory *mem, size_t requested_capacity) {
|
||||
size_t actual_capacity = ceil(requested_capacity / (double)page_size) * page_size;
|
||||
size_t actual_capacity = ceil_dbl_to_size_t(requested_capacity / (double)page_size) * page_size;
|
||||
|
||||
#if defined(SOUNDIO_OS_WINDOWS)
|
||||
BOOL ok;
|
||||
|
|
|
@ -693,7 +693,7 @@ static int outstream_open_pa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os) {
|
|||
int bytes_per_second = outstream->bytes_per_frame * outstream->sample_rate;
|
||||
if (outstream->software_latency > 0.0) {
|
||||
int buffer_length = outstream->bytes_per_frame *
|
||||
ceil(outstream->software_latency * bytes_per_second / (double)outstream->bytes_per_frame);
|
||||
ceil_dbl_to_int(outstream->software_latency * bytes_per_second / (double)outstream->bytes_per_frame);
|
||||
|
||||
ospa->buffer_attr.maxlength = buffer_length;
|
||||
ospa->buffer_attr.tlength = buffer_length;
|
||||
|
@ -925,7 +925,7 @@ static int instream_open_pa(SoundIoPrivate *si, SoundIoInStreamPrivate *is) {
|
|||
if (instream->software_latency > 0.0) {
|
||||
int bytes_per_second = instream->bytes_per_frame * instream->sample_rate;
|
||||
int buffer_length = instream->bytes_per_frame *
|
||||
ceil(instream->software_latency * bytes_per_second / (double)instream->bytes_per_frame);
|
||||
ceil_dbl_to_int(instream->software_latency * bytes_per_second / (double)instream->bytes_per_frame);
|
||||
ispa->buffer_attr.fragsize = buffer_length;
|
||||
}
|
||||
|
||||
|
|
11
src/util.hpp
11
src/util.hpp
|
@ -50,6 +50,17 @@ static inline bool soundio_streql(const char *str1, int str1_len, const char *st
|
|||
return memcmp(str1, str2, str1_len) == 0;
|
||||
}
|
||||
|
||||
static inline int ceil_dbl_to_int(double x) {
|
||||
const double truncation = (int)x;
|
||||
return truncation + (truncation < x);
|
||||
}
|
||||
|
||||
static inline double ceil_dbl(double x) {
|
||||
const double truncation = (long long) x;
|
||||
const double ceiling = truncation + (truncation < x);
|
||||
return ceiling;
|
||||
}
|
||||
|
||||
|
||||
template <typename T, long n>
|
||||
static constexpr long array_length(const T (&)[n]) {
|
||||
|
|
Loading…
Reference in a new issue