kernel: work_q: error handling
When trying to cancel a NULL work queue return -EAGAIN. Signed-off-by: Anas Nashif <anas.nashif@intel.com>
This commit is contained in:
parent
361a84d07f
commit
154af912e8
1 changed files with 4 additions and 1 deletions
|
@ -16,6 +16,7 @@
|
||||||
#include <spinlock.h>
|
#include <spinlock.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <sys/check.h>
|
||||||
|
|
||||||
#define WORKQUEUE_THREAD_NAME "workqueue"
|
#define WORKQUEUE_THREAD_NAME "workqueue"
|
||||||
|
|
||||||
|
@ -54,7 +55,9 @@ void k_delayed_work_init(struct k_delayed_work *work, k_work_handler_t handler)
|
||||||
|
|
||||||
static int work_cancel(struct k_delayed_work *work)
|
static int work_cancel(struct k_delayed_work *work)
|
||||||
{
|
{
|
||||||
__ASSERT(work->work_q != NULL, "");
|
CHECKIF(work->work_q == NULL) {
|
||||||
|
return -EAGAIN;
|
||||||
|
}
|
||||||
|
|
||||||
if (k_work_pending(&work->work)) {
|
if (k_work_pending(&work->work)) {
|
||||||
/* Remove from the queue if already submitted */
|
/* Remove from the queue if already submitted */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue