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

📄 plx9054_diag.c

📁 Vxworks 下PLX 9054 的驱动
💻 C
📖 第 1 页 / 共 2 页
字号:
        fgets(line, sizeof(line), stdin);
        sscanf(line, "%d",&cmd);
        #if 1
        if (cmd>=1 && cmd <=21)
        {
            i = cmd-1;
            printf ("Enter value (hex format) to write to %s register (or 'X' to cancel): ",
                fields[i].name);
            fgets(line, sizeof(line), stdin);
            if (toupper (line[0])!='X')
            {
                UINT32 dwVal;
                dwVal = 0;
                sscanf(line,"%x",&dwVal);
                if ((dwVal>0xff && fields[i].dwBytes==1)|| 
                    (dwVal>0xffff && fields[i].dwBytes==2)|| 
                    (dwVal>0xffffff && fields[i].dwBytes==3))
                {
                    printf ("Error: value to big for register\n");
                }
                else
                {
                    fields[i].dwVal = dwVal;
                    #ifndef PLX_DEBUG
                    PLX9054_Pci_Reg_Write(index, fields[i].dwOffset, fields[i].dwVal, (DATA_WIDTH_MODE)(fields[i].dwBytes));
                    #endif
                }
            }
        }
        #endif
    } while (cmd!=99);

    return OK;
}

/*
PLX9054_EditLocalReg
读写PLX9054 PCI 配置寄存器测试函数
input
       index: 设备索引
*/
STATUS PLX9054_EditLocalReg(int index)
{
    PLX9054_DRVCTRL * pDrvCtrl;
    struct 
    {
        char *name;
        int dwOffset;
        UINT32 dwVal;
    } fields[30];

    int cmd;
    int i;
    int field_count;
    
    pDrvCtrl = PLX9054_GetDrvCtrl( );
    /* 输入参数判断*/
    #ifdef PLX_INPUT_CHECK
    if( (index < 0)  || (index > (pDrvCtrl->plxCardNum - 1)))
    {
        printf("Index out of range file:%s, line:%d.\n", __FILE__, __LINE__);
        return ERROR;
    }
    #endif
    
    i = 0;
    fields[i].name = "LAS0RR"; fields[i++].dwOffset = 0x00;
    fields[i].name = "LAS0BA"; fields[i++].dwOffset = 0x04;
    fields[i].name = "EROMRR"; fields[i++].dwOffset = 0x10;
    fields[i].name = "EROMBA"; fields[i++].dwOffset = 0x14;
    fields[i].name = "LBRD0"; fields[i++].dwOffset = 0x18;
    fields[i].name = "MBOX0"; fields[i++].dwOffset = 0x40;
    fields[i].name = "MBOX1"; fields[i++].dwOffset = 0x44;
    fields[i].name = "MBOX2"; fields[i++].dwOffset = 0x48;
    fields[i].name = "MBOX3"; fields[i++].dwOffset = 0x4c;
    fields[i].name = "MBOX4"; fields[i++].dwOffset = 0x50;
    fields[i].name = "MBOX5"; fields[i++].dwOffset = 0x54;
    fields[i].name = "MBOX6"; fields[i++].dwOffset = 0x58;
    fields[i].name = "MBOX7"; fields[i++].dwOffset = 0x5c;
    fields[i].name = "P2LDBELL"; fields[i++].dwOffset = 0x60;
    fields[i].name = "L2PDBELL"; fields[i++].dwOffset = 0x64;
    fields[i].name = "INTCSR"; fields[i++].dwOffset = 0x68;
    fields[i].name = "CNTRL"; fields[i++].dwOffset = 0x6c;
    fields[i].name = "SECID"; fields[i++].dwOffset = 0x70;
    fields[i].name = "REVISON"; fields[i++].dwOffset = 0x74;
    fields[i].name = "LAS1RR"; fields[i++].dwOffset = 0xf0;
    fields[i].name = "LAS1BA"; fields[i++].dwOffset = 0xf4;
    fields[i].name = "DMA0M"; fields[i++].dwOffset = 0x80;
    fields[i].name = "DMA0PA"; fields[i++].dwOffset = 0x84;
    fields[i].name = "DMA0LA"; fields[i++].dwOffset = 0x88;
    fields[i].name = "DMA0BC"; fields[i++].dwOffset = 0x8c;
    fields[i].name = "DMA0DP"; fields[i++].dwOffset = 0x90;
    fields[i].name = "DMA0CS"; fields[i++].dwOffset = 0xa8;
    fields[i].name = "Mode/DMA"; fields[i++].dwOffset = 0xac;
    fields[i].name = "DMATHR"; fields[i++].dwOffset = 0xb0;
    field_count = i;
    do
    {
        int row;
        int col;
        int row_count = field_count/2 + field_count%2;

        printf ("\n");
        printf ("Edit PLX 9054 registers\n");
        printf ("--------------------------------\n");
        for (row = 0; row<row_count; row++)
        {
            for (col = 0; col<=1; col++)
            {
                if (col==0) i = row;
                else i = row + row_count;

                if (i<field_count)
                {
                    fields[i].dwVal = 0;
                    PLX9054_Local_Reg_Read(index, fields[i].dwOffset, &(fields[i].dwVal));
                    printf ("%2d. %8s : %08x     ",i+1, fields[i].name, fields[i].dwVal);
                }
                if (col==1) printf ("\n");
            }
        }

        printf ("99. Back to main menu\n");
        printf ("Choose register to write to, or 99 to exit: ");
        cmd = 0;
        fgets(line, sizeof(line), stdin);
        sscanf (line, "%d",&cmd);
        if (cmd>=1 && cmd <= field_count)
        {
            i = cmd-1;
            printf ("Enter value to write to %s register (or 'X' to cancel): ",fields[i].name);
            fgets(line, sizeof(line), stdin);
            if (toupper (line[0])!='X')
            {
                sscanf (line,"%x",&(fields[i].dwVal));
                PLX9054_Local_Reg_Write(index, fields[i].dwOffset, fields[i].dwVal);
            }
        }
    } while (cmd!=99);
    
    return OK;
}

/*
PLX9054_SpaceAccess
读FIFO 及写DSP 的测试函数
input
       index: 设备索引
*/
void PLX9054_SpaceAccess(int index)
{
    int cmd;
    UINT32 dwData;

    do
    {
        printf ("Access the DSP board's FIFO\n");
        printf ("--------------------------------\n");        
        printf ("1. Read/Display FIFO content\n");
        printf ("2. Write Dword Data to DSP\n");
        printf ("99. Back to main menu\n");
        printf ("\n");
        printf ("Enter option: ");
        cmd = 0;
        fgets(line, sizeof(line), stdin);
        sscanf (line, "%d",&cmd);
        switch (cmd)
        {
        int i;
        case 1:
            PLX9054_FIFORead(index, &dwData);
            printf ("\t0x%08x\n", dwData);
            break;
        case 2:
            printf ("Enter value to write to DSP (or 'X' to cancel): 0x");
            fgets(line, sizeof(line), stdin);
            if (toupper (line[0])!='X')
            {
                sscanf (line,"%x",&dwData);
                for(i = 0; i < 10; i++)
                {
                    dwData = ~dwData;
                    PLX9054_WriteDsp(index, dwData);
                }
            }
            break;
        default:
            break;
        }
    } while (cmd!=99);
}

/*******************************************************************
PLX9054_FIFORead
读取DSP 采集板上的FIFO
*/
void PLX9054_FIFORead(int index, UINT32 * pData)
{
    PLX9054_DRVCTRL * pDrvCtrl;
    
    pDrvCtrl = PLX9054_GetDrvCtrl( );

    *pData = *(UINT32 *)(pDrvCtrl->pDevice[index]->spaceDesc[AD_PCI_BAR2].dwPciBar);
}

/*******************************************************************
PLX9054_WriteDsp, 按32位方式写,只有低8位有效
向DSP 写控制字,如选择信号源,控制采样参数等
*/
void PLX9054_WriteDsp(int index, UINT32 dwData)
{
    PLX9054_DRVCTRL * pDrvCtrl;
    
    pDrvCtrl = PLX9054_GetDrvCtrl( );

    *(UINT32 *)(pDrvCtrl->pDevice[index]->spaceDesc[AD_PCI_BAR3].dwPciBar) = dwData;
}

/*
PLX9054_EnableDisableInt
中断测试
input
       index: 设备索引
*/
void PLX9054_EnableDisableInt(int index)
{
    return;
}

/**********************************************************************
PLX9054_EepromAccess
读写EEPROM 的测试函数
input
       index: 设备索引
author: wang.qi
data: 2006-10-18
*/
void PLX9054_EepromAccess( int index)
{
    int cmd;
    UINT32 addr;
    UINT32 dwData;

    do
    {
        printf ("Access the board's serial EEPROM\n");
        printf ("--------------------------------\n");
        if (!PLX9054_EEPROM_Valid(index))
            printf ("Note: PLX EEPROM valid BIT is 0\n");
        printf (" Note: reading/writing to odd addresses is meaningless,\n");
        printf ("       as data is stored in words.\n");
        printf ("1. Display EEPROM content\n");
        printf ("2. Read dword from serial EEPROM on the board\n");
        printf ("3. Write dword to the serial EEPROM on the board\n");
        printf ("99. Back to main menu\n");
        printf ("\n");
        printf ("Enter option: ");
        cmd = 0;
        fgets(line, sizeof(line), stdin);
        sscanf (line, "%d",&cmd);
        switch (cmd)
        {
        case 1:
            for (addr=0; addr<0x58; addr += 4)
            {
                if (!(addr % 0x10))
                printf("\n %02x: ", addr);
                if (ERROR == PLX9054_EepromReadDword(index, Eeprom93CS56, addr, &dwData))
                {
                    printf("\nError occurred reading serial EEPROM!\n");
                    break;
                }
                printf("%08x  ", dwData);
            }
            printf ("\n");
            break;
        case 2:
            printf ("Enter address to read from (0-ff): ");
            fgets(line, sizeof(line), stdin);
            sscanf (line, "%x", &addr);
            if (OK == PLX9054_EepromReadDword(index, Eeprom93CS56, addr, &dwData))
                printf ("Value read: %x\n", dwData);
             else
                printf("\nError occurred reading serial EEPROM!\n");
            break;

        case 3:
            printf ("Enter address to write to (0-ff): ");
            fgets(line, sizeof(line), stdin);
            sscanf (line, "%x", &addr);
            printf ("Enter data to write: ");
            fgets(line, sizeof(line), stdin);
            sscanf (line, "%x",&dwData);
            if (ERROR==PLX9054_EepromWriteDword(index, Eeprom93CS56, addr, dwData))
                printf("\nError occurred reading serial EEPROM!\n");
            break;

        default:
            break;
        }
    } while (cmd!=99);
}

/********************************************************************
PLX9054_ShowSpaceInfo
显示指定PCI9054扩展卡占用/申请的空间信息
输入:  index 设备索引
*/
void PLX9054_ShowSpaceInfo(int index)
{
    PLX9054_DRVCTRL * pDrvCtrl;
    PLX9054_SPACE_DESC * pPlxSpace;
    int i;
    
    pDrvCtrl = PLX9054_GetDrvCtrl( );

    for(i = 0; i < AD_PCI_BARS; i++)
    {
        pPlxSpace = &(pDrvCtrl->pDevice[index]->spaceDesc[i]);
        if(pPlxSpace->fIsEnable)
        {
            printf("%s: PciBar=0x%08x, LBar=0x%08x, Range=0x%08x.\n", 
                     pPlxSpace->spaceName, pPlxSpace->dwPciBar, pPlxSpace->dwLocalBase, pPlxSpace->dwRange);
        }
    }    
    return;
}

LOCAL void PLX9054_DmaTest(int index)
{
    
    PLX9054_DMAReadWriteBlock(index, 0, 0x6000000, 0x100, TRUE);
}

#ifdef __cplusplus
}
#endif

⌨️ 快捷键说明

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