FPGA设计思想之串并转换
数据流中,用面积换速度-串行转并行的操作
并行转串行数据输出:采用计数方法,将并行的数据的总数先表示出来,然后发送一位数据减一,后面的接收的这样表示: data_out <= data[cnt];//cnt表示计数器
`timescale 1ns/1ns module p2s
(
input clk,
input rst_n,
input load,
input [:] pdata,
output sclk,
output sdat
);
`define FULL 'hf
reg [:] bitcnt;
reg en;
reg [:] sbuff;
always @(posedge clk or negedge rst_n)
if(!rst_n) en <= ;
else if(load) en <= 'b1;
else if(bitcnt==`FULL) en <= 'b0;
always @(posedge clk or negedge rst_n)
if(!rst_n) bitcnt <= ;
else if(en) bitcnt <= bitcnt + 'b1;
else bitcnt <= ;
assign sclk = bitcnt[];
always @(posedge clk or negedge rst_n)
if(!rst_n) sbuff <= 'b0;
else if(load) sbuff <= pdata;
else if(sclk) sbuff <= sbuff<<;
assign sdat = sbuff[];
endmodule
串行转并行数据输出:采用位拼接结束,将串行的数据总数先表示出来,然后发送一位数据加一,后面的接收的这样标志:data <= {data[6:0],data_out };------用过的74HC595
module SerialToParallel(
input CLK, //时钟
input RSTn, //复位
input Enable, //输入有效
input DataIn, //串行输入
output reg Ready, //输出有效
output[:] Index, //并行数据索引
output[:] ParallelData //并行数据输出
); reg[:] Data_Temp; //数据缓存
reg[:] counter; //位数计数器
reg[:] state; //状态机
reg[:] Index_Temp; //索引缓存 assign Index=Index_Temp;
assign ParallelData=Ready?Data_Temp:'d0; ////////////////////////////////////////
//state:
//4'd0:复位
//
//4'd1:未复位,未使能
//
//4'd2:未复位,输入使能
// always@(posedge CLK or negedge RSTn)
if(!RSTn)
begin
state<='d0; //复位
Ready<=;
counter<='d0;
Data_Temp<='d0;
Index_Temp<='d0;
end
else
begin
case(state)
'd0:
begin
if(!Enable)state<='d1;
else state<='d2;
Ready<=;
end
'd1:
begin
if(!Enable)state<='d1;
else state<='d2;
Ready<=;
counter<='d0;
Data_Temp<='d0;
end
'd2:
begin
if(!Enable)state<='d1;
else state<='d2;
case(counter)
'd0:begin Data_Temp[0]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd1:begin Data_Temp[1]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd2:begin Data_Temp[2]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd3:begin Data_Temp[3]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd4:begin Data_Temp[4]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd5:begin Data_Temp[5]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd6:begin Data_Temp[6]<=DataIn;counter<=counter + 1'b1;Ready<=;end
'd7:begin Data_Temp[7]<=DataIn;counter<=4'd0;Index_Temp<=Index_Temp + 'b1;Ready<=1'b1;end
endcase
end
endcase
end endmodule
FPGA设计思想之串并转换的更多相关文章
- FPGA设计思想与技巧(转载)
		题记:这个笔记不是特权同学自己整理的,特权同学只是对这个笔记做了一下完善,也忘了是从那DOWNLOAD来的,首先对整理者表示感谢.这些知识点确实都很实用,这些设计思想或者也可以说是经验吧,是很值得每一 ... 
- 09A-独立按键消抖实验01——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯队长精心奉献 实验目的: 1.复习状态机的设计思想并以此为基础实现按键消抖 2.单bit异步信号同步化以及边沿检测 3.在激励文件中学会使用随机数发生函数$random 4.仿真模 ... 
- 08-FPGA状态机设计实例——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯队长精心奉献 实验目的:1.学习状态机的相关概念 2.理解一段式.两段式以及三段式状态机的区别以及优缺点 实验平台:芯航线FPGA核心板 实验原理: 状态机全称是有限状态机(fin ... 
- 02-FPGA设计流程介绍——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线——普利斯队长精心奉献 课程目标: 1.了解并学会FPGA开发设计的整体流程 2.设计一个二选一选择器并进行功能仿真.时序仿真以及板级验证 实验平台:芯航线FPGA开发板.杜邦线 实验内容: 良 ... 
- 10-8位7段数码管驱动实验——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯队长精心奉献 实验目的: 1.实现FPGA驱动数码管动态显示: 2.使用In system sources and probes editor工具,输入需要显示在数码管上的的数据, ... 
- 09B-独立按键消抖实验02——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯队长精心奉献 实验目的: 1.复习按键的设计 2.用模块化设计的方式实现每次按下按键0,4个LED显示状态以二进制加法格式加1,每次按下按键1,4个LED显示状态以二进制加法格式减 ... 
- 05-IP核应用之计数器——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯顿队长精心奉献 实验目的:了解FPGA的IP核相关知识并以计数器IP核为例学会基本IP使用的流程 实验平台:无 实验原理: IP核(Intellectual Propert ... 
- 04-时序逻辑电路设计之计数器——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线--普利斯队长精心奉献 实验目的:以计数器为例学会简单的时序逻辑电路设计 实验平台:芯航线FPGA核心板 实验原理: 时序逻辑电路是指电路任何时刻的稳态输出不仅取决于当前的输入,还与前一时刻输入 ... 
- 03-组合逻辑电路设计之译码器——小梅哥FPGA设计思想与验证方法视频教程配套文档
		芯航线——普利斯队长精心奉献 课程目标: 1. 再次熟悉Quartus II工程的建立以及完整的FPGA开发流程 2. 以译码器为例学会简单组合逻辑电路设计 实验平台:无 实验原理: 组合逻辑, ... 
随机推荐
- Maven--Cargo远程部署
			参考:https://www.digitalocean.com/community/questions/how-to-access-tomcat-8-admin-gui-from-different- ... 
- idea启动服务连接mysql后 Navicat连接mysql就报错2013-Lost connection toMySQL server at
			我是使用navicat的windows端 连接centos下mysql服务器 第一次常规连接mysql正常,idea启动服务连接mysql后 Navicat连接mysql就报错2013-Lost co ... 
- Java   final  关键字的用法以及原理(7)
			/* final : 最终.作为一个修饰符, 1:可以修饰类,函数,变量. 2:被final修饰的类不可以被继承.为了避免被继承,被子类复写功能. 3:被final修饰的方法不可以被复写. 4:被fi ... 
- Python说文解字_杂谈05
			1. isinstance和type: is和==符号,is指的是内存地址,是不是一个对象,ID知否相同 集成链 class A: pass class B(A): pass b = B() prin ... 
- JAVA初学者——逻辑运算符
			Hello!大家好,我是浩宇大熊猫~ 加油~充实每一天~ java里面的逻辑运算符有与(&).或(|).异或(^).非(!) 其实这些初高中数学课都学过哈,很简单~ public class ... 
- 吴裕雄--天生自然 PHP开发学习:MySQL 插入数据
			<?php $servername = "localhost"; $username = "root"; $password = "admin& ... 
- MySQL——事务(transaction)简单总结
			简介: MySQL事务操作主要用于处理操作量大,复杂度高的数据,比如说,在人员管理系统中要删除一个人员,你既要删除他的基本资料,也要删除该人员的相关信息,如文章.信箱等.这些数据库操作语句就构成了一个 ... 
- Python 进阶 - 面向对象
			Python 面向对象 面向过程 把完成某个需求的所有步骤,从头到尾逐步实现 根据开发需求,将某些功能独立的代码封装成一个又一个函数 最后完成的代码,就是顺序地调用不同的函数 面向过程特点: 注重步骤 ... 
- 浙江省赛  ZOJ - 4033
			题意: 第一行给出T代表有几个测试样例, 第二行给出n代表有几个人, 第三行给出一个由0和1组成的字符串,0代表女生,1代表男生. 并且第i个人有i个宝石. 现在要把这些人分为四组,G1 G2 两组是 ... 
- Linux轻量级自动化运维工具— Ansible
			Ansible 是什么 ? ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配 ... 
