3

我正在尝试使用 Python 读取硬件(FPGA)中的一些寄存器。我已经有一个 C 代码来读取寄存器,它工作正常。我想使用 ctypes 在 python 中使用它们。

rdaxi.c

#include <fcntl.h>
#include <sys/ioctl.h>
#include <stdio.h>
#include <stdint.h>
#include <string.h>

#define NF10_IOCTL_CMD_READ_STAT (SIOCDEVPRIVATE+0)
#define NF10_IOCTL_CMD_WRITE_REG (SIOCDEVPRIVATE+1)
#define NF10_IOCTL_CMD_READ_REG (SIOCDEVPRIVATE+2)  

int main(int argc, char* argv[]){
    int f;
    uint64_t v;
    uint64_t addr;

    if(argc < 2){
        printf("usage: rdaxi reg_addr(in hex)\n\n");
        return 0;
    }
    else{
        sscanf(argv[1], "%llx", &addr);
    }

    //----------------------------------------------------
    //-- open nf10 file descriptor
    //----------------------------------------------------
    f = open("/dev/nf10", O_RDWR);
    if(f < 0){
        perror("/dev/nf10");
        return 0;
    }

    printf("\n");

    v = addr;
    if(ioctl(f, NF10_IOCTL_CMD_READ_REG, &v) < 0){
        perror("nf10 ioctl failed");
        return 0;
    }
    // upper 32bits contain the address and are masked away here
    // lower 32bits contain the data
    v &= 0xffffffff;

    printf("AXI reg 0x%llx=0x%llx\n", addr, v);

    printf("\n");

    close(f);

    return 0;
}

编译并获得可执行文件后,我只需执行以下操作即可获得结果

./rdaxi 0x5a000008
AXI reg 0x5a000008 = 2

我想用 Python 做同样的事情。我开始知道我必须使用 Ctypes。然后我为我的c文件创建了共享库(.so)。以下是我编写的python代码。我是python的初学者,请原谅我的错误。我得到一个分段错误。我该如何解决这个问题并读取寄存器。

rdaxi.py

#!/usr/bin/env python

# For creating shared library
# gcc -c -Wall -fPIC rdaxi.c
# gcc -shared -o librdaxi.so rdaxi.o



import os
import sys
from ctypes import *
print "opening device descriptor"
nf = os.open( "/dev/nf10", os.O_RDWR )
print "loading the .so file"
librdaxi=cdll.LoadLibrary('/root/Desktop/apps/librdaxi.so')
librdaxi.main(nf,0x5b000008)

有关我的应用程序的更多信息。请看下文。 使用python读取硬件中的寄存器

谢谢

4

1 回答 1

2

main()接受两个参数,argcand argv,但你传递给它一个参数,即你的地址。

这是您如何称呼它的示例:

librdaxi.main.argtypes = [c_int,POINTER(c_char_p)]
argv=(c_char_p*2)()
argv[0]='rdaxi'
argv[1]='0x5a000008'
librdaxi.main(2,argv)
于 2013-05-05T13:47:08.270 回答