1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

A Generic AMP/IPC Framework For Linux

Linux Kernel

Published on 28 June 2011 08:48 AM EDT
Written by Michael Larabel in Linux Kernel
6 Comments

Being proposed by Ohad Ben-Cohen for integration into the mainline Linux kernel is a generic AMP/IPC framework. This a-symmetric multi-processing (AMP) framework with inter-process communication (IPC) integration makes it possible to control remote processors and communicate messages with these remote processors. This work is the primary target of modern SoC devices.

Modern SoC designs have a main SMP application processor that's usually running Linux, but then connected to them are often a-symmetric multi-processing processors, which may be running Linux or a different operating system entirely. These other processors are often for handling a specific task such as multi-media hardware acceleration. With this generic AMP/IPC framework, it's possible to control these remote AMP processors (power on, power off, boot) and to communicate (send/receive) messages to the remote units.

This generic framework introduces rpmsg, which is a VirtIO-based messaging bus for communicating between the Linux kernel and remote processors. The actual drivers of this framework then need to expose the user-space interface. The other part of the equation is remoteproc, which is a generic driver for maintaining the state of remote processors. Hardware differences are abstracted by this driver with the initial support being the OMAP4 Cortex-M3 and the Davinci DSP, from the Panda Board and Hawk Board, respectively.

For those interested in this new framework that could potentially be integrated into the mainline Linux 3.1 kernel, see the kernel mailing list announcement.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Articles & Reviews
  1. Khronos Group Announces Vulkan, OpenCL 2.1, SPIR-V
  2. Samsung 850 EVO SSD Linux Benchmarks
  3. Kubuntu 15.04 Is Turning Out Quite Nice, Good Way To Try Out The Latest KDE
  4. 5-Way Linux Distribution Comparison On The Core i3 NUC
  5. OCZ ARC 100 Linux SSD Benchmarks
  6. Lenovo ThinkPad X1 Carbon Works Great As A Linux Ultrabook
Latest Linux News
  1. NVIDIA Announces Shield Set-Top Gaming Box
  2. Valve Launches $49 Steam Link, SteamOS-Powered Streaming Device
  3. Valve Announces Source 2, It's Going To Be Free To Content Developers
  4. Gitorious Gets Acquired By GitLab
  5. Unity 5.0 Brings PhysX 3.3, WebGL Preview, Animation System Work
  6. Linux 4.0-rc2 Kernel Released After Delay Due To Intel DRM Driver
  7. Linux 3.19 Officially Lands For Ubuntu 15.04
  8. Clutter Now Supports Quad-Buffer Stereo Displays, Mir Backend
  9. Pricing Details On The Alleged MJ Ubuntu Tablet Design
  10. Understanding The Linux Kernel's BPF In-Kernel Virtual Machine
Most Viewed News This Week
  1. More Proof That Allwinner Is Violating The GPL
  2. The Tremendous Features Of Fedora 22
  3. Krita 2.9 Released, Their Biggest Release Ever
  4. A Single UEFI Executable With The Linux Kernel, Initrd & Command Line
  5. Xfce 4.12 Released After Nearly Three Years Of Work
  6. LLVM 3.6 & Clang 3.6 Deliver More Features, Complete C++14 Support
  7. Firefox 36 Brings Full HTTP/2 Support
  8. ALSA 1.0.29 Released
%%CLICK_URL_UNESC%%