FPGA UARTlite linux 系统

1.搜先确定自己已经下载了包含有uartlite 核的IP bit 文件。
2.在linux 系统写如下代码,没有写main函数是因为我要供给python 调用,我生成了.iso链接文件。同多笔记本电脑的USB端口检测串口,我用的是CP2012这个硬件转化模块。使用usleep是应为linux系统的时钟频率远高于串口的速率,否则会有数据的丢失。
#include
#include
#include
#include
#include
#define UL_BASE_ADDRESS 0x42c00000
#define UL_Tx_OFFSET 4
#define MAP_SIZE 64
#define MAP_MASK (MAP_SIZE-1)
int uart_fun(int knn_number){
int memfd;
off_t dev_base = UL_BASE_ADDRESS;
memfd = open("/dev/mem",O_RDWR | O_SYNC);
if (memfd == -1){

printf("Can't open /dev");
exit(0);
}
int i=0;
volatile int *mapped_base,*mapped_dev_base;
mapped_base = mmap(0,MAP_SIZE,PROT_READ | PROT_WRITE,MAP_SHARED,memfd,0x42c00000);
//while(1){
//i=i+1;
//*((volatile int *)(mapped_base+1))=7;
//printf("int: %d\n",i);
//printf("%d\n",*((volatile int*)(mapped_base+2)));
if((*((volatile int*)(mapped_base+2))&0x00000008)==8){
   *((volatile int *)(mapped_base+3))=3;
   printf("error2:%d\n",*((volatile int *)(mapped_base+2))&0x00000008);
  //复位输出数据
  //等到信号为空再发送
   while (*((volatile int*)(mapped_base+2))&0x00000004!=4){
 }
    }
else if ((*(volatile int*)(mapped_base+2))<=4){
    i=i+1;
    *((volatile int *)(mapped_base+1))=knn_number;
    usleep(1000); 
    }
//}
close(memfd);
return 0;
}
3.测试结果如下:

FPGA UARTlite linux 系统_第1张图片

18 串口输出结果



你可能感兴趣的:(FPGA UARTlite linux 系统)