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

📄 ex123l.c.rtf

📁 us/osII最新解读
💻 RTF
📖 第 1 页 / 共 3 页
字号:
                    TASK_2_ID, &Task2Stk[0], TASK_STK_SIZE, &TaskUserData[TASK_2_ID], 0);

    strcpy(TaskUserData[TASK_3_ID].TaskName, "MsgQ Rx Task #2");
    OSTaskCreateExt(Task3, (void *)0, &Task3Stk[TASK_STK_SIZE-1], TASK_3_PRIO,
                    TASK_3_ID, &Task3Stk[0], TASK_STK_SIZE, &TaskUserData[TASK_3_ID], 0);

    strcpy(TaskUserData[TASK_4_ID].TaskName, "MboxPostPendTask");
    OSTaskCreateExt(Task4, (void *)0, &Task4Stk[TASK_STK_SIZE-1], TASK_4_PRIO,
                    TASK_4_ID, &Task4Stk[0], TASK_STK_SIZE, &TaskUserData[TASK_4_ID], 0);

    strcpy(TaskUserData[TASK_5_ID].TaskName, "TimeDlyTask");
    OSTaskCreateExt(Task5, (void *)0, &Task5Stk[TASK_STK_SIZE-1], TASK_5_PRIO,
                    TASK_5_ID, &Task5Stk[0], TASK_STK_SIZE, &TaskUserData[TASK_5_ID], 0);

    PC_DispStr( 0, 22, "#Tasks          : xxxxx  CPU Usage: xxx %", DISP_FGND_WHITE);
    PC_DispStr( 0, 23, "#Task switch/sec: xxxxx", DISP_FGND_WHITE);
    for (;;) {
        sprintf(s, "%5d", OSTaskCtr);                      /* Display #tasks running                   */
        PC_DispStr(18, 22, s, DISP_FGND_BLUE + DISP_BGND_CYAN);
        sprintf(s, "%3d", OSCPUUsage);                     /* Display CPU usage in %                   */
        PC_DispStr(36, 22, s, DISP_FGND_BLUE + DISP_BGND_CYAN);
        sprintf(s, "%5d", OSCtxSwCtr);                     /* Display #context switches per second     */
        PC_DispStr(18, 23, s, DISP_FGND_BLUE + DISP_BGND_CYAN);
        sprintf(s, "V%3.2f", (float)OSVersion() * 0.01);
        PC_DispStr(75, 24, s, DISP_FGND_YELLOW + DISP_BGND_BLUE);
        
        OSCtxSwCtr = 0;                                    /* Clear the context switch counter         */

        if (PC_GetKey(&key)) {                             /* See if key has been pressed              */
            if (key == 0x1B) {                             /* Yes, see if it's the ESCAPE key          */
                PC_DOSReturn();                            /* Yes, return to DOS                       */
            }
        }

        OSTimeDly(OS_TICKS_PER_SEC);                       /* Wait one second                          */
    }
}
*********************************************************************************************************
*                                               TASK #1
* Description: This task executes 5 times per second but doesn't do anything.
*********************************************************************************************************
void  Task1 (void *data)
{
    char one   = '1';
    char two   = '2';
    char three = '3'; 
    data = data;
    for (;;) {
        OSQPost(MsgQueue, (void *)&one);
        OSTimeDlyHMSM(0, 0, 1,   0);        /* Delay for 1 second                                      */
        OSQPost(MsgQueue, (void *)&two);
        OSTimeDlyHMSM(0, 0, 0, 500);        /* Delay for 500 mS                                        */
        OSQPost(MsgQueue, (void *)&three);
        OSTimeDlyHMSM(0, 0, 1,   0);        /* Delay for 1 second                                      */
    }
}
*********************************************************************************************************
*                                               TASK #2
* Description: This task waits for messages sent by task #1.
*********************************************************************************************************
void  Task2 (void *data)
{
    INT8U *msg;
    INT8U  err;    
    data = data;
    for (;;) {
        msg = (INT8U *)OSQPend(MsgQueue, 0, &err);    /* Wait forever for message                      */
        PC_DispChar(70, 14, *msg, DISP_FGND_YELLOW + DISP_BGND_BLUE);
        OSTimeDlyHMSM(0, 0, 0, 500);                  /* Delay for 500 mS                              */
    }
}
*********************************************************************************************************
*                                               TASK #3
* Description: This task waits for up to 500 mS for a message sent by task #1.
*********************************************************************************************************
void  Task3 (void *data)
{
    INT8U *msg;
    INT8U  err;
    data = data;
    for (;;) {
        msg = (INT8U *)OSQPend(MsgQueue, OS_TICKS_PER_SEC / 4, &err);  /* Wait up to 250 mS for a msg  */
        if (err == OS_TIMEOUT) {
            PC_DispChar(70, 15, 'T',  DISP_FGND_YELLOW + DISP_BGND_RED);
        } else {
            PC_DispChar(70, 15, *msg, DISP_FGND_YELLOW + DISP_BGND_BLUE);
        }
    }
}
*********************************************************************************************************
*                                               TASK #4
* Description: This task posts a message to a mailbox and then immediately reads the message.
*********************************************************************************************************
void  Task4 (void *data)
{
    OS_EVENT *mbox;
    INT8U     err;
    data = data;
    mbox = OSMboxCreate((void *)0);
    for (;;) {
        OSMboxPost(mbox, (void *)1);             /* Send message to mailbox                            */
        OSMboxPend(mbox, 0, &err);               /* Get message from mailbox                           */
        OSTimeDlyHMSM(0, 0, 0, 10);              /* Delay 10 mS                                        */
    }
}
*********************************************************************************************************
*                                               TASK #5
** Description: This task simply delays itself.  We basically want to determine how long OSTimeDly() takes
*              to execute.
*********************************************************************************************************
void  Task5 (void *data)
{
    data = data;
    for (;;) {
        OSTimeDly(1);
    }
}

void DispTaskStat (INT8U id)
{
    char s[80];
    sprintf(s, "%-18s %05u      %5u          %10ld", 
            TaskUserData[id].TaskName,
            TaskUserData[id].TaskCtr,
            TaskUserData[id].TaskExecTime,
            TaskUserData[id].TaskTotExecTime);
    PC_DispStr(0, id + 11, s, DISP_FGND_LIGHT_GRAY);
}

void  TaskClk (void *data)
{
    char  s[40];
    data = data;
    for (;;) {
        PC_GetDateTime(s);
        PC_DispStr(0, 24, s, DISP_FGND_BLUE + DISP_BGND_CYAN);
        OSTimeDlyHMSM(0, 0, 0, 100);             /* Execute every 100 mS                               */
    }
}
*********************************************************************************************************
*                                           TASK CREATION HOOK
* Description: This function is called when a task is created.
*Arguments  : ptcb    is a pointer to the task being created.
*Note(s)    : 1) Interrupts are disabled during this call.
*********************************************************************************************************
void OSTaskCreateHook (OS_TCB *ptcb)
{
    ptcb = ptcb;                       /* Prevent compiler warning                                     */
}
*********************************************************************************************************
*                                           TASK DELETION HOOK
*Description: This function is called when a task is deleted.
*Arguments  : ptcb    is a pointer to the task being created.
*Note(s)    : 1) Interrupts are disabled during this call.
*********************************************************************************************************
void OSTaskDelHook (OS_TCB *ptcb)
{
    ptcb = ptcb;                       /* Prevent compiler warning                                     */
}
*********************************************************************************************************
*                                           TASK SWITCH HOOK
* Description: This function is called when a task switch is performed.  This allows you to perform other
*              operations during a context switch.
*Arguments  : none
*Note(s)    : 1) Interrupts are disabled during this call.
*              2) It is assumed that the global pointer 'OSTCBHighRdy' points to the TCB of the task that
*                 will be 'switched in' (i.e. the highest priority task) and, 'OSTCBCur' points to the task
*                 being switched out (i.e. the preempted task).
*********************************************************************************************************
void OSTaskSwHook (void)
{
    INT16U          time;
    TASK_USER_DATA *puser;
    time  = PC_ElapsedStop();                    /* This task is done                                  */
    PC_ElapsedStart();                           /* Start for next task                                */
    puser = OSTCBCur->OSTCBExtPtr;               /* Point to used data                                 */
    if (puser != (void *)0) {     
        puser->TaskCtr++;                        /* Increment task counter                             */
        puser->TaskExecTime     = time;          /* Update the task's execution time                   */
        puser->TaskTotExecTime += time;          /* Update the task's total execution time             */
    }
}
*********************************************************************************************************
*                                          STATISTIC TASK HOOK
* Description: This function is called every second by uC/OS-II's statistics task.  This allows your 
*              application to add functionality to the statistics task.
**********************************************************************************************************
void OSTaskStatHook (void)
{
    char   s[80];
    INT8U  i;
    INT32U total;
    INT8U  pct;
    total = 0L;                                          /* Totalize TOT. EXEC. TIME for each task */
    for (i = 0; i < 7; i++) {
        total += TaskUserData[i].TaskTotExecTime;
        DispTaskStat(i);                                 /* Display task data                      */
    }
    if (total > 0) {
        for (i = 0; i < 7; i++) {                        /* Derive percentage of each task         */
            pct = 100 * TaskUserData[i].TaskTotExecTime / total;
            sprintf(s, "%3d %%", pct);
            PC_DispStr(62, i + 11, s, DISP_FGND_YELLOW);
        }
    }
    if (total > 1000000000L) {                           /* Reset total time counters at 1 billion */
        for (i = 0; i < 7; i++) {
            TaskUserData[i].TaskTotExecTime = 0L;
        }
    }
}

void OSTimeTickHook (void)
{
}


⌨️ 快捷键说明

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