examples/fmsynth: Fix freaze when execute it in 2nd time
Fix a freaze BUG when the example is executed again after 1st execution.
This commit is contained in:
parent
2d6f5f230e
commit
2b4a25c8d5
@ -68,7 +68,7 @@ static int configure_audio(int fd, int ch, int fs, int bps, int chmap)
|
|||||||
* name: create_audiomq
|
* name: create_audiomq
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static mqd_t create_audiomq(int fd, int buf_num)
|
static mqd_t create_audiomq(const char *mqname, int fd, int buf_num)
|
||||||
{
|
{
|
||||||
mqd_t ret;
|
mqd_t ret;
|
||||||
struct mq_attr attr;
|
struct mq_attr attr;
|
||||||
@ -78,8 +78,7 @@ static mqd_t create_audiomq(int fd, int buf_num)
|
|||||||
attr.mq_curmsgs = 0;
|
attr.mq_curmsgs = 0;
|
||||||
attr.mq_flags = 0;
|
attr.mq_flags = 0;
|
||||||
|
|
||||||
ret = mq_open(CONFIG_AUDIOUTILS_NXAUDIO_MSGQNAME,
|
ret = mq_open(mqname, O_RDWR | O_CREAT, 0644, &attr);
|
||||||
O_RDWR | O_CREAT, 0644, &attr);
|
|
||||||
if (ret >= (mqd_t)0)
|
if (ret >= (mqd_t)0)
|
||||||
{
|
{
|
||||||
int rr;
|
int rr;
|
||||||
@ -147,14 +146,13 @@ static void free_audio_buffers(FAR struct nxaudio_s *nxaudio)
|
|||||||
|
|
||||||
void fin_nxaudio(FAR struct nxaudio_s *nxaudio)
|
void fin_nxaudio(FAR struct nxaudio_s *nxaudio)
|
||||||
{
|
{
|
||||||
free_audio_buffers(nxaudio);
|
ioctl(nxaudio->fd, AUDIOIOC_SHUTDOWN, 0);
|
||||||
ioctl(nxaudio->fd, AUDIOIOC_STOP, 0);
|
|
||||||
ioctl(nxaudio->fd, AUDIOIOC_UNREGISTERMQ, (unsigned long)nxaudio->mq);
|
ioctl(nxaudio->fd, AUDIOIOC_UNREGISTERMQ, (unsigned long)nxaudio->mq);
|
||||||
ioctl(nxaudio->fd, AUDIOIOC_RELEASE, 0);
|
ioctl(nxaudio->fd, AUDIOIOC_RELEASE, 0);
|
||||||
ioctl(nxaudio->fd, AUDIOIOC_SHUTDOWN, 0);
|
free_audio_buffers(nxaudio);
|
||||||
|
close(nxaudio->fd);
|
||||||
mq_close(nxaudio->mq);
|
mq_close(nxaudio->mq);
|
||||||
mq_unlink(CONFIG_AUDIOUTILS_NXAUDIO_MSGQNAME);
|
mq_unlink(CONFIG_AUDIOUTILS_NXAUDIO_MSGQNAME);
|
||||||
close(nxaudio->fd);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -163,10 +161,23 @@ void fin_nxaudio(FAR struct nxaudio_s *nxaudio)
|
|||||||
|
|
||||||
int init_nxaudio(FAR struct nxaudio_s *nxaudio,
|
int init_nxaudio(FAR struct nxaudio_s *nxaudio,
|
||||||
int fs, int bps, int chnum)
|
int fs, int bps, int chnum)
|
||||||
|
{
|
||||||
|
return init_nxaudio_devname(nxaudio, fs, bps, chnum,
|
||||||
|
CONFIG_AUDIOUTILS_NXAUDIO_DEVPATH,
|
||||||
|
CONFIG_AUDIOUTILS_NXAUDIO_MSGQNAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* name: init_nxaudio_devname
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int init_nxaudio_devname(FAR struct nxaudio_s *nxaudio,
|
||||||
|
int fs, int bps, int chnum,
|
||||||
|
const char *devname, const char *mqname)
|
||||||
{
|
{
|
||||||
struct ap_buffer_info_s buf_info;
|
struct ap_buffer_info_s buf_info;
|
||||||
|
|
||||||
nxaudio->fd = open(CONFIG_AUDIOUTILS_NXAUDIO_DEVPATH, O_RDWR | O_CLOEXEC);
|
nxaudio->fd = open(devname, O_RDWR | O_CLOEXEC);
|
||||||
if (nxaudio->fd >= 0)
|
if (nxaudio->fd >= 0)
|
||||||
{
|
{
|
||||||
if (ioctl(nxaudio->fd, AUDIOIOC_RESERVE, 0) < 0)
|
if (ioctl(nxaudio->fd, AUDIOIOC_RESERVE, 0) < 0)
|
||||||
@ -186,7 +197,7 @@ int init_nxaudio(FAR struct nxaudio_s *nxaudio,
|
|||||||
|
|
||||||
/* Create message queue to communicate with audio driver */
|
/* Create message queue to communicate with audio driver */
|
||||||
|
|
||||||
nxaudio->mq = create_audiomq(nxaudio->fd, buf_info.nbuffers + 8);
|
nxaudio->mq = create_audiomq(mqname, nxaudio->fd, buf_info.nbuffers + 8);
|
||||||
|
|
||||||
/* Create audio buffers to inject audio sample */
|
/* Create audio buffers to inject audio sample */
|
||||||
|
|
||||||
@ -218,6 +229,24 @@ int nxaudio_enqbuffer(FAR struct nxaudio_s *nxaudio,
|
|||||||
(unsigned long)(uintptr_t)&desc);
|
(unsigned long)(uintptr_t)&desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* name: nxaudio_pause
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int nxaudio_pause(FAR struct nxaudio_s *nxaudio)
|
||||||
|
{
|
||||||
|
return ioctl(nxaudio->fd, AUDIOIOC_PAUSE, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* name: nxaudio_resume
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int nxaudio_resume(FAR struct nxaudio_s *nxaudio)
|
||||||
|
{
|
||||||
|
return ioctl(nxaudio->fd, AUDIOIOC_RESUME, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* name: nxaudio_setvolume
|
* name: nxaudio_setvolume
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -252,6 +281,8 @@ int nxaudio_stop(FAR struct nxaudio_s *nxaudio)
|
|||||||
{
|
{
|
||||||
struct audio_msg_s term_msg;
|
struct audio_msg_s term_msg;
|
||||||
|
|
||||||
|
ioctl(nxaudio->fd, AUDIOIOC_STOP, 0);
|
||||||
|
|
||||||
term_msg.msg_id = AUDIO_MSG_STOP;
|
term_msg.msg_id = AUDIO_MSG_STOP;
|
||||||
term_msg.u.data = 0;
|
term_msg.u.data = 0;
|
||||||
mq_send(nxaudio->mq, (FAR const char *)&term_msg, sizeof(term_msg), 0);
|
mq_send(nxaudio->mq, (FAR const char *)&term_msg, sizeof(term_msg), 0);
|
||||||
|
@ -79,7 +79,6 @@ struct key_convert_s
|
|||||||
* Private Function Prototypes
|
* Private Function Prototypes
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
extern int board_external_amp_mute_control(bool en);
|
|
||||||
static void app_dequeue_cb(unsigned long arg,
|
static void app_dequeue_cb(unsigned long arg,
|
||||||
FAR struct ap_buffer_s *apb);
|
FAR struct ap_buffer_s *apb);
|
||||||
static void app_complete_cb(unsigned long arg);
|
static void app_complete_cb(unsigned long arg);
|
||||||
@ -91,6 +90,7 @@ static void app_user_cb(unsigned long arg,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static struct kbd_s g_kbd;
|
static struct kbd_s g_kbd;
|
||||||
|
static bool g_running = true;
|
||||||
|
|
||||||
static struct nxaudio_callbacks_s cbs =
|
static struct nxaudio_callbacks_s cbs =
|
||||||
{
|
{
|
||||||
@ -191,7 +191,10 @@ static void app_dequeue_cb(unsigned long arg,
|
|||||||
NULL, 0);
|
NULL, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_running)
|
||||||
|
{
|
||||||
nxaudio_enqbuffer(&kbd->nxaudio, apb);
|
nxaudio_enqbuffer(&kbd->nxaudio, apb);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -373,11 +376,11 @@ int main(int argc, FAR char *argv[])
|
|||||||
int i;
|
int i;
|
||||||
int ret;
|
int ret;
|
||||||
int key;
|
int key;
|
||||||
bool running = true;
|
|
||||||
pthread_t pid;
|
pthread_t pid;
|
||||||
struct app_options appopt;
|
struct app_options appopt;
|
||||||
int key_idx;
|
int key_idx;
|
||||||
|
|
||||||
|
g_running = true;
|
||||||
if (configure_option(&appopt, argc, argv) != OK)
|
if (configure_option(&appopt, argc, argv) != OK)
|
||||||
{
|
{
|
||||||
print_help(argv[0]);
|
print_help(argv[0]);
|
||||||
@ -414,7 +417,7 @@ int main(int argc, FAR char *argv[])
|
|||||||
printf("Start %s\n", argv[0]);
|
printf("Start %s\n", argv[0]);
|
||||||
print_keyusage();
|
print_keyusage();
|
||||||
|
|
||||||
while (running)
|
while (g_running)
|
||||||
{
|
{
|
||||||
key = getchar();
|
key = getchar();
|
||||||
if (key != EOF)
|
if (key != EOF)
|
||||||
@ -422,7 +425,7 @@ int main(int argc, FAR char *argv[])
|
|||||||
switch (key)
|
switch (key)
|
||||||
{
|
{
|
||||||
case 'q':
|
case 'q':
|
||||||
running = false;
|
g_running = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -438,8 +441,6 @@ int main(int argc, FAR char *argv[])
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
board_external_amp_mute_control(true);
|
|
||||||
|
|
||||||
nxaudio_stop(&g_kbd.nxaudio);
|
nxaudio_stop(&g_kbd.nxaudio);
|
||||||
pthread_join(pid, NULL);
|
pthread_join(pid, NULL);
|
||||||
|
|
||||||
|
@ -98,6 +98,7 @@ static void app_user_cb(unsigned long arg,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static struct mmlplayer_s g_mmlplayer;
|
static struct mmlplayer_s g_mmlplayer;
|
||||||
|
static bool g_running = true;
|
||||||
|
|
||||||
static struct nxaudio_callbacks_s cbs =
|
static struct nxaudio_callbacks_s cbs =
|
||||||
{
|
{
|
||||||
@ -263,7 +264,11 @@ static void app_dequeue_cb(unsigned long arg,
|
|||||||
mmlplayer->nxaudio.chnum,
|
mmlplayer->nxaudio.chnum,
|
||||||
tick_callback,
|
tick_callback,
|
||||||
(unsigned long)(uintptr_t)mmlplayer);
|
(unsigned long)(uintptr_t)mmlplayer);
|
||||||
|
|
||||||
|
if (g_running)
|
||||||
|
{
|
||||||
nxaudio_enqbuffer(&mmlplayer->nxaudio, apb);
|
nxaudio_enqbuffer(&mmlplayer->nxaudio, apb);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -503,12 +508,12 @@ int main(int argc, FAR char *argv[])
|
|||||||
int i;
|
int i;
|
||||||
int ret;
|
int ret;
|
||||||
int key;
|
int key;
|
||||||
bool running = true;
|
|
||||||
pthread_t pid;
|
pthread_t pid;
|
||||||
struct app_options appopt;
|
struct app_options appopt;
|
||||||
|
|
||||||
printf("Start %s\n", argv[0]);
|
printf("Start %s\n", argv[0]);
|
||||||
|
|
||||||
|
g_running = true;
|
||||||
if (configure_option(&appopt, argc, argv) != OK)
|
if (configure_option(&appopt, argc, argv) != OK)
|
||||||
{
|
{
|
||||||
print_help(argv[0]);
|
print_help(argv[0]);
|
||||||
@ -540,7 +545,7 @@ int main(int argc, FAR char *argv[])
|
|||||||
|
|
||||||
pid = create_audio_thread(&g_mmlplayer);
|
pid = create_audio_thread(&g_mmlplayer);
|
||||||
|
|
||||||
while (running)
|
while (g_running)
|
||||||
{
|
{
|
||||||
key = getchar();
|
key = getchar();
|
||||||
if (key != EOF)
|
if (key != EOF)
|
||||||
@ -548,7 +553,7 @@ int main(int argc, FAR char *argv[])
|
|||||||
switch (key)
|
switch (key)
|
||||||
{
|
{
|
||||||
case 'q':
|
case 'q':
|
||||||
running = false;
|
g_running = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -63,6 +63,9 @@ extern "C"
|
|||||||
|
|
||||||
int init_nxaudio(FAR struct nxaudio_s *nxaudio,
|
int init_nxaudio(FAR struct nxaudio_s *nxaudio,
|
||||||
int fs, int bps, int chnum);
|
int fs, int bps, int chnum);
|
||||||
|
int init_nxaudio_devname(FAR struct nxaudio_s *nxaudio,
|
||||||
|
int fs, int bps, int chnum,
|
||||||
|
const char *devname, const char *mqname);
|
||||||
void fin_nxaudio(FAR struct nxaudio_s *nxaudio);
|
void fin_nxaudio(FAR struct nxaudio_s *nxaudio);
|
||||||
int nxaudio_enqbuffer(FAR struct nxaudio_s *nxaudio,
|
int nxaudio_enqbuffer(FAR struct nxaudio_s *nxaudio,
|
||||||
FAR struct ap_buffer_s *apb);
|
FAR struct ap_buffer_s *apb);
|
||||||
|
Loading…
Reference in New Issue
Block a user