Design, Implementation and Verification of 32-Bit ALU With VIO
Design, Implementation and Verification of 32-Bit ALU With VIO
net/publication/326073359
CITATION READS
1 1,283
2 authors:
Some of the authors of this publication are also working on these related projects:
SoC Designs using Zed Boards with ARTIX7 FPGA View project
All content following this page was uploaded by Dharmavaram Asha Devi on 08 November 2018.
Abstract—Any Digital design can be represented as RTL form functionality developed by Xilinx. There are two fundamental
by using either VHDL or Verilog_HDL. Such designs can be intellectual property (IP) cores present in ChipScope which
simulated, synthesized, implemented and finally can be verified give real-time observability and controllability. For
by using popular front end tool Xilinx and FPGA development observability ChipScope has a logic analyzer soft core called
boards. In such cases, if the design specification is large enough
to face the difficulty to verify the functionality on the target
the integrated logic analyzer (ILA). For controllability
board, then we can use the virtual I/O concept. The Virtual ChipScope has the soft core called the virtual input output
Input/Output (VIO) debug feature can both monitor and drive core (VIO)[1],[2]. Thus with the latest feature available in the
internal FPGA signals in real time. This feature is used when Xilinx Tool, the proposed 32-bit ALU is examined and drive
there is no possibility to access on physical input and output internal FPGA nodes deep in the design, all done real-time and
devices on the target hardware, we can use this debug feature to in-circuit.
drive and monitor signals that are present on the real hardware.
In the proposed work a 32-bit ALU is designed simulated and II. VIO DESIGN CONCEPT
verified through VIO. This work is designed with Verilog HDL,
and implemented with Xilinx Vivado System Design Suite 2017.1
and Nexys DDR4 FPGA development board is used.
I. INTRODUCTION
ii. Provides optional activity detectors on input ports in order Table.1: Functional description of 32-Bit ALU
to detect rising and falling transitions between samples.
iii. Provides virtual buttons and other controls through output S.No. S: Selection of the operation For S=
ports. 1. Addition 0
iv. It provides the custom output initialization which allows us 2. Subtraction 1
to specify the value of the VIO core outputs immediately 3. Multiplication 2
following device configuration and start-up. 4. Modulus 3
v. Run time reset of the VIO core to its initial values. 5. Division 4
6. Increment 5
Two types of signals are available in the VIO core: 7. Decrement 6
i. Input probes 8. Logical AND 7
ii. Output probes 9. Logical OR 8
Input Probes: These inputs to the VIO core registered using 10. Logical XOR 9
the design clock that is attached to the CLK input port. The 11. Logical NAND 10
input values are read back one by one and displayed in the 12. Logical NOR 11
Vivado_ logic analyzer feature. 13. Logical XNOR 12
Output Probes: These are the outputs from the VIO core and 14. Logical Right Shift 13
are driven to the user design. The output probes of VIO can be 15. Logical Left Shift 14
initialized to any desired value during the generation time. 16. Logical Negation 15
Activity Detectors: Each VIO core input has additional cells 17. Default Don’t Care
to capture the presence of transitions on the input. Because the
design clock is most likely much faster than the sample period Step2: Verification of the Design using Simulation Process
of the Analyzer, it is possible for the signal being monitored to
transition many times between successive samples. The To do the simulation, testbench module [3] is created for the
activity detectors capture the behavior and the results are 32-Bit ALU design module. Then RUN the testbench module
displayed along with the value in the VLA. to observe the functional behavior of the ALU design.
The functional Description of the 32-Bit ALU is described in Step4: Create one top level Design which includes both VIO
the Table.1. and DUT as shown in Fig.4.
For Top-Module only ‘clk’ is the input scalar pin which is E3 Fig.7 Synthesized Schematic
for ARTIX-7 FPGA used in target Nexys DDR4 board.
by a logic synthesis tool[4],[5],[6]. The results of the synthesis
Step6: Synthesize the Design are then used by placement and routing tools to create a