Xilinx FPGA中SRL原理

时间:2025-11-16  作者:Diven  阅读:0

SRL(移位寄存器)资源,在FPGA中都有,不过是叫不同的名字。Xilinx FPGA内部的LUT有个特殊功能,就是可以配置成可变长度SRL。

Xilinx FPGA中SRL原理

5输入的一个LUT可以变成32bit 的SRL

6输入的,可以变成64bit的SRL

所以,你写的SRL可能被综合成LUT。

可以定义移位长度的移位寄存器

就是用一个lut可以实现16位的移位寄存器。

SRL16 的是 16bit移位寄存器查找表 // 16-Bit Shift Register Look-Up-Table (LUT)

在一个LUT中可以实现16个FF移位的功能!

SSRL16 SRL16_inst (

.Q(Q), // SRL data output

.A0(A0), // Select[0] input

.A1(A1), // Select[1] input

.A2(A2), // Select[2] input

.A3(A3), // Select[3] input

.CLK(CLK), // Clock input

.D(D) // SRL data input

);

Xilinx 官网的说明——原理

SRL16 is a shift register look up table (LUT)。 The inputs A3, A2, A1, and A0 select the output length of the shift register. The shift register may be of a fixed, statIC length or it may be dynamICally adjusted.

The shift register LUT contents are initialized by assigning a four-digit hexadecimal number to an INIT attribute. The first, or the left-most, hexadecimal digit is the most significant bit. If an INIT value is not specified, it defaults to a value of four zeros (0000) so that the shift register LUT is cleared during configuration.

The data (D) is loaded into the first bit of the shift register during the Low-to-High clock (CLK) transition. During subsequent Low-to-High clock transitions data is shifted to the next highest bit position as new data is loaded. The data appears on the Q output when the shift register length determined by the address inputs is reached.

这里说了几点,

- 移位寄存器的初始值可以用INIT属性初始化;

- 移位寄存器的长度由地址线的取值决定;

- 移位数据从D端输入,Q端输出

- 先移入的数据是MSB

Xilinx 官网的说明——Static Length Mode

To get a fixed length shift register, drive the A3 through A0 inputs with static values. The length of the shift register can vary from 1 bit to 16 bits as determined from the following formula:

Length = (8*A3) +(4*A2) + (2*A1) + A0 +1

If A3, A2, A1, and A0 are all zeros (0000), the shift register is one bit long. If they are all ones (1111), it is 16 bits long.

Xilinx 官网的说明——Dynamic Length Mode

The length of the shift register can be changed dynamically by changing the values driving the A3 through A0 inputs. For example, if A2, A1, and A0 are all ones (111) and A3 toggles between a one (1) and a zero (0), the length of the shift register changes from 16 bits to 8 bits.

Internally, the length of the shift register is always 16 bits and the input lines A3 through A0 select which of the 16 bits reach the output.

Inputs Output

Am CLK D Q

Am X X Q(Am)

Am ↑ D Q(Am-1)

m= 0, 1, 2, 3

这里提示了几个要点:

- 移位寄存器是可变长度的

- 长度的改变由地址线来指定

- 内部的寄存器长度是不变的,只是截取的长度变了

- 数据先移入到A0,然后到A1,以此类推,最后从指定长度的Am-1处输出,比如A=8,则数据从地址0输入,从地址7输出,这样有效的移位长度就为8。

Xilinx 官网的说明——VHDL例化实例

-- SRL16: 16-bit shift register LUT operating on posedge of clock

-- All FPGAs

-- Xilinx HDL Libraries Guide version 7.1i

SRL16_inst : SRL16

-- The following generic declaration is only necessary if you wish to

-- change the initial contents of the SRL to anything other than all

-- zero‘s.

generic map (

INIT =》 X“0000”)

port map (

Q =》 Q, -- SRL data output

A0 =》 A0, -- Select[0] input

A1 =》 A1, -- Select[1] input

A2 =》 A2, -- Select[2] input

A3 =》 A3, -- Select[3] input

CLK =》 CLK, -- Clock input

D =》 D -- SRL data input

);

-- End of SRL16_inst instantiation

复制代码

Xilinx 官网的说明——Verilog例化实例

-- SRL16: 16-bit shift register LUT operating on posedge of clock

- All FPGAs

-- Xilinx HDL Libraries Guide version 7.1i

SSRL16 SRL16_inst (

.Q(Q), // SRL data output

.A0(A0), // Select[0] input

.A1(A1), // Select[1] input

.A2(A2), // Select[2] input

.A3(A3), // Select[3] input

.CLK(CLK), // Clock input

.D(D) // SRL data input

);

// The following defparam declaration is only necessary if you wish to

// change the initial contents of the SRL to anything other than all

// zero’s. If the instance name to the SRL is changed, that change

// needs to be reflected in the defparam statements.

defparam SRL16_inst.INIT = 16‘h0000;

// End of SRL16_inst instantiation

然后具体例子:

基于SRL16的分布式RAM不再支持V5、S6和V6等器件,但是SRL16是所有XIlinx器件都支持的,并且在设计中应用非常频繁,因此可通过调用原语的方法来调用SRL16E甚至SRL32E来实现原来ISE分布式RAM IP核的设计。下面给出一段示例代码

Module s2p_8channels_srl16(

a, d, clk, we, qspo

);

input [3:0] a;

input [4:0] d;

input clk;

input we;

output [4:0] qspo;

SRL16E #(

.INIT(16’h0000) // Initial Value of Shift Register

) SRL16_inst_1 (

.Q(qspo[0]), // SRL data output

.A0(a[0]), // Select[0] input

.A1(a[1]), // Select[1] input

.A2(a[2]), // Select[2] input

.A3(a[3]), // Select[3] input

.CE(we),

.CLK(clk), // Clock input

.D(d[0]) // SRL data input

);

SRL16E #(

.INIT(16‘h0000) // Initial Value of Shift Register

) SRL16_inst_2 (

.Q(qspo[1]), // SRL data output

.A0(a[0]), // Select[0] input

.A1(a[1]), // Select[1] input

.A2(a[2]), // Select[2] input

.A3(a[3]), // Select[3] input

.CE(we),

.CLK(clk), // Clock input

.D(d[1]) // SRL data input

);

SRL16E #(

.INIT(16’h0000) // Initial Value of Shift Register

) SRL16_inst_3 (

.Q(qspo[2]), // SRL data output

.A0(a[0]), // Select[0] input

.A1(a[1]), // Select[1] input

.A2(a[2]), // Select[2] input

.A3(a[3]), // Select[3] input

.CE(we),

.CLK(clk), // Clock input

.D(d[2]) // SRL data input

);

SRL16E #(

.INIT(16‘h0000) // Initial Value of Shift Register

) SRL16_inst_4 (

.Q(qspo[3]), // SRL data output

.A0(a[0]), // Select[0] input

.A1(a[1]), // Select[1] input

.A2(a[2]), // Select[2] input

.A3(a[3]), // Select[3] input

.CE(we),

.CLK(clk), // Clock input

.D(d[3]) // SRL data input

);

SRL16E #(

.INIT(16’h0000) // Initial Value of Shift Register

) SRL16_inst_5 (

.Q(qspo[4]), // SRL data output

.A0(a[0]), // Select[0] input

.A1(a[1]), // Select[1] input

.A2(a[2]), // Select[2] input

.A3(a[3]), // Select[3] input

.CE(we),

.CLK(clk), // Clock input

.D(d[4]) // SRL data input

);

猜您喜欢

保险丝作为保护电路安全的重要元件,其性能参数受到关注。Kacon 凯昆作为知名的保险丝品牌,其产品因稳定的质量和优良的性能在市场上占据一席之地。本文将围绕“Ka...
2020-10-16 05:30:30

电子电路中,二极管是重要的元件,其主要功能是允许电流单向流动。在进行电路维修或搭建时,判断二极管的正负极非常重要。使用万用表可以轻松地测量二极管的正负极,确保电...
2025-03-31 00:00:01

压控温补振荡器(VCTXO)是高性能的频率控制器件,应用于通信、导航和精密测量等领域。其主要优势体现在以下几个方面:VCTXO具有很好的频率稳定性。通过温度补偿...
2012-11-14 00:00:00

随着工业自动化和电气设备的普及,电流阻断器作为保护电路安全的重要装置,其正确的接线方式受到关注。本文将围绕“电流阻断器接线图解视频”主题,详细介绍电流阻断器的接...
2025-11-04 22:01:40

您是否曾好奇,那些体积小巧的电子设备是如何稳定供电的呢?答案就在于一颗颗小小的心脏——开关电源芯片。而八脚开关电源芯片,更是以其麻雀虽小,五脏俱全的优势,在电子...
2024-07-21 00:00:00

管理箱是一款专为现代企业设计的高效管理工具,旨在提升团队协作和项目管理的效率。集成了任务分配、进度跟踪、文件共享等多种功能,帮助团队成员在一个平台上实现无缝沟通...
2011-01-04 00:00:00

螺丝批头接杆是应用于各类工具和设备中的附件,主要用于连接螺丝批头和电动螺丝刀。其应用领域涵盖了多个行业,以下是几个主要的应用领域。家居维修和装配是螺丝批头接杆的...
2016-07-13 00:00:00

现代电子设备和机械连接中,连接器的选择非常重要。CONN_18X2MM_TM是常见的连接器型号,因其独特的设计和优良的性能,应用于各种领域。本文将对CONN_1...
2025-04-23 08:01:41

光谱传感器的响应时间是指传感器从接收到光谱信号到产生稳定输出所需的时间。这个参数对于光谱传感器的性能和应用至关重要。以下是对光谱传感器响应时间的详细分析:一、...
2025-01-27 15:36:00

VISHAY(威世)作为全球领先的电子元件制造商,高品质的精密电阻闻名业界。精密电阻作为电路设计中不可少的元件,应用于测量仪器、医疗设备、汽车电子等多个领域。本...
2023-03-15 21:19:11