一、移位器(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代码的更多相关文章

  1. Verilog代码规范I

    Verilog代码规范I "规范"这问题 "规范"这个富含专业气息的词汇(个人感觉),其实规范这种东西,就是大家都约定熟成的东西,一旦你不遵守这个东西,专业人士 ...

  2. HD,3G视频数据中行号的插入方法---Verilog代码实现

    HD,3G视频数据中行号的插入方法---Verilog代码实现 行号的生成: `timescale 1ns / 1ps //////////////////////////////////////// ...

  3. 串口接收端verilog代码分析

    串口接收端verilog代码分析 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...

  4. 串口发送端verilog代码分析

    串口发送端verilog代码分析 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...

  5. verilog 代码分析与仿真

    verilog 代码分析与仿真 注意:使用vivado 自带的仿真工具, reg和wire等信号需要赋予初始值 边沿检测 module signal_test( input wire cmos_pcl ...

  6. 总线读写---verilog代码

    总线读写---verilog代码 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////// ...

  7. FIFO 的控制逻辑---verilog代码

    FIFO 的控制逻辑---verilog代码 //fifo的例化 wire fifo_full; wire fifo_empty; : ] fifo_dout; :]rd_data_count; :] ...

  8. 信号滤波模块verilog代码---UNLOCK,LOCK状态机方式

    信号滤波模块verilog代码 `timescale 1ns / 1ps /////////////////////////////////////////////////////////////// ...

  9. verilog代码 想法验证---与寄存器输出有关

    verilog代码 想法验证---与寄存器输出有关 1. module test_mind( input wire clk, input wire reset, input wire i, outpu ...

随机推荐

  1. feign响应Image流对象

    feign面向方法签名的http调用,越来越受欢迎,类型于rpc的thrift,只需要关注方法签名和返回值即可,当然feign响应流对象时,需要我们做一下特殊处理,否则会出现异常.也有一些文章通过重写 ...

  2. 将Android封装库通过gradle部署到maven私服并依赖使用

    一.在需要发布的模块chrisbaselibrary下的build.gradle中添加以下部分 //maven插件 apply plugin: 'maven' //打包main目录下代码和资源的 ta ...

  3. SpringBoot条件注解的总结

    https://blog.csdn.net/qq_31142553/article/details/86439950

  4. android屏幕监视工具 android screen monitor使用

    android screen monitor是一个非常好用的手机屏幕监视工具,可以将你的手机界面动态的显示出来,可用于项目演示. 这个工具就是其实一个jar文件,不到300KB大小,依赖jdk,并且还 ...

  5. Logstash filter 插件之 date

    使用 date 插件解析字段中的日期,然后使用该日期或时间戳作为事件的 logstash 时间戳.对于排序事件和导入旧数据,日期过滤器尤其重要.如果您在事件中没有得到正确的日期,那么稍后搜索它们可能会 ...

  6. 在CV尤其是CNN领域的一些想法

    现在的CNN还差很多,未来满是变数. 你看,现在的应用领域也无非merely就这么几类----分类识别,目标检测(定位+识别),对象分割......,但是人的视觉可不仅仅这么几个功能啊!是吧. 先说说 ...

  7. ubuntu 默认python版本切换

    电脑上面有些脚本是python2的,有些是python3的,但是系统默认是python2,需要设置环境变量来进行切换. python2切换到python3: echo alias python=pyt ...

  8. Java 添加Word文本水印、图片水印

    水印是一种常用于各种文档的声明.防伪手段,一般可设置文字水印或者加载图片作为水印.以下内容将分享通过Java编程给Word文档添加水印效果的方法,即 文本水印 图片水印 使用工具:Free Spire ...

  9. 【重拾基础】耐人寻味的CSS属性white-space

    <耐人寻味的CSS属性white-space>,本文说的white-space是一个控制换行和空白处理的CSS属性.我曾经被这个属性烦死,一直没记住,今天决定还是写下来好好琢磨下. 属性值 ...

  10. AttributeError: 'unicode' object has no attribute 'tzinfo' 未解决

    Internal Server Error: /demo/machineinfo.htmlTraceback (most recent call last): File "C:\Python ...