.. _file_formats_bitstream_setting: Bitstream Setting (.xml) ------------------------ An example of bitstream settings is shown as follows. This can define a hard-coded bitstream for a reconfigurable resource in FPGA fabrics. .. warning:: Bitstream setting is a feature for power-users. It may cause wrong bitstream to be generated. For example, the hard-coded bitstream is not compatible with LUTs whose nets may be swapped during routing stage (cause a change on the truth table as well as bitstream). It is users's responsibility to ensure correct bitstream. .. code-block:: xml pb_type-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^ The following syntax are applicable to the XML definition tagged by ``pb_type`` in bitstream setting files. .. option:: name="" The ``pb_type`` name to be constrained, which should be the full path of a ``pb_type`` consistent with VPR's architecture description. For example, .. code-block:: xml pb_type="clb.fle[arithmetic].soft_adder.adder_lut4" .. option:: source="" The source of the ``pb_type`` bitstream, which could be from a ``.eblif`` file. For example, .. code-block:: xml source="eblif" .. option:: content="" The content of the ``pb_type`` bitstream, which could be a keyword in a ``.eblif`` file. For example, ``content=".attr LUT"`` means that the bitstream will be extracted from the ``.attr LUT`` line which is defined under the ``.blif model`` (that is defined under the ``pb_type`` in VPR architecture file). .. option:: is_mode_select_bitstream="" Can be either ``true`` or ``false``. When set ``true``, the bitstream is considered as mode-selection bitstream, which may overwrite ``mode_bits`` definition in ``pb_type_annotation`` of OpenFPGA architecture description. (See details in :ref:`annotate_vpr_arch_pb_type_annotation`) .. option:: bitstream_offset="" Specify the offset to be applied when overloading the bitstream to a target. For example, a LUT may have a 16-bit bitstream. When ``offset=1``, bitstream overloading will skip the first bit and start from the second bit of the 16-bit bitstream. Default Mode Bits-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The following syntax are applicable to the XML definition tagged by ``default_mode_bits`` in bitstream setting files. .. option:: name="" The ``pb_type`` name to be constrained, which should be the full path of a ``pb_type`` consistent with VPR's architecture description. For example, .. note:: This must be a valid primitive pb_type (one has zero leaf nodes)! .. code-block:: xml pb_type="clb.fle[arithmetic].soft_adder.adder_lut4" .. option:: mode_bits="" The default mode bits when the ``pb_type`` is not mapped. Note that the size of mode bits must comply with the definition in the OpenFPGA architecture description (See details in :ref:`annotate_vpr_arch_pb_type_annotation`). For example, .. note:: Bitstream setting has a higher priority than the ``mode_bits`` definition in the OpenFPGA architecture description! .. code-block:: xml mode_bits="0100" Interconnection-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The following syntax are applicable to the XML definition tagged by ``interconnect`` in bitstream setting files. .. option:: name="" The ``interconnect`` name to be constrained, which should be the full path of a ``pb_type`` consistent with VPR's architecture description. For example, .. code-block:: xml pb_type="clb.fle[arithmetic].mux1" .. option:: default_path="" The default path denotes an input name that is consistent with VPR's architecture description. For example, in VPR architecture, there is a mux defined as .. code-block:: xml The default path can be either ``iopad.inpad`` or ``ff.Q`` which corresponds to the first input and the second input respectively. Clock Routing-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The following syntax are applicable to the XML definition tagged by ``clock_routing`` in bitstream setting files. This is to force the routing for clock tap multiplexers (green line in :numref:`fig_prog_clock_network_example_2x2`) even when they are not used/mapped. If no specified, only the used clock tap multiplexers will be configured to propagate clock signals. .. note:: This requires the benchmark has at least 1 global signal. Otherwise, the clock routing will be skipped, and there is no impact from this setting. .. option:: network="" The ``network`` name to be constrained, which should be a valid name defined in the clock network file (See details in :ref:`file_formats_clock_network`). For example, .. code-block:: xml The network and pin correspond to the clock network name and a valid pin of ``global_port`` in the clock network description. .. code-block:: xml .. option:: pin="" The pin should be a valid pin of the ``global_port`` that is defined in the clock network description under the selected clock network. non_fabric-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^^^^ This is special syntax to extract PB defined parameter or attribute and save the data into dedicated JSON file outside of fabric bitstream The following syntax are applicable to the XML definition tagged by ``non_fabric`` in bitstream setting files. .. option:: name="" The ``pb_type`` top level name that the data to be extracted. For example, .. code-block:: xml name="bram" .. option:: file="" The filepath the data is saved to. For example, .. code-block:: xml file="bram.json" .. option:: pb child element name="" Together with ``pb_type`` top level name, that is the source of the ``pb_type`` bitstream The final ``pb_type`` name is "" + "" For example, .. code-block:: xml The final ``pb_type`` name is "bram.bram_lr[mem_36K_tdp].mem_36K" .. option:: pb child element content="" The content of the ``pb_type`` data to be extracted. For example, ``content=".param INIT_i"`` means that the data will be extracted from the ``.param INIT_i`` line defined under the ``.blif model``. overwrite_bitstream-related Settings ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ This is to allow user to set value of a list of bits which is represented using full path in the hierarchy of FPGA fabric This ``overwrite_bitstream`` settings has the highest priority than loading any external bitstream file Each bit to overwrite is represented by one ``bit`` child node/tag The following syntax are applicable to the XML definition tagged by ``bit`` node under ``overwrite_bitstream`` setting. .. option:: value="<0 or 1>" The boolean ``0`` or ``1`` that will be set. For example, .. code-block:: xml value="0" .. option:: path="" ``path`` represents the location of this block in FPGA fabric, i.e., the full path in the hierarchy of FPGA fabric. .. code-block:: xml path="fpga_top.grid_clb_1__2_.logical_tile_clb_mode_clb__0.mem_fle_9_in_5[0]"