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

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

?? os_mbox.lst

?? stm32+ucos-ii
?? LST
?? 第 1 頁 / 共 5 頁
字號:
   \   00000036   002D               CMP      R5,#+0
   \   00000038   09D0               BEQ.N    ??OSMboxCreate_3
    114                  pevent->OSEventType    = OS_EVENT_TYPE_MBOX;
   \   0000003A   0120               MOVS     R0,#+1
   \   0000003C   2870               STRB     R0,[R5, #+0]
    115                  pevent->OSEventCnt     = 0u;
   \   0000003E   0020               MOVS     R0,#+0
   \   00000040   2881               STRH     R0,[R5, #+8]
    116                  pevent->OSEventPtr     = pmsg;           /* Deposit message in event control block             */
   \   00000042   6C60               STR      R4,[R5, #+4]
    117          #if OS_EVENT_NAME_EN > 0u
    118                  pevent->OSEventName    = (INT8U *)(void *)"?";
   \   00000044   ....               ADR.N    R0,??DataTable3  ;; "\?"
   \   00000046   6861               STR      R0,[R5, #+20]
    119          #endif
    120                  OS_EventWaitListInit(pevent);
   \   00000048   2800               MOVS     R0,R5
   \   0000004A   ........           BL       OS_EventWaitListInit
    121              }
    122              return (pevent);                             /* Return pointer to event control block              */
   \                     ??OSMboxCreate_3:
   \   0000004E   2800               MOVS     R0,R5
   \                     ??OSMboxCreate_1:
   \   00000050   70BD               POP      {R4-R6,PC}       ;; return
    123          }
    124          /*$PAGE*/
    125          /*
    126          *********************************************************************************************************
    127          *                                         DELETE A MAIBOX
    128          *
    129          * Description: This function deletes a mailbox and readies all tasks pending on the mailbox.
    130          *
    131          * Arguments  : pevent        is a pointer to the event control block associated with the desired
    132          *                            mailbox.
    133          *
    134          *              opt           determines delete options as follows:
    135          *                            opt == OS_DEL_NO_PEND   Delete the mailbox ONLY if no task pending
    136          *                            opt == OS_DEL_ALWAYS    Deletes the mailbox even if tasks are waiting.
    137          *                                                    In this case, all the tasks pending will be readied.
    138          *
    139          *              perr          is a pointer to an error code that can contain one of the following values:
    140          *                            OS_ERR_NONE             The call was successful and the mailbox was deleted
    141          *                            OS_ERR_DEL_ISR          If you attempted to delete the mailbox from an ISR
    142          *                            OS_ERR_INVALID_OPT      An invalid option was specified
    143          *                            OS_ERR_TASK_WAITING     One or more tasks were waiting on the mailbox
    144          *                            OS_ERR_EVENT_TYPE       If you didn't pass a pointer to a mailbox
    145          *                            OS_ERR_PEVENT_NULL      If 'pevent' is a NULL pointer.
    146          *
    147          * Returns    : pevent        upon error
    148          *              (OS_EVENT *)0 if the mailbox was successfully deleted.
    149          *
    150          * Note(s)    : 1) This function must be used with care.  Tasks that would normally expect the presence of
    151          *                 the mailbox MUST check the return code of OSMboxPend().
    152          *              2) OSMboxAccept() callers will not know that the intended mailbox has been deleted!
    153          *              3) This call can potentially disable interrupts for a long time.  The interrupt disable
    154          *                 time is directly proportional to the number of tasks waiting on the mailbox.
    155          *              4) Because ALL tasks pending on the mailbox will be readied, you MUST be careful in
    156          *                 applications where the mailbox is used for mutual exclusion because the resource(s)
    157          *                 will no longer be guarded by the mailbox.
    158          *********************************************************************************************************
    159          */
    160          
    161          #if OS_MBOX_DEL_EN > 0u

   \                                 In section .text, align 2, keep-with-next
    162          OS_EVENT  *OSMboxDel (OS_EVENT  *pevent,
    163                                INT8U      opt,
    164                                INT8U     *perr)
    165          {
   \                     OSMboxDel:
   \   00000000   2DE9F843           PUSH     {R3-R9,LR}
   \   00000004   8146               MOV      R9,R0
   \   00000006   0C00               MOVS     R4,R1
   \   00000008   1500               MOVS     R5,R2
    166              BOOLEAN    tasks_waiting;
    167              OS_EVENT  *pevent_return;
    168          #if OS_CRITICAL_METHOD == 3u                               /* Allocate storage for CPU status register */
    169              OS_CPU_SR  cpu_sr = 0u;
   \   0000000A   5FF00008           MOVS     R8,#+0
    170          #endif
    171          
    172          
    173          
    174          #ifdef OS_SAFETY_CRITICAL
    175              if (perr == (INT8U *)0) {
    176                  OS_SAFETY_CRITICAL_EXCEPTION();
    177                  return ((OS_EVENT *)0);
    178              }
    179          #endif
    180          
    181          #if OS_ARG_CHK_EN > 0u
    182              if (pevent == (OS_EVENT *)0) {                         /* Validate 'pevent'                        */
    183                  *perr = OS_ERR_PEVENT_NULL;
    184                  return (pevent);
    185              }
    186          #endif
    187              if (pevent->OSEventType != OS_EVENT_TYPE_MBOX) {       /* Validate event block type                */
   \   0000000E   99F80000           LDRB     R0,[R9, #+0]
   \   00000012   0128               CMP      R0,#+1
   \   00000014   03D0               BEQ.N    ??OSMboxDel_0
    188                  *perr = OS_ERR_EVENT_TYPE;
   \   00000016   0120               MOVS     R0,#+1
   \   00000018   2870               STRB     R0,[R5, #+0]
    189                  return (pevent);
   \   0000001A   4846               MOV      R0,R9
   \   0000001C   6AE0               B.N      ??OSMboxDel_1
    190              }
    191              if (OSIntNesting > 0u) {                               /* See if called from ISR ...               */
   \                     ??OSMboxDel_0:
   \   0000001E   ....               LDR.N    R0,??DataTable3_1
   \   00000020   0078               LDRB     R0,[R0, #+0]
   \   00000022   0028               CMP      R0,#+0
   \   00000024   03D0               BEQ.N    ??OSMboxDel_2
    192                  *perr = OS_ERR_DEL_ISR;                            /* ... can't DELETE from an ISR             */
   \   00000026   0F20               MOVS     R0,#+15
   \   00000028   2870               STRB     R0,[R5, #+0]
    193                  return (pevent);
   \   0000002A   4846               MOV      R0,R9
   \   0000002C   62E0               B.N      ??OSMboxDel_1
    194              }
    195              OS_ENTER_CRITICAL();
   \                     ??OSMboxDel_2:
   \   0000002E   ........           BL       OS_CPU_SR_Save
   \   00000032   8046               MOV      R8,R0
    196              if (pevent->OSEventGrp != 0u) {                        /* See if any tasks waiting on mailbox      */
   \   00000034   99F80A00           LDRB     R0,[R9, #+10]
   \   00000038   0028               CMP      R0,#+0
   \   0000003A   02D0               BEQ.N    ??OSMboxDel_3
    197                  tasks_waiting = OS_TRUE;                           /* Yes                                      */
   \   0000003C   0120               MOVS     R0,#+1
   \   0000003E   0600               MOVS     R6,R0
   \   00000040   01E0               B.N      ??OSMboxDel_4
    198              } else {
    199                  tasks_waiting = OS_FALSE;                          /* No                                       */
   \                     ??OSMboxDel_3:
   \   00000042   0020               MOVS     R0,#+0
   \   00000044   0600               MOVS     R6,R0
    200              }
    201              switch (opt) {
   \                     ??OSMboxDel_4:
   \   00000046   E4B2               UXTB     R4,R4            ;; ZeroExt  R4,R4,#+24,#+24
   \   00000048   002C               CMP      R4,#+0
   \   0000004A   02D0               BEQ.N    ??OSMboxDel_5
   \   0000004C   012C               CMP      R4,#+1
   \   0000004E   22D0               BEQ.N    ??OSMboxDel_6
   \   00000050   49E0               B.N      ??OSMboxDel_7
    202                  case OS_DEL_NO_PEND:                               /* Delete mailbox only if no task waiting   */
    203                       if (tasks_waiting == OS_FALSE) {
   \                     ??OSMboxDel_5:
   \   00000052   F6B2               UXTB     R6,R6            ;; ZeroExt  R6,R6,#+24,#+24
   \   00000054   002E               CMP      R6,#+0
   \   00000056   17D1               BNE.N    ??OSMboxDel_8
    204          #if OS_EVENT_NAME_EN > 0u
    205                           pevent->OSEventName = (INT8U *)(void *)"?";
   \   00000058   ....               ADR.N    R0,??DataTable3  ;; "\?"
   \   0000005A   C9F81400           STR      R0,[R9, #+20]
    206          #endif
    207                           pevent->OSEventType = OS_EVENT_TYPE_UNUSED;
   \   0000005E   0020               MOVS     R0,#+0
   \   00000060   89F80000           STRB     R0,[R9, #+0]
    208                           pevent->OSEventPtr  = OSEventFreeList;    /* Return Event Control Block to free list  */
   \   00000064   ....               LDR.N    R0,??DataTable3_2
   \   00000066   0068               LDR      R0,[R0, #+0]
   \   00000068   C9F80400           STR      R0,[R9, #+4]
    209                           pevent->OSEventCnt  = 0u;
   \   0000006C   0020               MOVS     R0,#+0
   \   0000006E   A9F80800           STRH     R0,[R9, #+8]
    210                           OSEventFreeList     = pevent;             /* Get next free event control block        */
   \   00000072   ....               LDR.N    R0,??DataTable3_2
   \   00000074   C0F80090           STR      R9,[R0, #+0]
    211                           OS_EXIT_CRITICAL();
   \   00000078   4046               MOV      R0,R8
   \   0000007A   ........           BL       OS_CPU_SR_Restore
    212                           *perr               = OS_ERR_NONE;
   \   0000007E   0020               MOVS     R0,#+0
   \   00000080   2870               STRB     R0,[R5, #+0]
    213                           pevent_return       = (OS_EVENT *)0;      /* Mailbox has been deleted                 */
   \   00000082   0020               MOVS     R0,#+0
   \   00000084   0700               MOVS     R7,R0
   \   00000086   05E0               B.N      ??OSMboxDel_9
    214                       } else {
    215                           OS_EXIT_CRITICAL();
   \                     ??OSMboxDel_8:
   \   00000088   4046               MOV      R0,R8
   \   0000008A   ........           BL       OS_CPU_SR_Restore
    216                           *perr               = OS_ERR_TASK_WAITING;
   \   0000008E   4920               MOVS     R0,#+73
   \   00000090   2870               STRB     R0,[R5, #+0]
    217                           pevent_return       = pevent;
   \   00000092   4F46               MOV      R7,R9
    218                       }
    219                       break;
   \                     ??OSMboxDel_9:
   \   00000094   2DE0               B.N      ??OSMboxDel_10
    220          
    221                  case OS_DEL_ALWAYS:                                /* Always delete the mailbox                */
    222                       while (pevent->OSEventGrp != 0u) {            /* Ready ALL tasks waiting for mailbox      */
   \                     ??OSMboxDel_6:
   \   00000096   99F80A00           LDRB     R0,[R9, #+10]
   \   0000009A   0028               CMP      R0,#+0
   \   0000009C   06D0               BEQ.N    ??OSMboxDel_11
    223                           (void)OS_EventTaskRdy(pevent, (void *)0, OS_STAT_MBOX, OS_STAT_PEND_OK);
   \   0000009E   0023               MOVS     R3,#+0
   \   000000A0   0222               MOVS     R2,#+2
   \   000000A2   0021               MOVS     R1,#+0
   \   000000A4   4846               MOV      R0,R9
   \   000000A6   ........           BL       OS_EventTaskRdy
   \   000000AA   F4E7               B.N      ??OSMboxDel_6
    224                       }
    225          #if OS_EVENT_NAME_EN > 0u
    226                       pevent->OSEventName    = (INT8U *)(void *)"?";

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品在线播放午夜| 亚洲精品成人悠悠色影视| 麻豆freexxxx性91精品| 在线综合亚洲欧美在线视频| 午夜私人影院久久久久| 7777精品伊人久久久大香线蕉超级流畅| 香蕉成人啪国产精品视频综合网 | 久久97超碰国产精品超碰| 日韩视频中午一区| 激情丁香综合五月| 国产精品视频线看| 91久久精品国产91性色tv| 亚洲最大成人网4388xx| 4438x亚洲最大成人网| 久久99精品久久久久| 国产精品黄色在线观看| 欧美色图激情小说| 国产在线视频一区二区| 国产精品人妖ts系列视频| 日本丶国产丶欧美色综合| 天天av天天翘天天综合网| 精品欧美久久久| 色婷婷久久久久swag精品| 蜜桃视频一区二区三区| 中文字幕欧美激情| 欧美精品1区2区3区| 国产成人免费视频 | 亚洲图片有声小说| 日韩精品一区二区三区中文精品| 懂色av一区二区三区免费看| 亚洲精品国产一区二区精华液 | 久久亚洲精华国产精华液| 91美女在线看| 国产在线播放一区二区三区| 亚洲欧美激情一区二区| 欧美成人vps| 欧美性色欧美a在线播放| 国产精品亚洲午夜一区二区三区| 亚洲制服丝袜在线| 国产日产欧美一区二区视频| 欧美日韩国产成人在线免费| 成人免费毛片aaaaa**| 美女www一区二区| 一区二区三区精密机械公司| 久久精品一区二区三区不卡牛牛| 欧美精品 日韩| 99久久国产综合精品色伊| 久久www免费人成看片高清| 亚洲自拍偷拍图区| 日本一区二区三区免费乱视频| 777亚洲妇女| 日本韩国一区二区三区视频| 丁香六月久久综合狠狠色| 免费成人av在线播放| 亚洲五码中文字幕| 亚洲精品网站在线观看| 国产精品国产成人国产三级| 久久久综合视频| 日韩精品一区二区三区在线播放 | 日韩高清一级片| 一区二区三区在线不卡| 国产欧美1区2区3区| 337p粉嫩大胆噜噜噜噜噜91av| 欧美日韩一区二区三区不卡| 91女人视频在线观看| 福利一区在线观看| 国产精品456露脸| 国产伦精品一区二区三区在线观看| 三级欧美在线一区| 日韩高清欧美激情| 日韩av电影一区| 免费观看在线色综合| 免费观看在线色综合| 人人狠狠综合久久亚洲| 日本亚洲欧美天堂免费| 日韩制服丝袜av| 日本女优在线视频一区二区| 热久久免费视频| 久久69国产一区二区蜜臀| 久久国产精品无码网站| 精品制服美女久久| 国产成人午夜视频| 成人免费观看视频| 91色在线porny| 欧美色综合天天久久综合精品| 欧美视频日韩视频在线观看| 欧美日韩在线精品一区二区三区激情| 欧美午夜精品理论片a级按摩| 欧美日韩亚洲不卡| 欧美一区二区视频免费观看| 正在播放一区二区| 精品盗摄一区二区三区| 国产丝袜美腿一区二区三区| 中文字幕中文字幕一区二区| 亚洲美女视频在线观看| 亚洲444eee在线观看| 奇米在线7777在线精品| 国产精品88888| 一本大道久久a久久综合婷婷| 欧美性大战久久久久久久| 91精品国产免费| 久久精品一区二区三区不卡| 日韩一区日韩二区| 午夜日韩在线电影| 国产精品资源网站| 欧洲亚洲精品在线| 精品国产1区二区| 中文字幕一区二区三区蜜月| 亚洲丶国产丶欧美一区二区三区| 免费在线观看成人| 不卡电影免费在线播放一区| 欧美优质美女网站| 精品国免费一区二区三区| 国产精品丝袜黑色高跟| 亚洲va天堂va国产va久| 国产精品1区2区| 在线视频一区二区三| 久久色视频免费观看| 一区二区三区四区在线播放| 久久99精品久久久久久动态图| 91美女片黄在线观看| 久久综合网色—综合色88| 亚洲乱码国产乱码精品精小说| 蜜臀av性久久久久蜜臀aⅴ| 91亚洲大成网污www| 亚洲精品一区二区三区香蕉| 亚洲日本在线天堂| 国产麻豆午夜三级精品| 欧美性受极品xxxx喷水| 国产精品视频线看| 久久精品久久精品| 欧美主播一区二区三区| 国产精品久久久久久亚洲伦 | 久久久www成人免费毛片麻豆| 亚洲美女淫视频| 成人免费毛片aaaaa**| 日韩欧美视频一区| 亚洲国产精品一区二区www| 成人免费视频网站在线观看| 欧美电影免费观看高清完整版| 日韩理论片一区二区| 国产精品一区一区| 日韩片之四级片| 亚洲图片自拍偷拍| 色婷婷综合久久| ...xxx性欧美| 国产成人在线观看| 日韩欧美一区二区视频| 亚洲综合色噜噜狠狠| www.欧美色图| 国产欧美视频一区二区| 久久se这里有精品| 欧美日韩精品欧美日韩精品一综合| 中文字幕高清一区| 国产精品1区二区.| 久久婷婷国产综合精品青草| 美国十次综合导航| 欧美一区二区在线观看| 亚洲国产毛片aaaaa无费看| 色妞www精品视频| 自拍偷拍欧美精品| av电影在线观看完整版一区二区 | 亚洲婷婷综合色高清在线| 国产在线观看一区二区| 日韩精品一区国产麻豆| 另类成人小视频在线| 日韩一级高清毛片| 日韩专区一卡二卡| 69p69国产精品| 日本系列欧美系列| 欧美一区二区三区免费观看视频| 亚洲自拍欧美精品| 欧美影片第一页| 亚洲成人在线免费| 91精品国产一区二区人妖| 日韩av在线发布| 日韩欧美一区电影| 久久99精品久久只有精品| 久久只精品国产| 国产成人精品www牛牛影视| 国产清纯白嫩初高生在线观看91| 国产成人亚洲综合a∨婷婷| 国产精品成人网| 91蜜桃视频在线| 亚州成人在线电影| 日韩美一区二区三区| 国产激情偷乱视频一区二区三区| 欧美极品xxx| 色先锋久久av资源部| 午夜激情一区二区| 精品国产百合女同互慰| 成人黄色免费短视频| 亚洲三级电影网站| 91麻豆精品国产91久久久资源速度 | 成人福利视频网站| 亚洲综合精品久久| 精品国一区二区三区| 91在线免费看| 首页综合国产亚洲丝袜| 久久久久国产一区二区三区四区|