blob: b62f8e2ad5f9e05e56aa0629ff569df973ebb08c [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
/**
Unit tests for the Semaphore api (ble_npl_sem):
ble_npl_error_t ble_npl_sem_init(struct ble_npl_sem *sem, uint16_t tokens);
ble_npl_error_t ble_npl_sem_release(struct ble_npl_sem *sem);
ble_npl_error_t ble_npl_sem_pend(struct ble_npl_sem *sem, uint32_t timeout);
uint16_t ble_npl_sem_get_count(struct ble_npl_sem *sem);
*/
#include "test_util.h"
#include "nimble/nimble_npl.h"
//#include "os/os.h"
#define TEST_ITERATIONS 10
#define TASK1_PRIO 1
#define TASK2_PRIO 1
#define TASK1_STACK_SIZE 1028
#define TASK2_STACK_SIZE 1028
static struct ble_npl_task task1;
static struct ble_npl_task task2;
static ble_npl_stack_t task1_stack[TASK1_STACK_SIZE];
static ble_npl_stack_t task2_stack[TASK2_STACK_SIZE];
struct ble_npl_sem task1_sem;
struct ble_npl_sem task2_sem;
/* Task 1 handler function */
void *
task1_handler(void *arg)
{
for (int i = 0; i < TEST_ITERATIONS; i++)
{
/* Release semaphore to task 2 */
SuccessOrQuit(ble_npl_sem_release(&task1_sem),
"ble_npl_sem_release: error releasing task2_sem.");
/* Wait for semaphore from task 2 */
SuccessOrQuit(ble_npl_sem_pend(&task2_sem, BLE_NPL_TIME_FOREVER),
"ble_npl_sem_pend: error waiting for task2_sem.");
}
printf("All tests passed\n");
exit(PASS);
return NULL;
}
/* Task 2 handler function */
void *
task2_handler(void *arg)
{
while(1)
{
/* Wait for semaphore from task1 */
SuccessOrQuit(ble_npl_sem_pend(&task1_sem, BLE_NPL_TIME_FOREVER),
"ble_npl_sem_pend: error waiting for task1_sem.");
/* Release task2 semaphore */
SuccessOrQuit(ble_npl_sem_release(&task2_sem),
"ble_npl_sem_release: error releasing task1_sem.");
}
return NULL;
}
/* Initialize task 1 exposed data objects */
void
task1_init(void)
{
/* Initialize task1 semaphore */
SuccessOrQuit(ble_npl_sem_init(&task1_sem, 0),
"ble_npl_sem_init: task1 returned error.");
}
/* Initialize task 2 exposed data objects */
void
task2_init(void)
{
/* Initialize task1 semaphore */
SuccessOrQuit(ble_npl_sem_init(&task2_sem, 0),
"ble_npl_sem_init: task2 returned error.");
}
/**
* init_app_tasks
*
* This function performs initializations that are required before tasks run.
*
* @return int 0 success; error otherwise.
*/
static int
init_app_tasks(void)
{
/*
* Call task specific initialization functions to initialize any shared objects
* before initializing the tasks with the OS.
*/
task1_init();
task2_init();
/*
* Initialize tasks 1 and 2 with the OS.
*/
ble_npl_task_init(&task1, "task1", task1_handler, NULL, TASK1_PRIO,
BLE_NPL_TIME_FOREVER, task1_stack, TASK1_STACK_SIZE);
ble_npl_task_init(&task2, "task2", task2_handler, NULL, TASK2_PRIO,
BLE_NPL_TIME_FOREVER, task2_stack, TASK2_STACK_SIZE);
return 0;
}
/**
* main
*
* The main function for the application. This function initializes the system and packages,
* calls the application specific task initialization function, then waits and dispatches
* events from the OS default event queue in an infinite loop.
*/
int
main(int argc, char **arg)
{
/* Initialize application specific tasks */
init_app_tasks();
while (1)
{
ble_npl_eventq_run(ble_npl_eventq_dflt_get());
}
/* main never returns */
}