FPGA之复选器(2)

8:1 复选器

每个slice具有一个F7AMUX和一个F7BMUX

F7AMUX 和 F7BMUX 原语:

MUXF7 MUXF7_inst (

.O(O),//Output of MUX to general routing.

I0(10), // Input (tie to LUT6 O6 pin)

II(II), //Input (tie to LUT6 O6 pin)

SS)// Input select to MUX

这两个多路复选器组合了两个 LUT 的输出,以形成多达 13 个输入(或 8:1 多路复选器)的组合功能。一个slice 中最多可以实现两个 8:1 MUX,如下图所示。

以LUTA和LUTB组从的8:1复选器为例不经过D触发器的对应代码:

always@(*)

if(AX)begin

case (SELA1:0)

2"b00: A= DATA_A0;

2'b01: A=DATA_A1;

2'b10: A= DATA_A2;

2'b11: A=DATA_A3;

default:A=1'bx;

endcase

end

else begin

case (SELB1:0)

2'b00: B=DATA_B0;

2'b01: B=DATA_B1;

2'b10: B=DATA_B2;

2'b11: B=DATA_B3;

default:B=1'bx;

endcase

end

assign AMUX=AX? A:B;

以上是没有经过优化的代码,代码可以优化为:

always@(*)

case ({AX,SELB1:0})

3'b000: AMUX=DATA_A0;

3'b001: AMUX=DATA_A1;

3'b010: AMUX=DATA_A2;

3b011: AMUX=DATA_A3;

3b100: AMUX=DATA_B0;

3b101: AMUX=DATA_B1;

3b110: AMUX=DATA_B2;

3b111: AMUX=DATA_B3;

default: AMUX=1'bx;

endcase

以LUTA和LUTB组从的8:1复选器为例经过D触发器的对应代码:

always@(posedge CLK)

case ({AX,SELB1:0})

3b000: AMUX <=DATA_A0;

3b001: AMUX <= DATA_A1;

3'b010: AMUX <= DATA_A2;

3"b011: AMUX <=DATA_A3;

3"b100: AMUX <=DATA_B0;

3b101: AMUX<=DATA_B1;

3b110: AMUX <=DATA_B2;

3"b111: AMUX<=DATA_B3;

default: AMUX<=1'bx;

endcase

相关推荐
TTGGGFF11 分钟前
ModelSim SE 10.1c 超详细安装与激活保姆级教程(图文详解 2026 仅供学习)
学习·fpga开发
Aaron158810 小时前
无人机反制中AOA+TDOA联合定位技术与雷达探测定位技术的应用对比分析
arm开发·嵌入式硬件·fpga开发·硬件工程·无人机·信息与通信·信号处理
暴风雨中的白杨18 小时前
fpga复位电平与资源消耗对比测试
fpga开发
ALINX技术博客19 小时前
【黑金云课堂】FPGA技术教程Linux开发:NVMe/Qt/OpenCV人脸检测
linux·qt·fpga开发
第二层皮-合肥19 小时前
【数据采集专栏】触发模式的设计
fpga开发
第二层皮-合肥19 小时前
【数据采集专栏】通道触发设计要点
fpga开发
高速上的乌龟20 小时前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.4 Hololink I2C外设控制深度全解析
fpga开发
Kent Gu21 小时前
MCU & FPGA调试
单片机·嵌入式硬件·fpga开发
浩子智控1 天前
EtherCAT技术概述
嵌入式硬件·fpga开发·硬件工程·信号处理
我爱C编程1 天前
【仿真测试】基于FPGA的8ASK扩频通信链路实现,包含帧同步,定时点,扩频伪码同步,信道,误码统计
fpga开发·帧同步·定时点·扩频通信·8ask·扩频伪码