CP/M
CP/M | |
---|---|
CP/M-86 | |
Entwickler | Digital Research Inc. |
Lizenz(en) | Public Domain (seit 7. Juli 2022) |
Erstveröff. | 1974 |
Akt. Version | 3.1 bzw. 1.2 (CP/M-68k) (1983) |
Kernel | BDOS: monolithisch (Assembler) |
Architektur(en) | Intel 8080/8085, Zilog Z80, Intel 8086/8087/8088 und Motorola 68000 |
Installationsmedium | Disketten |
Sprache(n) | Englisch |
www.digitalresearch.biz/CPM.HTM |
CP/M (Abkürzung für Control Program for Microcomputers, „Steuerprogramm für Mikrocomputer“) ist eine Reihe von Betriebssystemen, die ab etwa 1974 von Digital Research unter Gary Kildall entwickelt wurden. CP/M war (neben dem für leistungsstärkere Rechner konzipierten Unix) das erste plattformunabhängige Betriebssystem. Eine Mehrbenutzer-Variante wurde unter dem Namen „MP/M“ entwickelt. Mit dem Aufkommen von MS-DOS bzw. dessen IBM-Variante PC DOS verlor CP/M seine Bedeutung.
CP/M ohne nähere Bezeichnung steht meist für „CP/M-80“, die ursprüngliche, ab 1974 entwickelte Version für die Mikroprozessoren Intel 8080 und den dazu kompatiblen Zilog Z80, eine 8-Bit-Architektur. Die letzte Version von CP/M-80 wurde „CP/M-Plus“ genannt. „CP/M-86“ war eine Portierung auf die Prozessoren Intel 8086 und 8088, eine 16-Bit-Architektur. Mit „CP/M-68K“ folgte eine weniger erfolgreiche Variante für den Motorola 68000 (ebenfalls 16 Bit).
Die Abkürzung CP/M stand ursprünglich für Control Program/Monitor („Steuerprogramm/Maschinencode-Monitor“). Das ursprüngliche Akronym wurde später in Control Program for Microcomputers umgedeutet.
Aufbau
[Bearbeiten | Quelltext bearbeiten]Die Entwicklung des Betriebssystems geschah zeitgleich mit Kildalls Arbeit bei Intel. Er nutzte die ebenfalls von ihm entworfene Programmiersprache PL/M sowie das Betriebssystem ISIS, an dem er gerade mitarbeitete, mit welchem sich CP/M die Befehle und grundlegende Funktionsweisen teilt.[1]
Die unterste Ebene von CP/M bildet als Hardwareabstraktionsschicht das Basic Input/Output System, kurz BIOS, welches eine standardisierte Schnittstelle für die hardwarenahen Aufgaben zur Verfügung stellt, vor allem zur Ein- und Ausgabe. Lediglich dieser Teil des Betriebssystems musste an den jeweiligen Computertyp angepasst werden, was normalerweise durch den Hersteller geschah. Die restlichen Teile konnten ohne große Veränderungen übernommen werden, da sie lediglich auf den Funktionen des CP/M-BIOS aufbauen.
Die standardisierten Funktionen des BIOS werden vom eigentlichen Systemkern, dem hardwareunabhängigen BDOS (Basic Disk Operating System), verwendet, das höhere Funktionen zur Verfügung stellt, vor allem zur Dateiverwaltung. Dieses greift auf die Hardware nur indirekt über das BIOS zu, wodurch die Hardwareunabhängigkeit realisiert wird.
Das BDOS wiederum wird vom CCP (Console Command Processor) verwendet, einem Kommandozeileninterpreter, der die Befehle des Benutzers entgegennimmt. Einige einfache Befehle werden vom CCP selbst ausgeführt (zum Beispiel dir
(Disketten-Inhaltsverzeichnis anzeigen), rename
(Umbenennen von Datei[en]) und weitere). Andernfalls wird ein entsprechendes Programm mit der Dateinamenserweiterung .com
(bei CP/M-68k: .68k
) geladen und gestartet. Beispiele: pip.com
(Kopierprogramm), stat.com
(Informationen über verschiedene Systemeinstellungen) usw.
Anwendungssoftware kommuniziert mit der Hardware meist nur über das gleichbleibende BDOS sowie über die standardisierten Einsprungspunkte des BIOS – und ist somit portabel. Allerdings ist die Anwendungssoftware für CP/M aus Geschwindigkeits- und Speicherplatzgründen oft in Assemblersprache geschrieben und nur selten im Quelltext veröffentlicht, so dass Portabilität in der Praxis nur innerhalb einer Prozessorfamilie gegeben war. Der Assembler-Quellcode von CP/M wurde zusammen mit dem Assemblerprogramm asm.com mitgeliefert. Somit konnte in Assembler das Betriebssystem nach eigenem Bedarf verändert und erweitert werden. Dennoch war CP/M kein „Open Source“ im heutigen Sinne, da die Weitergabe modifizierter Versionen nicht erlaubt war.
Der Aufbau von CP/M wurde später auch durch MS-DOS übernommen: Hier heißen die oben beschriebenen Teile (Bootdateien) nun IO.SYS
statt BIOS, MSDOS.SYS
statt BDOS und (der Kommandointerpreter) und COMMAND.COM
statt CCP. Überhaupt lehnte sich die erste Version von MS-DOS sehr stark an CP/M an,[2] die hauptsächliche Änderung war das verbesserte Dateisystem File Allocation Table (FAT).
Schwachpunkte
[Bearbeiten | Quelltext bearbeiten]Ein Schwachpunkt von CP/M war, dass es kein einheitliches Format für 5¼-Zoll-Disketten gab. Das einzige offizielle (IBM-Industriestandard)-Format war ein 8-Zoll-Format, so dass nach dem weitgehenden Verschwinden der 8-Zoll-Diskettenlaufwerke der Austausch von Disketten zwischen CP/M-Rechnern verschiedener Hersteller sehr schwierig bis unmöglich wurde. Auch die Bildschirm- und Druckersteuerung war in CP/M-Systemen nicht einheitlich, denn CP/M war ursprünglich für bildschirmlose, Fernschreiber-basierte Systeme (TTY) entwickelt worden. Spätere Systeme, auf denen CP/M lief, emulierten häufig weitverbreitete Bildschirmtypen, beispielsweise das Terminal VT100 der Digital Equipment Corporation, damit möglichst viel Software unverändert darauf eingesetzt werden konnte. Kommerzielle Programme mussten auf das jeweilige Zielsystem angepasst werden. Im günstigsten Fall war die Auswahl über ein vordefiniertes Installationsprogramm (Setup) möglich. Nicht selten musste der Anwender allerdings die notwendigen Steuerzeichen für z. B. „Bildschirm löschen“ oder Cursor-Positionierung sowie auch Steuercodes für den verwendeten Drucker in Erfahrung bringen und in den Programmcode integrieren. In solchen Fällen war meist ein Patch im Anwendungsprogramm mittels Debugger erforderlich. Einige professionelle Programme, wie die Textverarbeitungssoftware WordStar, waren durch vorbereitete Patch-Bereiche bereits konzeptionell darauf eingerichtet.
Auf der anderen Seite war das nur eine Folge der Flexibilität von CP/M: Es legte als Hardware nur den Prozessor und eine Mindestspeichergröße fest. Dadurch konnte es auf sehr verschiedenen Computern von Heimcomputern wie dem Schneider/Amstrad CPC bis hin zu Rechnern wie dem Epson QX 10 mit 256 Kilobyte (kB) Arbeitsspeicher laufen. Der Hersteller musste in seiner CP/M-Version nur den BIOS-Teil an die verwendete Hardware anpassen.
Mit dem raschen Verfall der Speicherpreise ab etwa 1981 wurde auch die Beschränkung auf 64 kB direkt nutzbaren Speichers ein Problem – schuld war hier allerdings nicht CP/M selbst, sondern die 8-Bit-Architektur der zeitgenössischen Prozessoren, auf denen es hauptsächlich eingesetzt wurde. Auch die schlechte Eignung für Festplattenlaufwerke bremste CP/M ab etwa 1982 zunehmend aus. Das Hauptproblem war dabei die Unfähigkeit von CP/M-80, Unterverzeichnisse zu verwalten, was für größere Datenträger fast unerlässlich ist. CP/Ms eigenes Unterteilungskonzept für Datenträger mittels sogenannter „Benutzernummern“ war zu beschränkt, da es nur 16 Bereiche und keine hierarchischen Strukturen ermöglichte. Allerdings erhielt MS-DOS diese Fähigkeit auch erst im Jahr 1983.
Bei Festplatten nutzte man diese Benutzernummern, um mit dem Befehl user
mehrere Bereiche auf einem Datenträger zu verwalten und nur die Daten anzuzeigen, die zu dem jeweiligen Benutzer gehören.
CP/M-Plus
[Bearbeiten | Quelltext bearbeiten]1983 erschien mit CP/M-Plus (der Version 3.0) die letzte Version des klassischen 8080er-CP/M, welche nun mittels Bank Switching auch mehr als 64 kB Speicher unterstützte. Außerdem wurde bei CP/M-Plus eine Reihe von Aufgaben, die bisher das herstellerspezifische BIOS erledigen musste, ins herstellerunabhängige BDOS verlegt und somit die Portierung weiter vereinfacht. Vor allem brauchte die codetechnisch nicht ganz einfache und daher fehleranfällige Umwandlung zwischen der bei CP/M grundlegenden Datenblockgröße von 128 Bytes und der eigentlich von der Hardware verwendeten, bei den neueren Disketten- und Festplattenformaten fast immer größeren Blockgröße, nicht mehr im BIOS von jedem Hersteller neu implementiert zu werden, sondern fand jetzt im BDOS statt. Jedoch war diese CP/M-Version zugleich auch langsamer und verbrauchte mehr Speicher für sich selbst. Diese Version ist zwar dank des Commodore 128 und des Schneider/Amstrad CPC 6128, bei denen sie mitgeliefert wurde, die weltweit meistverkaufte, konnte allerdings, was die tatsächliche Nutzung betrifft, nicht mehr an die Popularität des kleineren und schnelleren CP/M 2.2 anknüpfen.
CP/M 3.0 konnte auch eine Erweiterung namens Graphics System Extension (GSX, vgl. Graphical Kernel System) enthalten, die das Problem, dass Drucker und Bildschirm je nach Hersteller unterschiedlich angesteuert werden, beseitigte. Es stellte eine zusätzliche Schnittstelle für Text- und Grafikausgabe (u. a. Balken- und Kreisdiagramme) zur Verfügung. GSX nutzte dazu Druckertreiber, die der Hersteller des Druckers bereitstellen musste.
Typische Hardware
[Bearbeiten | Quelltext bearbeiten]Typische Rechner aus den frühen 1980er Jahren, auf denen CP/M eingesetzt wurde, hatten einen Zilog-Z80-Prozessor (codekompatibel zum Intel 8080) mit 2 bis 4 Megahertz (MHz), 64 oder 128 kB Hauptspeicher, einen einfarbigen Bildschirm, der 80×24 Zeichen Text (aber keine Grafik) darstellen konnte, ein oder zwei Diskettenlaufwerke mit 8-Zoll- oder 5¼-Zoll-Disketten, selten auch eine Festplatte mit etwa 5 MB. Dies leitete sich von der Ausstattung des Intel MDS-800 Entwicklungssystems ab, auf dem CP/M entworfen wurde.
CP/M wurde auch von vielen Bastlern auf ihren selbstgebauten Computern verwendet. Dominierten in der Frühzeit noch S-100-Bus-Systeme wie etwa der IMSAI 8080, so waren bekannte kommerzielle CP/M-Computer der späteren Jahre der Osborne 1 und die Kaypro-Modelle; auf dem Apple II wurde CP/M häufig mittels einer zusätzlichen Z80-Prozessorkarte (Apple CP/M) genutzt. Weiterhin gab es Zusatzkarten für die Commodore-Arbeitsplatzrechner der CBM-3000- und CBM-4000-Serie (Nachfolger des PET 2001).
Auch auf vielen Heimcomputern konnte CP/M genutzt werden, beispielsweise auf dem Schneider/Amstrad CPC, Commodore 64 (mit Zusatzmodul) und dem Commodore 128; in der Praxis wurde es auf diesen aber eher selten eingesetzt, da sie zusätzlich jeweils noch ein eigenes Betriebssystem mitbrachten, das besser auf die jeweilige Hardware abgestimmt war und somit vor allem für grafische Computerspiele besser geeignet war.
Auch der Schneider Joyce/Amstrad PCW hatte neben dem aus Marketinggründen als kombiniertes Betriebs- und Textverarbeitungssystem konzipiertem LocoScript als zweites, davon unabhängiges Betriebssystem CP/M an Bord. Der PC war ausgestattet mit einem Zilog-Z80-Prozessor mit 4 MHz und 256 bzw. 512 kB Arbeitsspeicher. Das gestartete CP/M-Betriebssystem war in dieser Konfiguration auf drei „Speicherbänke“ zu je 64 kB verteilt, mit einem gemeinsamen „Common“-Bereich ab Adresse HxC000 (zum Beispiel Kernel in Bank 1, Tastatur und Bildschirm in Bank 0, Drucker in Bank 2). Diese Versionen waren an der Dateinamenserweiterung .ems
erkennbar.
Portierungen von CP/M
[Bearbeiten | Quelltext bearbeiten]CP/M in der Deutschen Demokratischen Republik
[Bearbeiten | Quelltext bearbeiten]In der DDR wurde CP/M meist unter der Bezeichnung Single User Control Program (SCP) auf MME-U880-basierter Hardware eingesetzt. Die Bezeichnung weist darauf hin, dass es sich um ein Einbenutzer-Betriebssystem handelt. Für allgemeine Büroarbeiten auf den 8-Bit-Mikrorechnern P8000 (compact) entstand mit OS/M ein zu CP/M kompatibles Betriebssystem.[3] Die Kleincomputer KC 85 konnten mit einem Aufsatz um 5¼-Zoll-Diskettenlaufwerke erweitert werden und so ebenfalls CP/M ausführen, welches in der Variante MicroDOS verwendet wurde. Innerhalb der Akademie der Wissenschaften der DDR wurde in den 1980er Jahren für die Rechner auf Basis der Z80/U880-Prozessoren (wie z. B. PC 1715, A 5110/A 5120/A 5130) das Betriebssystem CP/A genutzt. Es hatte gegenüber CP/M bzw. SCP den Vorteil, dass z. B. 5¼-Zoll-Disketten mit der vollen Speicherkapazität von 800 kB für Daten genutzt werden konnten, während CP/M nur 720 >kB Daten erlaubte und 80 kB für das System reservierte. Vom VEB Mansfeld Kombinat „Wilhelm Pieck“ wurden für deren Arbeitsplatzrechner der Mansfeld-MPC-Reihe CP/M-Versionen unter dem Namen „SCP/M 2“ entwickelt.[4] Beim VEB Carl Zeiss Jena wurde das „CP/Z“-System entwickelt, das besonders wenig, dafür aber sehr effizienten Programmcode hatte. Es entstand ein reger Softwareaustausch zwischen den DDR-Firmen, da Verletzungen des Urheberrechts ausländischer Firmen in der DDR nicht verfolgt wurden. Nur ab und zu gab es auf internationalen Messen böse Überraschungen. Die Firma Ashton-Tate machte nach dem Ende der DDR allen dBase-Nutzern ein vergünstigtes Angebot.
CP/M-86
[Bearbeiten | Quelltext bearbeiten]Neben der Intel-8080- bzw. Zilog-Z80-Version von CP/M erlangte vor allem CP/M-86 praktische Bedeutung: eine CP/M-Version für Intel-8086- und Intel-8088-Hauptprozessoren.
CP/M-86 hatte ab Januar 1982 durchaus die Chance, zum Standardbetriebssystem des IBM Personal Computer, dem ersten Personal Computer von IBM, zu werden. Unter bis heute umstrittenen Umständen bekam CP/M aber MS-DOS von Microsoft, welches konzeptionell stark an CP/M-80 angelehnt war, als Konkurrenten. Obwohl IBM anfangs dem Kunden die Wahl des Betriebssystems überließ, setzte sich MS-DOS – das in der von IBM ausgelieferten Variante PC DOS hieß – aufgrund seines niedrigeren Preises von 40 US-Dollar (nach heutiger Kaufkraft rund 120 Euro) recht schnell gegen das wesentlich teurere CP/M-86 durch, wobei Software zunächst für beide Plattformen entwickelt wurde.
Das aus CP/M-86 abgeleitete, dazu weitgehend kompatible Betriebssystem SCP1700 wurde auf Intel-8086-/K1810WM86-basierten Bürocomputern des Kombinat Robotron eingesetzt. Auf dem 1985 vorgestellten Robotron A 7100 war SCP1700 das empfohlene Standardbetriebssystem.
CP/M-68K
[Bearbeiten | Quelltext bearbeiten]Die Portierung auf den Motorola 68000, genannt CP/M-68k, war kein großer kommerzieller Erfolg.
MP/M
[Bearbeiten | Quelltext bearbeiten]MP/M war ein Mehrbenutzersystem-Version (“multi user system”) von CP/M. Mehrere Benutzer konnten gleichzeitig über ASCII-Terminals an einem Rechner arbeiten.
CP/NET
[Bearbeiten | Quelltext bearbeiten]Eine in den späten 1980ern entstandene Betriebssystemerweiterung zur Kommunikation zwischen CP/M-Systemen wurde „CP/NET“ genannt. Als Server diente ein MP/M-System, auf den Clients lief CP/NET. Die Clients konnten auch festplattenlos betrieben werden. Neben der gemeinsamen Nutzung von Dateisystemen waren auch elektronische Nachrichten implementiert.[5]
CCP/M-86
[Bearbeiten | Quelltext bearbeiten]Später wurde aus CP/M-86 und MP/M-86 eine neue Variante „Concurrent CP/M“ (CCP/M-86) entwickelt. Diese vereinigte die Mehrbenutzerfähigkeiten von MP/M mit hoher Kompatibilität zu CP/M-86.
Software für CP/M
[Bearbeiten | Quelltext bearbeiten]Unter CP/M wurden Anwendungsprogramme wie die Textverarbeitungen Electric Pencil und WordStar, die Tabellenkalkulationen Supercalc und Microsoft Multiplan sowie die Datenbanksoftware dBASE II (von Ashton-Tate) angeboten. Ein integriertes Office-Paket, mit der Möglichkeit der leichten Datenübernahme z. B. von der Datenbank in die Textverarbeitung, gab es unter CP/M noch nicht. Allerdings waren die damaligen Dateiformate noch recht einfach aufgebaut, so dass meist eine händische Übernahme möglich war, oder es musste ein eigenes kleines Programm dafür geschrieben werden.
Neben den Anwendungsprogrammen lag der Schwerpunkt der Software für CP/M bei Programmiersprachen zur Erstellung spezifischer Programme. Erwähnenswert sind hier MBASIC von Microsoft, Fortran, Turbo Pascal von Borland, PL/I, muLISP und COMAL. Die von Digital Research selbst angebotene Sprache PL/M, eine systemnahe Programmiersprache mit Ähnlichkeiten zu PL/I, wurde bei Digital Research auch intern viel verwendet; die Ähnlichkeit mit dem Namen des Betriebssystems ist somit nicht zufällig. Einige der mit CP/M standardmäßig mitgelieferten Hilfsprogramme wurden in dieser Sprache geschrieben. Die später so dominante Sprache C war unter CP/M noch ziemlich unbedeutend, entsprechend gibt es nur wenige Compiler für diese Sprache, die unter CP/M laufen – beispielsweise BDS C. Mit Aztec C wurde gegen Ende der Lebenszeit von CP/M ein brauchbarer Compiler verfügbar.
Zudem gab es recht große Sammlungen an gemeinfreien Programmen für CP/M, die zum Beispiel von Benutzervereinigungen oder privaten Kleinvertrieben auf durchnummerierten Disketten zusammengestellt wurden. In diesem Bereich finden sich auch Computerspiele, die im Bereich der kommerziellen CP/M-Software nie eine Rolle spielten. Viele dieser Sammlungen wurden später auf CD-ROM oder zum Herunterladen im Internet wiederveröffentlicht. Eine CD-ROM kann leicht zehntausend oder mehr der nach heutigen Maßstäben winzigen CP/M-Programme fassen.
Emulationen
[Bearbeiten | Quelltext bearbeiten]Beim Übergang von 8-Bit-Prozessoren (wie dem Zilog Z80) zu 16-Bit-Maschinen (wie z. B. dem Intel 8086 und 80286) Anfang der 1980er Jahre bestand zunächst ein großer Mangel an Anwendungsprogrammen für die neue leistungsfähigere Hardware. Deshalb wurden Software-Emulationen entwickelt, die CP/M und einen Z80-Hauptprozessor virtuell auf einem 16-Bit-System nachbildeten, so dass bestehende Anwendungen und Anwendungsdaten (z. B. eine dBase-II-Datenbank) auf dem neuen System weiterverwendet werden konnten. Für MacOS gibt es eine native CP/M Emulation.[6]
Freigaben
[Bearbeiten | Quelltext bearbeiten]2001 gab Caldera CP/Ms Quelltext unter einer liberalen Open-Source-Lizenz, welche Redistribution und Modifikation erlaubt, via Tim Olmsteads “The Unofficial CP/M Web site” frei.[7][8][9] Im Oktober 2014, um den 40. Jahrestag der Erstpräsentation zu feiern, veröffentlichte das Computer History Museum weitere frühe Quelltextversionen von CP/M unter einer Lizenz zur nicht-kommerziellen Verwendung.[10]
Gemeinfreiheit
[Bearbeiten | Quelltext bearbeiten]2022 wurde CP/M, in der Version von Digital Research, von Bryan Sparks, dem Rechteinhaber am geistigen Eigentum von Digital Research, der Allgemeinheit freigegeben.[11][12]
„Let this paragraph represent a right to use, distribute, modify, enhance, and otherwise make available in a nonexclusive manner CP/M and its derivatives. This right comes from the company, DRDOS, Inc.'s purchase of Digital Research, the company and all assets, dating back to the mid-1990's. DRDOS, Inc. and I, Bryan Sparks, President of DRDOS, Inc. as its representative, is the owner of CP/M and the successor in interest of Digital Research assets.“
Literatur
[Bearbeiten | Quelltext bearbeiten]- Rodnay Zaks: CP/M-Handbuch. 5. Auflage. SYBEX-Verlag, Düsseldorf 1984, ISBN 3-88745-053-1 (englisch: The CP/M Handbook. Übersetzt von Klaus-Jürgen Schmidt).
- Bernd Pol: Vom Umgang mit CP/M. Eine allgemeinverständliche Einführung. 6. Auflage. IWT-Verlag, Vaterstetten 1985, ISBN 3-88322-004-3.
- Jürgen Plate: Betriebssystem CP/M. vom Monitorprogramm zum Mehrbenutzersystem. 2., neubearbeitete und erweiterte Auflage. Franzis-Verlag, München, ISBN 3-7723-7522-7.
- Alfons Steinhoff, Klaus Michael Rübsam: Arbeiten mit CP/M. SYBEX-Verlag, Düsseldorf 1987, ISBN 3-88745-622-X.
- Joachim Bernert, Michael Burow, Christian Hanisch: CP/M in der Praxis. Verlag Technik, Ost-Berlin 1988, ISBN 3-341-00567-6.
Weblinks
[Bearbeiten | Quelltext bearbeiten]- Yet Another Z80 Emulator by AG – YAZE-AG: Z80 CPU Emulator mit CP/M 3.1 auf der Internetpräsenz der Universität Ulm (englisch)
- Quellcode bei www.computerhistory.org „Early Digital Research CP/M Source Code“ ca. 150 MB (englisch)
Einzelnachweise
[Bearbeiten | Quelltext bearbeiten]- ↑ Herb Johnson: ISIS, Osiris, Intellec, PL/M, iRMX, and Intel - 20th century. 30. Juli 2021, abgerufen am 10. Januar 2022.
- ↑ digitalresearch.biz
- ↑ Betriebssystem OS/M In: robotrontechnik.de
- ↑ robotrontechnik.de (abgerufen am 26. Juni 2012)
- ↑ digitalresearch.biz (abgerufen am 26. Juni 2012)
- ↑ Thomas Harte: TomHarte/CP-M-for-OS-X. 29. Februar 2020, abgerufen am 28. März 2020.
- ↑ The Unofficial CP/M Web site (englisch)
- ↑ CP/M collection is back online with an Open Source licence The Register, 26. November 2001 (englisch)
- ↑ License agreement for the CP/M material presented on this site (englisch)
- ↑ David Laws: Early Digital Research CP/M Source Code. Computer History Museum, 1. Oktober 2014, abgerufen am 25. Juli 2015 (englisch).
- ↑ License Agreement. Abgerufen am 16. Juli 2022.
- ↑ Sebastian Grüner: IBM PCs und Zilog Z80: Erstes PC-Betriebssystem CP/M offiziell Open Source. In: golem.de. 18. Juli 2022, abgerufen am 3. Februar 2024.