Global Sources
EE Times-Asia
Stay in touch with EE Times Asia
EE Times-Asia > EDA/IP

RTOS packs real-time responsiveness for multicore

Posted: 18 May 2010 ?? ?Print Version ?Bookmark and Share

Keywords:multicore? RTOS? processor? embedded?

Express Logic, working in cooperation with MIPS Technologies, has developed ThreadX/SMP, an enhanced version of ThreadX that provides synchronous multicore support with real-time responsiveness called "Real-Time SMP." ThreadX/SMP enables developers to take advantage of the significant performance boost achieved by sharing the processing load over the multiple processor cores of the 1004K CPS, while maintaining the real-time responsiveness critical to demanding embedded applications.

For developers of products based on the 1004K CPS, ThreadX/SMP offers incremental processing, automatic load-balancing across all cores, easy application programming, use of same code for single and multicore versions, and increased performance without increased programming complexity.

ThreadX/SMP is based on Express Logic's ThreadX RTOS, a small, highly-efficient embedded OS that minimizes system overhead and provides lightning-fast real-time response. With as small as a 10Kbyte footprint and sub-microsecond interrupt response and context switch, ThreadX/SMP complements the multicore architecture of the 1004K CPS with the ease of SMP, while retaining hard real-time responsiveness.

ThreadX/SMP is designed for demanding real-time applications where high-efficiency and high-performance are imperative. Together, ThreadX/SMP and the 1004K CPS provide the system developer with a combination of high-performance and ease-of-use that speeds time to market.

MIPS Technologies' 1004K CPS offers up to four processors, each with one or two virtual processor execution units, and a unified shared memory accessible by all processors. Express Logic uses this shared memory to design a symmetric multiprocessor version of the ThreadX RTOS that runs concurrently on all processors from a single copy in shared memory. Application processing is automatically distributed across the processors as processing demands dictate, so the developer does not need to be concerned with managing multiple processors. Because of this, programming the 1004K CPS is as straightforward as developing an application for a single-core processor with the benefit of multicore performance.

"We're delighted that ThreadX/SMP will support licensees of our 1004K CPSthe industry's only licensable multi-threaded multiprocessing IP core," noted Art Swift, VP of marketing, MIPS Technologies. "The 1004K CPS leverages multi-threading to extend performance beyond traditional multiprocessor solutions. It is ideal for applications that demand high efficiency and real-time response, and the addition of ThreadX/SMP enhances these capabilities. Our combined solution will accelerate customer development in performance-hungry applications."

ThreadX/SMP achieves a high degree of ease-of-use by enabling multicore applications to be developed without needing to know the details of the 1004K architecture. ThreadX/SMP efficiently allocates and manages powerful hardware resources to maximize application thread efficiency. ThreadX/SMP transparently maps application threads to individual cores within the 1004K CPS, providing automatic load balancing.

The low overhead of ThreadX produces an efficient thread-to-core allocation and assignment, a feat that can be difficult for larger RTOS to achieve, especially when there are more threads than cores.

Real-Time SMP enables an application to apply the resources of multiple processors to serve its threads, without tailoring the program logic to manage and arbitrate among the processors. In a single processor system, once a top-priority thread begins execution, other threads must wait. With Real-Time SMP, threads of equal priority can run in parallel on the other processors, effectively balancing overload situations where one processor could not handle the volume of data requiring processing.

Using Real-Time SMP, the application can launch a second, third, and fourth thread to help with the processing. The additional threads can be defined at initialization and automatically run on any available processor as needed, or created dynamically as the executing thread identifies processing demand beyond its capabilities. The ThreadX/SMP scheduler can service up to four threads at a time as long as they are of equal priority. The developer can choose to define Real-Time SMP as fully automatic, allowing the RTOS scheduler to run threads on all processors as needed, or semi-automatic, where the application thread makes the determination that it wants to start another core to help with the workload.

When activated, the ThreadX scheduler determines the highest priority thread ready to run (READY). The scheduler then sets the context for that thread and causes it to run on processor-1. The scheduler also determines if there is an additional thread at the same priority, which also is READY. If so, that thread's context is set, and the thread run on processor-2. The scheduler then goes into idle to await an event or service request from an executing thread.

ThreadX/SMP enables developers to migrate existing multithreaded applications for a single core to the 1004K CPS in order to gain a significant performance boost without rewriting the application. ThreadX/SMP and the MIPS 1004K CPS enable applications to run faster, without a redesign.

ThreadX/SMP is available in full source code form, royalty-free, with project license prices starting at $15,500.

- Toni McConnel

Article Comments - RTOS packs real-time responsiveness ...
*? You can enter [0] more charecters.
*Verify code:


Visit Asia Webinars to learn about the latest in technology and get practical design tips.

Back to Top