移位寄存器及verilog代码
一、移位器(shifter)
作用:移位器和循环移位器用于移动位并完成2的幂的乘法或除法。
分类:
逻辑移位器——左移(LSL)或右移(LSR),以0填充空位。11001 LSR 2 =00110; 11001 LSL 2 = 00100;(veilog 操作符号>> or <<)
算数移位器——算数左移(ASL)与逻辑左移相同,但算数右移(ASR)时会把原来数据的最高有效位填充在数据的最高有效位上,对于有符号数的乘法或除法有用。11001 ASR 2 = 11110; 11001 ASL 2 =00100;(verilog操作符号>>> or <<<)
循环移位器——循环移动数字,从一端移走的位重新填充到另一端的空位。11001 ROR 2 = 01110;11001 ROL 2 = 00111。
二、移位寄存器(shift register)
输入:包括时钟clk,串行输入Sin,串行输出Sout和N位并行输出QN-1:0。
工作原理:在时钟的边沿,从Sin移入一个新的位,所有后续内容都向前移动,最后一位在Sout中。
作用:可以作为串行到并行(serial-to-parrallel)的转换器,输入由Sin提供,经N个周期后,前面的N位输入可以在Q中进行并行访问。
组成:如图5-34所示,N位的移位寄存器由N个触发器串联而成,有些移位寄存器还有触发器的复位信号。

相关电路:包含并行到串行转换器(parrallel-to-serial)的移位寄存器,并行加载N位,然后依次移出一位。
工作原理:相比于移位寄存器增加了并行输入DN-1:0和控制信号Load。当Load信号有效时,触发器从D中并行加载数据;否则正常移位。

通用移位寄存器
作用:后续补全
//通用移位寄存器
module Universal_Shift_Reg#(parameter word_size = )(
output reg[word_size-:] Data_out,
output MSB_out, LSB_out,
input [word_size-:] Data_in,
input MSB_in, LSB_in,
input s0, s1, clk, rst
);
assign MSB_out = Data_out[word_size-];
assign LSB_out = Data_out[]; always @(posedge clk)
begin
if(rst=='b1) Data_out <= 0;
else
case({s1, s0})
: Data_out <= Data_out; //maintain
: Data_out <= {MSB_in, Data_out[word_size-:]}; //MSB shift
: Data_out <= {Data_out[word_size-:], LSB_in}; //LSB shift
: Data_out <= Data_in; //parallel input
endcase end
endmodule
移位寄存器
作用
module shift_reg#(parameter word_size = )(
output reg_out,
input clk, rst,reg_in
);
reg [word_size-:] reg_data;
assign reg_out = reg_data[];
always @(posedge clk, negedge rst)
if(!rst) reg_data <= {word_size{'b0}}; //nonblock assignment
else reg_data <= {reg_in, reg_data[word_size-:]};
endmodule
桶形移位寄存器
作用
module barrel_reg #(parameter word_size = )(
output reg [word_size-:] data_out,
input [word_size-:] data_in,
input load, clk, rst
);
always @(posedge clk, posedge rst)
begin
if(rst) data_out <= {word_size{'b0}};
else if(load) data_out <= {data_in[word_size-:], data_in[word_size-]};
end
endmodule
算术移位寄存器
// 移一位和八位的算数寄存器
module top_module(
input clk,
input load,
input ena,
input [:] amount,
input [:] data,
output reg [:] q);
always @(posedge clk)
if(load)
q <= data;
else if(ena)
begin
case(amount)
'b00: q <= {q[62:0], 1'b0};
'b01: q <= {q[55:0], 8'b0};
'b10: q <= {q[63], q[63:1]};
'b11: q <= {{8{q[63]}}, q[63:8]};
endcase
end
else
q <= q; endmodule
扫描链(scan chain)
作用:通过扫描链技术,移位寄存器经常用于测试时序电路。
原因:由于时序电路中存在状态,测试相对困难。从一个已知的初始装填开始,可能需要许多周期的测试向量才能使电路进入期望状态。为解决这一问题,希望可以通过增加测试模式来实现直接观察和控制有限状态机的所有状态。。然而由于系统中触发器太多以至于无法为每个触发器分配一个管脚进行读写。但是,系统中所有触发器都连接在扫描链的以为寄存器中。
测试模式:允许自由地向所有触发器的内容读出或者加载所需要的值。在测试模式中,扫描链通过Sin和Sout串行地移出内容或写入新的内容。

移位寄存器及verilog代码的更多相关文章
- Verilog代码规范I
Verilog代码规范I "规范"这问题 "规范"这个富含专业气息的词汇(个人感觉),其实规范这种东西,就是大家都约定熟成的东西,一旦你不遵守这个东西,专业人士 ...
- HD,3G视频数据中行号的插入方法---Verilog代码实现
HD,3G视频数据中行号的插入方法---Verilog代码实现 行号的生成: `timescale 1ns / 1ps //////////////////////////////////////// ...
- 串口接收端verilog代码分析
串口接收端verilog代码分析 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...
- 串口发送端verilog代码分析
串口发送端verilog代码分析 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...
- verilog 代码分析与仿真
verilog 代码分析与仿真 注意:使用vivado 自带的仿真工具, reg和wire等信号需要赋予初始值 边沿检测 module signal_test( input wire cmos_pcl ...
- 总线读写---verilog代码
总线读写---verilog代码 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...
- FIFO 的控制逻辑---verilog代码
FIFO 的控制逻辑---verilog代码 //fifo的例化 wire fifo_full; wire fifo_empty; : ] fifo_dout; :]rd_data_count; :] ...
- 信号滤波模块verilog代码---UNLOCK,LOCK状态机方式
信号滤波模块verilog代码 `timescale 1ns / 1ps /////////////////////////////////////////////////////////////// ...
- verilog代码 想法验证---与寄存器输出有关
verilog代码 想法验证---与寄存器输出有关 1. module test_mind( input wire clk, input wire reset, input wire i, outpu ...
随机推荐
- springcloud vue.js 微服务分布式 前后分离 集成代码生成器 shiro权限 activiti工作流
1.代码生成器: [正反双向](单表.主表.明细表.树形表,快速开发利器)freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本.处理类.service等完整模块2. ...
- GitLab-怎样使用GitLab托管项目
场景 Docker Compose部署GitLab服务,搭建自己的代码托管平台(图文教程): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/det ...
- JS Timing
JS Timing 通过使用 JavaScript,我们有能力做到在一个设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行.我们称之为计时事件. JavaScript 计时事件 通过使用 Ja ...
- C语言入门-全局变量
一.全局变量 定义在函数外面的变量是全局变量 全局变量具有全局的生存期和作用域 它们与任何函数无关,在任何函数内部都可以使用它们 #include <stdio.h> int f(void ...
- c#中的跳转语句
break:跳出循环,执行循环外的语句:continue:跳出此次循环,进入下一次循环: goto:不建议使用 return:终止它所在的方法的执行,并将控制权返回给调用方法.
- jxl.jar下载
jxl.jar是通过java操作excel表格的工具类库,是由java语言开发而成的. 在网上找了很多,不是链接失效,就是csdn上要钱的,所以干脆上传个到自己的博客文件里,方便你们下载. 下载地址: ...
- tensorflow和pytorch教程
https://github.com/dragen1860/Deep-Learning-with-TensorFlow-book
- Java之IO初识(字节流和字符流)
IO概述 生活中,你肯定经历过这样的场景.当你编辑一个文本文件,忘记了 ctrl+s ,可能文件就白白编辑了.当你电脑上插入一个U盘,可以把一个视频,拷贝到你的电脑硬盘里.那么数据都是在哪些设备上的呢 ...
- java之等待唤醒机制(线程之间的通信)
线程间通信 概念:多个线程在处理同一个资源,但是处理的动作(线程的任务)却不相同.比如:线程A用来生成包子的,线程B用来吃包子的,包子可以理解为同一资源,线程A与线程B处理的动作,一个是生产,一个是消 ...
- MAC地址表(交换机)、ARP缓存表以及路由表(路由器)