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

📄 plx9054_diag.c

📁 Vxworks 下PLX 9054 的驱动
💻 C
📖 第 1 页 / 共 2 页
字号:

/* Plx9054_diag.c: Plx9054 PCI桥片驱动测试维护模块*/
/* author: Wang.qi Jilin Univ. 2004512025*/

/*
modification history
------------------
2006-09-19
*/

#ifdef __cplusplus
extern "C" {
#endif

/* includes (header file) 头包含文件 */
#include "vxWorks.h"
#include "vme.h"
#include "memLib.h"
#include "sysLib.h"
#include "string.h"
#include "intLib.h"
#include "config.h"
#include "logLib.h"
#include "taskLib.h"
#include "vxLib.h"
#include "errnoLib.h"
#include "dosFsLib.h"
#include "stdio.h"
#include "cacheLib.h"
#include "private/vmLibP.h"
#include "arch/i86/pentiumLib.h"
#include <ctype.h>

#include "drv/pci/pciConfigLib.h"
#include "drv/pci/pciIntLib.h"

#include "plx9054.h"

/* define 宏定义 */

/* global */

/* local */
static char line[256];

/* import */

/* function declarations*/
STATUS PLX9054_TestInit(void);
STATUS PLX9054_EditConfigReg(int index);
STATUS PLX9054_EditLocalReg(int index);
void PLX9054_SpaceAccess(int index);
void PLX9054_EnableDisableInt(int index);
void PLX9054_EepromAccess(int index);
void PLX9054_ShowSpaceInfo(int index);
void PLX9054_FIFORead(int index, UINT32 * pData);
void PLX9054_WriteDsp(int index, UINT32 dwData);
LOCAL void PLX9054_DmaTest(int index);

/* function */
/*
PLX9054_diag
PLX9054测试维护模块入口函数
*/
void PLX9054_diag(void)
{
    int cmd, index = 0;
    PLX9054_DRVCTRL * pDrvCtrl;
    
    printf ("PLX 9054 diagnostic utility.\n");
    printf ("Write by Wang.qi Jilin Univ.\n");

    #ifdef PLX_DEBUG
        PLX9054_TestInit();
    #endif
    
    pDrvCtrl = PLX9054_GetDrvCtrl( ); /*获取驱动控制指针*/

    do
    {
        printf ("\n");
        printf ("PLX 9054 main menu\n");
        printf ("-------------------\n");
        printf ("1. Scan PCI bus\n");
        if (pDrvCtrl->plxCardNum > 0)  /* 系统中存在PLX9054扩展卡*/
        {
            printf ("2. Choose PLX 9054 board\n");
            printf ("3. PCI configuration registers\n");
            printf ("4. PLX 9054 local registers\n");
            printf ("5. Read the DSP board's FIFO or Write Data to DSP\n");
            printf ("6. Enable / Disable interrupts\n");
            printf ("7. Access serial EEPROM on the board\n");
            printf ("8. Show Space Info\n");
            printf ("9. Soft Reset PLX9054 Board\n");
            printf ("10. DMA Read FIFO Test\n");
        }
        printf ("99. Exit\n");
        printf ("Enter option: ");
        cmd = 0;
        fgets(line, sizeof(line), stdin);
        sscanf (line, "%d",&cmd);
        switch (cmd)
        {
        case 1: /* Scan PCI bus */
            PLX9054_Pci_Show();
            break;
        case 2: /* Choose PLX 9054 board */
            if(0 == pDrvCtrl->plxCardNum)
            {
                printf("No Plx9054 Cards.\n");
            }
            else
            {
                index = 0;
                printf("Input Cards Index(0..%d):", pDrvCtrl->plxCardNum - 1);
                fgets(line, sizeof(line), stdin);
                sscanf (line, "%d",&index);
                if((index < 0 ) || (index > (pDrvCtrl->plxCardNum - 1)))
                {
                    printf("Out of Range.\n");
                    index = 0;
                }
            }
            break;
        case 3: /* PCI configuration registers */
            if (pDrvCtrl->plxCardNum > 0)
            {
                PLX9054_EditConfigReg(index);
            }
            break;
        case 4: /* PLX 9054 local registers */
            if (pDrvCtrl->plxCardNum > 0)
            {
                /*PLX9054_EditLocalReg(index);*/
                PLX9054_EditLocalReg(0);
            }
            break;
        case 5: /* Access address spaces on the board */
            if (pDrvCtrl->plxCardNum > 0)
            {
                PLX9054_SpaceAccess(index);
            }
            break;
        case 6: /* Enable / Disable interrupts */
            if (pDrvCtrl->plxCardNum > 0)
            {
                PLX9054_EnableDisableInt(index);
            }
            break;
        case 7: /* Access serial EEPROM on the board */
             if (pDrvCtrl->plxCardNum > 0)
            {
                PLX9054_EepromAccess(index);
            }
            break;
        case 8: /* Show Space Infomation.*/
            if (pDrvCtrl->plxCardNum > 0)
            {
                PLX9054_ShowSpaceInfo(index);
            }
        case 9: /* soft reset board */
            PLX9054_SoftReset(index);
            break;
        case 10: /* DMA 方式读取FIFO 测试*/
            PLX9054_DmaTest(index);
        default:
            break;
        }
    } while (cmd!=99);

    return;
}

/* 
 PLX9054_TestInit
脱离硬件环境时,对结构体做初始化,
实现驱动程序无硬件环境下的单元测试。
*/
STATUS PLX9054_TestInit(void)
{

    int 		unit;
    int 		plx9054Units = 0;
    
    PLX9054_PCI_RESOURCES plx9054PciResrcs [] = /*默认分配给PLX 的PCI资源,测试用*/
    {
    {PLX9054_MEM_ADR0, PLX9054_IO_ADR0, PLX9054_INT_LVL0, PLX9054_INT_VEC0,
     PCI_CFG_TYPE, 0, 1, 0},
    {PLX9054_MEM_ADR1, PLX9054_IO_ADR1, PLX9054_INT_LVL1, PLX9054_INT_VEC1,
     PCI_CFG_TYPE, 0, 2, 0},
    {PLX9054_MEM_ADR2, PLX9054_IO_ADR2, PLX9054_INT_LVL2, PLX9054_INT_VEC2,
     PCI_CFG_TYPE, 0, 3, 0},
    {PLX9054_MEM_ADR3, PLX9054_IO_ADR3, PLX9054_INT_LVL3, PLX9054_INT_VEC3,
     PCI_CFG_TYPE, 0, 4, 0}
    };

    PLX9054_SPACE_DESC lSpaceDesc[PLX9054_MAX_DEV][AD_PCI_BARS] =
    {
        {
            {"PCI Configuration Mem"},
            {"PCI Configuration I/O"},
            {"PLX9054 Local Space 0", 0xEF000000, 0x100000, 0x10000000, TRUE, TRUE, FALSE},
            {"PLX9054 Local Space 1", 0xEE000000, 0x100000, 0x20000000, TRUE, TRUE, FALSE},
            {"PLX9054 Local Eeprom", 0, 0x100000, 0x10000000, TRUE, FALSE, FALSE},
            {},
            {}
        }
    };

    PLX9054_DRVCTRL *  pDrvCtrl = NULL;
    PLX9054_DEVICE * pDevCtrl = NULL;

    /* 为驱动结构体申请内存空间*/
    pDrvCtrl = (PLX9054_DRVCTRL *)malloc(sizeof(PLX9054_DRVCTRL));
    if(NULL == pDrvCtrl)
    {
        printf("Malloc return NULL File:%s, Line:%d.\n", __FILE__, __LINE__);
        return ERROR;
    }
    memset((void *)pDrvCtrl, 0, sizeof(PLX9054_DRVCTRL));
    /* find all plx9054 cards */
    for (unit = 0; unit < PLX9054_MAX_DEV; unit++)
    {
                /* 为设备结构体申请内存空间*/
                pDevCtrl = (PLX9054_DEVICE *)malloc(sizeof(PLX9054_DEVICE));
                if(NULL == pDevCtrl)
                {
                    printf("Malloc return NULL File:%s, Line:%d.\n", __FILE__, __LINE__);
                    return ERROR;
                }
                memset((void *)pDevCtrl, 0, sizeof(PLX9054_DEVICE));
                
                /* load up the PCI device table */
                pDevCtrl->PlxPciRsrc = plx9054PciResrcs[unit];

                /*本地空间初始化*/
                pDevCtrl->spaceDesc[P9054_ADDR_SPACE0] = lSpaceDesc[unit][P9054_ADDR_SPACE0];
                pDevCtrl->spaceDesc[P9054_ADDR_SPACE1] = lSpaceDesc[unit][P9054_ADDR_SPACE0];
                pDevCtrl->spaceDesc[P9054_ADDR_EPROM] = lSpaceDesc[unit][P9054_ADDR_EPROM];
                
                pDrvCtrl->pDevice[unit] = pDevCtrl;

                plx9054Units++;   	/* number of units found */
    }
    
    pDrvCtrl->plxCardNum = plx9054Units;
    

    PLX9054_SetDrvCtrl(pDrvCtrl);   /* 设置全局设备驱动结构体指针*/
    
    return OK; 
}

/*
PLX9054_EditConfigReg
读写PLX9054 PCI 配置寄存器测试函数
input
       index: 设备索引
*/
STATUS PLX9054_EditConfigReg(int index)
{
    PLX9054_DRVCTRL * pDrvCtrl;
    struct {
        char *name;
        UINT dwOffset;
        UINT dwBytes;
        UINT32 dwVal;
    } fields[30] = {
        { "VID", 0x0, 2 },
        { "DID", 0x2, 2 },
        { "CMD", 0x4, 2 },
        { "STS", 0x6, 2 },
        { "RID", 0x8, 1 },
        { "CLCD", 0x9, 3 },
        { "CALN", 0xc, 1 },
        { "LAT", 0xd, 1 },
        { "HDR", 0xe, 1 },
        { "BIST", 0xf, 1 },
        { "BADDR0", 0x10, 4 },
        { "BADDR1", 0x14, 4 },
        { "BADDR2", 0x18, 4 },
        { "BADDR3", 0x1c, 4 },
        { "BADDR4", 0x20, 4 },
        { "BADDR5", 0x24, 4 },
        { "EXROM", 0x30, 4 },
        { "INTLN", 0x3c, 1 },
        { "INTPIN", 0x3d, 1 },
        { "MINGNT", 0x3e, 1 },
        { "MAXLAT", 0x3f, 1 },
        { NULL, 0, 0 },
        { NULL, 0, 0 }
    };

    int cmd, i;

    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
    
    do {
        int row;
        int col;

        printf ("\n");
        printf ("Edit PCI configuration registers\n");
        printf ("--------------------------------\n");
        for (row = 0; row<=10; row++)
        {
            for (col = 0; col <=1; col++)
            {
                i = ((0 == col) ? row : (row + 10));
                
                if (row==10 && col==0)
                    printf("%26s","");
                else
                {
                    #ifndef PLX_DEBUG
                    UINT32 dwVal = 0;
                    PLX9054_Pci_Reg_Read(index, fields[i].dwOffset, &dwVal, (DATA_WIDTH_MODE)(fields[i].dwBytes));
                    fields[i].dwVal = dwVal;
                    #endif
                    printf ("%2d. %6s : %0*x %*s    ",i+1, fields[i].name, 
                        fields[i].dwBytes*2, fields[i].dwVal, 
                        8-fields[i].dwBytes*2, "");
                }
                if (col==1)
                    printf ("\n");
            }
        }

        printf ("99. Back to main menu\n");
        printf ("Choose register to write to, or 99 to exit: ");
        cmd = 0;

⌨️ 快捷键说明

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