X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=plugins%2Fradio%2Fradio-rtlsdr.c;h=7d7e498ad86ac4bc3fb5ef1ce2fde9e5bb09d1ca;hb=e6298876fdbf457b6dd61556472060a9fa652c82;hp=e5a609e38f139544b9f8926530394fbed0e1613f;hpb=3bce4a6a8648c91b6ddea478116b3b0679ef4648;p=src%2Fapp-framework-binder.git diff --git a/plugins/radio/radio-rtlsdr.c b/plugins/radio/radio-rtlsdr.c index e5a609e3..7d7e498a 100644 --- a/plugins/radio/radio-rtlsdr.c +++ b/plugins/radio/radio-rtlsdr.c @@ -16,11 +16,12 @@ * along with this program. If not, see . */ +#include +#include + #include "radio-api.h" #include "radio-rtlsdr.h" -static audioCtxHandleT *actx = NULL; - /* ------------- RADIO RTLSDR IMPLEMENTATION ---------------- */ /* --- PUBLIC FUNCTIONS --- */ @@ -47,14 +48,7 @@ PUBLIC unsigned char _radio_on (unsigned int num, radioCtxHandleT *ctx) { dev_ctx[num]->demod = NULL; dev_ctx[num]->output = NULL; _radio_dev_init(dev_ctx[num], num); - - actx = malloc (sizeof(audioCtxHandleT)); - actx->idx = -1; - actx->volume = 25; - actx->channels = 2; - actx->mute = 0; - _alsa_init ("default", actx); - + return 1; } @@ -69,9 +63,6 @@ PUBLIC void _radio_off (unsigned int num) { } /* free(dev_ctx); */ - - _alsa_free ("default"); - free (actx); } PUBLIC void _radio_set_mode (unsigned int num, Mode mode) { @@ -82,11 +73,11 @@ PUBLIC void _radio_set_mode (unsigned int num, Mode mode) { _radio_apply_params(dev_ctx[num]); } -PUBLIC void _radio_set_freq (unsigned int num, float freq) { +PUBLIC void _radio_set_freq (unsigned int num, double freq) { if (!dev_ctx || !dev_ctx[num]) return; - dev_ctx[num]->freq = freq; + dev_ctx[num]->freq = (float)freq; _radio_apply_params(dev_ctx[num]); } @@ -407,14 +398,22 @@ STATIC void* _demod_thread_fn (void *ctx) { STATIC void* _output_thread_fn (void *ctx) { dev_ctx_T *dev_ctx = (dev_ctx_T *)ctx; output_ctx *output = dev_ctx->output; + FILE *file; + + file = fopen (AUDIO_BUFFER, "wb"); while (dev_ctx->should_run) { pthread_wait(&output->ok, &output->ok_m); pthread_rwlock_rdlock(&output->lck); - if (!dev_ctx->mute) - _alsa_play(actx->idx, (void*)&output->buf, output->buf_len); + if (!dev_ctx->mute && file) { + fwrite (output->buf, 2, output->buf_len, file); + fflush (file); + fseek (file, 0, SEEK_SET); + } pthread_rwlock_unlock(&output->lck); } + if (file) fclose(file); + unlink (AUDIO_BUFFER); output->thr_finished = 1; return 0;