RISC-V out-of-order data conversion co-processor
暂无分享,去创建一个
Data conversion operations are important and essential part of floating point units in a processor and typical instructions include conversion between various precisions, integer to floating point and vice versa, floating point to fixed point and vice versa etc. Besides few processors have instructions to round and truncate data, sign injections, move data between co-processors registers and general purpose registers and vice versa etc. Conversion operations are part of ARM, MIPS, and RISC-V etc. instruction sets. The conversion functionalities can be part of hardware or may be implemented in software. This paper details an architectural exploration for data conversion coprocessor for RISC-V [1] data conversion instructions. The Floating point conversion unit that has been designed with RISC-V data conversion instructions is fully compatible with IEEE 754-2008 standard as well. The floating point conversion co-processor is capable of handling both single and double precision floating point data operands in out-of-order for execution and in-order commit. The front end of the data conversion processor accepts three data operands, rounding mode and associated Op-code fields for decoding. Each conversion operation is tagged with an instruction token for in-order completion and commit. The output of the floating point unit is tagged with either single or double precision results along with floating point exceptions if any, based on the RISC-V instruction set. The co-processor for data conversion integrates with integer pipeline. The proposed architecture for data conversion co-processor with out-of-order execution, in-order commit and completion / retire has been synthesized, tested and verified on Xilinx Virtex 6 xc6vlx550t-2ff1759 FPGA. A performance throughput of 350MFLOPs (data conversion operations) per second have been observed.
[1] Yunsup Lee,et al. The RISC-V Instruction Set Manual , 2014 .