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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? os_flag.txt

?? ucos2.86版本結(jié)合STM板極支持包
?? TXT
?? 第 1 頁 / 共 5 頁
字號:
000102  b16c              CBZ      r4,|L1.288|
000104  6862              LDR      r2,[r4,#4]
000106  600a              STR      r2,[r1,#0]  ; OSFlagFreeList
000108  2105              MOVS     r1,#5
00010a  7021              STRB     r1,[r4,#0]
00010c  8126              STRH     r6,[r4,#8]
00010e  2600              MOVS     r6,#0
000110  6066              STR      r6,[r4,#4]
000112  213f              MOVS     r1,#0x3f
000114  72a1              STRB     r1,[r4,#0xa]
000116  72e6              STRB     r6,[r4,#0xb]
000118  f7fff7ff          BL       OS_CPU_SR_Restore
00011c  702e              STRB     r6,[r5,#0]
00011e  e003              B        |L1.296|
                  |L1.288|
000120  f7fff7ff          BL       OS_CPU_SR_Restore
000124  2072              MOVS     r0,#0x72
000126  7028              STRB     r0,[r5,#0]
                  |L1.296|
000128  4620              MOV      r0,r4
00012a  bd70              POP      {r4-r6,pc}
;;;246    
                          ENDP

                  OS_FlagUnlink PROC
;;;1154   
;;;1155       pnode_prev = (OS_FLAG_NODE *)pnode->OSFlagNodePrev;
00012c  6842              LDR      r2,[r0,#4]
;;;1156       pnode_next = (OS_FLAG_NODE *)pnode->OSFlagNodeNext;
00012e  6801              LDR      r1,[r0,#0]
;;;1157       if (pnode_prev == (OS_FLAG_NODE *)0) {                      /* Is it first node in wait list?      */
000130  2300              MOVS     r3,#0
000132  b922              CBNZ     r2,|L1.318|
;;;1158           pgrp                 = (OS_FLAG_GRP *)pnode->OSFlagNodeFlagGrp;
000134  68c2              LDR      r2,[r0,#0xc]
;;;1159           pgrp->OSFlagWaitList = (void *)pnode_next;              /*      Update list for new 1st node   */
000136  6051              STR      r1,[r2,#4]
;;;1160           if (pnode_next != (OS_FLAG_NODE *)0) {
000138  b121              CBZ      r1,|L1.324|
;;;1161               pnode_next->OSFlagNodePrev = (OS_FLAG_NODE *)0;     /*      Link new 1st node PREV to NULL */
00013a  604b              STR      r3,[r1,#4]
00013c  e002              B        |L1.324|
                  |L1.318|
;;;1162           }
;;;1163       } else {                                                    /* No,  A node somewhere in the list   */
;;;1164           pnode_prev->OSFlagNodeNext = pnode_next;                /*      Link around the node to unlink */
00013e  6011              STR      r1,[r2,#0]
;;;1165           if (pnode_next != (OS_FLAG_NODE *)0) {                  /*      Was this the LAST node?        */
000140  b101              CBZ      r1,|L1.324|
;;;1166               pnode_next->OSFlagNodePrev = pnode_prev;            /*      No, Link around current node   */
000142  604a              STR      r2,[r1,#4]
                  |L1.324|
;;;1167           }
;;;1168       }
;;;1169   #if OS_TASK_DEL_EN > 0
;;;1170       ptcb                = (OS_TCB *)pnode->OSFlagNodeTCB;
000144  6880              LDR      r0,[r0,#8]
;;;1171       ptcb->OSTCBFlagNode = (OS_FLAG_NODE *)0;
000146  6243              STR      r3,[r0,#0x24]
;;;1172   #endif
;;;1173   }
000148  4770              BX       lr
;;;1174   #endif
                          ENDP

                  OS_FlagTaskRdy PROC
;;;1101   static  BOOLEAN  OS_FlagTaskRdy (OS_FLAG_NODE *pnode, OS_FLAGS flags_rdy)
;;;1102   {
00014a  b510              PUSH     {r4,lr}
;;;1103       OS_TCB   *ptcb;
;;;1104       BOOLEAN   sched;
;;;1105   
;;;1106   
;;;1107       ptcb                 = (OS_TCB *)pnode->OSFlagNodeTCB; /* Point to TCB of waiting task             */
00014c  6882              LDR      r2,[r0,#8]
;;;1108       ptcb->OSTCBDly       = 0;
00014e  2300              MOVS     r3,#0
000150  8553              STRH     r3,[r2,#0x2a]
;;;1109       ptcb->OSTCBFlagsRdy  = flags_rdy;
000152  8511              STRH     r1,[r2,#0x28]
;;;1110       ptcb->OSTCBStat     &= ~(INT8U)OS_STAT_FLAG;
000154  f892f892          LDRB     r1,[r2,#0x2c]
000158  f021f021          BIC      r1,r1,#0x20
00015c  f882f882          STRB     r1,[r2,#0x2c]
;;;1111       ptcb->OSTCBStatPend  = OS_STAT_PEND_OK;
000160  f882f882          STRB     r3,[r2,#0x2d]
;;;1112       if (ptcb->OSTCBStat == OS_STAT_RDY) {                  /* Task now ready?                          */
000164  f892f892          LDRB     r1,[r2,#0x2c]
000168  b999              CBNZ     r1,|L1.402|
;;;1113           OSRdyGrp               |= ptcb->OSTCBBitY;         /* Put task into ready list                 */
00016a  49dc              LDR      r1,|L1.1244|
00016c  f892f892          LDRB     r3,[r2,#0x32]
000170  f891f891          LDRB     r12,[r1,#0]  ; OSRdyGrp
000174  ea43ea43          ORR      r3,r3,r12
000178  700b              STRB     r3,[r1,#0]  ; OSRdyGrp
;;;1114           OSRdyTbl[ptcb->OSTCBY] |= ptcb->OSTCBBitX;
00017a  f892f892          LDRB     r1,[r2,#0x30]
00017e  4bd8              LDR      r3,|L1.1248|
000180  f892f892          LDRB     r2,[r2,#0x31]
000184  f813f813          LDRB     r12,[r3,r1]
000188  ea4cea4c          ORR      r2,r12,r2
00018c  545a              STRB     r2,[r3,r1]
;;;1115           sched                   = OS_TRUE;
00018e  2401              MOVS     r4,#1
000190  e000              B        |L1.404|
                  |L1.402|
;;;1116       } else {
;;;1117           sched                   = OS_FALSE;
000192  2400              MOVS     r4,#0
                  |L1.404|
;;;1118       }
;;;1119       OS_FlagUnlink(pnode);
000194  f7fff7ff          BL       OS_FlagUnlink
;;;1120       return (sched);
000198  4620              MOV      r0,r4
;;;1121   }
00019a  bd10              POP      {r4,pc}
;;;1122   
                          ENDP

                  OSFlagDel PROC
;;;285    OS_FLAG_GRP  *OSFlagDel (OS_FLAG_GRP *pgrp, INT8U opt, INT8U *perr)
;;;286    {
00019c  e92de92d          PUSH     {r4-r12,lr}
0001a0  4604              MOV      r4,r0
0001a2  4688              MOV      r8,r1
0001a4  4615              MOV      r5,r2
;;;287        BOOLEAN       tasks_waiting;
;;;288        OS_FLAG_NODE *pnode;
;;;289        OS_FLAG_GRP  *pgrp_return;
;;;290    #if OS_CRITICAL_METHOD == 3                                /* Allocate storage for CPU status register */
;;;291        OS_CPU_SR     cpu_sr = 0;
;;;292    #endif
;;;293    
;;;294    
;;;295    
;;;296    #if OS_ARG_CHK_EN > 0
;;;297        if (perr == (INT8U *)0) {                              /* Validate 'perr'                          */
0001a6  b915              CBNZ     r5,|L1.430|
;;;298            return (pgrp);
0001a8  4620              MOV      r0,r4
0001aa  e8bde8bd          POP      {r4-r12,pc}
                  |L1.430|
;;;299        }
;;;300        if (pgrp == (OS_FLAG_GRP *)0) {                        /* Validate 'pgrp'                          */
0001ae  b924              CBNZ     r4,|L1.442|
;;;301            *perr = OS_ERR_FLAG_INVALID_PGRP;
0001b0  206e              MOVS     r0,#0x6e
0001b2  7028              STRB     r0,[r5,#0]
;;;302            return (pgrp);
0001b4  4620              MOV      r0,r4
0001b6  e8bde8bd          POP      {r4-r12,pc}
                  |L1.442|
;;;303        }
;;;304    #endif
;;;305        if (OSIntNesting > 0) {                                /* See if called from ISR ...               */
0001ba  48c6              LDR      r0,|L1.1236|
0001bc  7800              LDRB     r0,[r0,#0]  ; OSIntNesting
0001be  b120              CBZ      r0,|L1.458|
;;;306            *perr = OS_ERR_DEL_ISR;                            /* ... can't DELETE from an ISR             */
0001c0  200f              MOVS     r0,#0xf
0001c2  7028              STRB     r0,[r5,#0]
;;;307            return (pgrp);
0001c4  4620              MOV      r0,r4
0001c6  e8bde8bd          POP      {r4-r12,pc}
                  |L1.458|
;;;308        }
;;;309        if (pgrp->OSFlagType != OS_EVENT_TYPE_FLAG) {          /* Validate event group type                */
0001ca  7820              LDRB     r0,[r4,#0]
0001cc  2805              CMP      r0,#5
0001ce  d004              BEQ      |L1.474|
;;;310            *perr = OS_ERR_EVENT_TYPE;
0001d0  2001              MOVS     r0,#1
0001d2  7028              STRB     r0,[r5,#0]
;;;311            return (pgrp);
0001d4  4620              MOV      r0,r4
0001d6  e8bde8bd          POP      {r4-r12,pc}
                  |L1.474|
;;;312        }
;;;313        OS_ENTER_CRITICAL();
0001da  f7fff7ff          BL       OS_CPU_SR_Save
0001de  4683              MOV      r11,r0
;;;314        if (pgrp->OSFlagWaitList != (void *)0) {               /* See if any tasks waiting on event flags  */
0001e0  6866              LDR      r6,[r4,#4]
0001e2  b10e              CBZ      r6,|L1.488|
;;;315            tasks_waiting = OS_TRUE;                           /* Yes                                      */
0001e4  2701              MOVS     r7,#1
0001e6  e000              B        |L1.490|
                  |L1.488|
;;;316        } else {
;;;317            tasks_waiting = OS_FALSE;                          /* No                                       */
0001e8  2700              MOVS     r7,#0
                  |L1.490|
;;;318        }
;;;319        switch (opt) {
0001ea  ea5fea5f          MOVS     r0,r8
0001ee  f8dff8df          LDR      r9,|L1.1240|
0001f2  f04ff04f          MOV      r8,#0x3f
0001f6  f04ff04f          MOV      r10,#0
0001fa  d003              BEQ      |L1.516|
0001fc  2801              CMP      r0,#1
0001fe  d13f              BNE      |L1.640|
000200  b32e              CBZ      r6,|L1.590|
;;;320            case OS_DEL_NO_PEND:                               /* Delete group if no task waiting          */
;;;321                 if (tasks_waiting == OS_FALSE) {
;;;322    #if OS_FLAG_NAME_SIZE > 1
;;;323                     pgrp->OSFlagName[0]  = '?';               /* Unknown name                             */
;;;324                     pgrp->OSFlagName[1]  = OS_ASCII_NUL;
;;;325    #endif
;;;326                     pgrp->OSFlagType     = OS_EVENT_TYPE_UNUSED;
;;;327                     pgrp->OSFlagWaitList = (void *)OSFlagFreeList; /* Return group to free list           */
;;;328                     pgrp->OSFlagFlags    = (OS_FLAGS)0;
;;;329                     OSFlagFreeList       = pgrp;
;;;330                     OS_EXIT_CRITICAL();
;;;331                     *perr                = OS_ERR_NONE;
;;;332                     pgrp_return          = (OS_FLAG_GRP *)0;  /* Event Flag Group has been deleted        */
;;;333                 } else {
;;;334                     OS_EXIT_CRITICAL();
;;;335                     *perr                = OS_ERR_TASK_WAITING;
;;;336                     pgrp_return          = pgrp;
;;;337                 }
;;;338                 break;
;;;339    
;;;340            case OS_DEL_ALWAYS:                                /* Always delete the event flag group       */
;;;341                 pnode = (OS_FLAG_NODE *)pgrp->OSFlagWaitList;
;;;342                 while (pnode != (OS_FLAG_NODE *)0) {          /* Ready ALL tasks waiting for flags        */
000202  e01d              B        |L1.576|
                  |L1.516|
000204  b9a7              CBNZ     r7,|L1.560|
000206  f884f884          STRB     r8,[r4,#0xa]
00020a  f884f884          STRB     r10,[r4,#0xb]
00020e  f884f884          STRB     r10,[r4,#0]
000212  f8d9f8d9          LDR      r0,[r9,#0]  ; OSFlagFreeList
000216  6060              STR      r0,[r4,#4]
000218  f8a4f8a4          STRH     r10,[r4,#8]
00021c  f8c9f8c9          STR      r4,[r9,#0]  ; OSFlagFreeList
000220  4658              MOV      r0,r11
000222  f7fff7ff          BL       OS_CPU_SR_Restore
000226  f885f885          STRB     r10,[r5,#0]
00022a  2000              MOVS     r0,#0
00022c  e8bde8bd          POP      {r4-r12,pc}
                  |L1.560|
000230  4658              MOV      r0,r11
000232  f7fff7ff          BL       OS_CPU_SR_Restore
000236  2049              MOVS     r0,#0x49
000238  7028              STRB     r0,[r5,#0]
00023a  4620              MOV      r0,r4
00023c  e8bde8bd          POP      {r4-r12,pc}
                  |L1.576|
;;;343                     (void)OS_FlagTaskRdy(pnode, (OS_FLAGS)0);
000240  2100              MOVS     r1,#0
000242  4630              MOV      r0,r6
000244  f7fff7ff          BL       OS_FlagTaskRdy
;;;344                     pnode = (OS_FLAG_NODE *)pnode->OSFlagNodeNext;
000248  6836              LDR      r6,[r6,#0]
00024a  2e00              CMP      r6,#0
00024c  d1f8              BNE      |L1.576|
                  |L1.590|
;;;345                 }
;;;346    #if OS_FLAG_NAME_SIZE > 1
;;;347                 pgrp->OSFlagName[0]  = '?';                   /* Unknown name                             */
00024e  f884f884          STRB     r8,[r4,#0xa]
;;;348                 pgrp->OSFlagName[1]  = OS_ASCII_NUL;
000252  f884f884          STRB     r10,[r4,#0xb]
;;;349    #endif
;;;350                 pgrp->OSFlagType     = OS_EVENT_TYPE_UNUSED;
000256  f884f884          STRB     r10,[r4,#0]

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美色爱综合网| 激情都市一区二区| 色爱区综合激月婷婷| 亚洲欧洲在线观看av| av福利精品导航| 亚洲日本青草视频在线怡红院| 99国产精品久久久久久久久久| 亚洲男人的天堂一区二区| 在线精品视频免费观看| 肉肉av福利一精品导航| 精品国产一区二区精华| 国产成人免费视频一区| 日韩美女啊v在线免费观看| 在线视频国产一区| 久久精品国产久精国产| 国产香蕉久久精品综合网| 9i在线看片成人免费| 亚洲精品视频免费观看| 制服丝袜一区二区三区| 国产在线乱码一区二区三区| 国产精品污污网站在线观看| 欧洲在线/亚洲| 韩国女主播成人在线观看| 国产精品麻豆久久久| 欧美色网一区二区| 国产精品资源在线看| 一区二区三区四区不卡视频| 欧美一区二区三区不卡| 国产91在线|亚洲| 亚洲成a人片综合在线| 国产夜色精品一区二区av| 在线观看日韩电影| 国产精品一区二区男女羞羞无遮挡| 最好看的中文字幕久久| 欧美一区二区三区免费观看视频| 成人性生交大片免费| 日韩专区一卡二卡| 成人免费一区二区三区视频| 欧美一级理论性理论a| 色悠悠久久综合| 国产一区二区在线影院| 亚洲一区二区三区中文字幕| 国产亚洲精品7777| 3atv在线一区二区三区| 99在线精品视频| 韩国v欧美v日本v亚洲v| 亚洲aⅴ怡春院| 中文字幕中文字幕一区二区 | 一区二区三区欧美日韩| 久久综合久久99| 欧美日韩精品电影| 91免费观看在线| 丁香天五香天堂综合| 久久国产精品色婷婷| 五月激情六月综合| 亚洲欧美偷拍另类a∨色屁股| 精品粉嫩aⅴ一区二区三区四区| 欧洲激情一区二区| 99国产精品久| 岛国一区二区在线观看| 国产精一区二区三区| 久久丁香综合五月国产三级网站| 舔着乳尖日韩一区| 樱花影视一区二区| 亚洲免费av高清| 亚洲视频在线观看一区| 国产精品国产三级国产专播品爱网| 久久久天堂av| 久久人人爽爽爽人久久久| 精品少妇一区二区三区日产乱码 | 欧美精品一卡二卡| 一本久久精品一区二区| www.欧美色图| 99久久国产综合精品女不卡| 成人一区二区三区视频| 国产高清久久久| 韩国成人在线视频| 精品一区二区三区在线观看| 美女精品一区二区| 麻豆精品一二三| 久久99久久久久久久久久久| 日韩和欧美一区二区| 天堂精品中文字幕在线| 日韩精品亚洲一区二区三区免费| 午夜欧美2019年伦理| 视频一区视频二区中文字幕| 亚洲无线码一区二区三区| 午夜精品久久一牛影视| 日韩激情在线观看| 久久激五月天综合精品| 国产一区中文字幕| 成人av免费网站| 在线亚洲精品福利网址导航| 欧美日韩综合不卡| 欧美一区二区三区精品| 久久综合色天天久久综合图片| 国产色产综合色产在线视频| 国产精品天干天干在观线| 亚洲欧洲99久久| 亚洲成av人片一区二区三区| 青青草97国产精品免费观看无弹窗版| 蜜臂av日日欢夜夜爽一区| 国产精品自在在线| 91丨porny丨首页| 欧美日韩色一区| 精品久久国产老人久久综合| 日本一区二区三区在线观看| 亚洲美女淫视频| 日韩电影在线观看电影| 国产精品一区二区在线播放| 91麻豆精东视频| 欧美伦理影视网| 久久综合九色综合久久久精品综合 | 亚洲一区二区三区四区在线免费观看| 视频一区免费在线观看| 韩国精品一区二区| 在线一区二区三区四区五区| 91精品国产色综合久久ai换脸| 久久精品网站免费观看| 亚洲综合免费观看高清在线观看| 麻豆国产欧美日韩综合精品二区| 高清久久久久久| 3d动漫精品啪啪一区二区竹菊| 国产欧美日韩卡一| 石原莉奈在线亚洲二区| 不卡视频在线看| 日韩欧美二区三区| 亚洲精品国产视频| 国产真实精品久久二三区| 91成人免费在线视频| 国产日韩精品视频一区| 视频一区二区三区中文字幕| av福利精品导航| 久久综合狠狠综合久久综合88| 一区二区三区欧美亚洲| 国产成人午夜精品影院观看视频 | 亚洲成av人片在www色猫咪| 国产精品99久久久久久有的能看| 欧美午夜影院一区| 亚洲国产高清在线| 久久国产综合精品| 精品婷婷伊人一区三区三| 国产精品理论在线观看| 极品销魂美女一区二区三区| 在线观看不卡视频| 国产精品福利一区二区| 狠狠色狠狠色综合| 日韩三区在线观看| 午夜影院在线观看欧美| 色噜噜狠狠成人网p站| 中文字幕av一区二区三区| 麻豆精品一区二区三区| 欧美日韩日日夜夜| 一区二区三区中文在线| 97se亚洲国产综合在线| 日本一区二区三区dvd视频在线| 久久国产免费看| 欧美一二三区在线| 日韩电影在线一区| 欧美日韩成人一区二区| 亚洲综合偷拍欧美一区色| 色婷婷久久久亚洲一区二区三区| 亚洲国产岛国毛片在线| 国产精品66部| 国产午夜三级一区二区三| 精品午夜久久福利影院| 精品久久久三级丝袜| 精品一区二区三区在线观看| 日韩区在线观看| 秋霞电影网一区二区| 91精品在线观看入口| 日产精品久久久久久久性色| 337p亚洲精品色噜噜狠狠| 蜜臀av亚洲一区中文字幕| 日韩免费视频一区| 韩国女主播成人在线观看| 久久久久88色偷偷免费| 成人一级视频在线观看| 亚洲图片激情小说| 在线中文字幕不卡| 日韩精品成人一区二区在线| 日韩一区二区不卡| 久久精品国产一区二区三| 久久久久久久久久久久电影| 成人影视亚洲图片在线| 亚洲人成在线观看一区二区| 色激情天天射综合网| 亚洲成人av一区二区三区| 日韩欧美一区二区免费| 国产精品小仙女| 亚洲少妇屁股交4| 欧美日韩一区视频| 久久精品国产精品亚洲精品| 国产亚洲一区字幕| 色综合久久中文综合久久97| 午夜精品福利久久久| 欧美变态凌虐bdsm| 成人app软件下载大全免费| 亚洲第一福利一区| 欧美v亚洲v综合ⅴ国产v|