⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nucleus.h

📁 test file nucleus source
💻 H
📖 第 1 页 / 共 4 页
字号:
/*************************************************************************//*                                                                       *//*               Copyright Mentor Graphics Corporation 2003              *//*                         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               *//*                                                                       *//*      nucleus.h                     Nucleus PLUS\Integrator\ADS 1.14.9 *//*                                                                       *//* COMPONENT                                                             *//*                                                                       *//*      System Constants                                                 *//*                                                                       *//* DESCRIPTION                                                           *//*                                                                       *//*      This file contains system constants common to both the           *//*      application and the actual Nucleus PLUS components.  This file   *//*      also contains data structure definitions that hide internal      *//*      information from the application.                                *//*                                                                       *//*                                                                       *//* DATA STRUCTURES                                                       *//*                                                                       *//*      NU_DRIVER                           I/O Driver control block     *//*      NU_EVENT_GROUP                      Event group control block    *//*      NU_HISR                             HISR control block           *//*      NU_MAILBOX                          Mailbox control block        *//*      NU_MEMORY_POOL                      Memory Pool control block    *//*      NU_PARTITION_POOL                   Partition Pool control block *//*      NU_PIPE                             Pipe control block           *//*      NU_QUEUE                            Queue control block          *//*      NU_SEMAPHORE                        Semaphore control block      *//*      NU_TASK                             Task control block           *//*      NU_TIMER                            Timer control block          *//*      NU_PROTECT                          Protection structure         *//*                                                                       *//* FUNCTIONS                                                             *//*                                                                       *//*      None                                                             *//*                                                                       *//* DEPENDENCIES                                                          *//*                                                                       *//*      None                                                             *//*                                                                       *//*************************************************************************//* Check to see if this file has been included already.  */#ifndef         NUCLEUS#ifdef          __cplusplusextern  "C" {                               /* C declarations in C++     */#endif#define         NUCLEUS#define         PLUS_1_11             1#define         PLUS_1_13             2#define         PLUS_1_14             3#define         PLUS_VERSION_COMP     PLUS_1_14#define         NU_SUPERV_USER_MODE   0#define         NU_MODULE_SUPPORT     0#define         NU_MMU_MODE           0/* MMU mode requries the module support */#if (NU_MMU_MODE == 1)#undef          NU_MODULE_SUPPORT#define         NU_MODULE_SUPPORT       1#endif/* Module support requries mode switching */#if (NU_MODULE_SUPPORT == 1)#undef          NU_SUPERV_USER_MODE#define         NU_SUPERV_USER_MODE   1#endif/* Define the clock frequency that is used by the timer control unit (must be defined in hertz */#define NU_System_Clock_Frequency       24000000/* Define the number of Nucleus PLUS ticks that will occur every second.   By default, the PLUS timer goes off every 10ms, so the PLUS System Clock   ticks 100 times in a second. */#define NU_PLUS_Ticks_Per_Second        100/* Define the number of timer ticks that will occur every second.  This is   usually the frequency of the timer used by the Nucleus clock.  It may   be modified by a prescalar.  See the INT assembler file for more   information about the clock */#define NU_HW_Ticks_Per_Second          (NU_System_Clock_Frequency / 16)/* The number of timer ticks between Nucleus timer interrupts that increment   TMD_System_Clock.  See timer initialization code for details about how to   determine this number. */#define NU_HW_Ticks_Per_SW_Tick         (NU_HW_Ticks_Per_Second / NU_PLUS_Ticks_Per_Second)/* Define NU_COUNT_DOWN if the system timer counts down to 0.  Undefine it if   the system timer counts up from 0. This macro is used to switch between   formulas to calculate the number of ticks since the systems started in   NU_Get_Clock */#define NU_COUNT_DOWN/* This macro returns the value of the Nucleus timer (not the system clock)   in the 32-bit variable, ticks.   The ARM Integrator Timer is a 16-bit timer */#define NU_Retrieve_Hardware_Clock(hw_tick) hw_tick = (0x0000FFFF & (*(UINT32 *)(0x13000104)))/* Toggle support for Nucleus POSIX */#define         INCLUDE_NU_POSIX           0/* Define standard data types.  These definitions allow Nucleus PLUS to   perform in the same manner on different target platforms.  */typedef unsigned long           UNSIGNED;typedef long                    SIGNED;typedef unsigned char           DATA_ELEMENT;typedef DATA_ELEMENT            OPTION;typedef DATA_ELEMENT            BOOLEAN;typedef int                     STATUS;typedef unsigned char           UNSIGNED_CHAR;typedef char                    CHAR;typedef unsigned int            UNSIGNED_INT;typedef int                     INT;typedef unsigned long *         UNSIGNED_PTR;typedef unsigned char *         BYTE_PTR;#define VOID voidtypedef char           INT8;typedef unsigned char  UINT8;typedef signed short   INT16;typedef unsigned short UINT16;typedef signed long    INT32;typedef unsigned long  UINT32;#define HUGE#define FAR/* Define register defines.  R1, R2, R3, and R4 are used in the Nucleus PLUS   source code in front of variables that are referenced often.  In some   ports, defining them as "register" will improve performance.  */#define         R1                              register#define         R2                              register#define         R3                              register#define         R4                              register/* Describe the static base register, needed for calling services *//* This also avoids allocating SB (=v6) to any other purpose.     */#ifdef __ARMCC_VERSION__global_reg(6) void *sb;#endif/* Define the number of accesses required to read or write a pointer data   type.  This value is used to make optimizations in some ports of Nucleus   PLUS.  */#define         NU_POINTER_ACCESS               1/* Define the padding required for usage of the DATA_ELEMENT type within   Nucleus PLUS structures.  These values insure proper alignment for the   next structure member.  */#define         PAD_1                           3#define         PAD_2                           2#define         PAD_3                           1/* Define constants that are target dependent and/or are used for internal   purposes.  */#define         NU_MIN_STACK_SIZE               240#define         NU_MAX_NAME                     8#define         NU_MAX_VECTORS                  22#define         NU_MAX_LISRS                    8/* Define constants for the number of UNSIGNED words in each of the basic   system data structures.  */#if ((NU_SUPERV_USER_MODE == 1)||(NU_MODULE_SUPPORT == 1))#define         NU_TASK_SIZE                    44#define         NU_HISR_SIZE                    24#else#define         NU_TASK_SIZE                    42#define         NU_HISR_SIZE                    22#endif#define         NU_MAILBOX_SIZE                 15#define         NU_QUEUE_SIZE                   20#define         NU_PIPE_SIZE                    20#define         NU_SEMAPHORE_SIZE               12#define         NU_EVENT_GROUP_SIZE             11#define         NU_PARTITION_POOL_SIZE          17#define         NU_MEMORY_POOL_SIZE             19#define         NU_TIMER_SIZE                   19#define         NU_PROTECT_SIZE                 4#define         NU_DRIVER_SIZE                  5/* Define what an interrupt vector looks like on the target processor.  */typedef struct NU_VECTOR_STRUCT{    VOID       *pointer;} NU_VECTOR;/* Define constants for use in service parameters.  */#define         NU_AND                          2#define         NU_AND_CONSUME                  3#define         NU_DISABLE_TIMER                4#define         NU_ENABLE_TIMER                 5#define         NU_FALSE                        0#define         NU_FIFO                         6#define         NU_FIXED_SIZE                   7#define         NU_NO_PREEMPT                   8#define         NU_NO_START                     9#define         NU_NO_SUSPEND                   0#define         NU_NULL                         0#define         NU_OR                           0#define         NU_OR_CONSUME                   1#define         NU_PREEMPT                      10#define         NU_PRIORITY                     11#define         NU_START                        12#define         NU_SUSPEND                      0xFFFFFFFFUL#define         NU_TRUE                         1#define         NU_VARIABLE_SIZE                13/* Define interrupt lockout and enable constants.  */#define         NU_DISABLE_INTERRUPTS           0xC0#define         NU_ENABLE_INTERRUPTS            0x00/* Define task suspension constants.  */#define         NU_DRIVER_SUSPEND               10#define         NU_EVENT_SUSPEND                7#define         NU_FINISHED                     11#define         NU_MAILBOX_SUSPEND              3#define         NU_MEMORY_SUSPEND               9#define         NU_PARTITION_SUSPEND            8#define         NU_PIPE_SUSPEND                 5#define         NU_PURE_SUSPEND                 1#define         NU_QUEUE_SUSPEND                4#define         NU_READY                        0#define         NU_SEMAPHORE_SUSPEND            6#define         NU_SLEEP_SUSPEND                2#define         NU_TERMINATED                   12/* Define service completion status constants.  */#define         NU_SUCCESS                      0#define         NU_END_OF_LOG                   -1#define         NU_GROUP_DELETED                -2#define         NU_INVALID_DELETE               -3#define         NU_INVALID_DRIVER               -4#define         NU_INVALID_ENABLE               -5#define         NU_INVALID_ENTRY                -6#define         NU_INVALID_FUNCTION             -7#define         NU_INVALID_GROUP                -8#define         NU_INVALID_HISR                 -9#define         NU_INVALID_MAILBOX              -10#define         NU_INVALID_MEMORY               -11#define         NU_INVALID_MESSAGE              -12#define         NU_INVALID_OPERATION            -13#define         NU_INVALID_PIPE                 -14#define         NU_INVALID_POINTER              -15#define         NU_INVALID_POOL                 -16#define         NU_INVALID_PREEMPT              -17#define         NU_INVALID_PRIORITY             -18#define         NU_INVALID_QUEUE                -19#define         NU_INVALID_RESUME               -20#define         NU_INVALID_SEMAPHORE            -21#define         NU_INVALID_SIZE                 -22#define         NU_INVALID_START                -23#define         NU_INVALID_SUSPEND              -24#define         NU_INVALID_TASK                 -25#define         NU_INVALID_TIMER                -26#define         NU_INVALID_VECTOR               -27#define         NU_MAILBOX_DELETED              -28#define         NU_MAILBOX_EMPTY                -29#define         NU_MAILBOX_FULL                 -30#define         NU_MAILBOX_RESET                -31#define         NU_NO_MEMORY                    -32#define         NU_NO_MORE_LISRS                -33#define         NU_NO_PARTITION                 -34#define         NU_NOT_DISABLED                 -35#define         NU_NOT_PRESENT                  -36#define         NU_NOT_REGISTERED               -37#define         NU_NOT_TERMINATED               -38#define         NU_PIPE_DELETED                 -39#define         NU_PIPE_EMPTY                   -40#define         NU_PIPE_FULL                    -41

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -