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

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

?? diag.c

?? s3c2510 VxWorks BSP包
?? C
?? 第 1 頁 / 共 4 頁
字號:
        if (ptr[i] != (UINT8)pattern)
        {
            printf("Mismatch\n       (offset 0x%08X, read 0x%02X, expect 0x%02X)\n\n",
                    (UINT32)i,
                    ptr[i],
                    (UINT8)pattern
                    );

            return ERROR;
        }
    }
    printf("OK\n");

    return OK;
}

/* All 0x00 */
STATUS diagAll0x00(UINT8 *ptr, int length)
{
    int i, pattern;

    printf("       Pattern 0x00 ..............");
    for (i=0, pattern=0x00; i<length; i++)
    {
        ptr[i] = (UINT8)pattern;
    }
    for (i=0, pattern=0x00; i<length; i++)
    {
        if (ptr[i] != (UINT8)pattern)
        {
            printf("Mismatch\n       (offset 0x%08X, read 0x%02X, expect 0x%02X)\n\n",
                    (UINT32)i,
                    ptr[i],
                    (UINT8)pattern
                    );

            return ERROR;
        }
    }
    printf("OK\n");

    return OK;
}

/* All 0xFF */
STATUS diagAll0xFF(UINT8 *ptr, int length)
{
    int i, pattern;

    printf("       Pattern 0xFF ..............");
    for (i=0, pattern=0xff; i<length; i++)
    {
        ptr[i] = (UINT8)pattern;
    }
    for (i=0, pattern=0xff; i<length; i++)
    {
        if (ptr[i] != (UINT8)pattern)
        {
            printf("Mismatch\n       (offset 0x%08X, read 0x%02X, expect 0x%02X)\n\n",
                    (UINT32)i,
                    ptr[i],
                    (UINT8)pattern
                    );

            return ERROR;
        }
    }
    printf("OK\n");

    return OK;
}

STATUS diagMem(UINT8 *ptr, int length)
{
    if (diagAddress((UINT32 *)ptr, length) != OK)
    {
        return ERROR;
    }

#ifdef  DIAG_ALIGN
    diagAlign1((UINT32 *)ptr, length);
    diagAlign2((UINT32 *)ptr, length);
    diagAlign3((UINT32 *)ptr, length);
#endif  /* DIAG_ALIGN */

    if (diagIncFrom0x00(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagDecFrom0xFF(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagIncWalkingOne(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagDecWalkingOne(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagAll0x55(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagAll0xAA(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagAll0xFF(ptr, length) != OK)
    {
        return ERROR;
    }

    if (diagAll0x00(ptr, length) != OK)
    {
        return ERROR;
    }

    printf("\n");

    return OK;
}

void diagEthMakeHeader(ETH_DRV_CTRL *pDrvCtrl, PETHTBD pTbd)
{
    bcopy(pDrvCtrl->IFADDR.phyAddress, ((ETH_HDR *)(pTbd->pBuf + SIZE_ETH_WA))->ether_shost, SIZE_ETH_ADDR);
    bcopy(pDrvCtrl->IFADDR.phyAddress, ((ETH_HDR *)(pTbd->pBuf + SIZE_ETH_WA))->ether_dhost, SIZE_ETH_ADDR);
    ((ETH_HDR *)(pTbd->pBuf + SIZE_ETH_WA))->ether_type = htons(ETHERTYPE_IP);
}

STATUS diagEthLoopTest(ETH_DRV_CTRL *pDrvCtrl1, ETH_DRV_CTRL *pDrvCtrl2, int repeat)
{
    int i, j;
    PETHRBD pRbd;
    PETHTBD pTbd;
    UINT32 tickStart;
    ULONG length;


    printf("\nETH%d: Verifying Data Transfer\n", pDrvCtrl1->unit);

    do
    {
        printf("ETH%d: Wait for a few seconds...\n", pDrvCtrl1->unit);

        for (i=0; i<2048; i++)
        {
            for (j=0; j<lengthFrame; j++)
            {
                buffer[j] = (UCHAR)(i + j + j / 256);
            }

            pTbd = ETH_DRV_TBD_GET(pDrvCtrl1);
            if (pTbd)
            {
                diagEthMakeHeader(pDrvCtrl1, pTbd);

                bcopy(buffer, (char *)(pTbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), lengthFrame);

                ETH_DRV_TBD_START(pDrvCtrl1, pTbd, lengthFrame + SIZE_ETH_HDR);

                if (ETH_DRV_TBD_CHECK(pDrvCtrl1, pTbd) != OK)
                {
#ifndef DIAG_QUIET
                    printf("ETH%d: Tx error, sequence %d, length %u, status 0x%04X\n", pDrvCtrl1->unit, i + 1, (UINT)pTbd->length, pTbd->status);
                    printf("ETH%d: TBD:%08X, TB:%08X\n", pDrvCtrl1->unit, (UINT32)pTbd, (UINT32)pTbd->pBuf);
#endif  /* DIAG_QUIET */

                    pDrvCtrl1->errTx++;
                }
                else
                {
                    pDrvCtrl1->okTx++;
                }
            }
            else
            {
                printf("ETH%d: Tx busy, sequence %d\n", pDrvCtrl1->unit, i + 1);

                pDrvCtrl1->errTx++;

                return ERROR;
            }

            tickStart = tickGet();
            while ((pRbd = ETH_DRV_RBD_GET(pDrvCtrl2)) == NULL)
            {
                if (((tickGet() - tickStart) / sysClkRateGet()) > 5)
                {
                    printf("ETH%d: no receive indication during 5 seconds, sequence %d\n", pDrvCtrl2->unit, i + 1);

                    pDrvCtrl2->errRx++;

                    return ERROR;
                }
            }

            length = ETH_DRV_RBD_CHECK(pDrvCtrl2, pRbd);

            if (length == (lengthFrame + SIZE_ETH_HDR))
            {
                for (j=0; j<lengthFrame; j++)
                {
                    if (((char *)(pRbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR))[j] != (UCHAR)(i + j + j / 256))
                    {
                        break;
                    }
                }

                if (j < lengthFrame)
                {
#ifndef DIAG_QUIET
                    printf("ETH%d: mismatch, sequence %d, addr %08X\n", pDrvCtrl2->unit, i + 1, pRbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR + j);
                    printf("ETH%d: RBD:%08X, RB:%08X\n", pDrvCtrl2->unit, (UINT32)pRbd, (UINT32)pRbd->pBuf);
#endif  /* DIAG_QUIET */

                    pDrvCtrl2->errRx++;

                    printf("Make Buffer\n");
                    diagHexDump((UCHAR *)buffer, lengthFrame);
                    printf("Tx Buffer\n");
                    diagHexDump((UCHAR *)(pTbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), lengthFrame);
                    printf("Rx Buffer\n");
                    diagHexDump((UCHAR *)(pRbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), lengthFrame);

                    return ERROR;
                }
                else
                {
                    pDrvCtrl2->okRx++;
                }
            }
            else
            {
#ifndef DIAG_QUIET
                printf("ETH%d: Rx error, sequence %d, length %u, status 0x%04X\n", pDrvCtrl2->unit, i + 1, (UINT)pRbd->length, pRbd->status);
                printf("ETH%d: RBD:%08X, RB:%08X\n", pDrvCtrl2->unit, (UINT32)pRbd, (UINT32)pRbd->pBuf);
#endif  /* DIAG_QUIET */

                pDrvCtrl2->errRx++;
            }

            ETH_DRV_RBD_FREE(pDrvCtrl2, pRbd);
        }

        printf("ETH%d: Number of Rx OKs : %d\n", pDrvCtrl2->unit, pDrvCtrl2->okRx);
        printf("ETH%d: Number of Rx ERRs: %d\n", pDrvCtrl2->unit, pDrvCtrl2->errRx);
        printf("ETH%d: Number of Tx OKs : %d\n", pDrvCtrl1->unit, pDrvCtrl1->okTx);
        printf("ETH%d: Number of Tx ERRs: %d\n", pDrvCtrl1->unit, pDrvCtrl1->errTx);

    } while ((repeat == 0) || (--repeat != 0));

#ifdef  DIAG_TASK
    taskDelay(0);
#endif  /* DIAG_TASK */

    return OK;
}

/* temp */
#if 0
STATUS diagEthRateTest(ETH_DRV_CTRL *pDrvCtrl1, ETH_DRV_CTRL *pDrvCtrl2, int repeat)
{
    int i;
    int seqRx;
    int seqTx;
    UINT32 seconds;
    UINT32 busyTx;
    UINT32 okRx;
    UINT32 okTx;
    int errRx;
    int errTx;
    PETHRBD pRbd;
    PETHTBD pTbd;
    UINT32 tickStart;
    ULONG length;


    printf("\nETH%d: Estimate Data Transfer Rate (two copy)\n", pDrvCtrl1->unit);

        printf("ETH%d: Wait for 30 seconds...\n", pDrvCtrl1->unit);

        seqRx   = 0;
        seqTx   = 0;
        seconds = 0;
        busyTx  = 0;
        okRx    = 0;
        okTx    = 0;
        errRx   = 0;
        errTx   = 0;

        for (i=0; i<lengthFrame; i++)
        {
            buffer[i] = (UCHAR)(i % 256);
        }

        tickStart = tickGet();

        while (seconds < 30)
        {
            pTbd = ETH_DRV_TBD_GET(pDrvCtrl1);
            if (pTbd)
            {
                seqTx++;

                if (pTbd->status != 0)
                {
                    if (ETH_DRV_TBD_CHECK(pDrvCtrl1, pTbd) != OK)
                    {
#ifndef DIAG_QUIET
                        printf("ETH%d: Tx error, sequence %d, length %u, status 0x%04X\n", pDrvCtrl1->unit, seqTx, (UINT)pTbd->length, pTbd->status);
                        printf("ETH%d: TBD:%08X, TB:%08X\n", pDrvCtrl1->unit, (UINT32)pTbd, (UINT32)pTbd->pBuf);
#endif  /* DIAG_QUIET */

                        pDrvCtrl1->err1Tx++;
                        errTx++;
                    }
                    else
                    {
                        pDrvCtrl1->ok1Tx++;
                        okTx++;
                    }
                }

                buffer[0] = (UCHAR)(i % 256);

                diagEthMakeHeader(pDrvCtrl1, pTbd);

                bcopy(buffer, (char *)(pTbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), lengthFrame);

                ETH_DRV_TBD_START(pDrvCtrl1, pTbd, lengthFrame + SIZE_ETH_HDR);
            }
            else
            {
                busyTx++;
            }

            while ((pRbd = ETH_DRV_RBD_GET(pDrvCtrl2)) != NULL)
            {
                seqRx++;

                length = ETH_DRV_RBD_CHECK(pDrvCtrl2, pRbd);

                if (length == (lengthFrame + SIZE_ETH_HDR))
                {
                    bcopy((char *)(pRbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), buffer, lengthFrame);

                    pDrvCtrl2->ok1Rx++;
                    okRx++;
                }
                else
                {
#ifndef DIAG_QUIET
                    printf("ETH%d: Rx error, sequence %d, length %u, status 0x%04X\n", pDrvCtrl2->unit, seqRx, (UINT)pRbd->length, pRbd->status);
                    printf("ETH%d: RBD:%08X, RB:%08X\n", pDrvCtrl2->unit, (UINT32)pRbd, (UINT32)pRbd->pBuf);
#endif  /* DIAG_QUIET */

                    pDrvCtrl2->err1Rx++;
                    errRx++;
                }

                /* Advance to next RBD. */
                pDrvCtrl2->rbdIndex++;
                if (pDrvCtrl2->rbdIndex == NUM_RBD_ETH)
                {
                    pDrvCtrl2->rbdIndex = 0;
                }
            }

            seconds = (tickGet() - tickStart) / sysClkRateGet();

            if ((okRx == 0) && (errRx == 0) && (seconds > 5))
            {
                printf("ETH%d: no receive indication during 5 seconds\n", pDrvCtrl2->unit);

                pDrvCtrl2->err1Rx++;
                errRx++;

                return ERROR;
            }

            if (seqTx >= 32)
            {
                break;
            }
        }

        while ((okRx + errRx) != seqTx)
        {
            while ((pRbd = ETH_DRV_RBD_GET(pDrvCtrl2)) != NULL)
            {
                seqRx++;

                length = ETH_DRV_RBD_CHECK(pDrvCtrl2, pRbd);

                if (length == (lengthFrame + SIZE_ETH_HDR))
                {
                    bcopy((char *)(pRbd->pBuf + SIZE_ETH_WA + SIZE_ETH_HDR), buffer, lengthFrame);

                    pDrvCtrl2->ok1Rx++;
                    okRx++;
                }
                else
                {
#ifndef DIAG_QUIET
                    printf("ETH%d: Rx error, sequence %d, length %u, status 0x%04X\n", pDrvCtrl2->unit, seqRx, (UINT)pRbd->length, pRbd->status);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区久久| 91蝌蚪国产九色| 国产精品久久久久久久久搜平片| 99精品视频在线播放观看| 奇米888四色在线精品| 国产精品久久久久精k8 | 国产精品色一区二区三区| 日本乱码高清不卡字幕| 麻豆免费精品视频| 一区二区欧美精品| 亚洲欧洲日韩在线| 久久久久久久国产精品影院| 欧美在线观看视频在线| 成人午夜激情影院| 日本美女视频一区二区| 亚洲一区二区三区自拍| 中文字幕在线观看不卡| 国产亚洲1区2区3区| 日韩一级免费观看| 欧美精品在线视频| 色先锋久久av资源部| 国产精品99久久久| 精品无人区卡一卡二卡三乱码免费卡| 亚洲一级片在线观看| 亚洲欧洲色图综合| 中文字幕在线不卡| 国产精品美女久久久久久久久久久 | 精品国产精品网麻豆系列| 欧美在线观看18| 色999日韩国产欧美一区二区| 成人av电影在线网| 国产白丝精品91爽爽久久| 国产一区二区三区免费看| 蜜桃视频第一区免费观看| 亚洲444eee在线观看| 婷婷久久综合九色国产成人| 亚洲国产va精品久久久不卡综合| 亚洲最新在线观看| 一区二区三区精品在线观看| 亚洲天堂福利av| 一区二区不卡在线播放| 亚洲欧美日韩一区| 亚洲一区二区三区四区不卡| 亚洲一二三四久久| 亚洲成在线观看| 日精品一区二区三区| 日韩专区一卡二卡| 精品一区二区三区视频在线观看| 精品一二三四在线| 国产老妇另类xxxxx| 国产白丝网站精品污在线入口 | 欧美电影在线免费观看| 91精品国产一区二区人妖| 日韩欧美亚洲另类制服综合在线| 日韩一级精品视频在线观看| 精品欧美黑人一区二区三区| 久久久精品日韩欧美| 中文字幕在线不卡| 亚洲国产综合人成综合网站| 午夜精品在线看| 国产一区免费电影| 成人国产精品免费观看| 91蝌蚪porny| 欧美日韩国产成人在线91| 欧美电视剧在线看免费| 中文一区二区完整视频在线观看| 综合在线观看色| 国产盗摄女厕一区二区三区| 91一区在线观看| 欧美卡1卡2卡| 国产亚洲一二三区| 亚洲午夜久久久久| 韩国午夜理伦三级不卡影院| voyeur盗摄精品| 91精品国产色综合久久ai换脸| 久久亚洲欧美国产精品乐播| 亚洲欧洲日韩综合一区二区| 亚洲444eee在线观看| 国产成人亚洲精品青草天美| 91丨九色丨蝌蚪富婆spa| 欧美精品日韩精品| 亚洲国产高清不卡| 水野朝阳av一区二区三区| 国产精品1区二区.| 欧美少妇一区二区| 久久久精品黄色| 性做久久久久久久久| 国产成人av一区| 欧美日韩国产123区| 国产精品美女久久久久久久| 无码av免费一区二区三区试看| 国产精品456| 欧美一二三区精品| 一区二区三区91| 国产成人精品三级麻豆| 欧美高清激情brazzers| 中文字幕亚洲综合久久菠萝蜜| 日本午夜精品视频在线观看| 99精品视频一区| 久久久久国产精品厨房| 日本伊人色综合网| 色先锋aa成人| 国产精品久久久久影院| 精品一区二区三区香蕉蜜桃| 欧美日韩激情在线| 亚洲欧美日韩在线播放| 成人免费视频视频在线观看免费| 欧美一区二区三区系列电影| 一区二区三区加勒比av| www.欧美日韩国产在线| 国产午夜精品美女毛片视频| 日韩福利视频导航| 色av综合在线| 亚洲免费观看在线视频| 国产.精品.日韩.另类.中文.在线.播放| 欧美日韩国产一级片| 一区二区三区四区乱视频| 波波电影院一区二区三区| 国产视频一区二区在线观看| 狠狠色伊人亚洲综合成人| 欧美xxxxxxxx| 美女一区二区在线观看| 欧美顶级少妇做爰| 午夜电影网亚洲视频| 在线观看视频一区| 亚洲国产三级在线| 在线观看不卡一区| 亚洲高清久久久| 欧美精品一级二级| 青青草97国产精品免费观看| 欧美日韩极品在线观看一区| 亚洲高清一区二区三区| 欧美自拍丝袜亚洲| 亚洲国产sm捆绑调教视频| 久久精品人人爽人人爽| 国产成人综合自拍| 国产日韩欧美精品综合| 东方欧美亚洲色图在线| 亚洲国产精品99久久久久久久久| 国产成人精品一区二区三区四区 | 综合久久久久久久| 99久久久精品免费观看国产蜜| 精品国产一区久久| 久久亚洲一级片| 久久久国产综合精品女国产盗摄| 亚洲综合一区在线| 麻豆一区二区99久久久久| 日韩精品中文字幕一区| 国产精一品亚洲二区在线视频| 2017欧美狠狠色| 成人av在线网站| 亚洲精品久久久久久国产精华液| 91理论电影在线观看| 亚洲一区在线观看免费观看电影高清| 欧美日韩电影一区| 久久99国产乱子伦精品免费| 精品国产乱码久久| 91在线高清观看| 天天综合天天做天天综合| 精品久久久网站| 国产99久久久国产精品潘金| 成人欧美一区二区三区黑人麻豆 | 亚洲国产精品二十页| 94色蜜桃网一区二区三区| 一区二区三区四区国产精品| 欧美日韩在线亚洲一区蜜芽| 免费人成黄页网站在线一区二区| 久久人人爽爽爽人久久久| 成人av在线观| 日韩国产欧美一区二区三区| 久久久蜜桃精品| 在线看日本不卡| 精品在线一区二区| 日韩理论片中文av| 日韩欧美资源站| 91亚洲精品乱码久久久久久蜜桃| 日韩一区精品视频| 中文幕一区二区三区久久蜜桃| 日本高清成人免费播放| 激情六月婷婷久久| 一区二区三区**美女毛片| 久久综合久久鬼色| 欧美日韩在线播放三区四区| 国产乱子轮精品视频| 亚洲综合无码一区二区| 久久免费午夜影院| 7777精品伊人久久久大香线蕉经典版下载 | hitomi一区二区三区精品| 视频一区视频二区在线观看| 国产欧美在线观看一区| 欧美日韩激情在线| 97精品视频在线观看自产线路二| 久久精品国产99国产精品| 亚洲欧洲精品一区二区三区| 亚洲精品在线免费观看视频| 色国产综合视频| 波波电影院一区二区三区| 久久精品国产**网站演员| 亚洲日本一区二区三区| 久久综合九色综合欧美98|