FreeCalypso > hg > ffs-editor
diff src/nucleus/tmd.c @ 0:92470e5d0b9e
src: partial import from FC Selenite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 15 May 2020 01:28:16 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/nucleus/tmd.c Fri May 15 01:28:16 2020 +0000 @@ -0,0 +1,200 @@ +/*************************************************************************/ +/* */ +/* Copyright Mentor Graphics Corporation 2002 */ +/* All Rights Reserved. */ +/* */ +/* THIS WORK CONTAINS TRADE SECRET AND PROPRIETARY INFORMATION WHICH IS */ +/* THE PROPERTY OF MENTOR GRAPHICS CORPORATION OR ITS LICENSORS AND IS */ +/* SUBJECT TO LICENSE TERMS. */ +/* */ +/*************************************************************************/ + +/*************************************************************************/ +/* */ +/* FILE NAME VERSION */ +/* */ +/* tmd.c Nucleus PLUS 1.14 */ +/* */ +/* COMPONENT */ +/* */ +/* TM - Timer Management */ +/* */ +/* DESCRIPTION */ +/* */ +/* This file contains global data structures for use within the */ +/* timer management component. */ +/* */ +/* DATA STRUCTURES */ +/* */ +/* TMD_Created_Timers_List Pointer to the linked-list */ +/* of created application */ +/* timers */ +/* TMD_Total_Timers Total number of created */ +/* application timers */ +/* TMD_Active_Timers_List Pointer to the linked-list */ +/* of active timers. */ +/* TMD_Active_List_Busy Flag indicating that the */ +/* active timer list is in use*/ +/* TMD_Created_List_Protect Created timer list protect */ +/* structure */ +/* TMD_System_Clock System clock */ +/* TMD_Timer_Start Starting value of timer */ +/* TMD_Timer Timer count-down value */ +/* TMD_Timer_State State of timer */ +/* TMD_Time_Slice Time slice count-down value */ +/* TMD_Time_Slice_Task Pointer to task to time-slice*/ +/* TMD_Time_Slice_State State of time slice */ +/* TMD_HISR Timer HISR control block */ +/* TMD_HISR_Stack_Ptr Pointer to HISR stack area */ +/* TMD_HISR_Stack_Size Size of HISR stack area */ +/* TMD_HISR_Priority Priority of timer HISR */ +/* */ +/* FUNCTIONS */ +/* */ +/* None */ +/* */ +/* DEPENDENCIES */ +/* */ +/* tm_defs.h Timer Management constants */ +/* tc_defs.h Thread Control constants */ +/* */ +/* HISTORY */ +/* */ +/* DATE REMARKS */ +/* */ +/* 03-01-1993 Created initial version 1.0 */ +/* 04-19-1993 Verified version 1.0 */ +/* 08-09-1993 Removed timer task structures, */ +/* making version 1.0a */ +/* 08-09-1993 Verified version 1.0a */ +/* 03-01-1994 Removed active list protect data */ +/* structure since system protect */ +/* is now used, resulting in */ +/* version 1.1 */ +/* */ +/* 03-18-1994 Verified version 1.1 */ +/* 04-17-1996 updated to version 1.2 */ +/* 03-24-1998 Released version 1.3. */ +/* 03-26-1999 Released 1.11m (new release */ +/* numbering scheme) */ +/* 04-17-2002 Released version 1.13m */ +/* 11-07-2002 Released version 1.14 */ +/*************************************************************************/ +#define NU_SOURCE_FILE + +#include "tm_defs.h" /* Timer constants */ + + +/* TMD_Created_Timers_List is the head pointer of the linked list of + created application timers. If the list is NU_NULL, there are no timers + currently created. */ + +CS_NODE *TMD_Created_Timers_List; + + +/* TMD_Total_Timers contains the total number of created application timers + in the system. */ + +UNSIGNED TMD_Total_Timers; + + +/* TMD_Active_Timers_List is the head pointer of the linked list of active + timers. This includes both the application timers and the system timers + used for task sleeping and timeouts. If the list is NU_NULL, there are + no timers currently active. */ + +TM_TCB *TMD_Active_Timers_List; + + +/* TMD_Active_List_Busy is a flag that indicates that the active timer list + is being processed. This is used to prevent multiple updates to the + active timer list. */ + +INT TMD_Active_List_Busy; + + +/* TMD_Created_List_Protect is used to protect the created application timers + list from multiple accesses. */ + +TC_PROTECT TMD_Created_List_Protect; + + +/* TMD_System_Clock is a continually incrementing clock. One is added to + the clock each timer interrupt. */ + +UNSIGNED TMD_System_Clock; + + +/* TMD_Timer_Start represents the starting value of the last set timer + request. */ + +UNSIGNED TMD_Timer_Start; + + +/* TMD_Timer is a count-down timer that is used to represent the smallest + active timer value in the system. Once this counter goes to zero, a + timer has expired. */ + +UNSIGNED TMD_Timer; + + +/* TMD_Timer_State indicates the state of the timer variable. If the state + is active, the timer counter is decremented. If the state is expired, + the timer HISR and timer task are initiated to process the expiration. If + the state indicates that the timer is not-active, the timer counter is + ignored. */ + +INT TMD_Timer_State; + + +/* TMD_Time_Slice contains the count-down value for the currently executing + task's time slice. When this value goes to zero, time slice processing + is started. */ + +UNSIGNED TMD_Time_Slice; + + +/* TMD_Time_Slice_Task is a pointer to the task to time-slice. This pointer + is built in the portion of the timer interrupt that determines if a time- + slice timer has expired. */ + +TC_TCB *TMD_Time_Slice_Task; + + +/* TMD_Time_Slice_State indicates the state of the time slice variable. If + the state is active, the time slice counter is decremented. If the + state is expired, the timer HISR is initiated to process the expiration. + If the state indicates that the time slice is not-active, the time slice + counter is ignored. */ + +INT TMD_Time_Slice_State; + + +/* TMD_HISR is the timer HISR's control block. */ + +TC_HCB TMD_HISR; + + +/* TMD_HISR_Stack_Ptr points to the memory area reserved for the timer HISR. + Note that this is setup in INT_Initialize. */ + +VOID *TMD_HISR_Stack_Ptr; + + +/* TMD_HISR_Stack_Size represents the size of the allocated timer HISR stack. + Note that this is setup in INT_Initialize. */ + +UNSIGNED TMD_HISR_Stack_Size; + + +/* TMD_HISR_Priority indicates the priority of the timer HISR. Priorities + range from 0 to 2, where priority 0 is the highest. Note that this is + also initialized in INT_Initialize. */ + +INT TMD_HISR_Priority; + + + + + +