mbed-os5 only for TYBLE16

Dependents:   TYBLE16_simple_data_logger TYBLE16_MP3_Air

Revision:
1:9db0e321a9f4
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/drivers/internal/TaskQueue.h	Tue Dec 31 06:02:27 2019 +0000
@@ -0,0 +1,142 @@
+/*
+ * Copyright (c) 2018-2019, Arm Limited and affiliates.
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef TASK_QUEUE_H
+#define TASK_QUEUE_H
+
+#include "drivers/internal/TaskBase.h"
+#include "platform/Callback.h"
+#include "mbed_critical.h"
+
+#define MBED_MAX_TASK_SIZE  32
+
+namespace events {
+
+/**
+ * \defgroup drivers_TaskQueue TaskQueue class
+ * \ingroup drivers-internal-api-usb
+ * @{
+ */
+
+/** TaskQueue
+ *
+ *  Flexible task queue for dispatching tasks
+ */
+class TaskQueue {
+public:
+
+    /** Create a TaskQueue
+     *
+     *  Create an event queue.
+     */
+    TaskQueue()
+    {
+
+    }
+
+    /** Destroy a TaskQueue
+     */
+    virtual ~TaskQueue()
+    {
+
+    }
+
+    /**
+     * Add this event to the queue for execution
+     *
+     * If the event is already in the queue then it is canceled and
+     * added to the end of the queue.
+     *
+     *  @param event    Pointer to the event
+     */
+    virtual void post(TaskBase *event) = 0;
+
+    /** Cancel an in-flight event
+     *
+     *  Cancels the given event so the event's memory can be reused.
+     *
+     *  The cancel function is IRQ safe.
+     *
+     *  If called while the event queue's dispatch loop is active, the cancel
+     *  function does not guarantee that the event will not execute after it
+     *  returns, as the event may have already begun executing. It does
+     *  guarantee that the event queue is no longer using event data so
+     *  the event can be freed or reused.
+     *
+     *  @param event    Pointer to the event
+     */
+    virtual void cancel(TaskBase *event) = 0;
+
+protected:
+
+    /**
+     * Get the size required to run this task
+     *
+     * Get the minimum size required for TaskQueue::task_start
+     *
+     * @param task The task to check size on
+     * @return required size
+     * @note This call must be made in a critical section
+     */
+    static uint32_t task_size(TaskBase *task)
+    {
+
+        return task->size();
+    }
+
+    /**
+     * Start processing this event by copying out its data
+     *
+     * Inform this event both that callback execution has started
+     * and that the event is free to be posted again.
+     *
+     * @param task The task to start processing
+     * @param dest The buffer to copy the callback arguments to
+     * @param size maximum size to copy
+     * @return Pointer to function run
+     *
+     * @note event_start must not be called on a canceled event as the
+     *                   memory may have been freed already
+     * @note Every call to event_start must be paired with event_finish
+     * @note This call must be made in a critical section
+     */
+    static TaskBase::run_callback_t task_start(TaskBase *task, uint8_t *dest, uint32_t size)
+    {
+
+        return task->_start(dest, size);
+    }
+
+    /**
+     * Finish processing this event
+     *
+     * Inform this event that the callback has run to completion.
+     *
+     * @param task The task to finish processing
+     *
+     * @note Every call to event_finish must be preceded by a call to event_start
+     * @note This call must be made in a critical section
+     */
+    static void task_finish(TaskBase *task)
+    {
+        task->_finish();
+    }
+};
+
+/** @}*/
+
+}
+#endif