一设计功能:(一)用两个分频模块,实现16分频,且让输入a 和b在16个系统时钟内,相与一次。

      (二)模块化设计思想(结构化思维)

          拆分,即把一个系统划分成多个功能模块,控制模块,组合模块。然后从功能模块开始,循序渐进一个个设计好,再把所有的模块连接起来,实现系统功能。

    

          

二设计输入

(一)顶层模块:定义输入输出端口,实现各个模块的连接通过例化   

//顶层模块

module top(

input wire Clk,

input wire Rst_n,

input wire a,

input wire b,

output wire c

);

wire p_flag;//connect po_flag0 to pi_flag0

wire flag;//connect po_flag to pi_flag

//例化

div_clk2 div_clk2m0(

.clk(Clk),

.rst_n(Rst_n),

.po_flag0(p_flag)

);

div_clk1 div_clk1m0(

.clk(Clk),

.rst_n(Rst_n),

.pi_flag0(p_flag),

.po_flag(flag)

);

a_and_b a_and_bm0(

. clk(Clk),

. rst_n(Rst_n),

. pi_flag(flag),

. pi_a(a),

. pi_b(b),

. po_c(c)

);

endmodule

        (二)分频模块:两个分频模块实现16分频

//分频模块2实现四分频并输出一个分频标志信号

module div_clk2(

input   wire            clk,

input   wire            rst_n,

output  reg             po_flag0

);

wire    rst;

reg [1:0] div_cnt;

assign rst = ~rst_n;

//div cnt

always @(posedge clk)begin

if(rst == 1'b1 )begin

div_cnt <= 'd0;

end

else if (div_cnt == 'd3) begin

div_cnt <= 'd0;

end

else

div_cnt <= div_cnt + 1'b1;

end

//po_flag0

always @(posedge clk) begin

if (rst == 1'b1 ) begin

po_flag0<= 1'b0;

end

else if(div_cnt== 'd2)begin

po_flag0 <= 1'b1;

end

else begin

po_flag0 <= 1'b0;

end

end

endmodule

//分频模块1在分频模块2的基础上,实现16分频并输出对应的分频标志信号

module div_clk1(

input wire clk,

input wire rst_n,

input wire pi_flag0,

output reg po_flag

);

wire rst;

assign rst = ~rst_n;

//div_cnt under the pi_flag0

reg [1:0]div_cnt;

always@(posedge clk)

if(rst)

div_cnt<=0;

else if(div_cnt==2'd3)

div_cnt<=0;

else if(pi_flag0)

div_cnt<=div_cnt+1'b1;

else

div_cnt<=div_cnt;

//po_flag

always@(posedge clk)

if(rst)

po_flag<=0;

else if(div_cnt==2'd3 & pi_flag0)//lack & pi_flag0 is error

po_flag<=1'b1;

else

po_flag<=0;

endmodule

          (三)相与模块

//相与模块,在16分频的标志信号下,相与

module a_and_b(

input wire clk,

input wire rst_n,

input wire pi_flag,

input wire pi_a,

input wire pi_b,

output reg po_c

);

wire rst;

assign rst = ~rst_n;

always@(posedge clk)

if(rst==1'b1)

po_c<=1'b0;

else if(pi_flag==1'b1)

po_c<=pi_a & pi_b;

else

po_c<=0;

endmodule

    三总结

        (一)常见疑问及答案

        1.在不同模块的信号,通过传输线连在一起,那这些信号会有延时嘛(即变化实际不一样)?

      实际上,在不同模块的同一信号如po_flag, pi_flag,flag,他们通过flag信号连在一起,是同时变化的。

        2.在什么情况下存在延时?

      存在延时一个时钟的会是在时序逻辑的always里,如下面的赋值语句中

else if(div_cnt== 'd2)begin

po_flag <= 1'b1;

po_flag在仿真中,实际为高电平在分频计数值为3.

else if (pi_flag == 1'b1) begin

po_c <= pi_a & pi_b;

end

而在相与模块里,发生相与操作是在po_flag为高后,再延迟一个时钟,故相与在分频计数值为2后,延迟了两个时钟周期,

    3.注意下面这句易出错

     else if(div_cnt==2'd3 & pi_flag0)//lack & pi_flag0 is error

       po_flag<=1'b1;

    若缺少后面的与条件,会持续四个时钟周期,由于div_cnt每四个时钟更新。

      (二)设计注意点

      1.sublime列编辑:shift+鼠标右键。

  2.赛灵思要求为同步复位,故开发板是异步复位,则程序设计为

    wire rst;

    assign  rst = ~rst_n;

  3.在例化,模块的接口是输入,可以连接wire或reg型变量。但模块的接口是输出,必须连接wire型。

   4.基本语法准则:即always赋值的输出信号,只能为reg型。而assign赋值的输出信号,只能为wire型。

    (三)仿真

  

`timescale 1ns/1ns

`define clk_period 20

module top_tb();

reg clk;

reg rst_n;

reg a;

reg b;

wire c;

top top_m0(

.Clk(clk),

.Rst_n(rst_n),

.a(a),

.b(b),

.c(c)

);

initial clk =1;

always#(`clk_period/2) clk = ~clk;

initial begin

rst_n =0;

a=0;

b=0;

#(`clk_period*2);

rst_n =1;

#(`clk_period*40);

rst_n = 0;

#(`clk_period*12);

$stop;

end

always#(`clk_period*2) a = {$random};

always#(`clk_period*2) b= {$random};

endmodule

//波形:

 

07模块化设计之top_down的更多相关文章

  1. iOS程序模块化设计

    一.模块化设计的概述: 模块化设计(Block-based design):对一定范围内的不同功能或相同功能的不同性能.不同规格的产品进行功能分析的基础上,划分并设计出一系列功能模块,通过模块的选择和 ...

  2. PHP--进行模块化设计

    PHP--进行模块化设计 [来源] 达内    [编辑] 达内   [时间]2012-10-30 导航模块可以简单列为一个关于三级页面链接的HTML文件.通常你可以通过用另一种颜色来标明对当前区域的链 ...

  3. 深入浅出百度地图API开发系列(3):模块化设计

    在前面两张简单介绍了百度地图API的基础知识和使用之后,我们来分析一下百度地图API的基本架构,了解一下基本架构可以帮助我们更清晰的了解API的功能和调用过程,也就可以帮助我们在实际开发中可以更方便的 ...

  4. AngularJs学习笔记7——四大特性之模块化设计

    模块化设计 1.引用自定义模块并调用 自定义模块中,如果有一些服务.封装好笑模块,在另外一个模块中(声明的时候,在依赖列表中加入要引入的模块) var app02 = angular.module(' ...

  5. C51的模块化设计方法

    一个大的单片机程序往往包含很多模块,我是这样组织的: 1.每一个C源文件都要建立一个与之名字一样的H文件(头文件),里面仅仅包括该C文件的函数的声明,其他的什么也不会有,比如变量的定义啊等等不应该有. ...

  6. thinkphp学习笔记5—模块化设计

    原文:thinkphp学习笔记5-模块化设计 1.模块结构 完整的ThinkPHP用用围绕模块/控制器/操作设计,并支持多个入口文件盒多级控制.ThinkPHP默认PATHINFO模式,如下: htt ...

  7. App 组件化/模块化之路——使用SDK的思路进行模块化设计接口

    在不久之前分享一篇<App 组件化/模块化之路——如何封装网络请求框架>文章介绍了我在项目中封装网络请求框架的思路.开发一个 App 会涉及到很多网络请求 API ,例如登录注册接口.用户 ...

  8. 基于layui的框架模版,采用模块化设计,接口分离,组件化思想

    代码地址如下:http://www.demodashi.com/demo/13362.html 1. 准备工作 编辑器vscode,需要安装liveServer插件在前端开启静态服务器 或者使用hbu ...

  9. Swift之xib模块化设计

    一.解决问题 Xib/Storybarod可以方便.可视化的设置约束,在开发中也越来越重要.由于Xib不能组件化,使得封装.重用都变得不可行.本文将介绍一种解决方案,来实现Xib组件化. 二.模型块原 ...

随机推荐

  1. java Excel 简单工具

    我就简单的分享一下我常用的工具 这次由于个人问题工具注释全部乱码差点无法还原,也是为了防止数据丢失后期找不到再次保留方法把. 调用工具个别方法 <dependency> <group ...

  2. Django中ORM创建表关系

    一:django中ORM创建表关系 ORM创建外键关系 1.表与表之间的关系 1.表与表之间的关系 一对多 一对一 多对多 2.操作目标条件: 图书表 出版社表 作者表 作者详情表 3.外键关联 一对 ...

  3. CobaltStrike逆向学习系列(2):Stageless Beacon 生成流程分析

    这是[信安成长计划]的第 2 篇文章 关注微信公众号 [信安成长计划] 0x00 目录 0x01 Patch Beacon 0x02 Patch Loader 0x03 文件对比 0x04 流程图 C ...

  4. WAF、IDS、IPS

    WAF:https://blog.csdn.net/gufenchen/article/details/93485351 IDS:https://blog.csdn.net/coldeye/artic ...

  5. Clickhouse 分布式表&本地表

    CK 分布式表和本地表 ck的表分为两种: 分布式表 一个逻辑上的表, 可以理解为数据库中的视图, 一般查询都查询分布式表. 分布式表引擎会将我们的查询请求路由本地表进行查询, 然后进行汇总最终返回给 ...

  6. Hadoop权威指南 - 学习笔记

    初识Hadoop.关于MapReduce Hadoop宏观介绍 相对于其他系统的优势 关系型数据库管理系统 为什么不能用配有大量硬盘的数据库进行大规模分析?为什么需要Hadoop? 因为计算机硬盘的发 ...

  7. Codeforces Round #770 (Div. 2)D

    传送门 题目大意: 交互题, n ( 4 ≤ n ≤ 1000 ) n(4\leq n\leq1000) n(4≤n≤1000)个数字组成的数列 a 1 , a 2 , - , a n ( 0 ≤ a ...

  8. VUE3 之 使用标签实现动画与过渡效果(下) - 这个系列的教程通俗易懂,适合新手

    1. 概述 毛毛虫效应: 有这样一个实验,将许多毛毛虫放在一个花盆边缘,使它们首尾相接,围成一个圈.然后在离花盆很近的地方撒了一些毛毛虫的食物. 此时,毛毛虫并不会向食物的方向爬去,而是在花盆边缘,一 ...

  9. 3. Java基础

    3.Java基础[基于IDEA] 3.1.快捷键 psvm 创建主方法 sout 打印 ctrl+d 复制当前行到下一行 alt+ender 创建局部变量,类: 3.2.注释,标识符,关键字 注释 平 ...

  10. tp 七牛云文件上传

    1.先创建好七牛云账号和存储空间 申请七牛云账号: 创建七牛云存储空间: 在账号的秘钥管理里面创建秘钥 获取AccessKey / SecretKey: 2.集成PHP-SDK 七牛云开发文档:htt ...