Professional Documents
Culture Documents
PA P E R
Gustavo Martinez,
Applications Engineer
Gagan Maur,
Applications Engineer
Texas Instruments
Abstract
Today, developers utilizing embedded pro-
performance and many different connectivity options are required. TI continues to extend the
capabilities of its SoCs by providing more connectivity options with every new generation.
Table 1 on the following page highlights the addition in connectivity options going from the
Even with these many connectivity options, the continuing innovation of developers and
diversity of applications invariably results in these devices lacking some elements needed by
the application. The missing attributes can be additional peripherals, system control inter-
It is often not possible to find a SoC that meets all requirements of an application and
trade-offs must be made. Application developers carefully consider different factors when
choosing the right processor for their application. These include cost, performance, power
consumption, peripheral features (e.g., Ethernet controller, USB, keypad controller, etc.) and
software support.
Often, application developers find that a particular SoC meets their performance, power,
and cost goals but does not meet all of their peripheral needs. Application developers have
few options when addressing this issue: implement the missing peripherals using an FPGA
or an ASIC, or use a combination of on-chip processor hardware and software to emulate the
missing peripheral.
Feature
requirements
SoC
features
Smart
peripheral
9-bit UART
Additional
SPI port
CAN
Serial ATA
Ethernet
connectivity,
DDR
Audio serial
interface,
port
NOR Flash
interface,
LCD
UART ports,
controller
SPI port
Texas Instruments
TMS320C674x*
DSP
TMS320C674x**
DSP
OMAP-L138
Processor
OMAP-L137
Processor
AM1808
MPU
AM1806
MPU
AM1707
MPU
AM1705
MPU
Floating-point
Floating-point/
Fixed-point
Floating-point/
Fixed-point
ARM926/
C6748
ARM926/
C6747
ARM926
ARM926
ARM926
ARM926
speed (Max)
456
456
456
456
456
456
511
511
511
511
511
511
DSP speed
300
456
456
456
456
600
3648
3648
3648
3648
I2C
Timers
CPU
ARM
Ethernet MAC
LCD controller
MMC/SD
Serial ATA
UART
USB
PWM
Using an FPGA or ASIC has several drawbacks. Both can be costly and require additional development
resources. Also, this approach requires additional board space which can be a problem for some size-constrained applications. Using discrete logic, for example a standalone Controller Area Network (CAN) controller,
increases the bill of materials cost and also requires resources to develop software drivers.
When implementing a peripheral through software, the application developer must consider the impact on
the performance of the main processor. If the main processor is heavily utilized, it may be necessary to lower
the performance of the implemented peripheral. In some cases, the real-time response requirements of the
peripheral are too demanding for the main processor to adequately handle without affecting other functionality.
Soft peripheral
approach with
the PRU
The PRU subsystem on the OMAP-L1x processors, C674x DSPs, and AM1x Sitara ARM MPUs allows the
application developer to implement soft peripherals; peripherals implemented using a combination of on-chip
hardware and software. Unlike soft peripherals implemented using the main processor, PRU soft peripherals
April 2011
Texas Instruments 3
do not take any processing time from the main processor. PRU soft peripherals can also be customized to
meet specific application requirements and they can be replaced on-the-fly with other soft peripherals.
The PRU subsystem is a programmable module which can be used for soft peripheral implementation,
specialized data handling, direct-memory access (DMA) operations, and for offloading tasks from the main
processor. The PRU subsystem consists of two 32-bit RISC cores (referred to as programmable real-time
units, or PRUs), local data and instruction memories, an interrupt controller for capturing and manipulating
system-wide events, and input/output pins. The PRU instruction set is simple and execution times
are deterministic.
A specialized DMA engine is an example of a soft peripheral that can be fully implemented by the PRU.
In other cases the PRU can leverage other SoC peripherals for tasks such as clock synchronization, external
input/output pins, and data computation to implement soft peripherals. Regardless of how it is implemented,
a soft peripheral is a programmable solution that is both flexible and customizable.
Table 2 lists some key features of the PRU subsystem when it comes to implementing soft peripherals.
Benefit
Each PRU has dedicated instruction and data memory and can operate
independently or in coordination with the ARM, DSP, or the other PRU
Use each PRU for a different task; use PRUs in tandem for more
advanced tasks
30 GPI
32 GPO
30 GPI
Interrupts to
ARM/DSP INTC
Events from
Periph + PRUs
PRU0 core
4KB IRAM
PRU1 core
4KB IRAM
Interrupt
controller
(INTC)
32 GPO
DRAM0
(512 Bytes)
DRAM1
(512 Bytes)
Master I/F
(to SCR2)
Slave I/F
(from SCR2)
April 2011
Texas Instruments
Fast, real-time
response
While generic general-purpose input/output (GPIO) pins can be used to implement some functions, GPIO supported by the SoC can be inadequate when a fast response time is required since often these pins cannot be
toggled or sampled at a very fast rate. The PRU includes dedicated, fast input/output pins which can be read
or toggled within a single cycle.
A soft CAN module is an example of where fast real-time response and fast input/output pins are required.
To adjust for frequency variations between CAN nodes, each receiving node must constantly adjust its
bit-sampling point. To meet this requirement, the CAN node must oversample its input pin at rates up to
25. The real-time response requirement is determined by the baud rate and the oversampling setting. For
example, when operating at a 150-kbit/sec rate with a 16 oversample clock, the CAN node has 416 sec
to process each bit. A 300-MHz DSP would have to process each bit every 126 cycles, which is possible but
extremely difficult to implement, but offloading such a task to the PRU would free up the DSP for more critical
tasks. Figure 3 shows a block diagram of a soft CAN implementation using the PRU. Note this implementation
is compatible, but not fully compliant, with the BOSCH CAN Specification 2.0B.
ARM/DSP
Interrupts
PRU RAM
MBX0
PRU0
Fast I/O
Soft CAN
CAN_RXD
CANH
Isolated
CAN
transceiver
MBX1
PRU1
MBX8
Fast I/O
CANL
CAN_TXD
PRUSS
Leveraging other
SoC resources
The PRU has access to all SoC resources including hardware peripherals, system memory, external memory,
and input/output pins. This allows the PRU subsystem to leverage other system resources to implement soft
peripherals. For example, a soft universal asynchronous receiver/transmitter (UART) can be implemented
using a serial port for data transmit and data receive using an 8 or 16 clock for oversampling. When data
is being received, the PRU could remove framing bits (start, stop, etc.), extract the actual data and transfer
the final result to SoC memory. For the transmit case, the PRU subsystem can move data from SoC memory,
add framing bits (start, stop, etc.) and directly access the serial port for transmission. Also, since the PRU is
programmable, custom features such as support for 9-bit characters and special baud rates can be added
to the soft UART. Figure 4 on the following page shows a block diagram of a soft UART implementation using
the PRU.
April 2011
Texas Instruments 5
ARM /DSP
Soft UART
Configure
Interrupts
AXINT
McASP
ARINT
Transmit buffer
TX_DATA [31:0]
Serializer
sUART_TXD
PRU
RX_DATA [31:0]
Receive buffer
Serializer
sUART_RXD
PRUSS
Conclusion
The PRU subsystem can be used to extend the functionality of existing SoCs by giving the system engineer
the capability to implement soft peripherals. Soft peripherals can vary from additional UARTs or SPI ports to
customized timers or DMA engines. Unlike traditional software peripherals, the PRU does not take processing
time away from the main processor(s) since it can operate independently. Furthermore, the reduced instruction set and deterministic operation of the PRU makes it easy to understand, allowing customers to quickly
start developing their own peripherals.
For additional information, please visit www.ti.com/sprc940-pru.
Important Notice: The products and services of Texas Instruments Incorporated and its subsidiaries described herein are sold subject to TIs standard terms and
conditions of sale. Customers are advised to obtain the most current and complete information about TI products and services before placing orders. TI assumes no liability
for applications assistance, customers applications or product designs, software performance, or infringement of patents. The publication of information regarding any
other companys products or services does not constitute TIs approval, warranty or endorsement thereof.
Sitara is a trademark of Texas Instruments Incorporated. All other trademarks are the property of their respective owners.
SPRY136A
IMPORTANT NOTICE
Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements,
and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should
obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are
sold subject to TIs terms and conditions of sale supplied at the time of order acknowledgment.
TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TIs standard
warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where
mandated by government requirements, testing of all parameters of each product is not necessarily performed.
TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and
applications using TI components. To minimize the risks associated with customer products and applications, customers should provide
adequate design and operating safeguards.
TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right,
or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information
published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a
warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual
property of the third party, or a license from TI under the patents or other intellectual property of TI.
Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied
by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive
business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional
restrictions.
Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all
express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not
responsible or liable for any such statements.
TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably
be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing
such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and
acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products
and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be
provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in
such safety-critical applications.
TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are
specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military
specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at
the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.
TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are
designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated
products in automotive applications, TI will not be responsible for any failure to meet such requirements.
Following are URLs where you can obtain information on other Texas Instruments products and application solutions:
Products
Applications
Audio
www.ti.com/audio
Amplifiers
amplifier.ti.com
www.ti.com/computers
Data Converters
dataconverter.ti.com
Consumer Electronics
www.ti.com/consumer-apps
DLP Products
www.dlp.com
www.ti.com/energy
DSP
dsp.ti.com
Industrial
www.ti.com/industrial
www.ti.com/clocks
Medical
www.ti.com/medical
Interface
interface.ti.com
Security
www.ti.com/security
Logic
logic.ti.com
www.ti.com/space-avionics-defense
Power Mgmt
power.ti.com
Transportation and
Automotive
www.ti.com/automotive
Microcontrollers
microcontroller.ti.com
www.ti.com/video
RFID
www.ti-rfid.com
Wireless
www.ti.com/wireless-apps
www.ti.com/lprf
TI E2E Community Home Page
e2e.ti.com
Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright 2011, Texas Instruments Incorporated