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

📄 os_mbox.lst

📁 IARSOURCECODE是基于LPC2478嵌入式软件IAR EWARM V4.42的应用实例代码
💻 LST
📖 第 1 页 / 共 5 页
字号:
    205                           *err                = OS_ERR_TASK_WAITING;
   \   00000108   4900A0E3           MOV      R0,#+73
   \   0000010C   0000C5E5           STRB     R0,[R5, #+0]
    206                           pevent_return       = pevent;
   \   00000110   210000EA           B        ??OSMboxDel_11
    207                       }
    208                       break;
    209          
    210                  case OS_DEL_ALWAYS:                                /* Always delete the mailbox                */
    211                       while (pevent->OSEventGrp != 0) {             /* Ready ALL tasks waiting for mailbox      */
    212                           (void)OS_EventTaskRdy(pevent, (void *)0, OS_STAT_MBOX, OS_STAT_PEND_OK);
   \                     ??OSMboxDel_12:
   \   00000114   0030A0E3           MOV      R3,#+0
   \   00000118   0220A0E3           MOV      R2,#+2
   \   0000011C   0010A0E3           MOV      R1,#+0
   \   00000120   0400B0E1           MOVS     R0,R4
   \   00000124   ........           _BLF     OS_EventTaskRdy,??OS_EventTaskRdy??rA
    213                       }
   \                     ??OSMboxDel_8:
   \   00000128   0A00D4E5           LDRB     R0,[R4, #+10]
   \   0000012C   000050E3           CMP      R0,#+0
   \   00000130   F7FFFF1A           BNE      ??OSMboxDel_12
    214          #if OS_EVENT_NAME_SIZE > 1
    215                       pevent->OSEventName[0] = '?';                 /* Unknown name                             */
   \   00000134   3F00A0E3           MOV      R0,#+63
   \   00000138   0F00C4E5           STRB     R0,[R4, #+15]
    216                       pevent->OSEventName[1] = OS_ASCII_NUL;
   \   0000013C   0000A0E3           MOV      R0,#+0
   \   00000140   1000C4E5           STRB     R0,[R4, #+16]
    217          #endif
    218                       pevent->OSEventType    = OS_EVENT_TYPE_UNUSED;
   \   00000144   0000A0E3           MOV      R0,#+0
   \   00000148   0000C4E5           STRB     R0,[R4, #+0]
    219                       pevent->OSEventPtr     = OSEventFreeList;     /* Return Event Control Block to free list  */
   \   0000014C   ........           LDR      R0,??DataTable9  ;; OSEventFreeList
   \   00000150   000090E5           LDR      R0,[R0, #+0]
   \   00000154   040084E5           STR      R0,[R4, #+4]
    220                       pevent->OSEventCnt     = 0;
   \   00000158   0000A0E3           MOV      R0,#+0
   \   0000015C   B800C4E1           STRH     R0,[R4, #+8]
    221                       OSEventFreeList        = pevent;              /* Get next free event control block        */
   \   00000160   ........           LDR      R0,??DataTable9  ;; OSEventFreeList
   \   00000164   004080E5           STR      R4,[R0, #+0]
    222                       OS_EXIT_CRITICAL();
   \   00000168   0700B0E1           MOVS     R0,R7
   \   0000016C   ........           _BLF     OS_CPU_SR_Restore,??OS_CPU_SR_Restore??rA
    223                       if (tasks_waiting == OS_TRUE) {               /* Reschedule only if task(s) were waiting  */
   \   00000170   010058E3           CMP      R8,#+1
   \   00000174   0000001A           BNE      ??OSMboxDel_13
    224                           OS_Sched();                               /* Find highest priority task ready to run  */
   \   00000178   ........           _BLF     OS_Sched,??OS_Sched??rA
    225                       }
    226                       *err          = OS_ERR_NONE;
   \                     ??OSMboxDel_13:
   \   0000017C   0000A0E3           MOV      R0,#+0
   \   00000180   0000C5E5           STRB     R0,[R5, #+0]
    227                       pevent_return = (OS_EVENT *)0;                /* Mailbox has been deleted                 */
   \   00000184   0040A0E3           MOV      R4,#+0
   \   00000188   030000EA           B        ??OSMboxDel_11
    228                       break;
    229          
    230                  default:
    231                       OS_EXIT_CRITICAL();
   \                     ??OSMboxDel_9:
   \   0000018C   0700B0E1           MOVS     R0,R7
   \   00000190   ........           _BLF     OS_CPU_SR_Restore,??OS_CPU_SR_Restore??rA
    232                       *err          = OS_ERR_INVALID_OPT;
   \   00000194   0700A0E3           MOV      R0,#+7
   \   00000198   0000C5E5           STRB     R0,[R5, #+0]
    233                       pevent_return = pevent;
    234                       break;
    235              }
    236              return (pevent_return);
   \                     ??OSMboxDel_11:
   \   0000019C   0400B0E1           MOVS     R0,R4
   \                     ??OSMboxDel_1:
   \   000001A0   F081BDE8           POP      {R4-R8,PC}       ;; return
    237          }
    238          #endif
    239          
    240          /*$PAGE*/
    241          /*
    242          *********************************************************************************************************
    243          *                                      PEND ON MAILBOX FOR A MESSAGE
    244          *
    245          * Description: This function waits for a message to be sent to a mailbox
    246          *
    247          * Arguments  : pevent        is a pointer to the event control block associated with the desired mailbox
    248          *
    249          *              timeout       is an optional timeout period (in clock ticks).  If non-zero, your task will
    250          *                            wait for a message to arrive at the mailbox up to the amount of time
    251          *                            specified by this argument.  If you specify 0, however, your task will wait
    252          *                            forever at the specified mailbox or, until a message arrives.
    253          *
    254          *              err           is a pointer to where an error message will be deposited.  Possible error
    255          *                            messages are:
    256          *
    257          *                            OS_ERR_NONE         The call was successful and your task received a
    258          *                                                message.
    259          *                            OS_ERR_TIMEOUT      A message was not received within the specified 'timeout'.
    260          *                            OS_ERR_PEND_ABORT   The wait on the mailbox was aborted.
    261          *                            OS_ERR_EVENT_TYPE   Invalid event type
    262          *                            OS_ERR_PEND_ISR     If you called this function from an ISR and the result
    263          *                                                would lead to a suspension.
    264          *                            OS_ERR_PEVENT_NULL  If 'pevent' is a NULL pointer
    265          *                            OS_ERR_PEND_LOCKED  If you called this function when the scheduler is locked
    266          *
    267          * Returns    : != (void *)0  is a pointer to the message received
    268          *              == (void *)0  if no message was received or,
    269          *                            if 'pevent' is a NULL pointer or,
    270          *                            if you didn't pass the proper pointer to the event control block.
    271          *********************************************************************************************************
    272          */
    273          

   \                                 In segment CODE, align 4, keep-with-next
    274          void  *OSMboxPend (OS_EVENT *pevent, INT16U timeout, INT8U *err)
    275          {
   \                     OSMboxPend:
   \   00000000   F0412DE9           PUSH     {R4-R8,LR}
   \   00000004   0050B0E1           MOVS     R5,R0
   \   00000008   0160B0E1           MOVS     R6,R1
   \   0000000C   0240B0E1           MOVS     R4,R2
    276              void      *msg;
    277              INT8U      pend_stat;
    278          #if OS_CRITICAL_METHOD == 3                           /* Allocate storage for CPU status register      */
    279              OS_CPU_SR  cpu_sr = 0;
   \   00000010   0070A0E3           MOV      R7,#+0
    280          #endif
    281          
    282          
    283          
    284          #if OS_ARG_CHK_EN > 0
    285              if (err == (INT8U *)0) {                          /* Validate 'err'                                */
   \   00000014   000054E3           CMP      R4,#+0
   \   00000018   0100001A           BNE      ??OSMboxPend_0
    286                  return ((void *)0);
   \   0000001C   0000A0E3           MOV      R0,#+0
   \   00000020   670000EA           B        ??OSMboxPend_1
    287              }
    288              if (pevent == (OS_EVENT *)0) {                    /* Validate 'pevent'                             */
   \                     ??OSMboxPend_0:
   \   00000024   000055E3           CMP      R5,#+0
   \   00000028   0300001A           BNE      ??OSMboxPend_2
    289                  *err = OS_ERR_PEVENT_NULL;
   \   0000002C   0400A0E3           MOV      R0,#+4
   \   00000030   0000C4E5           STRB     R0,[R4, #+0]
    290                  return ((void *)0);
   \   00000034   0000A0E3           MOV      R0,#+0
   \   00000038   610000EA           B        ??OSMboxPend_1
    291              }
    292          #endif
    293              if (pevent->OSEventType != OS_EVENT_TYPE_MBOX) {  /* Validate event block type                     */
   \                     ??OSMboxPend_2:
   \   0000003C   0000D5E5           LDRB     R0,[R5, #+0]
   \   00000040   010050E3           CMP      R0,#+1
   \   00000044   0300000A           BEQ      ??OSMboxPend_3
    294                  *err = OS_ERR_EVENT_TYPE;
   \   00000048   0100A0E3           MOV      R0,#+1
   \   0000004C   0000C4E5           STRB     R0,[R4, #+0]
    295                  return ((void *)0);
   \   00000050   0000A0E3           MOV      R0,#+0
   \   00000054   5A0000EA           B        ??OSMboxPend_1
    296              }
    297              if (OSIntNesting > 0) {                           /* See if called from ISR ...                    */
   \                     ??OSMboxPend_3:
   \   00000058   ........           LDR      R0,??DataTable10  ;; OSIntNesting
   \   0000005C   0000D0E5           LDRB     R0,[R0, #+0]
   \   00000060   010050E3           CMP      R0,#+1
   \   00000064   0300003A           BCC      ??OSMboxPend_4
    298                  *err = OS_ERR_PEND_ISR;                       /* ... can't PEND from an ISR                    */
   \   00000068   0200A0E3           MOV      R0,#+2
   \   0000006C   0000C4E5           STRB     R0,[R4, #+0]
    299                  return ((void *)0);
   \   00000070   0000A0E3           MOV      R0,#+0
   \   00000074   520000EA           B        ??OSMboxPend_1
    300              }
    301              if (OSLockNesting > 0) {                          /* See if called with scheduler locked ...       */
   \                     ??OSMboxPend_4:
   \   00000078   48019FE5           LDR      R0,??OSMboxPend_5  ;; OSLockNesting
   \   0000007C   0000D0E5           LDRB     R0,[R0, #+0]
   \   00000080   010050E3           CMP      R0,#+1
   \   00000084   0300003A           BCC      ??OSMboxPend_6
    302                  *err = OS_ERR_PEND_LOCKED;                    /* ... can't PEND when locked                    */
   \   00000088   0D00A0E3           MOV      R0,#+13
   \   0000008C   0000C4E5           STRB     R0,[R4, #+0]
    303                  return ((void *)0);
   \   00000090   0000A0E3           MOV      R0,#+0
   \   00000094   4A0000EA           B        ??OSMboxPend_1
    304              }
    305              OS_ENTER_CRITICAL();
   \                     ??OSMboxPend_6:
   \   00000098   ........           _BLF     OS_CPU_SR_Save,??OS_CPU_SR_Save??rA
   \   0000009C   0070B0E1           MOVS     R7,R0
    306              msg = pevent->OSEventPtr;
   \   000000A0   048095E5           LDR      R8,[R5, #+4]
    307              if (msg != (void *)0) {                           /* See if there is already a message             */
   \   000000A4   000058E3           CMP      R8,#+0
   \   000000A8   0700000A           BEQ      ??OSMboxPend_7
    308                  pevent->OSEventPtr = (void *)0;               /* Clear the mailbox                             */
   \   000000AC   0000A0E3           MOV      R0,#+0
   \   000000B0   040085E5           STR      R0,[R5, #+4]
    309                  OS_EXIT_CRITICAL();
   \   000000B4   0700B0E1           MOVS     R0,R7

⌨️ 快捷键说明

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