Jump to content

ThreadX

From Wikipedia, the free encyclopedia
(Redirected from Express Logic)
Eclipse ThreadX
DeveloperExpress Logic (original)
Microsoft (former)
Eclipse Foundation (current)
Written inC
Working stateCurrent
Source modelOpen source
Initial release1997; 27 years ago (1997)
Latest release6.4.1[1] / February 28, 2024; 8 months ago (2024-02-28)
Repositorygithub.com/eclipse-threadx/threadx/
Marketing targetEmbedded systems, IoT: including sensors, devices, edge routers, gateways
Update methodRe-install
Package managerNone
PlatformsARC, ARM, Blackfin, CEVA, C6x, MIPS, NXP, PIC, PowerPC, RISC-V, RX, SH, SHARC, TI, V850, Xtensa, x86, Coldfire, others
Kernel typeEmbedded, deterministic, real-time microkernel, picokernel
Default
user interface
Embedded UI support (GUIX)
LicenseMIT License
Official websitethreadx.io

Eclipse ThreadX is a highly deterministic, embedded real-time operating system (RTOS) programmed mostly in the language C. Originally it was named ThreadX when Express Logic first developed it, later it was renamed to Azure RTOS after Express Logic was purchased by Microsoft, most recently it was renamed again to Eclipse ThreadX after it transitioned to open source model under the stewardship of the Eclipse Foundation.

Overview

[edit]

ThreadX was initially developed and marketed by Express Logic of San Diego, California, United States. The author of ThreadX is William Lamie,[2] who was also the original author of the Nucleus RTOS in 1990. William Lamie was President and CEO of Express Logic.

Express Logic was purchased for an undisclosed sum by Microsoft on April 18, 2019 and renamed it to Azure RTOS.[3] On November 21, 2023, Microsoft announced Azure RTOS would be transitioning to an open source model under the stewardship of the Eclipse Foundation, and making the project available under the permissive MIT License.[4] With Eclipse Foundation as the new home, Azure RTOS was renamed to Eclipse ThreadX, or "ThreadX" in its short form.

The name ThreadX is derived from the threads that are used as the executable elements, and the letter X represents context switching, i.e., it switches threads. ThreadX provides priority-based, preemptive scheduling, fast interrupt response, memory management, interthread communication, mutual exclusion, event notification, and thread synchronization features. Major distinguishing technology characteristics of ThreadX include preemption-threshold, priority inheritance, efficient timer management, fast software timers, picokernel design, event-chaining, and small size: minimal size on an ARM architecture processor is about 2 KB.

ThreadX supports multi-core processor environments via either asymmetric multiprocessing (AMP) or symmetric multiprocessing (SMP). Application thread isolation with memory management unit (MMU) or memory protection unit (MPU) memory protection is available with ThreadX Modules.

ThreadX has extensive safety certifications from Technischer Überwachungsverein (TÜV, English: Technical Inspection Association) and UL (formerly Underwriters Laboratories) and is Motor Industry Software Reliability Association MISRA C compliant.

ThreadX is the foundation of Express Logic's X-Ware Internet of things (IoT) platform, which also includes embedded file system support (FileX), embedded UI support (GUIX), embedded Internet protocol suite (TCP/IP) and cloud connectivity (NetX/NetX Duo), and Universal Serial Bus (USB) support (USBX). ThreadX has won high appraisal from developers and is a very popular RTOS.[5] As of 2017, according to marketing research firm VDC Research, the ThreadX RTOS has become one of the most popular RTOSes in the world, having been deployed in over 6.2 billion devices, including consumer electronics, medical devices, data networking applications, and SoCs.[6]

Supported platforms

[edit]
  • Analog Devices
    • Blackfin
    • CM4xx
    • Precision Microcontrollers
    • SHARC
    • ULP Microcontrollers
  • ARM
    • ARM7
    • ARM9
    • ARM Cortex-A
    • ARM Cortex-R
    • ARM Cortex-M
    • ARM Cortex-A 64-bit
    • ARMv8M TrustZone
  • Cadence
    • Xtensa
  • CEVA
    • TeakLite-III
  • Intel
    • Nios II
    • Cyclone
    • Arria 10
    • x86
  • Microchip
    • AVR32
    • PIC24
    • dsPIC33
    • PIC32
    • SAM C-V
    • SAM7
    • SAM9
    • SAMA5
  • MIPS
    • MIPS32 4Kx
    • MIPS32 14Kx
    • MIPS32 24Kx
    • MIPS32 34Kx
    • MIPS32 74Kx
    • MIPS32 1004Kx
    • interAptiv
    • microAptiv
    • proAptiv
    • M-Class
  • NXP
    • ColdFire+/ColdFire
    • i.MX
    • Kinetis
    • LPC
    • PowerPC
    • S32
  • Renesas
    • H8/300H
    • RX
    • RZ
    • SH
    • Synergy
    • V850
  • ST
    • STM32F0
    • STM32F1
    • STM32F2
    • STM32F3
    • STM32F4
    • STM32F7
    • STM32H5
    • STM32H7
    • STM32L
    • STM32U0
    • STM32U5
    • STM32WB
  • Silicon Labs
    • Gecko
    • Giant Gecko
    • Giant Gecko S1
    • Happy Gecko
    • Jade Gecko
    • Leopard Gecko
    • Pearl Gecko
    • Tiny Gecko
    • Wonder Gecko
    • Zero Gecko
  • ARC
    • ARC 600
    • ARC 700
    • ARC EM
    • ARC HS
  • Xilinx
    • Microblaze
    • Zynq-7000
    • Zynq UltraScale+

History

[edit]

ThreadX was first introduced in 1997. ThreadX 4 was introduced in 2001. ThreadX 5 was introduced in 2005, and is the latest version as of 2020.

FileX – the embedded file system for ThreadX was introduced in 1999.

NetX – the embedded TCP/IP networking stack for ThreadX was introduced in 2002.

USBX – the embedded USB support for ThreadX was introduced in 2004.

ThreadX SMP for SMP multi-core environments was introduced in 2009.

ThreadX Modules was introduced in 2011.

ThreadX achieved safety certifications for: TÜV IEC 61508 in 2013, and UL 60730 in 2014.

GUIX – the embedded UI for ThreadX was introduced in 2014.

Express Logic was purchased for an undisclosed sum by Microsoft on April 18, 2019.[3]

Technology

[edit]

ThreadX implements a priority-based, preemptive scheduling algorithm with a proprietary feature called preemption-threshold. The latter has been shown to provide greater granularity within critical sections, reduce context switches, and has been the subject of academic research on guaranteeing scheduling.[7]

ThreadX provides a unique construct called event chaining,[8] where the application can register a callback function on all application programming interfaces (APIs) that can signal an external event. This helps applications chain together various public objects in ThreadX such that one thread can effectively block on multiple objects.

ThreadX also provides counting semaphores, mutexes with optional priority inheritance, event flags, message queues, software timers, fixed sized block memory, and variable sized block memory. All APIs in ThreadX that block on resources also have an optional timeout.

ThreadX offers multi-core processor support via either AMP or SMP. Application code isolation is available through ThreadX Modules component.

Major components

[edit]

ThreadX RTOS components include:

  1. Embedded file system
  2. Embedded graphical user interface
  3. Embedded networking
  4. Embedded USB
  5. Safety certification
  6. Packaging

Embedded file system

[edit]

FileX is the embedded file system for ThreadX. FileX supports FAT12, 16, 32, and exFAT formats. The latter extends FAT file sizes beyond 4 GB, which is especially useful for video files, and it requires license directly from Microsoft for use. FileX also offers fault tolerance and supports direct NOR and NAND flash memory media through a flash wear leveling product called LevelX.

Embedded graphical user interface

[edit]

GUIX is the embedded graphical user interface (GUI) for ThreadX. GUIX provides a 2D runtime system (environment) for embedded applications running ThreadX. GUIX supports multiple display devices with a variety of screen resolutions and color depths. Many predefined graphical widgets are available. A Windows WYSIWYG host tool called GUIX Studio automatically generates C code for GUIX to execute at runtime.

Embedded networking

[edit]

NetX Duo is the embedded TCP/IP system for ThreadX. NetX Duo supports both IPv4 and IPv6 networking along with protocols such as ARP, Auto IP, DHCP, DNS, DNS-SD, FTP, HTTP, ICMP, IGMP, mDNS, POP3, PPP, PPPoE, RARP, TFTP, SNTP, SMTP, SNMP, and TELNET. IP layer network security is provided by IPsec. TCP and UDP socket layer security is provided by TLS and DTLS, respectively. IoT Cloud protocol support includes CoAP, MQTT, and LWM2M. NetX Duo also supports Thread and 6LoWPAN. In 2017, ThreadX and NetX Duo became a Thread Certified Product.[9]

Embedded USB

[edit]

USBX is the embedded Universal Serial Bus (USB) system for ThreadX. USBX supports both host and device. Host controller support includes EHCI, OHCI, and proprietary USB host controllers. USBX also supports OTG. USBX class support includes Audio, Asix, CDC/ACM, CDC/ECM, DFU, GSER, HID, PIMA, Printer, Prolific, RNDIS, and Storage.

Safety certification

[edit]

ThreadX (and FileX and NetX Duo) have been precertified by SGS-TÜV Saar to the following safety standards: IEC 61508 SIL 4, IEC 62304 Class C, ISO 26262 ASIL D, and EN 50128 SW-SIL 4.

ThreadX (and FileX and NetX Duo) have been precertified by UL to the following safety standards: UL/IEC 60730, UL/IEC 60335, UL 1998

ThreadX has also been certified to DO-178 standards by various military and aerospace companies. It is supported by popular Transport Layer Security (SSL/TLS) libraries such as wolfSSL.[10]

Packaging

[edit]

As of 2017, ThreadX is packaged as part of X-Ware IoT Platform in full source code and with no runtime royalty payment.

Products using it

[edit]

Some high-profile products using ThreadX range from small wearable devices, to Hewlett-Packard printers, and even NASA’s Deep Impact space probe.[11]

The Raspberry Pi line of single-board computers runs ThreadX as a binary blob on the graphics processing unit (GPU). This controls initial booting, which in turn is used to boot secondary operating systems such as Linux, and continues to operate in a more privileged role even after the boot process.[12]

See also

[edit]

References

[edit]
  1. ^ "Releases · eclipse-rtos/Threadx". GitHub.
  2. ^ Cole, Bernard; McConnel, Toni (September 3, 2010). "Bill Lamie: Story of a man and his real-time operating systems". Embedded. AspenCore.
  3. ^ a b Janakiram, MSV (April 21, 2019). "How Does The Express Logic Acquisition Help Microsoft and the IoT Ecosystem". Forbes.
  4. ^ "Microsoft Contributes Azure RTOS to Open Source". Microsoft. Retrieved 23 November 2023.
  5. ^ Carbone, John. "High Performance RTOS "ThreadX": Express Logic: Enabling Shorter Time to Market and Reduced Development Cost". Renesas.
  6. ^ "IoT & Embedded Operating Systems". VDC Research. Retrieved 2018-07-31.
  7. ^ Wang, Yun; Saksena, Manas. "Scheduling Fixed-Priority Tasks with Preemption Threshold" (PDF). Department of Computer Science. University of Utah.
  8. ^ "Event Chaining Enables Real-Time Systems to Respond to Multiple Real-Time Events More Efficient" (PDF). Express Logic.
  9. ^ "Thread Certified Products". Thread Group. Archived from the original on 2018-06-14. Retrieved 2018-01-11.
  10. ^ "wolfSSL with Improved ThreadX/NetX Support". wolfSSL. 2018-01-16. Retrieved 2019-02-13.
  11. ^ "NASA's "Deep Impact" employs embedded systems to score bullseye 80 million miles away". Military Embedded Systems.
  12. ^ nachoparker (February 2, 2019). "What's Wrong with the Raspberry Pi". Own Your Bits. Archived from the original on 2022-05-31. Retrieved 2024-03-09.
[edit]