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

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

?? lib_mem.c

?? 基于ucos的arm7 lpc2138的lcd程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
*                                             Mem_Copy()
*
* Description : Copy data octets from one buffer to another buffer.
*
* Argument(s) : pdest       Pointer to destination memory buffer.
*
*               psrc        Pointer to source      memory buffer.
*
*               size        Number of data buffer octets to copy.
*
* Return(s)   : none.
*
* Caller(s)   : various.
*
* Note(s)     : (1) Null copies allowed (i.e. 0-octet size).
*
*               (2) Memory buffers NOT checked for overlapping.
*
*               (3) For best CPU performance, optimized to fill data buffer using 'CPU_ALIGN'-sized data words.
*
*                   (a) Since many word-aligned processors REQUIRE that multi-octet words be accessed on 
*                       word-aligned addresses, 'CPU_ALIGN'd words MUST be accessed on 'CPU_ALIGN'd addresses.
*
*               (4) Modulo arithmetic is used to determine whether a memory buffer starts on a 'CPU_ALIGN'
*                   address boundary.
*
*                   Modulo arithmetic in ANSI-C REQUIREs operations performed on integer values.  Thus, 
*                   address values MUST be cast to an appropriately-sized integer value PRIOR to any
*                   mem_align_modulo arithmetic operation.
*********************************************************************************************************
*/
/*$PAGE*/
#if ((!defined(uC_CFG_OPTIMIZE_ASM_EN)) || \
     ((defined(uC_CFG_OPTIMIZE_ASM_EN)) && \
              (uC_CFG_OPTIMIZE_ASM_EN   != DEF_ENABLED)))
void  Mem_Copy (void        *pdest,
                void        *psrc,
                CPU_SIZE_T   size)
{
    CPU_SIZE_T    size_rem;
    CPU_ALIGN    *pmem_align_dest;
    CPU_ALIGN    *pmem_align_src;
    CPU_INT08U   *pmem_08_dest;
    CPU_INT08U   *pmem_08_src;
    CPU_INT08U    i;
    CPU_INT08U    mem_align_modulo_dest;
    CPU_INT08U    mem_align_modulo_src;
    CPU_BOOLEAN   mem_aligned;


    if (size < 1) {                                             /* See Note #1.                                         */
        return;
    }
    if (pdest == (void *)0) {
        return;
    }
    if (psrc  == (void *)0) {
        return;
    }


    size_rem              = (CPU_SIZE_T  )size;

    pmem_08_dest          = (CPU_INT08U *)pdest;
    pmem_08_src           = (CPU_INT08U *)psrc;
                                                                /* See Note #4.                                         */
    mem_align_modulo_dest = (CPU_INT08U  )((CPU_ADDR)pmem_08_dest % sizeof(CPU_ALIGN));
    mem_align_modulo_src  = (CPU_INT08U  )((CPU_ADDR)pmem_08_src  % sizeof(CPU_ALIGN));

    mem_aligned           = (mem_align_modulo_dest == mem_align_modulo_src) ? DEF_YES : DEF_NO;

    if (mem_aligned == DEF_YES) {                               /* If mem bufs' alignment offset equal, ...             */
                                                                /* ... optimize copy for mem buf alignment.             */
        if (mem_align_modulo_dest != 0) {                       /* If leading octets avail,                   ...       */
            i = mem_align_modulo_dest;
            while ((size_rem   >  0) &&                         /* ... start mem buf copy with leading octets ...       */
                   (i          <  sizeof(CPU_ALIGN ))) {        /* ... until next CPU_ALIGN word boundary.              */
               *pmem_08_dest++ = *pmem_08_src++;
                size_rem      -=  sizeof(CPU_INT08U);
                i++;
            }
        }

        pmem_align_dest = (CPU_ALIGN *)pmem_08_dest;            /* See Note #3a.                                        */
        pmem_align_src  = (CPU_ALIGN *)pmem_08_src;
        while (size_rem      >=  sizeof(CPU_ALIGN)) {           /* While mem bufs aligned on CPU_ALIGN word boundaries, */
           *pmem_align_dest++ = *pmem_align_src++;              /* ... copy psrc to pdest with CPU_ALIGN-sized words.   */
            size_rem         -=  sizeof(CPU_ALIGN);
        }

        pmem_08_dest = (CPU_INT08U *)pmem_align_dest;
        pmem_08_src  = (CPU_INT08U *)pmem_align_src;
    }

    while (size_rem > 0) {                                      /* For unaligned mem bufs or trailing octets, ...       */
       *pmem_08_dest++ = *pmem_08_src++;                        /* ... copy psrc to pdest by octets.                    */
        size_rem      -=  sizeof(CPU_INT08U);
    }
}
#endif


/*$PAGE*/
/*
*********************************************************************************************************
*                                              Mem_Cmp()
*
* Description : Verify that ALL data octets in two memory buffers are identical in sequence.
*
* Argument(s) : p1_mem      Pointer to first  memory buffer.
*
*               p2_mem      Pointer to second memory buffer.
*
*               size        Number of data buffer octets to compare.
*
* Return(s)   : DEF_YES, if 'size' number of data octets are identical in both memory buffers.
*
*               DEF_NO,  otherwise.
*
* Caller(s)   : various.
*
* Note(s)     : (1) Null compares allowed (i.e. 0-octet size); 'DEF_YES' returned to indicate identical 
*                   null compare.
*
*               (2) Many memory buffer comparisons vary ONLY in the least significant octets -- e.g. 
*                   network address buffers.  Consequently, memory buffer comparison is more efficient 
*                   if the comparison starts from the end of the memory buffers which will abort sooner 
*                   on dissimilar memory buffers that vary only in the least significant octets.
*
*               (3) For best CPU performance, optimized to fill data buffer using 'CPU_ALIGN'-sized data words.
*
*                   (a) Since many word-aligned processors REQUIRE that multi-octet words be accessed on 
*                       word-aligned addresses, 'CPU_ALIGN'd words MUST be accessed on 'CPU_ALIGN'd addresses.
*
*               (4) Modulo arithmetic is used to determine whether a memory buffer starts on a 'CPU_ALIGN'
*                   address boundary.
*
*                   Modulo arithmetic in ANSI-C REQUIREs operations performed on integer values.  Thus, 
*                   address values MUST be cast to an appropriately-sized integer value PRIOR to any
*                   mem_align_modulo arithmetic operation.
********************************************************************************************************
*/
/*$PAGE*/
CPU_BOOLEAN  Mem_Cmp (void        *p1_mem,
                      void        *p2_mem,
                      CPU_SIZE_T   size)
{
    CPU_SIZE_T    size_rem;
    CPU_ALIGN    *p1_mem_align;
    CPU_ALIGN    *p2_mem_align;
    CPU_INT08U   *p1_mem_08;
    CPU_INT08U   *p2_mem_08;
    CPU_INT08U    i;
    CPU_INT08U    mem_align_modulo_1;
    CPU_INT08U    mem_align_modulo_2;
    CPU_BOOLEAN   mem_aligned;
    CPU_BOOLEAN   mem_cmp;


    if (size < 1) {                                             /* See Note #1.                                         */
        return (DEF_YES);
    }
    if (p1_mem == (void *)0) {
        return (DEF_NO);
    }
    if (p2_mem == (void *)0) {
        return (DEF_NO);
    }


    mem_cmp            =  DEF_YES;
    size_rem           =  size;
                                                                /* Start @ end of mem bufs (see Note #2).               */
    p1_mem_08          = (CPU_INT08U *)p1_mem + size;
    p2_mem_08          = (CPU_INT08U *)p2_mem + size;
                                                                /* See Note #4.                                         */
    mem_align_modulo_1 = (CPU_INT08U  )((CPU_ADDR)p1_mem_08 % sizeof(CPU_ALIGN));
    mem_align_modulo_2 = (CPU_INT08U  )((CPU_ADDR)p2_mem_08 % sizeof(CPU_ALIGN));

    mem_aligned        = (mem_align_modulo_1 == mem_align_modulo_2) ? DEF_YES : DEF_NO;

    if (mem_aligned == DEF_YES) {                               /* If mem bufs' alignment offset equal, ...             */
                                                                /* ... optimize cmp for mem buf alignment.              */
        if (mem_align_modulo_1 != 0) {                          /* If trailing octets avail,                  ...       */
            i = mem_align_modulo_1;
            while ((mem_cmp == DEF_YES) &&                      /* ... cmp mem bufs while identical &         ...       */
                   (size_rem > 0)       &&                      /* ... start mem buf cmp with trailing octets ...       */
                   (i        > 0)) {                            /* ... until next CPU_ALIGN word boundary.              */
                p1_mem_08--;
                p2_mem_08--;
                if (*p1_mem_08 != *p2_mem_08) {                 /* If ANY data octet(s) NOT identical, cmp fails.       */
                     mem_cmp = DEF_NO;
                }
                size_rem -= sizeof(CPU_INT08U);
                i--;
            }
        }

        if (mem_cmp == DEF_YES) {                               /* If cmp still identical, cmp aligned mem bufs.        */
            p1_mem_align = (CPU_ALIGN *)p1_mem_08;              /* See Note #3a.                                        */
            p2_mem_align = (CPU_ALIGN *)p2_mem_08;

            while ((mem_cmp  == DEF_YES) &&                     /* Cmp mem bufs while identical & ...                   */
                   (size_rem >= sizeof(CPU_ALIGN))) {           /* ... mem bufs aligned on CPU_ALIGN word boundaries.   */
                p1_mem_align--;
                p2_mem_align--;
                if (*p1_mem_align != *p2_mem_align) {           /* If ANY data octet(s) NOT identical, cmp fails.       */
                     mem_cmp = DEF_NO;
                }
                size_rem -= sizeof(CPU_ALIGN);
            }

            p1_mem_08 = (CPU_INT08U *)p1_mem_align;
            p2_mem_08 = (CPU_INT08U *)p2_mem_align;
        }
    }

    while ((mem_cmp == DEF_YES) &&                              /* Cmp mem bufs while identical ...                     */
           (size_rem > 0)) {                                    /* ... for unaligned mem bufs or trailing octets.       */
        p1_mem_08--;
        p2_mem_08--;
        if (*p1_mem_08 != *p2_mem_08) {                         /* If ANY data octet(s) NOT identical, cmp fails.       */
             mem_cmp = DEF_NO;
        }
        size_rem -= sizeof(CPU_INT08U);
    }

    return (mem_cmp);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费的国产精品| 国产精品1区2区3区| 亚洲图片另类小说| 日本一区二区成人在线| 久久久亚洲综合| 26uuu欧美| 久久精品欧美一区二区三区不卡| 日韩免费高清av| 精品日韩一区二区三区免费视频| 日韩免费观看高清完整版| 日韩精品一区在线| 2023国产精品| 久久久99精品免费观看不卡| 国产视频一区在线播放| 中文字幕 久热精品 视频在线| 国产精品拍天天在线| 国产精品乱人伦一区二区| 亚洲欧洲一区二区在线播放| 亚洲欧洲韩国日本视频| 亚洲精品日产精品乱码不卡| 一区二区久久久久久| 亚洲综合成人网| 日韩国产欧美在线视频| 激情小说亚洲一区| 丁香另类激情小说| 欧洲av一区二区嗯嗯嗯啊| 欧美亚男人的天堂| 一区二区三区四区五区视频在线观看| 欧美日韩免费高清一区色橹橹 | 亚洲一级二级在线| 亚洲一区二区四区蜜桃| 日韩不卡一区二区| 国产乱子伦一区二区三区国色天香| 国产盗摄精品一区二区三区在线 | 欧美激情一区在线观看| 国产精品福利一区二区| 亚洲一区电影777| 久久国产精品免费| 不卡在线观看av| 欧美日韩一区二区欧美激情| 精品免费一区二区三区| 中文字幕在线观看一区二区| 亚洲成人免费看| 国产精品自拍三区| 欧洲一区二区三区免费视频| 日韩精品一区在线| 亚洲人成在线播放网站岛国 | 欧美视频一区二区三区四区| 欧美xxxxx牲另类人与| 国产精品国产精品国产专区不蜜| 香蕉成人啪国产精品视频综合网| 韩日av一区二区| 色婷婷久久久久swag精品| 日韩欧美一二三| 亚洲精品午夜久久久| 捆绑调教一区二区三区| 91污片在线观看| 日韩欧美国产综合一区| 亚洲精品久久嫩草网站秘色| 精品一区二区三区欧美| 欧美中文字幕一区| 国产欧美精品一区二区色综合朱莉| 亚洲国产精品久久久久婷婷884| 国产一区二区三区在线观看精品 | 欧美精品三级在线观看| 国产精品水嫩水嫩| 美女任你摸久久| 色88888久久久久久影院野外| www国产成人| 视频一区二区三区在线| 91性感美女视频| 国产欧美日韩麻豆91| 无吗不卡中文字幕| 色综合中文字幕| 国产日韩欧美一区二区三区乱码| 天堂久久一区二区三区| 99vv1com这只有精品| 久久久一区二区| 久久国内精品视频| 欧美精品xxxxbbbb| 亚洲夂夂婷婷色拍ww47| 成人h动漫精品一区二| 精品国产一区二区三区久久影院| 性做久久久久久| 欧美色精品在线视频| 亚洲欧洲另类国产综合| 国产精品一级在线| 久久亚洲捆绑美女| 久久99精品网久久| 日韩视频一区二区| 日本欧美肥老太交大片| 欧美私人免费视频| 一区二区三区欧美日韩| 91女人视频在线观看| 中文字幕一区二区三区在线不卡| 国产不卡视频在线观看| 久久亚洲私人国产精品va媚药| 麻豆精品视频在线观看免费| 欧美一三区三区四区免费在线看| 亚洲国产成人porn| 精品噜噜噜噜久久久久久久久试看 | 久久综合久久鬼色中文字| 国产精品久久网站| 岛国一区二区三区| 亚洲国产精品二十页| 国产.欧美.日韩| 国产欧美日韩在线观看| 成人免费高清在线| 国产精品的网站| 91免费看视频| 亚洲综合免费观看高清在线观看| 色偷偷久久一区二区三区| 亚洲人成精品久久久久久 | 国产嫩草影院久久久久| 国产精品99久久久| 国产亚洲婷婷免费| 成人美女在线视频| 综合激情网...| 在线免费一区三区| 亚洲图片自拍偷拍| 91精品国产91久久综合桃花 | 精品成人一区二区| 国产伦精品一区二区三区免费| 中文字幕乱码亚洲精品一区| jizz一区二区| 亚洲在线观看免费视频| 欧美浪妇xxxx高跟鞋交| 秋霞影院一区二区| 久久人人爽人人爽| 成人av集中营| 亚洲欧美日韩国产手机在线| 欧美日韩综合在线免费观看| 奇米精品一区二区三区在线观看| 精品成a人在线观看| 不卡视频一二三| 午夜亚洲国产au精品一区二区| 日韩欧美一区在线| 成人一道本在线| 亚洲国产精品影院| 久久只精品国产| 91丨porny丨中文| 日韩精品福利网| 国产婷婷色一区二区三区在线| 91麻豆福利精品推荐| 日本欧美一区二区三区| 国产精品丝袜久久久久久app| 欧美日韩精品三区| 国产久卡久卡久卡久卡视频精品| 亚洲免费视频中文字幕| 日韩欧美国产一区在线观看| 99精品国产一区二区三区不卡| 视频一区视频二区中文| 日本一区二区电影| 欧美一区国产二区| 99在线精品一区二区三区| 日韩成人一级大片| 亚洲欧洲日产国产综合网| 日韩美女主播在线视频一区二区三区 | 成人av网址在线观看| 免费在线成人网| 综合久久久久久| 欧美成va人片在线观看| 一本到不卡精品视频在线观看| 美女网站在线免费欧美精品| 一区二区三区美女| 国产午夜亚洲精品羞羞网站| 正在播放亚洲一区| 91麻豆自制传媒国产之光| 精品一区二区三区在线播放 | 欧美性xxxxxxxx| 国产成人在线视频免费播放| 日日摸夜夜添夜夜添精品视频| 中文字幕一区二区在线播放| 久久久噜噜噜久久中文字幕色伊伊| 在线观看视频一区二区欧美日韩| 国产成人一级电影| 美女视频网站黄色亚洲| 香蕉久久一区二区不卡无毒影院 | 日韩精品亚洲专区| 成人免费一区二区三区在线观看| 欧美sm美女调教| 欧美美女一区二区三区| 91麻豆国产精品久久| 高清成人免费视频| 精品一区二区三区影院在线午夜| 亚洲h在线观看| 悠悠色在线精品| 亚洲色图视频网站| 国产精品嫩草影院com| 久久众筹精品私拍模特| 欧美不卡在线视频| 日韩欧美亚洲国产另类| 亚洲丝袜另类动漫二区| 欧美一级理论性理论a| 欧美性色欧美a在线播放| 91网站在线播放| av中文一区二区三区| 激情图片小说一区| 精品亚洲成a人| 久久国产人妖系列|