【iCore4 双核心板_FPGA】例程十二:基于UART的ARM与FPGA通信实验
实验现象:
1、先烧写ARM程序,然后烧写FPGA程序。
2、打开串口精灵,会接收到字符GINGKO。
3、通过串口精灵发送命令可以控制ARM·LED和FPGA·LED。
核心代码:
int main(void)
{ /* USER CODE BEGIN 1 */
int i;
char buffer[];
char buffer1[]; /* USER CODE END 1 */ /* MCU Configuration----------------------------------------------------------*/ /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
HAL_Init(); /* USER CODE BEGIN Init */ /* USER CODE END Init */ /* Configure the system clock */
SystemClock_Config(); /* USER CODE BEGIN SysInit */ /* USER CODE END SysInit */ /* Initialize all configured peripherals */
MX_GPIO_Init();
MX_USART6_UART_Init();
MX_UART4_Init(); /* USER CODE BEGIN 2 */
uart4.initialize();
usart6.initialize();
usart6.printf("Hello,I am iCore4!\r\n");
LED_GREEN_ON;
/* USER CODE END 2 */ /* Infinite loop */
/* USER CODE BEGIN WHILE */
while ()
{
/* USER CODE END WHILE */ /* USER CODE BEGIN 3 */
if(usart6.receive_ok_flag == ){
usart6.receive_ok_flag = ;
for(i = ;i < ;i ++){
buffer[i] = tolower(usart6.receive_buffer[i]);
}
//±È½Ï½ÓÊÕÐÅÏ¢
if(memcmp(buffer,"ledr",strlen("ledr")) == ){ //ARMºìµÆÁÁ
LED_RED_ON;
LED_GREEN_OFF;
LED_BLUE_OFF;
uart4.printf("LEDR\n"); //´®¿Ú2Êä³ö
}
if(memcmp(buffer,"ledg",strlen("ledg")) == ){ //ARMÂ̵ÆÁÁ
LED_GREEN_ON;
LED_RED_OFF;
LED_BLUE_OFF;
uart4.printf("LEDG\n"); //´®¿Ú2Êä³ö
}
if(memcmp(buffer,"ledb",strlen("ledb")) == ){ //ARMÀ¶µÆÁÁ
LED_BLUE_ON;
LED_GREEN_OFF;
LED_RED_OFF;
uart4.printf("LEDB\n"); //´®¿Ú2Êä³ö
}
}
if (uart4.receive_ok_flag){ //´®¿Ú2½ÓÊÕÍê³É
uart4.receive_ok_flag = ;
for(i = ;i < ;i++){
buffer1[i] = uart4.receive_buffer[i];
}
usart6.printf(buffer1); //´®¿Ú4Êä³ö
}
}
/* USER CODE END 3 */ }
module txd_rxd(
input rst_n,
input uart_clk,
input rx,
output tx,
output led_red,
output led_green,
output led_blue
);
//---------------------------parameter--------------------------//
parameter ledr = 'b01001100_01000101_01000100_01010010_00001010,
ledg = 'b01001100_01000101_01000100_01000111_00001010,
ledb = 'b01001100_01000101_01000100_01000010_00001010; //---------------------------------rx---------------------------//
/* 接收模块 */
reg[:]j;
reg[:]data_in;
reg [:]receive_data,data_inr; always@(posedge uart_clk or negedge rst_n)
if(!rst_n)
begin
j <= 'd0;
data_in <= 'd0;
data_inr <= 'd0;
receive_data <= 'd0;
end
else case(j)
'd0: //判断起始标志
begin
if(!rx)
begin
data_in <= 'd0;
j <= j + 'd1;
end
else j <= j;
end
'd1,4'd2,'d3,4'd4,'d5,4'd6,'d7,4'd8: //接收数据
begin
j <= j + 'd1;
data_in <= {rx,data_in[:]};
end
'd9: //接收校验位
begin
receive_data <= {receive_data[:],data_in};
j <= j + 'd1;
end
'd10: //接收停止位
begin
j <= 'd0;
if(receive_data[:] == 'b00001010)
begin
data_inr <= receive_data;
end
end
default: j <= 'd0;
endcase //---------------------------------led---------------------------//
/*对比接收数据 */
reg [:]led; always@(posedge uart_clk or negedge rst_n)
if(!rst_n)
begin
led <= 'b101;
end
else if (data_inr == ledr)
led <= 'b011;
else if (data_inr == ledg)
led <= 'b101;
else if (data_inr == ledb)
led <= 'b110; assign {led_red,led_green,led_blue} = led; //---------------------------------tx---------------------------// /*发送模块,定时发送GINGKO*/
reg tx_r; //串行发送数据的寄存器,空闲状态默认为1
reg[:]i;
reg[:]data_out;
reg[:]cnt;
reg[:]GINGKO; always @(posedge uart_clk or negedge rst_n)
if (!rst_n)
begin
i <= 'd0;
tx_r <= 'd1; //空闲状态为1
cnt <= 'd0;
data_out <= 'd0;
GINGKO <= {'d71,8'd73,'d78,8'd71,'d75,8'd79,'d13,8'd10};
end
else //开始发送DATA
case(i)
'd0: begin //先发送起始位0
i <= i + 'd1;
{data_out,GINGKO[:]} <= GINGKO;
tx_r <= 'd0;
end
'd1,14'd2,'d3,14'd4,'d5,14'd6,'d7,14'd8: //tx_r
begin
i <= i + 'd1;
{data_out[:],tx_r} <= data_out; //串口发送时,低位在先
end
'd9: begin //1位奇偶校验位和1位停止位
i <= i + 'd1;
tx_r <= 'd1;
end
'd10: begin //1位停止位
if(cnt == 'd7)
begin
i <= i + 'd1;
cnt <= 'd0;
end
else
begin
i <= 'd0;
cnt <= cnt + 'd1;
end
end
'd115200: begin //定时约为1s
i <= 'd0;
GINGKO <= {'d71,8'd73,'d78,8'd71,'d75,8'd79,'d13,8'd10};
end
default: i <= i + 'd1; //i为其他无效数值时,直接转到退出TXD模块状态
endcase assign tx = tx_r; endmodule
源代码下载链接:
链接:http://pan.baidu.com/s/1nv836RZ 密码:iky7
iCore4链接:
【iCore4 双核心板_FPGA】例程十二:基于UART的ARM与FPGA通信实验的更多相关文章
- 【iCore4 双核心板_FPGA】例程十三:基于SPI的ARM与FPGA通信实验
实验现象: 1.先烧写ARM程序,然后烧写FPGA程序. 2.打开串口精灵,通过串口精灵给ARM发送数据从而给FPGA发送数据 ,会接收到字符HELLO. 3.通过串口精灵发送命令可以控制ARM·LE ...
- 【iCore3 双核心板】例程十二:通用定时器实验——定时点亮LED
实验指导书及代码包下载: http://pan.baidu.com/s/1kTWAAJ9 iCore3 购买链接: https://item.taobao.com/item.htm?id=524229 ...
- 【iCore4 双核心板_FPGA】例程二:GPIO输入实验——识别按键输入
实验现象: 按键每按下一次,三色LED切换一次状态. 核心源代码: module key_ctrl( input clk_25m, input rst_n, input key, output fpg ...
- 【iCore4 双核心板_FPGA】例程十:FSMC总线通信实验——复用地址模式
实验原理: STM32F767上自带FMC控制器,本实验将通过FMC总线的地址复用模式实现STM32与FPGA 之间通信,FPGA内部建立RAM块,FPGA桥接STM32和RAM块,本实验通过FSMC ...
- 【iCore4 双核心板_FPGA】例程十四:基于I2C的ARM与FPGA通信实验
实验现象: 1.先烧写ARM程序,然后烧写FPGA程序. 2.打开串口精灵,通过串口精灵给ARM发送数据从而给FPGA发送数据 ,会接收到字符GINGKO. 3.通过串口精灵发送命令可以控制ARM·L ...
- 【iCore4 双核心板_FPGA】例程十五:基于单口RAM的ARM+FPGA数据存取实验
实验现象: 写RAM命令格式:write:地址(0-255),数据(0-65535)\cr\lf 读RAM命令格式:read:地址(0-255)\cr\lf 核心代码: int main(void) ...
- 【iCore4 双核心板_FPGA】例程十六:基于双口RAM的ARM+FPGA数据存取实验
实验现象: 核心代码: int main(void) { /* USER CODE BEGIN 1 */ int i; int address,data; ; ]; ]; char *p; /* US ...
- 【iCore4 双核心板_FPGA】实验二十:NIOS II之UART串口通信实验
实验指导书及源代码下载地址: 链接:https://pan.baidu.com/s/1g_tWYYJxh4EgiGvlfkVu1Q 提取码:dwwa 复制这段内容后打开百度网盘手机App,操作更方便哦 ...
- 【iCore4 双核心板_FPGA】例程四:Signal Tapll 实验——逻辑分析仪
实验现象: 三色led轮流闪烁,具体的逻辑分析仪使用教程请参考iCore3逻辑分析仪例程 核心代码: module signal_ctrl( input clk_25m, input rst_n, o ...
随机推荐
- 2、函数y=f(x)
/* Note:Your choice is C IDE */ #include "stdio.h" /* 3.函数y=f(x)可表示为: */ void main() { int ...
- swoole深入学习 4. process
swoole-1.7.2增加了一个进程管理模块,用来替代PHP的pcntl扩展.pcntl是php新增的一个多进程扩展,用来实现多进程,但是有很多不完善的地方,swoole 就完善了这些地方,而且使得 ...
- System类与Runtime类
PS: Java程序在不同操作系统上运行时,可能需要取得平台相关的属性,或者调用平台命令来完成特定功能.java提供了System类与Runtime类来与程序的运行平台进行交互. System类: 1 ...
- db2文件系统已满
文章主要讲述的是DB2文件系统已满的正确解决方案,此文首先是以列举错误案例来对其进行分析,之后再给出正确的解决方案,以下就是文章的主要内容的具体描述,望大家浏览之后会对其有更好的了解. DB2文件系统 ...
- Linux的cron与%
这个cron不能执行: * * * * * /bin/echo `/bin/date +"%Y-%m-%d-%T"` >> /home/adminuser/test.t ...
- AngularJS自定义Directive中link和controller的区别
在AngularJS中,自定义Directive过程中,有时用link和controller都能实现相同的功能.那么,两者有什么区别呢? 使用link函数的Directive 页面大致是: <b ...
- 常见爬虫/BOT 对抗技术简介(二)
上一篇文章分别从网络协议,Robots文件,JS渲染,行为分析等多方面讲了些“反爬虫”,“反-反爬虫”技术. 点击查看:<常见爬虫/BOT 对抗技术简介(一)> 本文将主要介绍各种IP地址 ...
- jQuery()方法的第二个参数
关于jQuery()方法的第二个参数,有下面这几种用法: 1.jQuery(selector, [context]) 这种用法,相当于 $(context).find(selector) 或者 con ...
- Revit中如何给不同构件着色
在Revit构件密集,默认的显示模式难以区分不同构件的区别,比如建筑立面有很多不同的机电管道,风管.水管,电缆桥架等,可一个给不同的机电管线添加不同的颜色,以示其区别,如下图所示,完成着色后,各种不同 ...
- [Android]_[0基础]_[adb 有用命令]
场景: 1. ADB 作为pc端和手机端通讯的桥梁, 起到调试手机app,查看手机信息的重要作用. 2. 这里列举了一些比較有用的命令方便速查. 查看开启USB调试的设备列表: adb devices ...