RTX: Real Time eXtensions für Windows

Betriebssystem

RTX (Real Time eXtensions for Windows) ist eine von IntervalZero entwickelte Echtzeit-Erweiterung, die Microsoft Windows in ein Echtzeitbetriebssystem verwandelt.[1] Es war das erste Echtzeit-Windows-Produkt.[2]

RTX
Entwickler IntervalZero
Lizenz(en) EULA
Akt. Version RTX2016 (32-bit)
RTX64 4.x (64-bit)
Architektur(en) x86, x64
www.IntervalZero.com

Beschreibung

Bearbeiten

Beginnend mit Windows-Version NT 3.5 unterstützt die Software seit 1994 stetig die NT-Architektur. Derzeit steht die Version RTX 2016[3] für die 32-Bit- und die Version RTX64 4.x für die 64-Bit-Version von Windows zur Verfügung.[4]

RTX wird von Embedded-Geräteherstellern[5] verwendet, die Windows als handelsübliches Betriebssystem nutzen, jedoch den Bedarf an einem Echtzeit-Betriebssystem (RTOS) haben. Durch den Software-Einsatz kann auf zusätzliche Echtzeit-Hardware verzichtet werden.[6]

Anwendung findet die Software vor allem in der Automatisierung, beim Militär, in der Luft- und Raumfahrttechnik, bei medizinischen Geräten, digitalen Medien und der Messtechnik, bei Videospielen, aber auch bei zukunftsfähigen, intelligenten Stromnetzanwendungen (z. B. Überwachung bei der Energieproduktion in Kraftwerken und bei der Energieverteilung (Smart Grid)).

Geschichte

Bearbeiten

Ursprünglich wurde RTX von der Firma VenturCom entwickelt, die im Jahr 2005 in Ardence umbenannt wurde. Ardence wurde zwei Jahre später von Citrix aufgekauft. Im Jahr 2008 spaltete Citrix den Bereich Embedded Systems unter dem Namen IntervalZero ab. Seitdem werden RTX und seine Folgeversionen von IntervalZero weiterentwickelt und gewartet.[7]

Technische Details

Bearbeiten

HAL Erweiterung (Hardware Abstraction Layer)

Bearbeiten

RTX64/RTX beruht auf einer Erweiterung des Windows HAL. Die RTX64/RTX-HAL-Erweiterung initialisiert und startet die RTX64/RTX zugeordneten Prozessoren und liefert dem RTX64/RTX-Echtzeit-Subsystem (RTSS) hochauflösende Timer (bis zu 1 Mikrosekunde). Ebenso bietet es auch Isolations-Mechanismen für Interrupts an.

Symmetrisches Multiprozessorsystem (SMP)

Bearbeiten

Wie Windows basieren auch RTX64 und RTX auf einer SMP-Architektur.[8] Passend zu den jeweiligen Echtzeit-Anforderungen kann der RTX64/RTX-Nutzer die Anzahl der Prozessoren wählen, die er RTX zuordnet, um seine Echtzeitanwendungen auszuführen (bis zu 63 zugeordnete Prozessoren für RTX64, und bis zu 31 Prozessoren für RTX). Durch Konfigurieren der Threads und der Interrupt-Bindung teilt der Nutzer anschließend seine Echtzeit-Anwendungen unter den RTX/RTX64 zugewiesenen Prozessoren auf.

Interrupt Management

Bearbeiten

RTX64/RTX unterstützt sowohl leitungsbasierte (IRQs) wie auch Message-basierte (MSI/MSI-X) Interrupts. Die Latenzzeiten des Interrupt Service Thread (IST) betragen weniger als 10 Mikrosekunden.

Speicherverwaltung

Bearbeiten

Der deterministische Speicher, der RTX64/RTX zugeordnet werden kann, wird aus dem „Non-Paged“- Speicherbereichen des Systemspeichers gebildet. Der „Non-Paged“- Speicherbereich, der RTX64/RTX zum Beispiel unter Windows 7 RTX64/RTX zugewiesen werden kann, beträgt:

  • bei 32-bit: 75 % des RAM bis zu einem Maximum von 2 GB
  • bei 64-bit: 75 % des RAM bis zu einem Maximum von 128 GB

Scheduling

Bearbeiten

Über alle Echtzeit-Prozessoren wird ein gemeinsamer Scheduler verwendet. Ein gemeinsamer Scheduler (eine Instanz für alle Echtzeit-Kerne) weist den Echtzeitkernen die entsprechende Aufgabe zu. Ein Symmetric Multiprocessing Scheduler verwendet sowohl prioritätsgesteuerte (128 Prioritätsebenen) als auch präemptive Algorithmen, um zeitkritische Thread-Umschaltungen zu gewährleisten. Um eine Inversion der Prioritäten zu vermeiden, implementiert das Echtzeit Subsystem (RTSS) die klassische Lösung der Prioritäten-Promotion. Dadurch laufen Threads mit hoher Priorität in einem Sub-Mikrosekunden-Bereich ab.

Windows-Interaktion

Bearbeiten

Durch die strikte Trennung der Echtzeitanwendungen von Windows und den Windows-Prozessen beeinflusst auch eine Windows-STOP- oder Shutdown-Message nicht den Echtzeitablauf, die bis zu einem Sicherheitsshutdown unabhängig (aber ohne Windowsservices nutzen zu können) weiterlaufen. Die Kommunikation Windows-RTX64/RTX wird standardmäßig durch eine Interprozess-Kommunikation zwischen Windows-Anwendungen (Windows Anwenderprozesse, oder Windows Kernel-Treiber) und Echtzeit-Prozessen durchgeführt. Events, Mutexe und Semaphoren können zur Synchronisierung genutzt werden, Shared Memory und Sockets dienen zur gemeinsamen Nutzung von Daten zur Kommunikation.

RTX64/RTX Anwendungsentwicklung

Bearbeiten

Die Anwendungsentwicklung für RTX64/RTX erfolgt mit Microsoft Visual Studio in C/C++ mit Windows-artigen APIs. RTX64/RTX ausführbare Dateien tragen die Namenserweiterungen «.rtss» und DLLs verwenden «.rtdll».

Netzwerk-Kommunikation

Bearbeiten

Der RT-TCP/IP-Echtzeit-Stack unterstützt TCP/UDP/IP-Netzwerke für RTX64/RTX-Prozesse; RTX64/RTX gemeinsame NICs-Treiber werden mit den RT-TCP/IP-Echtzeit-Stack bereitgestellt.

Einzelnachweise

Bearbeiten
  1. http://www.all-electronics.de/texte/anzeigen/49092/Transformiert-Windows-in-ein-RTOS
  2. Real-Time for Windows Support. United Electronic Industries, abgerufen am 12. April 2015.
  3. https://www.intervalzero.com/products/product-release-notices/
  4. IntervalZero: RTX64 Downloads
  5. http://www.computer-automation.de/steuerungsebene/industrie-pc/artikel/112952/2/
  6. http://www.businesswire.com/news/home/20120517005456/de/#.VSfBdvWJjcs
  7. IntervalZero Overview. IntervalZero, abgerufen am 17. April 2015.
  8. http://www.intervalzero.com/german/technische-daten-rtx-64rtx/