流水灯与移位寄存器实验

实验目的

(1) 熟悉移位寄存器的功能特性。

(2) 用HDL语言设计移位寄存器功能模块。

(3) 理解计算机中常见的移位运算。

实验内容1:流水灯

一组LED指示灯在某一时刻只有部分LED点亮,依次变换点亮的LED灯,并且不停地循环,这种效果通常称为流水灯或走马灯。

参考设计1

实验材料中给出了一个流水灯的设计,将循环左移移位寄存器的输出连接到LED指示灯上,当寄存器中存储的数据移位时,看起来就像LED在移动,形成流水灯的效果。认真阅读HDL代码,理解其逻辑功能;编译后加载到实验板,观察流水灯效果。虚拟面板如图 1

image
图 1. 流水灯的虚拟面板

实验任务1

用HDL设计一个可并行装载的右移移位寄存器,并在实验系统上验证。

  1. 要求将其设计为一个单独的模块,端口定义如下。

module RightShifter
#(parameter N = 4)
(
    input wire iClk,
    input wire iReset,
    input wire iLoad,
    input wire iEnable,
    input wire iShiftIn,
    input wire [N-1:0] iD,
    output logic [N-1:0] oQ
);

parameter N = 4”定义了一个参数N,若上层模块实例化时未传递该参数,默认取值为4。Reset是异步复位信号,Load和Enable是同步装数和使能信号,表 1是功能表。可以看出,这些控制信号是有优先级的;只要Reset有效,就会使寄存器清零,与Load和Enable无关;当Reset无效时,如果Load有效,在时钟上升沿到来时将输入数据D保存在寄存器中,与Enable是什么电平无关;如果Reset和Load都无效但Enable=1,则寄存器内容右移一位,并且将ShiftIn移入寄存器的最高位;否则寄存器内容保持不变。这种有优先级的结构适合用“if-else if”语句描述。

表 1. 右移移位寄存器的功能表
Reset Load Enable 功能

0

0

0

保持不变

0

0

1

右移一位(高位移入的数据来自ShiftIn)

0

1

X

并行装载(保存iD输入数据)

1

X

X

清零(异步)

ShiftIn是移入数据的端口,在上层模块实例化时将不同的数据或信号连接到ShiftIn,可以实现逻辑右移、算术右移和循环右移。

  1. 实验材料中提供了虚拟面板,如图 2。除了Load和Enable各用一个开关控制外,还有8个开关提供并行装载的数据,用来设置灯的初始状态。在实验平台上打开虚拟面板,记下虚拟元件的序号以便在代码中对应。

image
图 2. 可并行装载的右移移位寄存器的虚拟面板
  1. 在虚拟实验板模块(VirtualBoard)中实例化RightShifter,按照虚拟面板放置的开关序号连接相应的端口,并且在VirtualBoard模块将Q0连接到ShiftIn(如图中虚线所示)构成循环右移;实例化时传递参数N的值为8,产生8位的循环右移移位寄存器。【思考】不改变RightShifter模块的设计,如何实现算术右移或逻辑右移。

  2. 编译成功后,加载FPGA,验证各项功能,如装载、右移和异步复位等。

实验内容2:桶形移位

基本原理

上面的设计是一个时钟移一位,如果需要移动多位,就需要多个时钟周期。但是现代计算机的移位指令,通常需要在一个时钟周期移动多位。实现多位移位的组合逻辑称作桶形移位器(barrel shifter),一般的实现方法是使用多路器阵列。图 3是一个四位的循环左移桶形移位器,由4个4选1多路器构成;DI3-0是4位输入,DO3-0是移位的输出,移位的位数由N1N0决定,一次可移位0~3位。N1N0实际是4选1多路器的选择信号,当N1N0=00时,DO3-0输出选择的是对应的DI3-0输入,即DO3-0=DI3-0,不进行移位;当N1N0=01时,DO3-1=DI2-0,即DI左移1位,而DO0=DI3,所以是循环左移1位;当N1N0=10时,DO3-2=DI1-0,DO1-0=DI3-2,循环左移2位;类似地,当N1N0=11时,循环左移3位。

barrel-shifter
图 3. 四位循环左移桶形移位原理图

由上可知,构造一个M位的桶形移位器需要M个M选1的多路器,最大可移位位数为M-1位。如果M较大,可采用分层的多路器阵列,以避免扇入数太大。

参考设计2

桶形移位器是一个组合逻辑,要实现桶形移位寄存器,还需要增加一个数据寄存器。参考设计范例2给出了一个8位的循环左移桶形移位寄存器的设计,阅读其HDL代码可知,该电路分为时序逻辑和组合逻辑两个部分,组合逻辑实现移位功能,而时序逻辑就是一个并行数据寄存器,用来将移位的结果保存在寄存器中。 电路框图如图 4虚拟面板所示,复位时数据寄存器的初值为00000001,寄存器的输出Q连到桶形移位逻辑的数据输入DI,Num决定移位位数,DO是移位输出。如果Num大于1,DI左移指定位数,当点击Clk按钮时,之前的移位输出保存到寄存器并且作为移位器新的输入,连续点击Clk,LED的视觉效果是一个跳跃的流水灯。

image
图 4. 左移的桶形移位寄存器的虚拟面板

实验任务2

用HDL设计一个具有多种移位功能的桶形移位器(不包含寄存器),可以对并行输入数据进行左移、逻辑右移、算术右移、并行传送等,见表 2。虚拟面板如图 5,其中Num指定移位的位数,SM0和SM1控制移位方式,具体含义如下表。AM控制是否算术移位,若AM=1,进行算术移位,否则进行逻辑移位;只有右移受AM控制,左移始终是逻辑移位。

image
图 5. 多功能桶形移位器的虚拟面板
表 2. 桶形移位器功能表
SM1 SM0 功能

0

0

输出零(DO=0)

0

1

右移Num位

1

0

左移Num位

1

1

传送(DO=DI)

  • 可以使用Verilog的移位运算符。

  • logic、reg等类型的逻辑变量默认是无符号数,可使用系统函数$signed()强制转换为带符号数,之后再做算术移位。

  • 本实验任务的设计可直接用于后面ALU实验的移位运算。