drivertest: Fix drivertest_audio crash

1.call AUDIOIOC_RELEASE when finished
2.make sure the driver dequeue all buffers before free the buffers

Signed-off-by: renjianguang <renjianguang@xiaomi.com>
This commit is contained in:
renjianguang 2023-08-17 13:16:04 +08:00 committed by Xiang Xiao
parent 4d9f2e3692
commit d9b8a0ee62

View File

@ -511,6 +511,12 @@ static int audio_test_cleanup(FAR struct audio_state_s *state, int direction)
ioctl(fd, AUDIOIOC_UNREGISTERMQ, (unsigned long)state->mq); ioctl(fd, AUDIOIOC_UNREGISTERMQ, (unsigned long)state->mq);
#ifdef CONFIG_AUDIO_MULTI_SESSION
ioctl(fd, AUDIOIOC_RELEASE, (unsigned long)state->session);
#else
ioctl(fd, AUDIOIOC_RELEASE, 0);
#endif
if (state->out_fd >= 0) if (state->out_fd >= 0)
{ {
close(state->out_fd); close(state->out_fd);
@ -535,6 +541,7 @@ static void audio_test_case(void **audio_state)
}; };
struct mq_attr attr; struct mq_attr attr;
int unconsumed = 0;
unsigned int prio; unsigned int prio;
bool streaming; bool streaming;
bool running; bool running;
@ -596,6 +603,8 @@ static void audio_test_case(void **audio_state)
printf("Start %s. \n", direct == AUDIO_TYPE_OUTPUT ? printf("Start %s. \n", direct == AUDIO_TYPE_OUTPUT ?
"Playback" : "Capture"); "Playback" : "Capture");
unconsumed = buf_info.nbuffers;
while (running) while (running)
{ {
ret = mq_receive(state->mq, (FAR char *)&msg, sizeof(msg), &prio); ret = mq_receive(state->mq, (FAR char *)&msg, sizeof(msg), &prio);
@ -607,6 +616,7 @@ static void audio_test_case(void **audio_state)
switch (msg.msg_id) switch (msg.msg_id)
{ {
case AUDIO_MSG_DEQUEUE: case AUDIO_MSG_DEQUEUE:
unconsumed--;
if (streaming) if (streaming)
{ {
if (direct == AUDIO_TYPE_INPUT) if (direct == AUDIO_TYPE_INPUT)
@ -627,11 +637,15 @@ static void audio_test_case(void **audio_state)
ret = audio_test_enqueuebuffer(state, ret = audio_test_enqueuebuffer(state,
msg.u.ptr, direct); msg.u.ptr, direct);
if (ret != OK) if (ret != OK)
{ {
close(state->out_fd); close(state->out_fd);
state->out_fd = -1; state->out_fd = -1;
streaming = false; streaming = false;
} }
else
{
unconsumed++;
}
} }
} }
break; break;
@ -659,12 +673,16 @@ static void audio_test_case(void **audio_state)
ret = mq_getattr(state->mq, &attr); ret = mq_getattr(state->mq, &attr);
assert_false(ret < 0); assert_false(ret < 0);
if (attr.mq_curmsgs == 0) if (attr.mq_curmsgs == 0 && unconsumed <= 0)
{ {
break; break;
} }
mq_receive(state->mq, (FAR char *)&msg, sizeof(msg), &prio); mq_receive(state->mq, (FAR char *)&msg, sizeof(msg), &prio);
if (msg.msg_id == AUDIO_MSG_DEQUEUE)
{
unconsumed--;
}
} }
while (ret >= 0); while (ret >= 0);