OSStartHighRdy

Description

OSStartHighRdy() is responsible for starting the highest-priority task that was created prior to calling OSStart()OSStartHighRdy() is a µC/OS-III port function that is generally written in assembly language.

Files

os.h/os_cpu_a.asm

Prototype

void  OSStartHighRdy (void)

Arguments

None

Returned Values

None

Required Configuration

None

Callers

OSStart().

Notes/Warnings

None

Example Usage

The pseudocode for OSStartHighRdy() is shown below.

OSStartHighRdy example usage
          OSStartHighRdy:
              OSTaskSwHook();                              (1)
              SP = OSTCBHighRdyPtr->StkPtr;                (2)
              Pop CPU registers off the task's stack;      (3)
              Return from interrupt;                       (4)

(1) OSStartHighRdy() must call OSTaskSwHook().

 When called, OSTCBCurPtr and OSTCBHighRdyPtr both point to the OS_TCB of the highest-priority task created.

 OSTaskSwHook() should check that OSTCBCurPtr is not equal to OSTCBHighRdyPtr as this is the first time OSTaskSwHook() is called and there is not a task being switched out.

(2) The CPU stack pointer register is loaded with the top-of-stack (TOS) of the task being started. The TOS is found in the .StkPtr field of the OS_TCB. For convenience, the .StkPtr field is the very first field of the OS_TCB data structure. This makes it easily accessible from assembly language.

(3) The registers are popped from the task’s stack frame. Recall that the registers should have been placed on the stack frame in the same order as if they were pushed at the beginning of an interrupt service routine.

(4) You must execute a return from interrupt. This starts the task as if it was resumed when returning from a real interrupt.