

Dr.-Ing. Oliver Knodel  
Faculty of Computer Science

# Reconfigurable Hardware Components in the Context of Cloud-Architectures

Los Angeles // 26. July 2018

# Introduction and motivation

## The Coming Data Avalanche — And How we'll Handle it [Rog16]

### Potentials and problems of cloud computing

- By 2020, cloud providers will sell more computing power than in-house data center manufacturers — Gartner 2018 [Man18].
- Growth rates of cloud computing of up to 30% worldwide in 2016 lead to a steady concentration of computing resources — IDC [IDC16].
- The energy needs of US data centers grew by approximately 24% between 2010 and 2014 — DoE [DoE16].

### An approach to reduce the data centres energy consumption

- Amazon [Ama17a], IBM [IBM15a] and Microsoft [Put+14] - the world's leading data center operators - deploy Field Programmable Gate Arrays (FPGAs) at the application level in various cloud services.
- Reconfigurable hardware for the acceleration of applications is a key technology for many companies — Forbes [Rog16].



[Rog16] Bruce Rogers. „The Coming Data Avalanche – And how we'll handle it“. In: *Forbes Insights*. 2016.

# Introduction and motivation

Why we should deploy FPGAs in the Cloud?

## Advantages of using FPGAs

- Reduce the **energy consumption** of a data center and thereby reduce operating costs by outsourcing calculations to energy efficient hardware.
- **Accelerate** compute-intensive services with dedicated low-latency, high-bandwidth hardware.
- Increased **security** (encryption, authentication, ...) through processing or anonymization on easier-to-protect special hardware.

## Special features and challenges

- Integration of special hardware into a resource management requires corresponding new **administrative structures** and an analysis of the different application possibilities.
- Abstraction of real hardware through **virtualization** to increase flexibility and increase utilization.



Amazon Web Services, Inc. [Ama18]

# Structure

Introduction and motivation

Literature review and classification

Requirements analysis and stakeholder

**System architecture of the cloud — RC3E**

- Requirements
- System architecture

**Virtualization of the FPGAs — RC2F**

- Infrastructure and virtualization
- Design process and integration into a host-system

**Results of the prototypical implementation**

- Required FPGA-ressources
- Behaviour simulation of the resource management system

**Final considerations**



# Literature review and classification

# Literature review and classification

## (a) FPGAs in the context of cloud-computing

| 1998 | ... | 2006 | 2007 | 2008 | 2009             | 2010                   | 2011            | 2012                   | 2013                   | 2014                    | 2015                 | 2016                 | 2017             |  |
|------|-----|------|------|------|------------------|------------------------|-----------------|------------------------|------------------------|-------------------------|----------------------|----------------------|------------------|--|
|      |     |      |      |      |                  |                        |                 |                        |                        |                         |                      | Pogliani<br>[Pog+16] | Geng<br>[GWS+17] |  |
|      |     |      |      |      |                  |                        |                 |                        |                        |                         |                      | Proano<br>[PCC16]    | Varela<br>[VW17] |  |
|      |     |      |      |      |                  |                        |                 |                        |                        | Weerasinghe<br>[Wee+15] | Kachris<br>[Kac+16b] | Hong<br>[HKK+17]     |                  |  |
|      |     |      |      |      |                  |                        |                 |                        | Grigoras<br>[Gri+14]   | Fahmy<br>[FVS15]        | Asiatici<br>[Asi+16] | He<br>[HWL17]        |                  |  |
|      |     |      |      |      |                  |                        |                 |                        | Byma<br>[Bym+14]       | Gazzano<br>[Don+15]     | Chow<br>[Cho16]      | Tarafdar<br>[TEL+17] |                  |  |
|      |     |      |      |      |                  |                        |                 |                        | Chen<br>[Che+14]       | IBM<br>[IBM15]          | Knodel<br>[KLS16]    | Orellana<br>[Ore17]  |                  |  |
|      |     |      |      |      |                  | Madhavapeddy<br>[MS11] | Yin<br>[Y+12]   | Knodel<br>[KS13]       | Knodel<br>[Kno14]      | Ghasemi<br>[Gha15]      | Orellana<br>[OCC16]  | Zha<br>[ZL17]        |                  |  |
|      |     |      |      |      | Shan<br>[Sha+10] | Mondol<br>[Mon11]      | Eguro<br>[EV12] | Kochberger<br>[Koc+13] | Putnam<br>[Put+14]     | Ovtcharov<br>[Ovt+15]   | Kachris<br>[Kac+16a] | Jadhav<br>[JGA+17]   |                  |  |
|      |     |      |      |      |                  |                        | Lim<br>[Lim+13] | Xu<br>[XSS14]          | Pöppelmann<br>[Pöp+15] | Gao<br>[GS16]           | Proano<br>[PCC17]    |                      |                  |  |

# Literature review and classification

## (b) virtualization of FPGAs

| 1998                         | ... | 2006                    | 2007 | 2008                      | 2009 | 2010 | 2011                      | 2012                            | 2013                     | 2014                     | 2015                           | 2016                        | 2017                        |
|------------------------------|-----|-------------------------|------|---------------------------|------|------|---------------------------|---------------------------------|--------------------------|--------------------------|--------------------------------|-----------------------------|-----------------------------|
|                              |     |                         |      |                           |      |      |                           |                                 |                          | <b>Byma</b><br>[Bym+14]  | <b>Weerasinghe</b><br>[Wee+15] | <b>Kidane</b><br>[KB16]     | <b>Sindhu</b><br>[SAF17]    |
|                              |     |                         |      |                           |      |      |                           |                                 |                          | <b>Chen</b><br>[Che+14]  | <b>Gazzano</b><br>[Don+15]     | <b>Chow</b><br>[Cho16]      | <b>Tarafdar</b><br>[TEL+17] |
|                              |     |                         |      |                           |      |      |                           | <b>Zuma</b><br>[BL12]           | <b>Koch</b><br>[KBL13]   | <b>Nguyen</b><br>[NK14]  | <b>Fahmy</b><br>[FVS15]        | <b>Asiatici</b><br>[Asi+16] | <b>Zhao</b><br>[TZ17]       |
|                              |     |                         |      | <b>So</b><br>[SB08]       |      |      | <b>Yu</b><br>[Yu+11]      | <b>Gonzalez</b><br>[Gon+12]     | <b>Cheng</b><br>[Che+13] | <b>Agne</b><br>[Agn+14]  | <b>Knodel</b><br>[KS15]        | <b>Knodel</b><br>[KLS16]    | <b>Chen</b><br>[CMN17]      |
| <b>Fornaciari</b><br>[FP98a] |     | <b>Peck</b><br>[Pec+06] |      | <b>EI-Araby</b><br>[EG08] |      |      | <b>Figuli</b><br>[Fig+11] | <b>Kirchgessner</b><br>[Kir+12] | <b>Wang</b><br>[WBP13]   | <b>Eckert</b><br>[Eck14] | <b>Happe</b><br>[HTK15]        | <b>Knodel</b><br>[KGS16]    | <b>Knodel</b><br>[KGS17]    |

# Literature review and classification



**CLOUD**

## Alibaba gets Xilinx FPGA for its F3 cloud

BY PARAS NEHRAMIC ON 11 MAY 2018

Twitter | Like | Share | Print | Email

One person likes this. Sign Up to see what your friends like.

<https://fudzilla.com/news/memory-and-storage/46283-alibaba-gets-xilinx-fpga-for-its-f3-cloud>

**WIRED**

CADE METZ BUSINESS 09.26.16 07:00 PM

# MICROSOFT BETS ITS FUTURE ON A REPROGRAMMABLE COMPUTER CHIP

<https://www.wired.com/2016/09/microsoft-bets-future-chip-reprogram-fly/>

## Facebook has a new job posting calling for chip designers

Matthew Lynley @matthewlynley Apr 19, 2018

<https://techcrunch.com/2018/04/18/facebook-has-a-new-job-posting-calling-for-chip-designers/>

## Microsoft takes step towards delivering FPGAs as a service

2018  
Launches preview of FPGA-powered Project Brainwave

<https://www.computerworld.com.au/article/640970/microsoft-takes-step-towards-delivering-fpgas>



## Amazon And Xilinx Deliver New FPGA Solutions

SEP 27, 2017 6:08:48 AM 8,423 0

Forbes

Share

<https://www.forbes.com/sites/moorinsights/2017/09/27/amazon-and-xilinx-deliver-new-fpga-solutions/#3f880862370a>

# FPGAs and the New Era of Cloud-based ‘Hardware Microservices’

8 Jun 2017 6:00am, by Mary Branscombe

<https://thenewstack.io/developers-fpgas-cloud/>

## I. Requirements and stakeholder analysis

II. System architecture of the cloud — RC3E

III. Virtualization of the FPGAs — RC2F

# Requirements and stakeholder analysis

Overall system partitioning and architecture — RC3E + RC2F (+SecFPGA)



# Requirements and stakeholder analysis

## Provision, security and service models

### Approach

- The user groups require a different level of visibility and virtualization.
- With division into service models, this abstraction can be integrated into resource management.

### Service-Models

- I. Reconfigurable Silicon as a Service (RSaaS).
- II. Reconfigurable Accelerator as a Service (RAaaS).
- III. Background Acceleration as a Service (BAaaS).



# Requirements and stakeholder analysis

The role of users in the context of FPGAs in the cloud

## Objectives

- Flexible deployment for different **groups of people** with different needs.
- The FPGA is **not visible** to the enduser and only *virtual* resources are used by the service providers.





## II. System architecture of the cloud — RC3E

### Architecture of the RC3E prototype

#### View of the hardware architecture

- The cloud consists of nodes with one CPU each and (two) PCIe-coupled FPGAs.
- Each physical FPGA can contain multiple virtual FPGAs.

#### Extension of the software architecture

- Manage resources (vFPGA and VMs) across all cloud nodes according to service models.
- Required components:
  - local node-management
  - RC2F host-hypervisor
  - FPGA-hypervisor (located on the FPGA)



## II. System architecture of the cloud — RC3E

Encapsulation in packages (vRAIs) and description of virtual resources (RCFG)

- All necessary files for a background accelerator are encapsulated in virtual Reconfigurable Acceleration Images (vRAIs).
- The vFPGA itself is described in the form of a **Reconfigurable (Device) Configuration (RCFG)**.
- A simple VM with hardware accelerator can be easily described:



```
service = 'ba'  
name = ['vfpga-kmeans']  
vm = ['vm1-pvm']  
  
vfpga = [1]  
size = [4]  
memory = [4000]  
  
boot= ['idle']  
design = ['kmeans-quad.vrai']
```

#Service Model BAaaS  
#vFPGA/User Design Name  
#VM-Instance Name  
  
#Number of vFPGAs  
#vFPGA-Slots  
#DDR-Memory Size  
  
#Initial vFPGA-State  
#Initial Design

Example of a RCFG for a vFPGA in model BAaaS.

## II. System architecture of the cloud — RC3E

Description of a more complex virtual resource in a RCFG



## II. System architecture of the cloud — RC3E

Interactions across the individual components within the RC3E



starting point for  
RC2F virtualization



### III. Virtualization of the FPGAs — RC2F

Transfer of the classic virtualization to the reconfigurable hardware

**Concept for the virtualization of FPGAs (approach based on classical System-VMs):**

- The user core is located directly (bare-metal) on the FPGA-resources within a dynamically reconfigurable region, the virtual FPGA (vFPGA).
- The static part of the FPGA contains management structures and the physical interfaces.
- The concept is equivalent to traditional virtual machines:

#### Native Typ 1 System-/Bare-Metal-Virtualization with same ISA

**Interface-Virtualization:**

- External devices are accessed through **paravirtualization** within the FPGA hypervisor (VMM).
- The interfaces of the vFPGAs are the **frontends**, which are connected to the **backend** in the static region.



### III. Virtualization of the FPGAs — RC2F

#### Definitions and terms

- A **vFPGA** is perceived by the user as a stand-alone resource with a dynamic number of hardware resources (slices, LUTs, registers, etc.).
- A vFPGA is mapped to **vFPGA-Slots** — smallest possible physical regions with a fixed number of hardware resources.
- A **vFPGA-Design** is the hardware design within a vFPGA.
- A partial Bitstream is called **vFPGA-Image** and
- if this is assigned to a user this becomes a **vFPGA-Instance**.



#### Distinctions in the term “Hypervisor”:

- The management structure for the vFPGAs on their host system is called the **RC2F Host-Hypervisor**.
- The **FPGA-Hypervisor** is the management structure on the FPGA (Dom0).

### III. Virtualization of the FPGAs — RC2F

#### Architecture for deploying virtualized FPGAs

##### Provision of vFPGAs on the physical FPGA-device:

- Multiple vFPGAs within vFPGA slots.
- The ICAP is used for dynamic partial reconfiguration.
- Direct management of the states of the vFPGAs on the FPGA within the vControl Unit (**vCU**).

##### Components of the infrastructure (FPGA-Hypervisor):

- Internal system bus used for the Paravirtualization.
- Hypervisor Control Unit (**HCU**) to monitor the physical FPGA infrastructure.
- **PCIe** and **Ethernet**-Interfaces.
- Access to **DDR3 memory** on the FPGA board via page tables.



### III. Virtualization of the FPGAs — RC2F

Mapping of the RC2F on homogeneous vFPGA slots (Xilinx Virtex-7 XC7VX485T)

- Establishment of vFPGA slots within the clock regions.
- Realization of **homogeneous** vFPGA slots on the physical FPGA to enable **migration** of the vFPGA-Instances.
- The distribution is dictated by the inhomogeneous FPGA architecture.



### III. Virtualization of the FPGAs — RC2F

Application scenario for using migration within RC2F virtualization



#### Example assignment within a simple scenario

- Full utilization of the physical FPGA by six single vFPGA-Instances.
- Release of individual instances by users.
- **Migration** to provide a larger contiguous area.
- Placement of a larger vFPGA-Instance (Triple).
- Provision of the entire FPGA for a maximum size (hexa) vFPGA-Instance.



# Results of the prototypical implementation of the RC3E & RC2F

# Results of the prototypical implementation of the RC3E & RC2F

## Hardware construction of the cloud prototype



- Structure of the cloud prototype includes different FPGAs.
- Used as a system for development (RSaaS) and teaching (RAaaS).
- For the evaluation of a larger system (BAaaS) a RC3E-Simulation was realized.



# Results of the prototypical implementation of the RC3E & RC2F

## Utilization of the areas of the RC2F prototype on a Virtex-7 (XC7VX485T)



# Results of the prototypical implementation of the RC3E & RC2F

## Transfer of the RC2F to a Virtex-7 UltraScale+ FPGA

- static area containing the RC2F-infrastructure and frontends
- areas not useable due to inhomogeneity
- partial reconfigurable areas containing the vFPGA-Slots



**RC2F-Prototype**  
Virtex-7 XC7VX485T

$\times 4,55$



**estimation for a productive cloud**  
Virtex-7 UltraScale+ XCVU9P

# Results of the prototypical implementation of the RC3E & RC2F

## Results of the RC3E simulation with a synthetic workload



Synthetic workload with 4,981 requests over 150 minutes.



Assignment of vFPGA-Slots in an simulation with additional migration to reduce defragmentation (+FPGAs +RC2F +migration).

# Results of the prototypical implementation of the RC3E & RC2F

Simulation of the RC3E management system in a cloud (BAaaS)

|                          | Scenario I (synthetic) — 4,981 requests |           |          |            |
|--------------------------|-----------------------------------------|-----------|----------|------------|
|                          | Basis (without FPGAs)                   | +FPGAs    | +RC2F    | +Migration |
| Compute Nodes            | 357                                     | 132       | 26       | 24         |
| Utilization of the FPGAs | —                                       | 27.34 %   | 78.14 %  | 85.07 %    |
| Energy demand (kWh)      | 35.37 kWh                               | 24.53 kWh | 8.64 kWh | 8.13 kWh   |
| Energy demand (%)        | 100 %                                   | 69.35 %   | 24.43 %  | 22.91 %    |

- By using two Virtex-7 FPGAs per node, the energy demand of the cloud can be reduced by **30.65 %**.
- RC2F virtualization reduces the energy demand of the cloud system to **24.43 %**.
- An additional migration of vFPGAs adds an extra **1.45 %** compared to a simple RC2F virtualization.

# Final considerations, summary and outlook

# Final considerations

## Comparison with other works

|                          | Host VM | Migration (vFPGAs) | Homogenous vFPGAs | Multiple User | Scalability |         |
|--------------------------|---------|--------------------|-------------------|---------------|-------------|---------|
|                          |         |                    |                   |               | FPGA        | Cluster |
| Kachris et al. [Kac+16b] | ✓       | ✗                  | ✗                 | ✗             | ✗           | ✗       |
| Byma et al. [Bym+14]     | ✗       | !                  | ✗                 | ✓             | !           | ✗       |
| Fahmy et al. [FVS15]     | ✗       | ✗                  | ✗                 | ✓             | !           | ✗       |
| Gazzone et al. [Don+15]  | ✗       | ✗                  | ✗                 | ✓             | ✗           | ✓       |
| Weerasinghe [Wee+15]     | !       | ✗                  | ✗                 | ✓             | ✗           | ✗       |
| Iordache et al. [Ior+16] | ✓       | !                  | ✗                 | ✗             | ✗           | ✓       |
| Chen et al. [Che+14]     | ✓       | !                  | ✗                 | ✓             | ✓           | ✗       |
| <b>RC3E + RC2F</b>       | ✓       | ✓                  | ✓                 | ✓             | ✓           | !       |

✓ realized

! limited

✗ not realized

# Final considerations

## Summary

### I. Requirements and stakeholder analysis

- Investigation of a flexible deployment and the basic use of **virtualized FPGAs** in a Cloud.
- Analysis of possibilities use-cases of FPGAs in a cloud environment with different **service models**.
- Investigation of involved groups of people (**stakeholder**) within an FPGA cloud.



### II. System architecture of the cloud — RC3E

- Embedding vFPGAs in a cloud management (**RC3E**) with the ability to migrate VM and vFPGA instances.
- Build a **configuration (.rcfg)** describing a vFPGA resource and different system configurations.
- Development of a two-stage scheduling with **migration** to increase the utilization.

### III. Virtualization of the FPGAs — RC2F

- Approach to virtualization of FPGAs (**RC2F**) analogous to system virtualization.
- Concept to adapt the size of the **homogeneous** vFPGAs to the resources of the user designs.
- Realization of the **migration** of an FPGA instance.

# Final considerations

## Outlook: Aspects for Future FPGA Architectures

### I. SoC-FPGA with a static RC2F-like Infrastructure:

Development of a static area for the administration with all necessary interfaces to the outside world.

### II. Structural changes within the FPGA architecture:

Establishment of homogeneous and areas with own clock regions on the FPGAs.

### III. Implementation of a security concept:

Security concept based on a trusted authority to provide verifiable RC2F infrastructure.



<https://www.wired.com/2016/09/microsoft-bets-future-chip-reprogram-fly/>



# Literatur

- [Ama18] **Amazon Web Services.** "Amazon EC2 F1-Instances" In: <https://aws.amazon.com/de/ec2/instance-types/f1/>, Online: 14.5.2018.
- [BAB12] **Anton Beloglazov, Jemal Abawajy und Rajkumar Buyya.** "Energy-aware resource allocation heuristics for efficient management of data centers for cloud computing". In: *Future generation computer systems* 28.5 (2012), S. 755–768.
- [BL12] **Alexander Brant und Guy GF Lemieux.** "Zuma: An open fpga overlay architecture". In: *Field-Programmable Custom Computing Machines (FCCM), 2012 IEEE 20th Annual Int'l Symp. on*. IEEE. 2012, S. 93–96.
- [Bym+14] **Stuart Byma, J Gregory Steffan, Hadi Bannazadeh, Alberto Leon Garcia und Paul Chow.** "FPGAs in the Cloud: Booting Virtualized Hardware Accelerators with OpenStack". In: *Field- Programmable Custom Computing Machines (FCCM), 22nd Annual Int'l Symp. on*. IEEE. 2014, S. 109–116.
- [CG03] **Paweł Chodowiec und Kris Gaj.** "Very compact FPGA implementation of the AES algorithm". In: *International Workshop on Cryptographic Hardware and Embedded Systems*. Springer. 2003, S. 319–333.
- [Che+13] **Peng Cheng, Stephen J Fink, Rodric Rabbah und Satyavati Shukla.** "The Liquid Metal IP bridge". In: *Design Automation Conf. (ASP-DAC), 2013 18th Asia and South Pacific*. IEEE. 2013, S. 313–319.
- [Che+14] **Fei Chen u. a.** "Enabling FPGAs in the cloud". In: *Computing Frontiers, Proc.of the 11th ACM Conf. on*. ACM. 2014.
- [Cor96] **Compaq Computer Corporation.** "Internet Solutions Division Strategy for Cloud Computing". November, 1996.
- [Don+15] **Julio Dondo Gazzano, Francisco Sanchez Molina, Fernando Rincon und Juan Carlos López.** "Integrating reconfigurable hardware-based grid for high performance computing". In: *The Scientific World Journal* 2015 (2015).
- [Eck14] **Marcel Eckert.** "FPGA-based system virtual machines". Dissertation. Helmut Schmidt Universität, Hamburg, 2014.
- [Eis+07] **Thomas Eisenbarth, Tim Güneysu, Christof Paar, Ahmad-Reza Sadeghi, Dries Schellekens und Marko Wolf.** "Reconfigurable trusted computing in hardware". In: *Proceedings of the 2007 ACM workshop on Scalable trusted computing*. ACM. 2007, S. 15–20.

# Literatur

- [EV12] **Ken Eguro und Ramarathnam Venkatesan.** "FPGAs for trusted cloud computing". In: *Field Programmable Logic and Applications (FPL), 22nd Int'l Conf. on. IEEE*. 2012, S. 63–70.
- [Fig+11] **Peter Figuli u. a.** "A heterogeneous SoC architecture with embedded virtual FPGA cores and runtime Core Fusion". In: *Adaptive Hardware and Systems (AHS), 2011 NASA/ESA Conf. on. IEEE*. 2011, S. 96–103.
- [FP98] **William Fornaciari und Vincenzo Piuri.** "Virtual FPGAs: Some steps behind the physical barriers". In: *Parallel and Distributed Processing*. Springer, 1998, S. 7–12.
- [FVS15] **Suhaib A Fahmy, Kizheppatt Vipin und Shanker Shreejith.** "Virtualized FPGA accelerators for efficient cloud computing". In: *Cloud Computing Technology and Science (CloudCom), Int'l Conf. on. IEEE*, 2015, S. 430–435.
- [HTK15] **Markus Happe, Andreas Traber und Ariane Keller.** "Preemptive Hardware Multitasking in ReconOS". In: *Applied Reconfigurable Computing*. Springer, 2015, S. 79–90.
- [IBM15] **IBM China.** "New OpenPOWER Cloud Boosts Ecosystem for Innovation and Development". In: *IBM News Release (2015)*.
- [IDC16] **IDC (Int'l Data Corporation) Research, Inc.** *Worldwide Semiannual Public Cloud Services Spending Guide*. 2016.
- [KBL13] **Dirk Koch, Christian Beckhoff und Guy GF Lemieux.** "An efficient FPGA overlay for portable custom instruction set extensions". In: *FieldProgrammable Logic and Applications (FPL), 23rd Int'l Conf. on. IEEE*. 2013, S. 1–8.
- [KGS16]** **Oliver Knodel, Paul Genßler und Rainer Spallek.** "Migration of long-running Tasks between Reconfigurable Resources using Virtualization". In: *ACM SIGARCH Computer Architecture News Volume 44, HEART 2016, July 25-27, Hongkong*. ACM. 2016.
- [KGS17]** **Oliver Knodel, Paul R. Gessler und Rainer G. Spallek.** „Virtualizing Reconfigurable Hardware to Provide Scalability in Cloud Architectures“. In: *Reconfigurable Architectures, Tools and Applications, RECATA 2017, Rome, Italy, September 10 - 14, ISBN: 978-1-61208-585-2, CENICS 2017 Best Paper Award*. IARIA. 2017, S. 33–38.
- [Kir+12] **Robert Kirchgessner, Greg Stitt, Alan George und Herman Lam.** "VirtualIRC: a virtual FPGA platform for applications and tools portability". In: *Field Programmable Gate Arrays, Proc.of the ACM/SIGDA Int'l Symp. on. ACM*. 2012.

# Literatur

- [KLS16] **Oliver Knodel, Patrick Lehmann und Rainer G Spallek.** "RC3E: Reconfigurable Accelerators in Data Centres and their Provision by Adapted Service Models". In: *9th Int'l Conf. on Cloud Computing, Cloud 2016, June 27 - July 2, San Francisco, CA, USA*. IEEE. 2016.
- [Kno14] **Oliver Knodel.** "Integration von FPGA-Ressourcen als Hardwarebeschleuniger und deren Bereitstellung sowie Verwaltung in einem Mehrbenutzersystem". In: *Dresdner Arbeitsstaugung Schaltungs- und Systementwurf, DASS 2014, Dresden, Germany*. 2014.
- [KS13] **Oliver Knodel und Rainer Spallek.** "FPGAs in der Cloud: Integration und Bereitstellung von rekonfigurierbaren Hardware-Ressourcen in einer Cloud-Infrastruktur". In: *5. Workshop für Grid-, Cloud- und Big-Data-Technologien für Systementwurf und -analyse, Grid4Sys 2013, Dresden, Germany*. 2013.
- [KS15] **Oliver Knodel und Rainer G. Spallek.** "Computing Framework for Dynamic Integration of Reconfigurable Resources in a Cloud". In: *2015 Euromicro Conference on Digital System Design, DSD 2015, Madeira, Portugal, August 26-28*. IEEE. 2015, S. 337–344.
- [Man18] **Jeffrey Mann.** "Gartner: Cloud-only verdrängt Cloud-first". In: <https://www.computerwoche.de/a/gartner-cloud-only-verdraengt-cloud-first>. 2018.
- [MG11] **Peter Mell und Timothy Grance.** "The NIST definition of cloud computing". In: *Computer Security Division, Information Technology Laboratory, National Institute of Standards and Technology Gaithersburg* (2011).
- [Mon11] **J-AM Mondol.** "Cloud security solutions using FPGA". In: *Communications, Computers and Signal Processing (PacRim), Pacific Rim Conf. on*. IEEE. 2011, S. 747–752.
- [MS11] **Anil Madhavapeddy und Satnam Singh.** "Reconfigurable data processing for clouds". In: *Field-Programmable Custom Computing Machines (FCCM), 19th Annual Int'l Symp. on*. IEEE. 2011, S. 141–145.
- [OCC16] **Julio Proano Orellana, Carmen Carrión und Blanca Caminero.** "FPGA-aware Scheduling Strategies at Hypervisor Level in Cloud Environments". In: *Scientific Programming, vol. 2016, Article ID 4670271* (2016).

# Literatur

- [Put+14] **Andrew Putnam u. a.** "A reconfigurable fabric for accelerating large-scale datacenter services". In: *Computer Architecture (ISCA), 2014 ACM/IEEE 41st Int'l Symp. on*. IEEE. 2014, S. 13–24.
- [Rav+11] **Vignesh T Ravi, Michela Becchi, Gagan Agrawal und Srimat Chakradhar.** "Supporting GPU sharing in cloud environments with a transparent runtime consolidation framework". In: *High performance distributed computing, Proc.of the 20th Int'l Symp. on*. ACM. 2011, S. 217–228.
- [Rog16] **Bruce Rogers.** „The Coming Data Avalanche – And how we'll handle it“. In: *Forbes Insights*. 2016.
- [SB08] **Hayden Kwok-Hay So und Robert Brodersen.** "A unified hardware/software runtime environment for FPGA-based reconfigurable computers using BORPH". In: *ACM Transactions on Embedded Computing Systems (TECS) 7.2* (2008).
- [SL05] **Haoyu Song und John W Lockwood.** "Efficient packet classification for network intrusion detection using FPGA". In: *Proceedings of the 2005 ACM/SIGDA 13th international symposium on Field-programmable gate arrays*. ACM. 2005.
- [SN05] **Jim Smith und Ravi Nair.** *Virtual machines: versatile platforms for systems and processes*. Elsevier, 2005.
- [WBP13] **Wei Wang, Miodrag Bolic und Jonathan Parri.** "pvFPGA: Accessing an FPGA-based hardware accelerator in a paravirtualized environment." In: *Hardware/Software Codesign and System Synthesis (CODES+ISSS), Int'l Conf. on*, 2013.
- [Wee+15] **Jagath Weerasinghe, Francois Abel, Christoph Hagleitner und Andreas Herkersdorf.** "Enabling FPGAs in Hyperscale Data Centers". In: *Cloud and Big Data Computing (CBDCom), Int'l Conf. on*. IEEE. 2015.
- [XSS14] **Lei Xu, Weidong Shi und Taewan Suh.** "PFC: Privacy Preserving FPGA Cloud-A Case Study of MapReduce". In: *Cloud Computing (CLOUD), 7th Int'l Conf. on*. IEEE. 2014, S. 280–287.

# Literatur

- [Yu+11] **Jibo Yu, Yongxin Zhu, Liang Xia, Meikang Qiu, Yuzhuo Fu und Guoguang Rong.** "Grounding high efficiency cloud computing architecture". In: *Applications of Digital Information and Web Technologies (ICADIWT), Fourth Int'l Conf. on.* 2011.
- [Pec+06] **Wesley Peck, Erik Anderson, Jason Agron, Jim Stevens, Fabrice Baijot und David Andrews.** "Hthreads: A computational model for reconfigurable devices". In: *Field Programmable Logic and Applications (FPL), Int'l Conf. on.* IEEE. 2006, S. 1–4.
- [Pöp+15] **Thomas Pöppelmann, Michael Naehrig, Andrew Putnam und Adrian Macias.** "Accelerating homomorphic evaluation on reconfigurable hardware". In: *International Workshop on Cryptographic Hardware and Embedded Systems*. Springer. 2015, S. 143–163.