Communities Blogs Groups

Search...

SEARCH

**↑** (/S/) FORUMS (/S/TOPICCATALOG) MY ACTIVITY V GET SUPPORT (/S/CONTACTSUPPORT) ABOUT OUR COMMUNITY V ADVANCED SEARCH V

Knowledge Base

VIVADO

> IMPLEMENTATION (/S/TOPIC/0T02E000000YKXIWAO/... (/S/TOPIC/0T02E000000YKXVWA...



splogdes (/s/profile/005KZ000000duhKYAQ) (Imperial College London (London)) asked a question. 12h ago (/s/question/0D5KZ00000uFXGr0AO/vivado-incorrectly-merges-srlc16e-blocks-and-rewires-d-input-to-the-wrong-signal)

## Vivado incorrectly merges SRLC16E blocks and rewires D input to the wrong signal

Given the attached design, Vivado 2024.2 produces incorrect logic during implementation. The original RTL instantiates two separate SRLC16E blocks, each with its own D input:

```
1 SRLC16E #(.INIT(16'h6655)) _060_ (
2
    .AO(_017_), .A1(_017_), .A2(_013_), .A3(_013_),
3
    .CE(1'b1), .CLK(_019_), .D(_013_), .Q(_061_), .Q15(_062_)
4);
  SRLC16E #(.INIT(16'h07A0)) _065_ (
6
    .A0(_003_), .A1(_062_), .A2(_003_), .A3(_007_),
    .CE(1'b1), .CLK(_019_), .D(_029_), .Q(_066_), .Q15(_067_)
8);
```

In the post-implementation output (write\_verilog -mode funcsim), both SRLs are incorrectly merged into one SRLC32E block:

```
1 SRLC32E #(.INIT(32'h07A06655)) _060__065_ (
     .A({1'b1,_007_,_003_,NLW__060__065__A_UNCONNECTED[1],_003_}),
3
    .CE(1'b1), .CLK(_019_), .D(_013_), .Q(_066_), .Q31(_067_)
4);
```

Critically, the D pin now only connects \_013\_ (originally only for the first SRL), and \_029\_ (connected to input \_999\_) is dropped. This results in incorrect data being shifted into the SRL and wrong values on \_067\_ (Which is connected to an output).

This violates functional equivalence.

The bug is triggered with the following files:

Vivado version: 2024.2 Device: xc7a35ticsg324-11



**IMPLEMENTATION** (/S/TOPIC/0T02E000000YKXVWAO/)

7 answers 74 views



## Top Rated Answers



hemangd (/s/profile/0052E00000N2nMvQAJ) (AMD)

3 hours ago

Hi @splogdes (/s/profile/005KZ000000duhKYAQ) (Imperial College London (London)), I have filed a Change Request with the factory to look into this issue.

The optimization of SRL is happening during power\_opt\_design phase (before place\_design phase) which is causing this issue.

For workaround, you can skip this power\_opt\_design step which you are running after opt\_design phase.

Selected as Best Like Remove as Best

## All Answers



drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member)

Edited 6h ago

Sorry can't open folders on the phone

But .

Is this the entirety of the code?

Functional equivalence is not down at the lut / register level , so it's possible the function of the overall is equivalent even if this particular sel is not. .

Like Reply Select as Best



hemangd (/s/profile/0052E00000N2nMvQAJ) (AMD)

3 hours ago

Hi @splogdes (/s/profile/005KZ000000duhKYAQ) (Imperial College London (London)), I have filed a Change Request with the factory to look into this issue.

The optimization of SRL is happening during power\_opt\_design phase (before place\_design phase) which is causing this issue.

For workaround, you can skip this power\_opt\_design step which you are running after opt\_design phase.

Selected as Best Like Reply Remove as Best



drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member)

an hour ago

Can I double check please @hemangd (/s/profile/0052E00000N2nMvQAJ) (AMD)

This is described by @splogdes (/s/profile/005KZ000000duhKYAQ) (Imperial College London (London)) as a change in function, implied it's between code and post p and

I.e. the code generated by the tools that goes into the dogs does NOT perform the same at the functional level as the code that was put into the synthesiser.

Your reply seems to say it's "just" a power consumption effect,

The former, a functional difference is MAJOR worry, whilst a power consumption of one SRL is a very minor worry.

Can you clarify please

Like Reply Select as Best



hemangd (/s/profile/0052E00000N2nMvQAJ) (AMD)

an hour ago

Hi @drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member),

This concerned logic optimization has happened during power\_opt\_design phase which changed the netlist even before the placer started.

Like Reply Select as Best



drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member)

an hour ago

So your saying the power\_opt\_dsesign can change the function of a design junit just optimise it, but change what a design does?

Functional equivalent . you design a system that you put in say 2 and 3 and got answer 5, and after the tool run makes the fpga, you put in 2 and 3 and get out 5.

Your saying that power\_opt\_design has changed a design so it's not functionally equivalent, i.e after synthesis etc I could put in 2 and 3 and get out 6!

That's a major bug

This needs to be clarified please . .

Reply Select as Best



hemangd (/s/profile/0052E00000N2nMvQAJ) (AMD)

Hi @drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member) at least for this design, power\_opt\_design changed the netlist, which does not seem functionally equivalent. You can check the same at your end using bug, v present here

Though only power\_opt\_design at post opt stage causes the issue here.

There is post place power\_opt\_design phase as well which is not causing any issue.

So i can only provide further info on what went wrong at post-opt power\_opt\_design stage, post factory debug.

Like Reply Select as Best 1 like



drjohnsmith (/s/profile/0052E00000N2no4QAB) (Member)

44 minutes ago

So your saying that the tools are changing the code written such that the generated fpga might not behave as your code says .

I.e. as per my example above , it's going to be possible because of the big that the output is wrong .

This is a very major bug.

I'll give you an hour to check, but if this is such a big the major companies I consult for are going to have to stop using xilinx parts!

Like Reply Select as Best



Write an answer...

## **Topics**

- IP AND TRANSCRIVERS
  - ETHERNET (https://support.xilinx.com/s/topic/0T02E000000YKXrWAO/ethernet)
  - $\textbf{\cdot} \, \underline{\text{VIDEO (https://support.xilinx.com/s/topic/0T02E000000YKY8WA0/video)}}\\$
  - \* DSP IP & VITIS MODEL COMPOSER (https://support.xilinx.com/s/topic/0T02E000000YKXoWA0/dsp-ip-tools)
  - PCIE (https://support.xilinx.com/s/topic/0T02E000000YKXYWA4/pcie)
  - MEMORY INTERFACES AND NOC (https://support.xilinx.com/s/topic/0T02E000000YKXyWA0/memory-interfaces-and-noc)
  - $\bullet \underline{\mathsf{SERIAL\ TRANSCEIVER\ (https://support.xillinx.com/s/topic/0TO2E000000YKY3WAO/serial-transceiver)}$
  - RF & DFE (https://support.xilinx.com/s/topic/0T02E000000YKY2WAO/rf-dfe)
  - $\bullet \underline{\text{OTHER INTERFACE \& WIRELESS IP (https://support.xilinx.com/s/topic/0T02E000000YKXzWAO/other-interface-wireless-ip)} \\$
- PROGRAMMABLE LOGIC, I/O & BOOT/CONFIGURATION
  - $\bullet \underline{ POWER \& POWER TOOLS (https://support.xilinx.com/s/topic/0T02E000000YKY0WAO/power-power-tools) } \\$
  - PROGRAMMABLE LOGIC, I/O AND PACKAGING (https://support.xilinx.com/s/topic/0T02E000000YKY1WAO/programmable-logic-io-and-packaging)
  - BOOT AND CONFIGURATION (https://support.xilinx.com/s/topic/0TO2E000000YKXWWA4/boot-and-configuration)
- VIVADO
  - · INSTALLATION AND LICENSING (https://support.xilinx.com/s/topic/0TO2E000000YKXwWAO/installation-and-licensing)
  - DESIGN ENTRY & VIVADO-IP FLOWS (https://support.xilinx.com/s/topic/0T02E000000YKXpWAO/design-entry-vivadoip-flows)
  - SIMULATION & VERIFICATION (https://support.xilinx.com/s/topic/0TO2E000000YKY4WAO/simulation-verification)
  - SYNTHESIS (https://support.xilinx.com/s/topic/0T02E000000YKY5WA0/synthesis)
  - IMPLEMENTATION (https://support.xilinx.com/s/topic/0T02E000000YKXvWAO/implementation)
  - TIMING AND CONSTRAINTS (https://support.xilinx.com/s/topic/0T02E000000YKY7WAO/timing-and-constraints)
  - VIVADO DEBUG TOOLS (https://support.xilinx.com/s/topic/0T02E000000YKYCWA4/vivado-debug-tools)
  - ADVANCED FLOWS (HIERARCHICAL DESIGN ETC.) (https://support.xilinx.com/s/topic/0T02E000000YKXkWAO/advanced-flows-hierarchical-design-etc)
- VITIS
  - \* VITIS EMBEDDED DEVELOPMENT & SDK (https://support.xilinx.com/s/topic/0T02E000000YKYBWA4/vitis-embedded-development-sdk)
  - · AI ENGINE ARCHITECTURE & TOOLS (https://support.xilinx.com/s/topic/0T02E000000YKXjWAO/ai-engine-architecture-tools)
  - VITIS AI & AI (https://support.xilinx.com/s/topic/0T02E000000YKY9WAO/vitis-ai-ai)
  - \* VITIS ACCELERATION & ACCELERATION (https://support.xillinx.com/s/topic/0T02E000000YKYAWA4/vitis-acceleration-acceleration)
  - HLS (https://support.xilinx.com/s/topic/0T02E000000YKXtWAO/hls)
- PRODUCTION CARDS AND EVALUATION BOARDS
  - ALVEO™ ACCELERATOR CARDS (https://support.xilinx.com/s/topic/0T02E000000YKXIWAO/alveo-accelerator-cards)
  - EVALUATION BOARDS (https://support.xilinx.com/s/topic/0T02E000000YKYEWA4/xilinx-evaluation-boards)
  - KRIA SOMS (https://support.xilinx.com/s/topic/0T02E000000YKXxWAO/kria-soms)
- · EMBEDDED SYSTEMS
  - EMBEDDED LINUX (https://support.xilinx.com/s/topic/0T02E000000YKXXWA4/embedded-linux)
  - PROCESSOR SYSTEM DESIGN AND AXL (https://support.xilinx.com/s/topic/0T02E000000YKXZWA4/processor-system-design-and-axi)
- · ISE & EDK TOOLS
  - $\bullet \underline{\mathsf{ISE} \& \mathsf{EDK} \, \mathsf{TOOL} \, \big( \mathsf{https://support.xillinx.com/s/topic/0TO2E000000YKXuWAO/ise-edk-tool} \big)} \\$
- · ABOUT OUR COMMUNITY
  - $\hbox{-} \underline{ANNOUNCEMENTS.(https://support.xillinx.com/s/topic/0TO2E000000YKXmWAO/announcements)}\\$
  - WELCOME AND JOIN (https://support.xilinx.com/s/topic/0T02E000000YKYDWA4/welcome-and-join)
  - $\bullet \underline{\text{GENERAL DISCUSSION (https://support.xilinx.com/s/topic/0T02E000000YKXsWAO/general-discussion)} \\$
  - DEVELOPER PROGRAM FORUM (https://support.xilinx.com/s/topic/0T02E000000YKXqWA0/developer-program-forum)
  - CUSTOMER TRAINING FORUM (https://support.xilinx.com/s/topic/0T02E000000YKXnWAO/customer-training-forum)
- · 赛灵思中文社区论坛
  - ・<u>自适应 SoC , FPGA架构和板卡 (https://support.xillinx.com/s/topic/0TO2E000000YOAaWAO/acapfpga%E6%9E%B6%E6%9E%84%E5%92%8C%E6%9D%BF%E5%8D%A1)</u>
  - IP应用 (https://support.xilinx.com/s/topic/0T02E000000YOAWWA4/ip%E5%BA%94%E7%94%A8)
  - ・开发工具 (https://support.xilinx.com/s/topic/0T02E000000Y0AfWAO/%E5%BC%80%E5%8F%91%E5%B7%A5%E5%85%B7)
  - ・<u>嵌入式开发 (https://support.xilinx.com/s/topic/0TO2E000000YOAXWA4/%E5%B5%BC%E5%B5%A5%E5%BC%8F%E5%BC%80%E5%BF%91)</u>
  - VITIS AI, 机器学习和 VITIS ACCELERATION (https://support.xilinx.com/s/topic/0T02E000000YOAkWAO/vitis-ai-%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0%E5%92%8 vitis-acceleration)
  - 综合讨论和文档翻译

ASK A QUESTION

GET SUPPORT

Don't see what you're looking for?

(https://www.amd.com/en) Adaptive SoC & FPGA Support \_(http://www.facebook.com/amd)
\_(https://www.instagram.com/amd)

(https://www.linkedin.com/company/amd)

\_(https://www.twitch.tv/amd) \_\_(https://twitter.com/amd)

\_(https://www.youtube.com/user/amd?sub\_confirmation=1)

(https://www.amd.com/en/preferences.html)

Terms and Conditions | Privacy | Trademarks | Supply Chain Transparency | Fair and Open Competition | UK Tax Strategy | Cookie Policy | Cookie Settings/Do Not Sell or Share My Personal Information

© 2025 Advanced Micro Devices, Inc