diff options
Diffstat (limited to 'c/src/tests/samples/unlimited/test2.c')
-rw-r--r-- | c/src/tests/samples/unlimited/test2.c | 229 |
1 files changed, 0 insertions, 229 deletions
diff --git a/c/src/tests/samples/unlimited/test2.c b/c/src/tests/samples/unlimited/test2.c deleted file mode 100644 index c892315143..0000000000 --- a/c/src/tests/samples/unlimited/test2.c +++ /dev/null @@ -1,229 +0,0 @@ -/* Init - * - * This routine is the initialization task for this test program. - * It is called from init_exec and has the responsibility for creating - * and starting the tasks that make up the test. If the time of day - * clock is required for the test, it should also be set to a known - * value by this function. - * - * Input parameters: NONE - * - * Output parameters: NONE - * - * COPYRIGHT (c) 1989-1997. - * On-Line Applications Research Corporation (OAR). - * - * The license and distribution terms for this file may in - * the file LICENSE in this distribution or at - * http://www.rtems.com/license/LICENSE. - * - * $Id$ - */ - -#include "system.h" -#include <stdio.h> -#include <stdlib.h> - -void test2() -{ - rtems_status_code result; - rtems_unsigned32 remove_task; - rtems_unsigned32 task; - rtems_unsigned32 block; - rtems_unsigned32 task_count = 0; - rtems_id removed_ids[TASK_ALLOCATION_SIZE * 2]; - - char c1 = 'a'; - char c2 = 'a'; - char c3 = '0'; - char c4 = '0'; - - printf( "\n TEST2 : re-allocate of index numbers, and a block free'ed and one inactive\n" ); - - /* - * Allocate enought tasks so the Inactive list is empty. Remember - * to count the Init task, ie ... - 1. - */ - - while (task_count < ((TASK_ALLOCATION_SIZE * 5) - TASK_INDEX_OFFSET)) - { - rtems_name name; - - printf(" TEST2 : creating task '%c%c%c%c', ", c1, c2, c3, c4); - - name = rtems_build_name(c1, c2, c3, c4); - - result = rtems_task_create(name, - 10, - RTEMS_MINIMUM_STACK_SIZE, - RTEMS_DEFAULT_ATTRIBUTES, - RTEMS_LOCAL, - &task_id[task_count]); - - if (status_code_bad(result)) - break; - - printf("number = %3i, id = %08x, starting, ", task_count, task_id[task_count]); - fflush(stdout); - - result = rtems_task_start(task_id[task_count], - test_task, - (rtems_task_argument) task_count); - - if (status_code_bad(result)) - break; - - /* - * Update the name. - */ - - NEXT_TASK_NAME(c1, c2, c3, c4); - - task_count++; - } - - /* - * Take out the second and fourth allocation size block of tasks - */ - - if (task_count != ((TASK_ALLOCATION_SIZE * 5) - TASK_INDEX_OFFSET)) { - printf( " FAIL2 : not enough tasks created -\n" - " task created = %i, required number = %i\n", - task_count, (TASK_ALLOCATION_SIZE * 5) - TASK_INDEX_OFFSET); - destory_all_tasks("TEST2"); - exit( 1 ); - } - - task = 0; - - for (block = 1; block < 4; block += 2) - { - for (remove_task = (block * TASK_ALLOCATION_SIZE) - TASK_INDEX_OFFSET; - remove_task < (((block + 1) * TASK_ALLOCATION_SIZE) - TASK_INDEX_OFFSET); - remove_task++) - { - if (!task_id[remove_task]) - { - printf( " FAIL2 : remove task has a 0 id -\n" - " task number = %i\n", - remove_task); - destory_all_tasks("TEST2"); - exit( 1 ); - } - - /* - * Save the id's to match them against the reallocated ids - */ - - removed_ids[task++] = task_id[remove_task]; - - printf(" TEST2 : block %i remove, signal task %08x, ", block, task_id[remove_task]); - rtems_event_send(task_id[remove_task], 1); - task_id[remove_task] = 0; - } - } - - for (task = 0; task < (TASK_ALLOCATION_SIZE * 2); task++) - { - rtems_name name; - rtems_unsigned32 id_slot; - - /* - * Find a free slot in the task id table. - */ - - for (id_slot = 0; id_slot < MAX_TASKS; id_slot++) - if (!task_id[id_slot]) - break; - - if (id_slot == MAX_TASKS) - { - printf( " FAIL2 : no free task id slot.\n"); - destory_all_tasks("TEST2"); - exit( 1 ); - } - - printf(" TEST2 : creating task '%c%c%c%c', ", c1, c2, c3, c4); - - name = rtems_build_name(c1, c2, c3, c4); - - result = rtems_task_create(name, - 10, - RTEMS_MINIMUM_STACK_SIZE, - RTEMS_DEFAULT_ATTRIBUTES, - RTEMS_LOCAL, - &task_id[id_slot]); - - if (status_code_bad(result)) - { - printf( " FAIL2 : re-creating a task -\n" - " task number = %i\n", - id_slot); - destory_all_tasks("TEST2"); - exit( 1 ); - } - - printf("number = %3i, id = %08x, starting, ", task_count, task_id[id_slot]); - - result = rtems_task_start(task_id[id_slot], - test_task, - (rtems_task_argument) task_count); - - if (status_code_bad(result)) - { - printf( " FAIL : re-starting a task -\n" - " task number = %i\n", - id_slot); - destory_all_tasks("TEST2"); - exit( 1 ); - } - - /* - * Update the name. - */ - - NEXT_TASK_NAME(c1, c2, c3, c4); - - /* - * Search the removed ids to see if it existed, clear the removed id when found - */ - - for (remove_task = 0; remove_task < (TASK_ALLOCATION_SIZE * 2); remove_task++) - if (removed_ids[remove_task] == task_id[id_slot]) - { - removed_ids[remove_task] = 0; - break; - } - - /* - * If not located in the removed id table, check and make sure it is not - * already allocated - */ - - if (remove_task == (TASK_ALLOCATION_SIZE * 2)) - { - rtems_unsigned32 allocated_id; - - for (allocated_id = 0; allocated_id < MAX_TASKS; allocated_id++) - if ((task_id[id_slot] == task_id[allocated_id]) && (id_slot != allocated_id)) - { - printf( " FAIL2 : the new id is the same as an id already allocated -\n" - " task id = %08x\n", - task_id[id_slot]); - exit( 1 ); - } - - printf( " FAIL2 : could not find the task id in the removed table -\n" - " task id = %08x\n", - task_id[id_slot]); - exit( 1 ); - } - - task_count++; - } - - destory_all_tasks("TEST2"); - - printf( " TEST2 : completed\n" ); -} - |