FPGA UARTlite linux 系统

1.搜先确定自己已经下载了包含有uartlite 核的IP bit 文件。
2.在linux 系统写如下代码,没有写main函数是因为我要供给python 调用,我生成了.iso链接文件。同多笔记本电脑的USB端口检测串口,我用的是CP2012这个硬件转化模块。使用usleep是应为linux系统的时钟频率远高于串口的速率,否则会有数据的丢失。
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <time.h>
#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.测试结果如下:

18 串口输出结果



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值