# Implementierung eines multithreaded TCP/IP Stacks für einen auf AMIDAR basierten Java Prozessor

Bachelorarbeit Robert Wiesner 31. Mai 2017





| Erklärung | gemäß | ξ | 22 | Abs. | 7 | <b>APB</b> |
|-----------|-------|---|----|------|---|------------|
|           |       |   |    |      |   |            |

Hiermit erkläre ich gemäß § 22 Abs. 7 der Allgemeinen Prüfungsbestimmungen (APB) der Technischen Universität Darmstadt in der Fassung der 4. Novelle vom 18. Juli 2012, dass ich die Arbeit selbstständig verfasst und alle genutzten Quellen angegeben habe und bestätige die Übereinstimmung von schriftlicher und elektronischer Fassung.

| Darmstadt, den 31. Mai 2017 |                |
|-----------------------------|----------------|
| Ort, Datum                  | Robert Wiesner |

## Fachbereich Elektro- und Informationstechnik

Institut für Datentechnik Fachgebiet Rechnersysteme

Prüfer: Prof. Dr.-Ing. Christian Hochberger Betreuer: Dipl.-Inform. Changgong Li

# Inhaltsverzeichnis

| 1 | Einleitung |                              | : |
|---|------------|------------------------------|---|
|   | 1.0.1      | Ethernet                     | 9 |
|   | 1.0.2      | IP                           |   |
|   |            | TCP                          |   |
|   | 1.0.4      | DHCP                         |   |
|   | 1.0.5      | AMIDAR                       |   |
| 2 | Implement  | ierung                       | 4 |
|   | •          | Überblick                    | 2 |
|   | 2.0.2      | TCP Stack                    | 2 |
|   | 2.0.3      | IP Stack                     | 2 |
|   | 2.0.4      | DHCP                         | 2 |
|   |            | Stream Sockets               |   |
| 3 | Evaluation |                              | 5 |
|   | 3.0.1      | Testaufbau                   |   |
|   | 3.0.2      | Übertragunsgeschwindigkeiten | 5 |
| 4 | 7usammen   | fassung                      | f |

| 1 Einleitung   |  |  |
|----------------|--|--|
|                |  |  |
| 1.0.1 Ethernet |  |  |
|                |  |  |
| 1.0.2 IP       |  |  |
|                |  |  |
| 1.0.3 TCP      |  |  |
|                |  |  |
| 1.0.4 DHCP     |  |  |
|                |  |  |
| 1.0.5 AMIDAR   |  |  |

| 2 Implementierung    |  |
|----------------------|--|
|                      |  |
| 2.0.1 Überblick      |  |
|                      |  |
| 2.0.2 TCP Stack      |  |
|                      |  |
| 2.0.3 IP Stack       |  |
|                      |  |
| 2.0.4 DHCP           |  |
|                      |  |
| 2.0.5 Stream Sockets |  |

| 3 Evaluation     |  |  |  |
|------------------|--|--|--|
|                  |  |  |  |
| 3.0.1 Testaufbau |  |  |  |
|                  |  |  |  |
| 3.0.2 Funktionen |  |  |  |
|                  |  |  |  |
| 3.0.3 Performanz |  |  |  |

| 4 Zusammenfassung |  |  |  |
|-------------------|--|--|--|
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |
|                   |  |  |  |

# Abkürzungsverzeichnis

**CLB** Configurable Logic Block

**CPU** central processing unit

**ELF** Executable and Linking Format

**FPGA** Field Programmable Gate Array

**MC** Microcontroller

**CPU** central processing unit

**NCD** Native Circuit Description Format

**SoC** System on Chip

**Sph** SpartanMC Hex Dateiformat

**XDL** Xilinx Design Language Format

### **Abbildungsverzeichnis**

### Literaturverzeichnis

- [BUG] BUG Xilinx XDL Programm. http://forums.xilinx.com/t5/Spartan-Family-FPGAs/A-bug-for-Spartan-6/td-p/271026
- [ELF] Executable and linkable Format. http://www.linux-kernel.de/appendix/ap05.pdf
- [GNU] GNU make. http://www.gnu.org/software/make/manual/make.html
- [OSE] Open Source ELF-Library. https://www.hpi.uni-potsdam.de/hirschfeld/trac/SqueakMaxine/browser/com.oracle.max.elf?rev= 1d81ff0c9a2a8a101fe33f4ac1495decc6147517#src/com/oracle/max/elf
- [UCS] XDL Use Case Senarios. http://www.cs.indiana.edu/hmg/le/project-home/xilinx/ise\_5.2/help/data/xdl/xdl-ucs-ext.html
- [XDL] Xilinx Design Language. http://www.cs.indiana.edu/hmg/le/project-home/xilinx/ise\_5.2/help/data/xdl/xdl.html

8