cloudFPGA (cF) API  1.0
The documentation of the source code of cloudFPGA (cF)
Modules
Here is a list of all modules:
[detail level 1234567]
 cFThis is the main cloudFPGA module
 cFSphereThe cloudFPGA Sphere or cFSphere is what constitutes the core of a cloudFPGA system. It is composed of several major software components, each of them being provided as a standalone cF repository
 cFDKThis is the cloudFPGA Development Kit (cFDK). The documentation of cFDK is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html
 SHELL LibraryThis is the SHELL library of cloudFPGA platform with its three basic components, i.e. NTS, FMC, NAL. The documentation of the SHELL library is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#shell-library
 FMCFPGA Management Core (FMC). The FMC is the core of the cloudFPGA Shell-Role-Architecture. The FMC controls the FPGA and exposes the management functionality via a RESTful HTTP API. Its tasks and responsibilities are sometimes complex and depend on the current situation and environment. In order to unbundle all these dependencies and to allow future extensions easily, the FMC contains a small Instruction-Set-Architecture (ISA). A detailed documentation of the FMC can be found at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#fpga-management-core-fmc
 MEMMemory Sub-System (MEM). This component implements the dynamic memory controllers for the FPGA module FMKU2595 equipped with a XCKU060. This memory sub-system implements two DDR4 memory channels (MC0 and MC1 ), each with a capacity of 8GB. By convention, the memory channel #0 (MC0) is dedicated to the network transport and session (NTS) stack, and the memory channel #1 (MC1) is reserved for the user application. The documentation of MEM is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#memory-sub-system-mem
 NALNetwork Abstraction Layer (NAL). The NAL separates the privileged management traffic from the unprivileged Role traffic. It also abstracts the details of port opening, connection handling and IP Address translation. The documentation of NAL is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#network-abstraction-layer-nal
 NTSNetwork Transport Stack (NTS). This component implements the TCP/IP Network and Transport Stack used by the cloudFPGA platform. The documentation of NTS is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#network-transport-stack-nts
 ARPAddress Resolution Protocol (ARS) server of the Network Transport Stack (NTS)
 ARP_TESTTestbench for the Address Resolution Protocol (ARS) server of the Network Transport Stack (NTS)
 ICMPInternet Control Message Protocol server (ICMP) of the Network Transport Stack (NTS)
 ICMP_TESTTestbench for the Internet Control Message Protocol server (ICMP) of the Network Transport Stack (NTS)
 IPRXIP Receiver packet handler (IPRX) of the Network Transport Stack (NTS)
 IPRX_TESTTestbench for the IP Receiver packet handler (IPRX) of the Network Transport Stack (NTS)
 IPTXIP Transmitter packet handler (IPTX) of the Network Transport Stack (NTS)
 IPTX_TESTTestbench for the IP Transmitter packet handler (IPTX) of the Network Transport Stack (NTS)
 RLBReady Logic Barrier (RLB) for the Network Transport Stack (NTS)
 RLB_TESTTestbench for the Ready Logic Barrier (RLB) for the Network Transport Stack (NTS)
 TOETCP Offload Engine (TOE) of the Network Transport Stack (NTS)
 TOE_TESTTestbench for the TCP Offload Engine (TOE) of the Network Transport Stack (NTS)
 TOECAMContent-Addressable Memory (CAM) for the TCP Offload Engine (TOE) of the Network Transport Stack (NTS)
 TOECAM_TESTTestbench for the Content-Addressable Memory (CAM) for the TCP Offload Engine (TOE) of the Network Transport Stack (NTS)
 UOEUDP Offload Engine (UOE) of the Network Transport Stack (NTS)
 UOE_TESTTestbench for the UDP Offload Engine (UOE) of the Network Transport Stack (NTS)
 SimNtsSupport and utilities for the simulation of the Network Transport Stack (NTS)
 SRAShell-Role-Architecture (SRA). To abstract the details of the hardware from the user and to assert certain levels of security, cloudFPGA uses a Shell-Role-Architecture (SRA). The documentation of SRA is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#sras
 ThemistoThis SRA type enables node2node communication within cloudFPGA. The network data streams have now a parallel meta stream to select the destinations or to see the source, respectively. The dual memory port is stream based. The documentation of Themisto is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#the-themisto-sra
 KaleThis version of the cF shell is used for the testing and the bring-up of a cloudFPGA (cF) module. The documentation of Kale is available at https://pages.github.ibm.com/cloudFPGA/Doc/pages/cfdk.html#the-shell-kale
 cFSPCFSP is the cloudFPGA Support Package and it includes a support library for accessing the data and control paths of a cloudFPGA instance
 cFpCloudFPGA Projects (cFp). This is a group with existing projects developed with cFDK and can be used as templates for new projects
 cFp_ZooThis project is based on Themisto Shell and it features several domain-specific accelerators
 cF Vitis VisionThis is the accelerated functions of Vitis Vision sub-library from Vitis Open Source Library
 HarrisThis is the Harris accelerated function from Vitis Vision Open Source Library
 Harris TestbenchThis is a subgroup of Harris accelerated function with only testbench-related functions/classes/
 Harris Vivado HLSThis is a subgroup of Harris accelerated function with only synthesizable (Vivado HLS) functions/classes
 Harris HostThis is a subgroup of Harris accelerated function with only host code software
 GammacorrectionThis is the Gammacorrection accelerated function from Vitis Vision Open Source Library
 Gammacorrection TestbenchThis is a subgroup of Gammacorrection accelerated function with only testbench-related functions/classes/
 Gammacorrection Vivado HLSThis is a subgroup of Gammacorrection accelerated function with only synthesizable (Vivado HLS) functions/classes
 Gammacorrection HostThis is a subgroup of Gammacorrection accelerated function with only host code software
 MedianBlurThis is the MedianBlur accelerated function from Vitis Vision Open Source Library
 MedianBlur TestbenchThis is a subgroup of MedianBlur accelerated function with only testbench-related functions/classes
 MedianBlur HLSThis is a subgroup of MedianBlur accelerated function with only synthesizable (HLS) functions/classes
 MedianBlur HostThis is a subgroup of MedianBlur accelerated function with only host code software
 SobelThis is the Sobel accelerated function from Vitis Vision Open Source Library
 Sobel TestbenchThis is a subgroup of Sobel accelerated function with only testbench-related functions/classes
 Sobel HLSThis is a subgroup of Sobel accelerated function with only synthesizable (HLS) functions/classes
 Sobel HostThis is a subgroup of Sobel accelerated function with only host code software
 WarpTransformThis is the WarpTransform accelerated function from Vitis Vision Open Source Library
 WarpTransform TestbenchThis is a subgroup of WarpTransform accelerated function with only testbench-related functions/classes
 WarpTransform HLSThis is a subgroup of WarpTransform accelerated function with only synthesizable (HLS) functions/classes
 WarpTransform HostThis is a subgroup of WarpTransform accelerated function with only host code software
 cF Vitis Quantitative FinanceThis is the accelerated functions of Vitis Quantitative Finance sub-library from Vitis Open Source Library
 MCEuropeanEngineThis is the MCEuropeanEngine accelerated function from Vitis Quantitative Finance Open Source Library
 MCEuropeanEngine TestbenchThis is a subgroup of MCEuropeanEngine accelerated function with only testbench-related functions/classes/
 MCEuropeanEngine Vivado HLSThis is a subgroup of MCEuropeanEngine accelerated function with only synthesizable (Vivado HLS) functions/classes
 MCEuropeanEngine HostThis is a subgroup of MCEuropeanEngine accelerated function with only host code software
 cF IBMZRL essentialsThis is a set of projects developed by IBM Research Zurich Lab. The group contains educational projects and platform-stressing ones
 UppercaseThis is the Uppercase educational example. The FPGA accepts a string and returns the upper-case converted one
 Uppercase TestbenchThis is a subgroup of Uppercase accelerated function with only testbench-related functions/classes
 Uppercase HLSThis is a subgroup of Uppercase accelerated function with only synthesizable (HLS) functions/classes
 Uppercase HostThis is a subgroup of Uppercase accelerated function with only host code software
 MemtestThis is the Memtest platform stressing project. The FPGA tests its DRAM memory
 Memtest TestbenchThis is a subgroup of Memtest accelerated function with only testbench-related functions/classes
 Memtest HLSThis is a subgroup of Memtest accelerated function with only synthesizable (HLS) functions/classes
 Memtest HostThis is a subgroup of Memtest accelerated function with only host code software
 cFp_HelloThemistoThis is the root of the current 'cFp_HelloThemisto' project
 cFp_HelloKaleThis is the root of the current 'cFp_HelloKale' project
 tcp_app_flashThis module implements a set of TCP-oriented tests and functions
 tcp_shell_ifThis module handles the control flow interface between the SHELL and the ROLE
 udp_app_flashThis module implements a set of UDP-oriented tests and functions
 udp_shell_ifThis module handles the control flow interface between the SHELL and the ROLE