Commit 4feb0f37 authored by Tuomas Tynkkynen's avatar Tuomas Tynkkynen Committed by Greg Kroah-Hartman

staging: bcm2835-audio: Check if workqueue allocation failed

Currently, if allocating a workqueue fails, the driver will probe
successfully but it will silently do nothing, which is rather silly.
So instead bail out with -ENOMEM in bcm2835_audio_open() if
alloc_workqueue() fails, and remove the now pointless checks for a NULL
workqueue.

While at it, get rid of the rather pointless one-line function
my_workqueue_init().
Signed-off-by: default avatarTuomas Tynkkynen <tuomas@tuxera.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 81f34e96
...@@ -117,44 +117,40 @@ static void my_wq_function(struct work_struct *work) ...@@ -117,44 +117,40 @@ static void my_wq_function(struct work_struct *work)
int bcm2835_audio_start(struct bcm2835_alsa_stream *alsa_stream) int bcm2835_audio_start(struct bcm2835_alsa_stream *alsa_stream)
{ {
if (alsa_stream->my_wq) { struct bcm2835_audio_work *work;
struct bcm2835_audio_work *work;
work = kmalloc(sizeof(*work), GFP_ATOMIC);
work = kmalloc(sizeof(*work), GFP_ATOMIC); /*--- Queue some work (item 1) ---*/
/*--- Queue some work (item 1) ---*/ if (!work) {
if (!work) { LOG_ERR(" .. Error: NULL work kmalloc\n");
LOG_ERR(" .. Error: NULL work kmalloc\n"); return -ENOMEM;
return -ENOMEM; }
} INIT_WORK(&work->my_work, my_wq_function);
INIT_WORK(&work->my_work, my_wq_function); work->alsa_stream = alsa_stream;
work->alsa_stream = alsa_stream; work->cmd = BCM2835_AUDIO_START;
work->cmd = BCM2835_AUDIO_START; if (!queue_work(alsa_stream->my_wq, &work->my_work)) {
if (!queue_work(alsa_stream->my_wq, &work->my_work)) { kfree(work);
kfree(work); return -EBUSY;
return -EBUSY;
}
} }
return 0; return 0;
} }
int bcm2835_audio_stop(struct bcm2835_alsa_stream *alsa_stream) int bcm2835_audio_stop(struct bcm2835_alsa_stream *alsa_stream)
{ {
if (alsa_stream->my_wq) { struct bcm2835_audio_work *work;
struct bcm2835_audio_work *work;
work = kmalloc(sizeof(*work), GFP_ATOMIC);
work = kmalloc(sizeof(*work), GFP_ATOMIC); /*--- Queue some work (item 1) ---*/
/*--- Queue some work (item 1) ---*/ if (!work) {
if (!work) { LOG_ERR(" .. Error: NULL work kmalloc\n");
LOG_ERR(" .. Error: NULL work kmalloc\n"); return -ENOMEM;
return -ENOMEM; }
} INIT_WORK(&work->my_work, my_wq_function);
INIT_WORK(&work->my_work, my_wq_function); work->alsa_stream = alsa_stream;
work->alsa_stream = alsa_stream; work->cmd = BCM2835_AUDIO_STOP;
work->cmd = BCM2835_AUDIO_STOP; if (!queue_work(alsa_stream->my_wq, &work->my_work)) {
if (!queue_work(alsa_stream->my_wq, &work->my_work)) { kfree(work);
kfree(work); return -EBUSY;
return -EBUSY;
}
} }
return 0; return 0;
} }
...@@ -162,40 +158,31 @@ int bcm2835_audio_stop(struct bcm2835_alsa_stream *alsa_stream) ...@@ -162,40 +158,31 @@ int bcm2835_audio_stop(struct bcm2835_alsa_stream *alsa_stream)
int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream, int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream,
unsigned int count, void *src) unsigned int count, void *src)
{ {
if (alsa_stream->my_wq) { struct bcm2835_audio_work *work;
struct bcm2835_audio_work *work;
work = kmalloc(sizeof(*work), GFP_ATOMIC);
work = kmalloc(sizeof(*work), GFP_ATOMIC); /*--- Queue some work (item 1) ---*/
/*--- Queue some work (item 1) ---*/ if (!work) {
if (!work) { LOG_ERR(" .. Error: NULL work kmalloc\n");
LOG_ERR(" .. Error: NULL work kmalloc\n"); return -ENOMEM;
return -ENOMEM; }
} INIT_WORK(&work->my_work, my_wq_function);
INIT_WORK(&work->my_work, my_wq_function); work->alsa_stream = alsa_stream;
work->alsa_stream = alsa_stream; work->cmd = BCM2835_AUDIO_WRITE;
work->cmd = BCM2835_AUDIO_WRITE; work->src = src;
work->src = src; work->count = count;
work->count = count; if (!queue_work(alsa_stream->my_wq, &work->my_work)) {
if (!queue_work(alsa_stream->my_wq, &work->my_work)) { kfree(work);
kfree(work); return -EBUSY;
return -EBUSY;
}
} }
return 0; return 0;
} }
static void my_workqueue_init(struct bcm2835_alsa_stream *alsa_stream)
{
alsa_stream->my_wq = alloc_workqueue("my_queue", WQ_HIGHPRI, 1);
}
static void my_workqueue_quit(struct bcm2835_alsa_stream *alsa_stream) static void my_workqueue_quit(struct bcm2835_alsa_stream *alsa_stream)
{ {
if (alsa_stream->my_wq) { flush_workqueue(alsa_stream->my_wq);
flush_workqueue(alsa_stream->my_wq); destroy_workqueue(alsa_stream->my_wq);
destroy_workqueue(alsa_stream->my_wq); alsa_stream->my_wq = NULL;
alsa_stream->my_wq = NULL;
}
} }
static void audio_vchi_callback(void *param, static void audio_vchi_callback(void *param,
...@@ -436,7 +423,9 @@ int bcm2835_audio_open(struct bcm2835_alsa_stream *alsa_stream) ...@@ -436,7 +423,9 @@ int bcm2835_audio_open(struct bcm2835_alsa_stream *alsa_stream)
int status; int status;
int ret; int ret;
my_workqueue_init(alsa_stream); alsa_stream->my_wq = alloc_workqueue("my_queue", WQ_HIGHPRI, 1);
if (!alsa_stream->my_wq)
return -ENOMEM;
ret = bcm2835_audio_open_connection(alsa_stream); ret = bcm2835_audio_open_connection(alsa_stream);
if (ret) { if (ret) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment