TY - JOUR
T1 - Virtualized Execution and Management of Hardware Tasks on a Hybrid ARM-FPGA Platform
AU - Jain, Abhishek Kumar
AU - Pham, Khoa Dang
AU - Cui, Jin
AU - Fahmy, Suhaib A.
AU - Maskell, Douglas L.
N1 - Generated from Scopus record by KAUST IRTS on 2021-03-16
PY - 2014/10/1
Y1 - 2014/10/1
N2 - Emerging hybrid reconfigurable platforms tightly couple capable processors with high performance reconfigurable fabrics. This promises to move the focus of reconfigurable computing systems from static accelerators to a more software oriented view, where reconfiguration is a key enabler for exploiting the available resources. This requires a revised look at how to manage the execution of such hardware tasks within a processor-based system, and in doing so, how to virtualize the resources to ensure isolation and predictability. This view is further supported by trends towards amalgamation of computation in the automotive and avionics domains, where such properties are essential to overall system reliability. We present the virtualized execution and management of software and hardware tasks using a microkernel-based hypervisor running on a commercial hybrid computing platform (the Xilinx Zynq). The CODEZERO hypervisor has been modified to leverage the capabilities of the FPGA fabric, with support for discrete hardware accelerators, dynamically reconfigurable regions, and regions of virtual fabric. We characterise the communication overheads in such a hybrid system to motivate the importance of lean management, before quantifying the context switch overhead of the hypervisor approach. We then compare the resulting idle time for a standard Linux implementation and the proposed hypervisor method, showing two orders of magnitude improved performance with the hypervisor.
AB - Emerging hybrid reconfigurable platforms tightly couple capable processors with high performance reconfigurable fabrics. This promises to move the focus of reconfigurable computing systems from static accelerators to a more software oriented view, where reconfiguration is a key enabler for exploiting the available resources. This requires a revised look at how to manage the execution of such hardware tasks within a processor-based system, and in doing so, how to virtualize the resources to ensure isolation and predictability. This view is further supported by trends towards amalgamation of computation in the automotive and avionics domains, where such properties are essential to overall system reliability. We present the virtualized execution and management of software and hardware tasks using a microkernel-based hypervisor running on a commercial hybrid computing platform (the Xilinx Zynq). The CODEZERO hypervisor has been modified to leverage the capabilities of the FPGA fabric, with support for discrete hardware accelerators, dynamically reconfigurable regions, and regions of virtual fabric. We characterise the communication overheads in such a hybrid system to motivate the importance of lean management, before quantifying the context switch overhead of the hypervisor approach. We then compare the resulting idle time for a standard Linux implementation and the proposed hypervisor method, showing two orders of magnitude improved performance with the hypervisor.
UR - http://link.springer.com/10.1007/s11265-014-0884-1
UR - http://www.scopus.com/inward/record.url?scp=84920260637&partnerID=8YFLogxK
U2 - 10.1007/s11265-014-0884-1
DO - 10.1007/s11265-014-0884-1
M3 - Article
SN - 1939-8115
VL - 77
SP - 61
EP - 76
JO - Journal of Signal Processing Systems
JF - Journal of Signal Processing Systems
IS - 1-2
ER -