亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? artx_config.c

?? 嵌入式例程系列1
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*----------------------------------------------------------------------------
 *      A R T X  -  K e r n e l
 *----------------------------------------------------------------------------
 *      Name:    ARTX_CONFIG.C
 *      Purpose: Configuration of ARTX Kernel for Philips LPC21xx
 *      Rev.:    V2.02 / 6-feb-2006
 *----------------------------------------------------------------------------
 *      This code is part of the ARTX-ARM kernel package of Keil Software.
 *      Copyright (c) 2004-2006 Keil Software. All rights reserved. 
 *---------------------------------------------------------------------------*/

#pragma INTERWORK
#define NOFRAME    __arm __task

#include <LPC21xx.H>                     /* LPC21xx definitions              */
#include <ARTX_Config.h>                 /* ARTX user configuration header   */

/*----------------------------------------------------------------------------
 *      ARTX User configuration part BEGIN
 *---------------------------------------------------------------------------*/

//-------- <<< Use Configuration Wizard in Context Menu >>> -----------------
//
// <h>Task Definitions
// ===================
//
//   <o>Number of concurrent running tasks <0-250>
//   <i> Define max. number of tasks that will run at the same time.
//   <i> Default: 6
#ifndef OS_TASKCNT
 #define OS_TASKCNT     6
#endif

//   <o>Number of tasks with user-provided stack <0-250>
//   <i> Define the number of tasks that will use a bigger stack.
//   <i> The memory space for the stack is provided by the user.
//   <i> Default: 0
#ifndef OS_PRIVCNT
 #define OS_PRIVCNT     0
#endif

//   <o>Task stack size [bytes] <20-4096:4><#/4>
//   <i> Set the stack size for tasks which is assigned by the system.
//   <i> Default: 200
#ifndef OS_STKSIZE
 #define OS_STKSIZE     50
#endif

// <q>Check for the stack overflow
// ===============================
// <i> Include the stack checking code for a stack overflow.
// <i> Note that additional code reduces the Kernel performance.
#ifndef OS_STKCHECK
 #define OS_STKCHECK    1
#endif

//   <o>Number of user timers <0-250>
//   <i> Define max. number of user timers that will run at the same time.
//   <i> Default: 0  (User timers disabled)
#ifndef OS_TIMERCNT
 #define OS_TIMERCNT    0
#endif

// </h>
// <h>System Timer Configuration
// =============================
//   <o>ARTX Kernel timer number <0=> Timer 0 <1=> Timer 1
//   <i> Define the ARM timer used as a system tick timer.
//   <i> Default: Timer 0
#ifndef OS_TIMER
 #define OS_TIMER       1
#endif

//   <o>Timer clock value [Hz] <1-1000000000>
//   <i> Set the timer clock value for selected timer.
//   <i> Default: 15000000  (15MHz at 60MHz CCLK and VPBDIV = 4)
#ifndef OS_CLOCK
 #define OS_CLOCK       15000000
#endif

//   <o>Timer tick value [us] <1-1000000>
//   <i> Set the timer tick value for selected timer.
//   <i> Default: 10000  (10ms)
#ifndef OS_TICK
 #define OS_TICK        10000
#endif

// </h>
// <e>Round-Robin Task switching
// =============================
// <i> Enable Round-Robin Task switching.
#ifndef OS_ROBIN
 #define OS_ROBIN       1
#endif

//   <o>Round-Robin Timeout [ticks] <1-1000>
//   <i> Define how long a task will execute before a task switch.
//   <i> Default: 5
#ifndef OS_ROBINTOUT
 #define OS_ROBINTOUT   5
#endif

// </e>

//------------- <<< end of configuration section >>> -----------------------

/*----------------------------------------------------------------------------
 *      ARTX User configuration part END
 *---------------------------------------------------------------------------*/

#if   (OS_TIMER == 0)                                   /* Timer 0          */
  #define OS_TID_       4                               /*  Timer ID        */
  #define OS_TIM_       (1 << OS_TID_)                  /*  Interrupt Mask  */
  #define OS_TRV        ((U32)(((double)OS_CLOCK*(double)OS_TICK)/1E6)-1)
  #define OS_TVAL       T0TC                            /*  Timer Value     */
  #define OS_TOVF       (T0IR & 1)                      /*  Overflow Flag   */
  #define OS_TREL()     ;                               /*  Timer Reload    */
  #define OS_TFIRQ()    VICSoftInt   |= OS_TIM_;        /*  Force Interrupt */
  #define OS_TIACK()    T0IR = 1;                       /*  Interrupt Ack   */ \
                        VICSoftIntClr = OS_TIM_;                               \
                        VICVectAddr   = 0;
  #define OS_TINIT()    T0MR0 = OS_TRV;                 /*  Initialization  */ \
                        T0MCR = 3;                                             \
                        T0TCR = 1;                                             \
                        VICDefVectAddr = (U32)os_def_interrupt;                \
                        VICVectAddr15  = (U32)os_clock_interrupt;              \
                        VICVectCntl15  = 0x20 | OS_TID_;
#elif (OS_TIMER == 1)                                   /* Timer 1          */
  #define OS_TID_       5                               /*  Timer ID        */
  #define OS_TIM_       (1 << OS_TID_)                  /*  Interrupt Mask  */
  #define OS_TRV        ((U32)(((double)OS_CLOCK*(double)OS_TICK)/1E6)-1)
  #define OS_TVAL       T1TC                            /*  Timer Value     */
  #define OS_TOVF       (T1IR & 1)                      /*  Overflow Flag   */
  #define OS_TREL()     ;                               /*  Timer Reload    */
  #define OS_TFIRQ()    VICSoftInt   |= OS_TIM_;        /*  Force Interrupt */
  #define OS_TIACK()    T1IR = 1;                       /*  Interrupt Ack   */ \
                        VICSoftIntClr = OS_TIM_;                               \
                        VICVectAddr   = 0;
  #define OS_TINIT()    T1MR0 = OS_TRV;                 /*  Initialization  */ \
                        T1MCR = 3;                                             \
                        T1TCR = 1;                                             \
                        VICDefVectAddr = (U32)os_def_interrupt;                \
                        VICVectAddr15  = (U32)os_clock_interrupt;              \
                        VICVectCntl15  = 0x20 | OS_TID_;
#else
  #error OS_TIMER invalid
#endif

#define OS_IACK()       VICVectAddr   = 0;              /* Interrupt Ack    */

#define OS_LOCK()       VICIntEnClr   = OS_TIM_;        /* Task Lock        */
#define OS_UNLOCK()     VICIntEnable |= OS_TIM_;        /* Task Unlock      */

/* WARNING ! Do not use IDLE mode if you are using a JTAG interface  */
/*           for debugging your application.                         */
#define _idle_()        PCON = 1;
#define INITIAL_CPSR    0x40000010
#define MAGIC_WORD      0xE25A2EA5

/*----------------------------------------------------------------------------
 *      Global Variables
 *---------------------------------------------------------------------------*/

extern P_TCB os_runtask;
extern struct OS_XCB os_rdy;
extern struct OS_TCB os_clock_TCB;
extern U16 os_time;
U16 const os_maxtaskrun = OS_TASKCNT;
/* Export following defines to uVision debugger. */
U32 const os_stackinfo = (OS_STKCHECK<<24) | (OS_PRIVCNT<<16) | (OS_STKSIZE*4);
U32 const os_clockrate  = OS_TICK;
U32 const os_timernum   = (OS_TIMER << 16) | OS_TIMERCNT;
U32 const os_rrobin     = (OS_ROBIN << 16) | OS_ROBINTOUT;

/*----------------------------------------------------------------------------
 *      Local Variables
 *---------------------------------------------------------------------------*/
/* Memory pool for TCB allocation    */
static U32 m_tcb[(sizeof(struct OS_TCB) * OS_TASKCNT)/4 + 3];

/* Memory pool for System stack allocation. Need to allocate 2 additional  */
/* entries for 'os_clock_demon()' and 'os_idle_demon()'.                   */
static U32 m_stk[OS_STKSIZE * (OS_TASKCNT-OS_PRIVCNT+2) + 3];

/* An array of Active task pointers.                                       */
P_TCB os_active_TCB[OS_TASKCNT];

#if (OS_ROBIN == 1)
  static U16  os_robin_time;
  static P_TCB os_tsk_robin;
#endif

#if (OS_TIMERCNT != 0)
  /* Memory pool for User Timer allocation                                 */
  static U32 m_tmr[(sizeof(struct OS_TMR) * OS_TIMERCNT)/4 + 3];
#endif

#if (OS_STKCHECK == 1)
  static BIT os_del_flag;
#endif

/*----------------------------------------------------------------------------
 *      Global Functions
 *---------------------------------------------------------------------------*/

/*--------------------------- os_idle_demon ---------------------------------*/

void os_idle_demon (void) __task {
   /* The idle demon is a system task. It is running when no other task is   */
   /* ready to run (idle situation). It must not terminate. Therefore it     */
   /* should contain at least an endless loop.                               */

   for (;;) {
   /* HERE: include here optional user code to be executed when no task runs.*/
   }
} /* end of os_idle_demon */


/*--------------------------- os_tmr_call -----------------------------------*/

void os_tmr_call (U16 info) {
   /* This function is called when the user timer has expired.               */
   /* Parameter "info" is the parameter defined when the timer was created.  */
   /* HERE: include here optional user code to be executed on timeout.       */
   info = info;
} /* end of os_tmr_call */

/*--------------------------- os_stk_overflow -------------------------------*/

#if (OS_STKCHECK == 1)
static void os_stk_overflow (void) {
   /* This function is called when a stack overflow is detected.             */
   /*  'os_runtask' points to a TCB of a task which has a stack overflow     */
   /*  'task_id'    holds a task id for this task                            */
   /* HERE: include here optional code to be executed on stack overflow.     */
   static OS_TID task_id;

   /* Get a task identification for a task with stack problem to 'task_id'.*/
   task_id = os_get_TID (os_runtask);
   /* Use a uVision 'Advanced RTX' debug dialog page 'Active Tasks' to    */
   /* check which task has got a stack overflow and needs a bigger stack. */
   for (;;);
}
#endif

/*--------------------------- os_clock_interrupt ----------------------------*/

void os_clock_interrupt (void) NOFRAME {
   /* Do task switch to clock demon: entered upon a clock interrupt. */
   __asm {
        STMDB   SP!,{R0-R1}                 ; Save Full Context
        STMDB   SP,{SP}^                    ; User SP
        LDMDB   SP,{R0}
        MRS     R1,SPSR                     ; User CPSR
        SUB     LR,LR,#0x4
        STMDB   R0!,{R1,LR}                 ; Push PC, CPSR
        STMDB   R0,{LR}^                    ; Push User LR
        SUB     R0,R0,#0x4                  ; Write back problem !!
        STMDB   R0!,{R2-R12}                ; Push R12-R2
        LDMIA   SP!,{R2-R3}
        STMDB   R0!,{R2-R3}                 ; Push R1-R0

        LDR     R1,=os_runtask              ; os_runtask
        LDR     R1,[R1,#0x0]                ; os_runtask
        STR     R0,[R1,#TCB_TSTACK]         ; os_runtask->tsk_stack
   }
   OS_TIACK();
   tsk_lock ();
   os_runtask->full_ctx = __TRUE;
   os_runtask->state  = READY;
   os_put_rdy_first (os_runtask);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产网站一区二区| 精品在线视频一区| 亚洲女人****多毛耸耸8| 国产清纯白嫩初高生在线观看91| 日韩精品一区二区三区swag | 欧美变态tickle挠乳网站| 欧美久久一二三四区| 欧美日本韩国一区| 欧美一区二区日韩| 精品国产91久久久久久久妲己| 日韩欧美黄色影院| 久久久久国产精品人| 中文字幕精品三区| 亚洲三级电影网站| 亚洲一区二区影院| 日本aⅴ精品一区二区三区 | gogogo免费视频观看亚洲一| 不卡一区二区三区四区| 91浏览器在线视频| 欧美日韩国产美| 日韩欧美在线网站| 久久久精品国产免大香伊| 国产精品久久久久久久岛一牛影视| 亚洲欧洲在线观看av| 樱桃视频在线观看一区| 日韩精品一二三区| 国产在线看一区| 一本色道久久综合亚洲91| 欧美色偷偷大香| 精品国产乱码久久久久久夜甘婷婷 | 欧美综合亚洲图片综合区| 欧美福利电影网| 久久久久久一级片| 亚洲精品成人a在线观看| 日韩经典一区二区| 国产成人av一区二区| 在线观看视频一区| 欧美大片在线观看一区| 中文字幕在线一区| 午夜电影网一区| 国产乱人伦精品一区二区在线观看| 99精品国产视频| 51精品久久久久久久蜜臀| 欧美精品一区在线观看| 亚洲嫩草精品久久| 蜜臀av国产精品久久久久 | 久久精子c满五个校花| 亚洲日本丝袜连裤袜办公室| 免费视频最近日韩| 99国产精品99久久久久久| 91麻豆精品91久久久久久清纯| 久久久久久久综合色一本| 亚洲宅男天堂在线观看无病毒| 精品一区免费av| 91极品视觉盛宴| 国产日本亚洲高清| 免费精品视频最新在线| 日韩视频免费观看高清完整版在线观看| 国产欧美日韩精品a在线观看| 亚洲成人av一区二区三区| 成人app软件下载大全免费| 日韩欧美国产综合一区| 又紧又大又爽精品一区二区| 韩国理伦片一区二区三区在线播放| 色偷偷一区二区三区| 国产亚洲一区二区三区在线观看| 亚洲成人中文在线| 99这里只有久久精品视频| 日韩精品一区二区三区在线| 亚洲成av人片在www色猫咪| 成人综合日日夜夜| 欧美tickling网站挠脚心| 亚洲成人免费av| 风间由美一区二区三区在线观看| 欧美一卡2卡三卡4卡5免费| 亚洲人成网站在线| 成人小视频在线观看| 精品久久免费看| 日韩电影在线一区二区| 欧美视频在线一区二区三区| 自拍偷拍亚洲激情| 成人免费看视频| 久久精品一二三| 国产一区三区三区| 日韩欧美在线一区二区三区| 日韩精品五月天| 欧美私人免费视频| 亚洲一区av在线| 91精品福利在线| 一区二区三区精品视频在线| 91丨porny丨国产入口| 国产免费成人在线视频| 国产成人亚洲综合a∨婷婷 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 日本精品裸体写真集在线观看| 亚洲国产精品黑人久久久| 国产精品一二一区| 久久久精品影视| 国产v综合v亚洲欧| 国产精品美女久久久久久久| 国产99久久久久久免费看农村| 国产欧美精品一区| 国产成人超碰人人澡人人澡| 国产午夜亚洲精品理论片色戒| 国产在线精品一区二区不卡了 | 欧美在线观看一区| 亚洲欧美激情一区二区| 色综合久久天天| 亚洲已满18点击进入久久| 欧美无砖专区一中文字| 天天操天天色综合| 欧美一区二区视频在线观看2020| 日韩精品欧美成人高清一区二区| 欧美人与性动xxxx| 久久成人麻豆午夜电影| 久久婷婷成人综合色| 国产成人在线观看免费网站| 亚洲欧洲另类国产综合| 一本大道久久a久久综合婷婷| 亚洲综合成人在线视频| 欧美日本在线一区| 久久国产精品第一页| 久久久久国产精品人| 99re这里只有精品视频首页| 一区二区三区丝袜| 91精品久久久久久久91蜜桃| 麻豆高清免费国产一区| 国产欧美一区二区三区网站| 97久久久精品综合88久久| 亚洲一区二区视频在线观看| 日韩欧美在线1卡| 成人美女在线观看| 亚洲午夜电影网| 精品国一区二区三区| 成人丝袜高跟foot| 亚洲成av人影院| 国产日韩精品一区二区三区| 91黄色小视频| 国内精品久久久久影院一蜜桃| 国产精品妹子av| 在线观看免费亚洲| 精品中文字幕一区二区小辣椒| 中文字幕国产一区二区| 欧美色图片你懂的| 国产成人夜色高潮福利影视| 亚洲国产日韩精品| 久久久久国产成人精品亚洲午夜| 色综合欧美在线| 精品亚洲成a人| 亚洲美腿欧美偷拍| 精品欧美一区二区三区精品久久| 成人福利视频在线| 麻豆成人免费电影| 亚洲欧美一区二区久久| 精品免费国产二区三区 | 久久久久国产免费免费| 欧美亚洲精品一区| 成人免费看的视频| 轻轻草成人在线| 亚洲人成网站在线| 久久精品综合网| 欧美一区二区三区爱爱| 色综合久久88色综合天天免费| 黑人精品欧美一区二区蜜桃| 一区二区理论电影在线观看| 久久亚洲春色中文字幕久久久| 欧美视频日韩视频| aaa欧美色吧激情视频| 国产综合色精品一区二区三区| 亚洲一区二区三区四区在线观看 | 毛片av一区二区| 亚洲影院在线观看| 国产精品三级视频| 精品日韩成人av| 3d动漫精品啪啪| 日本丶国产丶欧美色综合| 成人一道本在线| 精品综合久久久久久8888| 五月婷婷久久丁香| 亚洲精品一二三区| 国产精品麻豆99久久久久久| 亚洲精品在线免费观看视频| 欧美日韩精品综合在线| 在线免费观看日韩欧美| 99国产精品国产精品久久| 成人精品亚洲人成在线| 国产乱码精品一品二品| 九色综合狠狠综合久久| 日本亚洲一区二区| 日韩精品一二三四| 五月天一区二区| 婷婷开心激情综合| 亚洲国产成人91porn| 又紧又大又爽精品一区二区| 自拍偷拍欧美精品| 日韩一区欧美一区| 国产精品乱人伦一区二区| 欧美国产日韩精品免费观看| 久久久久久久久久看片| 久久婷婷成人综合色|