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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? artx_config.c

?? 嵌入式例程系列1
?? C
?? 第 1 頁 / 共 2 頁
字號:
   os_runtask = &os_clock_TCB;
   os_clock_TCB.state = RUNNING;
   __asm {
        LDR     R0,=os_runtask              ; os_runtask
        LDR     R0,[R0,#0x0]                ; os_runtask
        LDR     R0,[R0,#TCB_TSTACK]         ; os_runtask->tsk_stack

        LDMIA   R0!,{R4-R8,R12}
        MSR     SPSR_cxsf,R8
        STMDB   SP,{R0}                     ; Set User SP
        LDMDB   SP,{SP}^
        MOVS    PC,R12                      ; RETI
   }
} /* end of os_clock_interrupt */

/*--------------------------- os_def_interrupt ------------------------------*/

void os_def_interrupt (void) __irq  {
   /* Default Interrupt Function: may be called when timer ISR is disabled */
   OS_IACK();
}

/*--------------------------- os_tmr_init -----------------------------------*/

void os_tmr_init (void) {
   /* Initialize hardware timer as system tick timer. This function is     */
   /* called at the system startup.                                        */
   OS_TINIT();
#if (OS_ROBIN == 1)
   os_robin_time = OS_ROBINTOUT;
#endif
} /* end of os_tmr_init */

/*--------------------------- os_tmr_reload ---------------------------------*/

void os_tmr_reload (void) {
   /* Reload system timer for next period if a timer requires reload.        */
   OS_TREL();
} /* end of os_tmr_reload */

/*--------------------------- os_tmr_force_irq ------------------------------*/

void os_tmr_force_irq (void) {
   /* Force a timer interrupt.                                               */
   OS_TFIRQ();
} /* end of os_tmr_force_irq */

/*--------------------------- os_tmr_inspect_cnt ----------------------------*/

U32 os_tmr_inspect_cnt (void) {
   /* Inspect current value of rtx timer.                                    */
   return (OS_TVAL);
} /* end of os_tmr_inspect_cnt */

/*--------------------------- os_tmr_inspect_ovf ----------------------------*/

BOOL os_tmr_inspect_ovf (void) {
   /* Inspect current state of timer overflow flag.                          */
   return (OS_TOVF);
} /* end of os_tmr_inspect_ovf */

/*--------------------------- tsk_lock --------------------------------------*/

void tsk_lock (void) {
   /* Lock out tasks: prevents task switching by locking out scheduler       */
   /* activation on interrupt.                                            .  */
   OS_LOCK();
} /* end of tsk_lock */

/*--------------------------- tsk_unlock ------------------------------------*/

void tsk_unlock (void) {
   /* Enable AR System Tick Timer Interrupts.                                */
   OS_UNLOCK();
} /* end of tsk_unlock */

/*--------------------------- os_init_mem -----------------------------------*/

void os_init_mem (void) {
   U32 i;

   for (i = 0; i < OS_TASKCNT; i++) {
      os_active_TCB[i] = NULL;
   }
   _init_box (&m_tcb, sizeof(m_tcb), sizeof(struct OS_TCB));
   _init_box (&m_stk, sizeof(m_stk), OS_STKSIZE*4);
#if (OS_TIMERCNT != 0)
   _init_box (&m_tmr, sizeof(m_tmr), sizeof(struct OS_TMR));
#endif
} /* end of os_init_mem */

/*--------------------------- os_alloc_TCB ----------------------------------*/

P_TCB os_alloc_TCB () {
   return (_alloc_box (m_tcb));
} /* end of os_alloc_TCB */

/*--------------------------- os_free_TCB -----------------------------------*/

void os_free_TCB (P_TCB p_TCB) {
   /* Free allocated memory resources for the task "p_TCB" */
   _free_box (m_stk, p_TCB->stack);
   _free_box (m_tcb, p_TCB);
#if (OS_STKCHECK == 1)
   if (os_runtask == p_TCB) {
      /* os_tsk_delete_self() called. */
      os_del_flag = __TRUE;
   }
#endif
} /* end of os_free_TCB */

/*--------------------------- os_alloc_TMR ----------------------------------*/

P_TMR os_alloc_TMR () {
#if (OS_TIMERCNT != 0)
   return (_alloc_box (m_tmr));
#else
   return (NULL);
#endif
} /* end of os_alloc_TMR */

/*--------------------------- os_free_TMR -----------------------------------*/

void os_free_TMR (P_TMR timer) {
   /* Free allocated memory resources for user timer 'timer' */
#if (OS_TIMERCNT != 0)
   _free_box (m_tmr, timer);
#else
   timer = timer;
#endif
} /* end of os_free_TMR */

/*--------------------------- os_init_context -------------------------------*/

void os_init_context (P_TCB p_TCB, U8 priority,
                      FUNCP task_body, U8 full_context) {
   /* Prepare TCB and saved context for a first time start of a task         */
   /* "p_TCB" points to TCB to be initialised. "priority" indicates desired  */
   /* execution priority. "task_body" is the start address of the task.      */
   /* "full_context" identifies context type.                                */
   U32 *stk,i;

   /* Initialize general part of TCB */
   p_TCB->cb_type = TCB;
   p_TCB->state   = READY;
   p_TCB->prio    = priority;
   p_TCB->p_lnk   = NULL;
   p_TCB->p_rlnk  = NULL;
   p_TCB->p_dlnk  = NULL;
   p_TCB->p_blnk  = NULL;
   p_TCB->delta_time    = 0;
   p_TCB->interval_time = 0;
   p_TCB->events  = 0;
   p_TCB->waits   = 0;

   /* Initialize ARM specific part of TCB */
   p_TCB->full_ctx = full_context;

   /* Prepare a complete interrupt frame for first task start */
   if (p_TCB->priv_stack != 0) {
      /* User has provided a memory space for the stack. */
      stk = &p_TCB->stack[p_TCB->priv_stack>>2];
   }
   else {
      /* Allocate the memory space for the stack. */
      p_TCB->stack = _alloc_box (m_stk);
      /* Write to the top of stack. */
      stk = &p_TCB->stack[OS_STKSIZE];
   }

   /* Initial PC and default CPSR */
   *--stk = (U32)task_body;
   i      = INITIAL_CPSR;

   /* If a task in THUMB mode, set T-bit. */
   if ((U32)task_body & 1) {
      i |= 0x00000020;
   }
   *--stk = i;

   /* Write initial registers. */
   for (i = full_context ? 13 : 4; i; i--) {
      *--stk = 0;
   }

   /* For "full_context" assign a void pointer to R0. */
   if (full_context) {
      *--stk = (U32)p_TCB->p_msg;
   }

   /* Initial Task stack pointer. */
   p_TCB->tsk_stack = (U32)stk;

   /* Task entry point. */
   p_TCB->ptask = task_body;
#if (OS_STKCHECK == 1)
   /* Set a magic word for checking of stack overflow. */
   p_TCB->stack[0] = MAGIC_WORD;
#endif
} /* end of os_init_context */


/*--------------------------- os_set_env ------------------------------------*/

void os_set_env (P_TCB p_TCB) {
   /* Fix up runtime environment to fit idle task. It is called after the  */
   /* idle task TCB initialization. "p_TCB" identifies the TCB to be used. */
   p_TCB = p_TCB;
   __asm {
        LDR     R0,[R0,#TCB_TSTACK]         ; p_TCB in R0
        MOV     SP,R0
        ADD     SP,SP,#24                   ; ignore default context
   }
} /* end of os_set_env */


/*--------------------------- os_switch_tasks -------------------------------*/

void os_switch_tasks (P_TCB p_new) __swi (0) {
   /* Switch to next task (identified by "p_new"). Saving old and restoring */
   /* new context is written in assembly (module: Swi_ARTX.s)               */

#if (OS_STKCHECK == 1)
   if (tstclrb (&os_del_flag) == __FALSE) {
      /* Do not check if task has deleted itself. */
      if ((os_runtask->tsk_stack < (U32)os_runtask->stack) || 
          (os_runtask->stack[0] != MAGIC_WORD )) {
         os_stk_overflow ();
      }
   }
#endif
   os_runtask->full_ctx = __FALSE;
   os_runtask = p_new;
   p_new->state = RUNNING;
#if (OS_ROBIN == 1)
   if (p_new->full_ctx == __TRUE) {
      os_tsk_robin = p_new;
   }
#endif
   /* Tsk_Unlock */
   OS_UNLOCK();
} /* end of os_switch_tasks */


/*--------------------------- os_chk_robin ----------------------------------*/

void os_chk_robin (void) {
   /* Check if Round Robin timeout expired and switch to the next ready task.*/
   /* This function is called from the "os_clock_demon()" task scheduler.    */
#if (OS_ROBIN == 1)
   P_TCB p_new;

   if (os_rdy.p_lnk != os_tsk_robin) {
      os_robin_time = os_time + OS_ROBINTOUT;
      return;
      }
   if (os_robin_time == os_time) {
      /* Round Robin timeout has expired. */
      os_robin_time += OS_ROBINTOUT;
      p_new = os_get_first (&os_rdy);
      os_put_prio ((P_XCB)&os_rdy, p_new);
      }
#endif
} /* end of os_chk_robin */

/*----------------------------------------------------------------------------
 * end of file
 *---------------------------------------------------------------------------*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲激情图片qvod| 国产精品91xxx| 国产精品一区二区你懂的| 色婷婷国产精品综合在线观看| 欧美男生操女生| 国产精品乱码一区二区三区软件| 五月综合激情网| 99精品国产99久久久久久白柏| 91精品欧美久久久久久动漫| 最新日韩在线视频| 国产精品1区2区3区| 欧美精品日韩精品| 亚洲黄色录像片| 成人午夜电影网站| 久久一留热品黄| 日韩电影在线一区| 欧美日韩一区二区三区四区五区| 国产精品免费久久| 成人一区在线观看| 国产日韩欧美高清| 国产一区二区三区免费播放| 欧美精品 国产精品| 一区二区高清免费观看影视大全| 99国内精品久久| 国产精品乱码久久久久久| 国产电影一区二区三区| 精品黑人一区二区三区久久| 美女视频黄久久| 日韩视频一区二区三区在线播放| 午夜欧美在线一二页| 欧美日韩一卡二卡三卡| 视频一区二区中文字幕| 91精品婷婷国产综合久久| 日本成人在线看| 日韩西西人体444www| 老司机精品视频导航| 精品国产123| 国产69精品一区二区亚洲孕妇| 久久久久久久久久久黄色| 国产乱子轮精品视频| 欧美激情资源网| 96av麻豆蜜桃一区二区| 亚洲女人****多毛耸耸8| 在线亚洲一区二区| 婷婷综合另类小说色区| 91精品国产欧美一区二区18| 久久精品噜噜噜成人88aⅴ| 久久免费看少妇高潮| 成人听书哪个软件好| 亚洲美女屁股眼交| 91麻豆精品国产91久久久久| 麻豆精品国产传媒mv男同| 久久夜色精品一区| 99国产精品久久久久久久久久久| 夜夜精品浪潮av一区二区三区| 欧美日韩三级一区二区| 久久国产精品99精品国产| 国产女主播一区| 欧美日韩一级视频| 国产在线精品视频| 亚洲精品午夜久久久| 日韩小视频在线观看专区| 成人激情校园春色| 亚洲成a人片综合在线| 久久丝袜美腿综合| 欧美伊人久久久久久久久影院 | 亚洲国产成人av网| 欧美大片免费久久精品三p| 成人一区二区三区在线观看| 亚洲va欧美va人人爽| 国产片一区二区三区| 欧美日韩一本到| 成人av资源下载| 免费人成黄页网站在线一区二区| 国产精品美女久久久久久久久久久| 精品视频免费在线| 大白屁股一区二区视频| 天堂影院一区二区| 国产精品久久久久毛片软件| 91精品国产综合久久精品app| 成人av电影在线| 久久国产精品99久久久久久老狼| 一区二区在线免费| 国产色一区二区| 在线观看网站黄不卡| 欧美xxx久久| 麻豆成人av在线| 性做久久久久久免费观看| 亚洲影院免费观看| 在线观看亚洲一区| 国产iv一区二区三区| 看电视剧不卡顿的网站| 亚洲国产一区二区视频| 国产精品久久久久久久午夜片 | 国产乱妇无码大片在线观看| 亚洲午夜免费视频| 国产精品久久久久aaaa樱花| 精品国产人成亚洲区| 91精品国产入口| 777久久久精品| 欧美高清hd18日本| 欧美精品日日鲁夜夜添| 欧美亚洲自拍偷拍| 在线免费观看一区| 色欧美日韩亚洲| 91视频国产资源| av成人老司机| 97久久精品人人爽人人爽蜜臀| 国产精品一级黄| 国产福利一区二区三区视频在线| 蜜臀91精品一区二区三区| 婷婷国产在线综合| 五月天久久比比资源色| 午夜激情一区二区三区| 婷婷国产在线综合| 毛片一区二区三区| 麻豆成人免费电影| 国产一区二区在线看| 国产乱淫av一区二区三区| 国产精品影视在线观看| 国产a视频精品免费观看| 国产69精品久久777的优势| 成人动漫av在线| 91国产丝袜在线播放| 欧美午夜精品一区二区三区| 欧美精品在线视频| 欧美精品一区二区久久婷婷| 久久精品夜色噜噜亚洲a∨| 国产亲近乱来精品视频| 亚洲精品视频在线看| 亚洲成人激情社区| 久久黄色级2电影| 高清国产午夜精品久久久久久| 成人免费视频网站在线观看| 色综合av在线| 91精品国产综合久久久蜜臀图片| 91精品一区二区三区久久久久久 | 一级精品视频在线观看宜春院 | 亚洲黄色性网站| 免费一级欧美片在线观看| 国产一区二区在线看| 91视频在线看| 91麻豆精品国产自产在线| 国产午夜精品一区二区三区视频 | 欧美一二三在线| 国产日韩精品一区| 亚洲精品第一国产综合野| 麻豆成人综合网| 色综合天天综合狠狠| 日韩一区二区在线观看| 国产精品无圣光一区二区| 午夜精品久久久| 国产精品自拍一区| 欧美午夜影院一区| 久久综合精品国产一区二区三区 | 国产精品99久久不卡二区| 91浏览器入口在线观看| 日韩欧美一级二级三级久久久| 亚洲国产经典视频| 日韩av电影免费观看高清完整版| fc2成人免费人成在线观看播放 | 欧美日韩五月天| 国产精品久久久久影院色老大 | 亚洲国产成人精品视频| 懂色av一区二区三区免费观看| 欧美另类变人与禽xxxxx| 国产精品午夜在线观看| 奇米亚洲午夜久久精品| 色乱码一区二区三区88| 精品福利av导航| 午夜精品久久久久| 色婷婷久久99综合精品jk白丝| 欧美成人一区二区三区| 午夜精品aaa| 欧洲国内综合视频| 国产精品久久久久久福利一牛影视| 日本中文字幕一区二区视频 | 99热在这里有精品免费| 欧美xxxxxxxxx| 免费观看久久久4p| 色综合天天综合在线视频| 日本一区二区久久| 国产麻豆视频一区二区| 日韩美女在线视频| 日韩电影一区二区三区四区| 欧美最猛性xxxxx直播| 亚洲图片你懂的| 成人av免费在线| 亚洲国产精品精华液2区45| 美美哒免费高清在线观看视频一区二区 | 3d动漫精品啪啪1区2区免费 | 自拍偷拍国产精品| 成人国产精品视频| 中文字幕第一区综合| 国产成人综合自拍| 欧美国产激情二区三区| 国产精品69毛片高清亚洲| wwwwww.欧美系列| 国产成人精品一区二| 亚洲国产精华液网站w|