.. _IP:sync_Pulse: PoC.misc.sync.Pulse ################### .. only:: html .. |gh-src| image:: /_static/logos/GitHub-Mark-32px.png :scale: 40 :target: https://github.com/VLSI-EDA/PoC/blob/master/src/misc/sync/sync_Pulse.vhdl :alt: Source Code on GitHub .. |gh-tb| image:: /_static/logos/GitHub-Mark-32px.png :scale: 40 :target: https://github.com/VLSI-EDA/PoC/blob/master/tb/misc/sync/sync_Pulse_tb.vhdl :alt: Source Code on GitHub .. sidebar:: GitHub Links * |gh-src| :pocsrc:`Sourcecode ` * |gh-tb| :poctb:`Testbench ` This module synchronizes multiple pulsed bits into the clock-domain ``Clock``. The clock-domain boundary crossing is done by two synchronizer D-FFs. All bits are independent from each other. If a known vendor like Altera or Xilinx are recognized, a vendor specific implementation is chosen. .. ATTENTION:: Use this synchronizer for very short signals (pulse). Constraints: General: Please add constraints for meta stability to all '_meta' signals and timing ignore constraints to all '_async' signals. Xilinx: In case of a Xilinx device, this module will instantiate the optimized module PoC.xil.sync.Pulse. Please attend to the notes of sync_Bits.vhdl. Altera sdc file: TODO .. rubric:: Entity Declaration: .. literalinclude:: ../../../../src/misc/sync/sync_Pulse.vhdl :language: vhdl :tab-width: 2 :linenos: :lines: 68-78 .. seealso:: :doc:`PoC.misc.sync.Bits ` For a common 2 D-FF synchronizer for *flag*-signals. :doc:`PoC.misc.sync.Reset ` For a special 2 D-FF synchronizer for *reset*-signals. :doc:`PoC.misc.sync.Strobe ` For a synchronizer for *strobe*-signals. :doc:`PoC.misc.sync.Vector ` For a multiple bits capable synchronizer. .. only:: latex Source file: :pocsrc:`misc/sync/sync_Pulse.vhdl `