我正在尝试使用 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读取硬件中的寄存器
谢谢