



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Details                    |                                                          |
|----------------------------|----------------------------------------------------------|
| Product Status             | Active                                                   |
| Core Processor             | ·                                                        |
| Core Size                  | 32-Bit 8-Core                                            |
| Speed                      | 80MHz                                                    |
| Connectivity               | -                                                        |
| Peripherals                | -                                                        |
| Number of I/O              | 32                                                       |
| Program Memory Size        | 32KB (32K x 8)                                           |
| Program Memory Type        | ROM                                                      |
| EEPROM Size                | <u>.</u>                                                 |
| RAM Size                   | 32K x 8                                                  |
| Voltage - Supply (Vcc/Vdd) | <u>.</u>                                                 |
| Data Converters            |                                                          |
| Oscillator Type            | Internal                                                 |
| Operating Temperature      | <u>.</u>                                                 |
| Mounting Type              | Through Hole                                             |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                 |
| Supplier Device Package    | 40-DIP                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/parallax/p8x32a-d40 |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

#### **Table of Contents**

| <b>1.0</b><br>1.1.<br>1.2.<br>1.3.<br>1.3.1.<br>1.3.2.<br>1.3.3.<br>1.3.4.<br>1.4.<br>1.4.1.                                                                       | Product Overview   1     Introduction   1     Stock Codes   1     Key Features and Benefits   3     32-bit Multicore Architecture   3     Clock System and Wait Instructions   3     Programming Languages and Resources   3     Flexible I/O and Peripheral Interface   3     Applications   3     Corporate and Community Support   3                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>2.0</b><br>2.1.<br>2.2.<br>2.3.<br>2.3.1.                                                                                                                       | Connection Diagrams   4     Pin Assignments   4     Pin Descriptions   4     Typical Connection Diagrams   5     Propeller Clip or Propeller Plug Connection - Recommended   5                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2.3.2.<br>3.0<br>3.1.<br>3.2.<br>3.3.                                                                                                                              | Alternative Serial Port Connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>4.0</b><br>4.1.<br>4.2.<br>4.3.<br>4.4.<br>4.5.<br>4.6.<br>4.7.<br>4.8.<br>4.9.<br>4.9.<br>4.9.1.<br>4.9.2.<br>4.9.3.<br>4.10.1.<br>4.10.2.<br>4.10.3.<br>4.11. | System Organization     6       Shared Resources     6       System Clock     6       Cogs (processors)     7       Hub     7       I/O Pins     8       System Counter     8       Locks     8       Assembly Instruction Execution Stages     9       Cog Counters     10       CTRA / CTRB – Control register     10       FRQA / FRQB – Frequency register     10       PHSA / PHSB – Phase register     10       Video Generator     11       VCFG – Video Configuration Register     11       VSCL – Video Scale Register     12       WAITVID Command/Instruction     12       CLK Register     14 |
| <b>5.0</b><br>5.1.<br>5.1.2.<br>5.1.3.<br>5.1.4.                                                                                                                   | Memory Organization   15     Main Memory   15     Main RAM   15     Main ROM   15     Character Definitions   15     Math Function Tables   16                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| 5.2.                                                                                         | Cog RAM                                                                                                                                                                                                                                                                                     | 16                                           |
|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| <b>6.0</b><br>6.1.<br>6.2.<br>6.3.<br>6.3.1.<br>6.4.<br>6.4.1.<br>6.4.2.<br>6.4.3.<br>6.4.4. | Programming Languages                                                                                                                                                                                                                                                                       | 17<br>18<br>19<br>21<br>22<br>24<br>24<br>24 |
| <b>7.0</b><br>7.1.<br>7.2.<br>7.3.                                                           | Electrical Characteristics<br>Absolute Maximum Ratings<br>DC Characteristics<br>AC Characteristics                                                                                                                                                                                          | 25<br>25                                     |
| 8.0<br>8.1.<br>8.2.<br>8.3.<br>8.4.<br>8.5.<br>8.6.                                          | Current Consumption Characteristics<br>Typical Current Consumption of 8 Cogs<br>Typical Current of a Cog vs. Operating Frequency<br>Typical PLL Current vs. VCO Frequency<br>Typical Crystal Drive Current<br>Cog and I/O Pin Relationship<br>Current Profile at Various Startup Conditions | 26<br>27<br>27<br>28<br>28                   |
| <b>9.0</b><br>9.1.<br>9.2.<br>9.3.                                                           | Temperature Characteristics                                                                                                                                                                                                                                                                 | 30<br>31                                     |
| <b>10.0</b><br>10.1.<br>10.2.<br>10.3.                                                       | Package Dimensions       P8X32A-D40 (40-pin DIP)       P8X32A-Q44 (44-pin LQFP)       P8X32A-M44 (44-pin QFN)                                                                                                                                                                               | 33<br>34                                     |
| <b>11.0</b><br>11.1.<br>11.2.                                                                | Manufacturing Info<br>Reflow Peak Temperature<br>Green/RoHS Compliance                                                                                                                                                                                                                      | 36                                           |
| <b>12.0</b><br>12.1.1.<br>12.1.2.<br>12.1.3.<br>12.1.4.                                      | Revision History                                                                                                                                                                                                                                                                            | 36<br>36<br>36                               |

# 1.3. Key Features and Benefits

The P8X32A design frees developers from common complexities of embedded systems programming.

# 1.3.1. 32-bit Multicore Architecture

- True parallel processing with eight symmetric 32-bit processors (cogs) in one microcontroller
- Multi-cog run-time management (run/wait/stop) easily solves event-handling problems and eliminates the need for interrupts. This greatly simplifies programming for asynchronous and synchronous events, resulting in a responsive and easily maintained application.
- 20 MIPS per cog, 160 MIPS total with all cogs running
- Solves mixed-bandwidth needs common to embedded applications
- Multi-purpose design lowers part count while increasing system capabilities
- Developer-driven cog assignments bring flexible response and deterministic timing to embedded applications

# 1.3.2. Clock System and Wait Instructions

- Flexible Clock Modes
  - Two internal, one external, plus optional 1x–16x PLL; up to 80 MHz system clock
  - Switchable in code at run-time; low frequency for low-power periods, high frequency for high-bandwidth moments
- Shared System Clock facilitates synchronization between cogs
- WAIT Instructions
  - Deliver powerful synchronous / asynchronous event management
  - Set dedicated event cogs to an "always ready," very low power state

# 1.3.3. Programming Languages and Resources

- Spin (object-based, high-level) and Assembly (PASM; low-level); used together for thorough development, i.e. fast development in Spin plus fast execution with prewritten high-speed PASM drivers
- Third-party support: C, BASIC, and more
- Enhanced Assembly Language
  - Conditional execution for individual instructions; enables jitter-free signal generation and event handling
  - Optional flag and result writing for individual instructions
- Open-source Objects
  - Objects are shared freely via the Propeller Object Exchange and Propeller Tool libraries
  - Select objects that fit a need, easily integrate them into a Propeller application

# 1.3.4. Flexible I/O and Peripheral Interface

# • 32 I/O Pins

- All general-purpose I/O after boot-up; accessible by every cog simultaneously
- Single-instruction access to any individual I/O pin or any contiguous I/O pin group
- Easily move designed functions between pins for simple system board layout
- Multi-function Counters
  - Configurable state machines generate or sense repetitive signals per clock cycle
  - Measure frequency, detect edges, count cycles, D/A or A/D conversion, and more
  - Operate autonomously with optional run-time monitoring and adjusting
  - Two counters per cog
- Video Generators
  - o RGB: VGA; 8 I/O pins
  - Composite: NTSC, PAL; 1-pin (B/W), 3-pin (typical), or 4-pin (optional)
  - One generator per cog
- Software Peripherals
  - Peripheral interfaces built with software and inexpensive passive components; not singlefunction on-chip hardware
  - Software-based interfaces are flexible; enhance as peripheral needs arise — no need to redesign with a chip variant

# 1.4. Applications

The P8X32A is particularly useful in projects that can be vastly simplified with simultaneous processing, including:

- Industrial control systems
- Sensor integration, signal processing, and data acquisition
- Handheld portable human-interface terminals
- Motor and actuator control
- User interfaces requiring NTSC, PAL, or VGA output, with PS/2 keyboard and mouse input
- Low-cost video game systems
- Industrial, educational or personal-use robotics
- Wireless video transmission (NTSC or PAL)

# 1.4.1. Corporate and Community Support

- Sales or technical support: (916) 632-4664
- Email sales: sales@parallaxsemiconductor.com
- Email support: support@parallaxsemiconductor.com
- Engineer-moderated Parallax Semiconductor subforum is available from http://forums.parallax.com
- Parallax-hosted Propeller Object Exchange library: http://obex.parallax.com

### 4.8. Assembly Instruction Execution Stages

Stage 1 2 3 4 5 (Execute N-1) (Execute N) Fetch Write Fetch Fetch Fetch Write Destination Instruction Instruction Result Source Result Ν N-1 Ν Ν N+1 Ν Μ M+1 M+2 M+3 M+4 M+5 clock cycle

Figure 4: Assembly Instruction Execution Stages

The Propeller executes assembly instructions in five stages. While an entire instruction takes six cycles to execute, two of those clock cycles are dedicated to the two adjacent instructions. This results in an overall throughput of four clock cycles per instruction.



In Stage 1, instruction N, pointed to by the Program Counter, is fetched from cog memory during clock cycle M. During cycle M+1 the result from the previous instruction is written to memory. The reason the previous instruction result is written after the current instruction is fetched will be explained shortly.

During Stage 2, if the immediate flag of Instruction N is set, the 9 bit source field is saved as the source value. If the value is not immediate, the location specified by the source field is fetched from cog memory during clock cycle M+2. During clock cycle M+3 the location specified in the destination field is fetched from cog memory (Stage 3).

At this point in time (Stage 4) the Arithmetic Logic Unit (ALU) has all the information needed to execute the instruction. Executing the instruction takes some amount of time before the result is available. The amount of time required for execution is dictated by the slowest operation the ALU performs. To provide enough time for the ALU to execute the instruction, a full clock cycle (M+4) is provided to the ALU for the result to settle into its final state. During this execution, the cog memory is not accessed by instruction N. To speed up the throughput of program execution, the next instruction to be executed is fetched from cog memory while the current instruction is executed in the ALU.

Finally at clock cycle M+5 the result of the current instruction N is written back to cog memory, completing Stage 5.

The partial interleaving of instructions has a couple implications to program flow. First, when code modification occurs through MOVI, MOVS, MOVD or any operations which modifies an assembly instruction, there must be at least one instruction executed before the modified instruction is executed. If the modification is done on the immediately following instruction (N+1), the unmodified version of instruction N+1 will be loaded a clock cycle before the modified version of instruction N+1 is written to cog memory.

Second, conditional jumps do not know for certain if they will jump until the end of clock cycle M+4. Since the next instruction has already been fetched, only one of the two possible branches can be predicted. In the Propeller, conditional branches are always predicted to take the jump. For loops using **DJNZ** where the jump is taken every time except the final loop, a tighter execution time of the loop is achieved.

In the event the jump is not taken, the cog takes no action until the next instruction is fetched. This is equivalent to a NOP being inserted before the next instruction is executed. Unconditional jumps always take four clock cycles to execute since the Propeller can always accurately predict what address needs to be loaded into the Program Counter for the next instruction to execute. Examples of unconditional jumps include JMP, JMPRET, CALL and RET.

If an instruction needs to access any Hub resource, Stage 4 is extended until the Hub becomes available, increasing execution time to at least 8 and potentially up to 23 clock cycles. See Section 4.4: Hub on page 7.

#### 4.11. CLK Register

The CLK register is the System Clock configuration control; it determines the source and characteristics of the System Clock. It configures the RC Oscillator, Clock PLL, Crystal Oscillator, and Clock Selector circuits (See the Block Diagram, page 1). It is configured at compile time by the **\_CLKMODE** declaration and is writable at run time through the **CLKSET** command. Whenever the CLK register is written, a global delay of ~75  $\mu$ s occurs as the clock source transitions.

Whenever this register is changed, a copy of the value written should be placed in the Clock Mode value location (which is BYTE[4] in Main RAM) and the resulting master clock frequency should be written to the Clock Frequency value location (which is LONG[0] in Main RAM) so that objects which reference this data will have current information for their timing calculations.

Use Spin's **CLKSET** command when possible (see sections 6.3 and 6.4) since it automatically updates all the abovementioned locations with the proper information.

| Table 13: Valid Clock Modes                                                             |                                                                                                                               |                                                                                                     |                                                                                                                                            |  |  |  |  |  |
|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Valid Expression                                                                        | CLK Reg. Value                                                                                                                | Valid Expression                                                                                    | CLK Reg. Value                                                                                                                             |  |  |  |  |  |
| RCFAST                                                                                  | 0_0_0_00_000                                                                                                                  | XTAL1 + PLL1X<br>XTAL1 + PLL2X                                                                      | 0_1_1_01_011<br>0 1 1 01 100                                                                                                               |  |  |  |  |  |
| RCSLOW                                                                                  | 0_0_0_00_001                                                                                                                  | XTAL1 + PLL4X<br>XTAL1 + PLL8X                                                                      | $0_1_1_01_101$<br>$0_1_1_01_101$<br>$0_1_1_01_110$                                                                                         |  |  |  |  |  |
| XINPUT                                                                                  | 0_0_1_00_010                                                                                                                  | XTAL1 + PLL16X                                                                                      | 0_1_1_01_111                                                                                                                               |  |  |  |  |  |
| XTAL1<br>XTAL2<br>XTAL3                                                                 | 0_0_1_01_010<br>0_0_1_10_010<br>0_0_1_11_010                                                                                  | XTAL2 + PLL1X<br>XTAL2 + PLL2X<br>XTAL2 + PLL4X<br>XTAL2 + PLL8X<br>XTAL2 + PLL8X<br>XTAL2 + PLL16X | $\begin{array}{c} 0\_1\_1\_10\_011\\ 0\_1\_1\_10\_100\\ 0\_1\_1\_10\_101\\ 0\_1\_1\_10\_110\\ 0\_1\_1\_10\_111\\ \end{array}$              |  |  |  |  |  |
| XINPUT + PLL1X<br>XINPUT + PLL2X<br>XINPUT + PLL4X<br>XINPUT + PLL8X<br>XINPUT + PLL16X | $\begin{array}{c} 0\_1\_1\_00\_011\\ 0\_1\_1\_00\_100\\ 0\_1\_1\_00\_101\\ 0\_1\_1\_00\_110\\ 0\_1\_1\_00\_111\\ \end{array}$ | XTAL3 + PLL1X<br>XTAL3 + PLL2X<br>XTAL3 + PLL4X<br>XTAL3 + PLL8X<br>XTAL3 + PLL16X                  | $\begin{array}{c} 0\_1\_1\_11\_011\\ 0\_1\_1\_11\_100\\ 0\_1\_1\_11\_101\\ 0\_1\_1\_11\_11\\ 0\_1\_1\_11\_11\\ 0\_1\_1\_11\_11\end{array}$ |  |  |  |  |  |

|         | Table 14: CLK Register Fields                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |             |               |                                 |                                 |                 |  |  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|---------------|---------------------------------|---------------------------------|-----------------|--|--|
| Bit     | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5                | 4           | 3             | 2                               | 1                               | 0               |  |  |
| Name    | RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PLLENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | OSCENA           | OSCM1       | OSCM2         | CLKSEL2                         | CLKSEL1                         | CLKSEL0         |  |  |
| RESET   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  | Ef          | fect          | ·                               | ·                               |                 |  |  |
| 0       | Always write '0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ' here unless yo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | u intend to rese | t the chip. |               |                                 |                                 |                 |  |  |
| 1       | Same as a har                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | dware reset – re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | boots the chip.  |             |               |                                 |                                 |                 |  |  |
| PLLENA  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  | Ef          | fect          |                                 |                                 |                 |  |  |
| 0       | Disables the P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | LL circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |             |               |                                 |                                 |                 |  |  |
| 1       | XIN signal to t<br>frequency range<br>CLKSEL bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Enables the PLL circuit. The PLL internally multiplies the XIN pin frequency by 16. OSCENA must be '1' to propagate the XIN signal to the PLL. The PLL's internal frequency must be kept within 64 MHz to 128 MHz – this translates to an XIN frequency range of 4 MHz to 8 MHz. Allow 100 µs for the PLL to stabilize before switching to one of its outputs via the CLKSEL bits. Once the OSC and PLL circuits are enabled and stabilized, you can switch freely among all clock sources by changing the CLKSEL bits. |                  |             |               |                                 |                                 |                 |  |  |
| OSCENA  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  | Ef          | fect          |                                 |                                 |                 |  |  |
| 0       | Disables the O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |             |               |                                 |                                 |                 |  |  |
| 1       | Enables the OSC circuit so that a clock signal can be input to XIN, or so that XIN and XOUT can function together as a feedback oscillator. The OSCM bits select the operating mode of the OSC circuit. Note that no external resistors or capacitors are required for crystals and resonators. Allow a crystal or resonator 10 ms to stabilize before switching to an OSC or PLL output via the CLKSEL bits. When enabling the OSC circuit, the PLL may be enabled at the same time so that they can share the stabilization period. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |             |               |                                 |                                 |                 |  |  |
| OSCM1   | OSCM2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | esistance        | XIN and XOU | T Capacitance | ce Frequency Range              |                                 |                 |  |  |
| 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Infi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | nite             | 6 pF (      | pad only)     | DC to 80 MHz                    | Input                           |                 |  |  |
| 0       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 Ω              | 36          | β pF          | 4 MHz to 16 MI                  | Hz Crystal/Reso                 | al/Resonator    |  |  |
| 1       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 Ω              | 26          | 6 pF          | 8 MHz to 32 MI                  | MHz to 32 MHz Crystal/Resonator |                 |  |  |
| 1       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 500                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Ω Ω              | 16          | 6 pF          | 20 MHz to 60 N                  | /IHz Crystal/Res                | onator          |  |  |
| CLKSEL2 | CLKSEL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CLKSEL0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Master           | r Clock     | Source        |                                 | Notes                           |                 |  |  |
| 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ~12              | MHz         | Internal      | No external parts (8 to 20 MHz) |                                 | )               |  |  |
| 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ~20              | kHz         | Internal      | No external par                 | rts, very low pow               | ver (13-33 kHz) |  |  |
| 0       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Х                | IN          | OSC           | OSCENA must                     | be '1'                          |                 |  |  |
| 0       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | XIN              | × 1         | OSC+PLL       | OSCENA and I                    | PLLENA must b                   | e '1'           |  |  |
| 1       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | XIN              | × 2         | OSC+PLL       | OSCENA and I                    | PLLENA must b                   | e '1'           |  |  |
| 1       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | XIN              | × 4         | OSC+PLL       | OSCENA and PLLENA must be '1'   |                                 |                 |  |  |
| 1       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | XIN              | × 8         | OSC+PLL       | OSCENA and I                    | PLLENA must be                  | e '1'           |  |  |
| 1       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | XIN              | × 16        | OSC+PLL       | OSCENA and I                    | PLLENA must b                   | e '1'           |  |  |



As shown in Figure 8, The character pairs are merged row-by-row such that each character's 16 horizontal pixels are spaced apart and interleaved with their neighbors' so that the even character takes bits 0, 2, 4, ...30, and the odd character takes bits 1, 3, 5, ...31. The leftmost pixels are in the lowest bits, while the rightmost pixels are in the highest bits. This forms a long for each row of pixels in the character pair. 32 such longs, building from top row down to bottom, make up the complete merged-pair definition. The definitions are encoded in this manner so that a cog's video hardware can handle the merged longs directly, using color selection to display either the even or the odd character.

Some character codes have inescapable meanings, such as 9 for Tab, 10 for Line Feed, and 13 for Carriage Return. These character codes invoke actions and do not equate to static character definitions. For this reason, their character definitions have been used for special four-color characters. These four-color characters are used for drawing 3-D box edges at run-time and are implemented as 16 x 16 pixel cells, as opposed to the normal 16 x 32 pixel cells. They occupy even-odd character pairs 0-1, 8-9, 10-11, and 12-13.

#### 5.1.4. Math Function Tables

Base-2 Log and Anti-Log tables, each with 2048 unsigned words, facilitate converting values to and from exponent form to facilitate some operations; see the Propeller Manual for access instructions. Also, a sine table provides 2049 unsigned 16-bit sine samples spanning 0° to 90° inclusively (0.0439° resolution).

### 5.2. Cog RAM

As stated in Section 4.3, the Cog RAM is used for executable code, data, and variables, and the last 16 locations serve as interfaces to the System Counter, I/O pins, and local cog peripherals (see Table 15). Cog RAM is long-addressable only.

When a cog is booted up, locations 0 (\$000) through 495 (\$1EF) are loaded sequentially from Main RAM / ROM and its special purpose locations, 496 (\$1F0) through 511 (\$1FF), are cleared to zero. Each Special Purpose register may be accessed via its physical address, its predefined name, or indirectly in Spin via a register array variable SPR with an index of 0 to 15, the last four bits of the register's address.

|       | Table 15: Cog RAM Special Purpose Registers |   |         |      |                         |                                             |  |  |  |  |
|-------|---------------------------------------------|---|---------|------|-------------------------|---------------------------------------------|--|--|--|--|
| Cog R | АМ Мар                                      |   | Address | Name | Туре                    | Description                                 |  |  |  |  |
|       |                                             |   | \$1F0   | PAR  | Read-Only <sup>1</sup>  | Boot Parameter                              |  |  |  |  |
| \$000 |                                             |   | \$1F1   | CNT  | Read-Only <sup>1</sup>  | System Counter                              |  |  |  |  |
|       |                                             |   | \$1F2   | INA  | Read-Only <sup>1</sup>  | Input States for P31 - P0                   |  |  |  |  |
|       |                                             |   | \$1F3   | INB  | Read-Only <sup>1</sup>  | Input States for P63- P32 <sup>3</sup>      |  |  |  |  |
|       |                                             |   | \$1F4   | OUTA | Read/Write              | Output States for P31 - P0                  |  |  |  |  |
|       | General Purpose                             |   | \$1F5   | OUTB | Read/Write              | Output States for P63 – P32 <sup>3</sup>    |  |  |  |  |
|       | Registers                                   |   | \$1F6   | DIRA | Read/Write              | Direction States for P31 - P0               |  |  |  |  |
|       | (496 x 32)                                  |   | \$1F7   | DIRB | Read/Write              | Direction States for P63 - P32 <sup>3</sup> |  |  |  |  |
|       |                                             |   | \$1F8   | CTRA | Read/Write              | Counter A Control                           |  |  |  |  |
|       |                                             |   | \$1F9   | CTRB | Read/Write              | Counter B Control                           |  |  |  |  |
|       |                                             |   | \$1FA   | FRQA | Read/Write              | Counter A Frequency                         |  |  |  |  |
| \$IEF |                                             |   | \$1FB   | FRQB | Read/Write              | Counter B Frequency                         |  |  |  |  |
| \$IF0 | Special Purpose<br>Registers                |   | \$1FC   | PHSA | Read/Write <sup>2</sup> | Counter A Phase:                            |  |  |  |  |
| \$IFF | (16 x 32)                                   |   | \$1FD   | PHSB | Read/Write <sup>2</sup> | Counter B Phase                             |  |  |  |  |
|       |                                             | l | \$1FE   | VCFG | Read/Write              | Video Configuration                         |  |  |  |  |
|       |                                             |   | \$1FF   | VSCL | Read/Write              | Video Scale                                 |  |  |  |  |

Note 1: Only accessible as a source register (i.e. MOV Dest, Source).

**Note 2:** Only readable as a Source Register (i.e. MOV *Dest, Source*); read-modify-write not possible as a Destination Register. **Note 3:** Reserved for future use.

# 6.0 PROGRAMMING LANGUAGES

The Propeller chip is programmed using two languages designed specifically for it: 1) Spin, a high-level object-based language, and 2) Propeller Assembly, a low-level, highly-optimized assembly language. There are many hardware-based commands in Propeller Assembly that have direct equivalents in the Spin language.

The Spin language is compiled by the Propeller Tool software into tokens that are interpreted at run time by the Propeller chip's built-in Spin Interpreter. The Propeller Assembly language is assembled into pure machine code by the Propeller Tool and is executed in its pure form at run time.

Propeller Objects can be written entirely in Spin or can use various combinations of Spin and Propeller Assembly. It is often advantageous to write objects almost entirely in Propeller Assembly, but at least two lines of Spin code are required to launch the final application.

# 6.1. Reserved Word List

All words listed are always reserved, whether programming in Spin or in Propeller Assembly. As of Propeller Tool v1.05:

|                       | Table 16: Reserved Word List |                           |                        |                     |                      |                       |  |  |  |
|-----------------------|------------------------------|---------------------------|------------------------|---------------------|----------------------|-----------------------|--|--|--|
| _CLKFREQ <sup>s</sup> | COGINIT <sup>d</sup>         | IF_C_AND_NZ <sup>a</sup>  |                        | NOP <sup>a</sup>    | REPEAT <sup>S</sup>  | TRUE <sup>d</sup>     |  |  |  |
| _CLKMODE <sup>s</sup> | COGNEW <sup>S</sup>          | IF_C_AND_Z <sup>a</sup>   | LOCKRET                | NOT <sup>s</sup>    | RES <sup>a</sup>     | TRUNC <sup>S</sup>    |  |  |  |
| _FREE <sup>s</sup>    | COGSTOP <sup>d</sup>         | IF_C_EQ_Z <sup>a</sup>    | LOCKSET <sup>d</sup>   | NR <sup>a</sup>     | RESULT <sup>S</sup>  | UNTIL <sup>S</sup>    |  |  |  |
| _STACK <sup>S</sup>   | CON <sup>S</sup>             | IF_C_NE_Z <sup>a</sup>    | LONG <sup>S</sup>      | OBJ <sup>s</sup>    | RET <sup>a</sup>     | VAR <sup>s</sup>      |  |  |  |
| _XINFREQ <sup>s</sup> | CONSTANT <sup>S</sup>        | IF_C_OR_NZ <sup>a</sup>   | LONGFILL <sup>S</sup>  | ONES <sup>a</sup> # | RETURN <sup>S</sup>  | VCFG <sup>d</sup>     |  |  |  |
| ABORT <sup>S</sup>    | CTRA                         | IF_C_OR_Z <sup>a</sup>    | LONGMOVE <sup>S</sup>  | $OR^{\mathrm{d}}$   | REV <sup>a</sup>     | VSCL <sup>d</sup>     |  |  |  |
| ABS <sup>a</sup>      | CTRB <sup>d</sup>            | IF_E <sup>a</sup>         | LOOKDOWN <sup>S</sup>  | ORG <sup>a</sup>    | ROL <sup>a</sup>     | WAITCNT               |  |  |  |
| ABSNEG <sup>a</sup>   | DAT <sup>s</sup>             | IF_NC <sup>a</sup>        | LOOKDOWNZ <sup>S</sup> | OTHER <sup>s</sup>  |                      | WAITPEQ <sup>d</sup>  |  |  |  |
| ADD <sup>a</sup>      | DIRA                         |                           | LOOKUP <sup>s</sup>    | OUTAd               |                      | WAITPNE               |  |  |  |
| ADDABS <sup>a</sup>   | DIRB <sup>d#</sup>           | IF_NC_AND_Z <sup>a</sup>  | LOOKUPZ <sup>S</sup>   | OUTB <sup>d#</sup>  | SAR <sup>a</sup>     | WAITVID <sup>d</sup>  |  |  |  |
| ADDS <sup>a</sup>     | DJNZ <sup>a</sup>            | IF_NC_OR_NZ <sup>a</sup>  | MAX <sup>a</sup>       | PAR <sup>d</sup> .  | SHL <sup>a</sup>     | WC <sup>a</sup>       |  |  |  |
| ADDSX <sup>a</sup>    | ELSE <sup>s</sup>            | IF_NC_OR_Z <sup>a</sup>   | MAXS <sup>a</sup>      | PHSAd               |                      | WHILE <sup>S</sup>    |  |  |  |
| ADDX <sup>a</sup>     | ELSEIF <sup>s</sup>          | IF_NE <sup>a</sup>        | MIN <sup>a</sup>       | PHŞB <sup>d</sup>   | SPR <sup>s</sup>     | WORD <sup>S</sup>     |  |  |  |
| and                   | ELSEIFNOT <sup>S</sup>       | IF_NEVER <sup>a</sup>     | MINS <sup>a</sup>      | PI <sup>d</sup>     |                      | WORDFILL <sup>S</sup> |  |  |  |
| andn <sup>a</sup>     | ENC <sup>a#</sup>            | IF_NZ <sup>a</sup>        | MOV <sup>a</sup>       | PLL1X <sup>s</sup>  | STRCOMP <sup>S</sup> | WORDMOVE <sup>S</sup> |  |  |  |
| BYTE <sup>s</sup>     | FALSE <sup>d</sup>           | IF_NZ_AND_C <sup>a</sup>  | MOVD <sup>a</sup>      | PLL2X <sup>s</sup>  | STRING <sup>S</sup>  | WR <sup>a</sup>       |  |  |  |
| BYTEFILL <sup>S</sup> | FILE <sup>s</sup>            | IF_NZ_AND_NC <sup>a</sup> | MOVI <sup>a</sup>      | PLL4X <sup>s</sup>  |                      | WRBYTE <sup>a</sup>   |  |  |  |
| BYTEMOVE <sup>S</sup> | FIT <sup>a</sup>             | IF_NZ_OR_C <sup>a</sup>   | MOVS                   | PLL8X <sup>s</sup>  |                      | WRLONG <sup>a</sup>   |  |  |  |
| CALL <sup>a</sup>     | FLOAT <sup>S</sup>           | IF_NZ_OR_NC <sup>a</sup>  | MUL <sup>a#</sup>      | PLL16X <sup>s</sup> |                      | WRWORD <sup>a</sup>   |  |  |  |
| CASE <sup>s</sup>     | FROM                         | IF_Z <sup>a</sup>         | MULS <sup>a#</sup>     | POSX <sup>d</sup>   |                      | WZ <sup>a</sup>       |  |  |  |
| CHIPVER <sup>s</sup>  | FRQA                         | IF_Z_AND_C <sup>a</sup>   | MUXC <sup>a</sup>      | PRI <sup>s</sup>    | SUBSX <sup>a</sup>   | XINPUT <sup>S</sup>   |  |  |  |
| CLKFREQ <sup>s</sup>  | FRQB <sup>d</sup>            | IF_Z_AND_NC <sup>a</sup>  | MUXNC <sup>a</sup>     | PUB <sup>s</sup>    | SUBX <sup>a</sup>    | XOR <sup>a</sup>      |  |  |  |
| CLKMODĘ <sup>s</sup>  | HUBOP <sup>a</sup>           | IF_Z_EQ_C <sup>a</sup>    | MUXNZ <sup>a</sup>     | QUIT <sup>S</sup>   | SUMC <sup>a</sup>    | XTAL1 <sup>s</sup>    |  |  |  |
| CLKSET <sup>d</sup>   | IF <sup>s</sup>              | IF_Z_NE_C <sup>a</sup>    | MUXZ <sup>a</sup>      | RCFAST <sup>S</sup> | SUMNC <sup>a</sup>   | XTAL2 <sup>s</sup>    |  |  |  |
| CMP <sup>a</sup>      | IFNOT <sup>S</sup>           | IF_Z_OR_C <sup>a</sup>    | NEG <sup>a</sup>       | RCL <sup>a</sup>    | SUMNZ <sup>a</sup>   | XTAL3 <sup>s</sup>    |  |  |  |
| CMPS <sup>a</sup>     | IF_A <sup>a</sup>            | IF_Z_OR_NC <sup>a</sup>   | NEGC <sup>a</sup>      | RCR <sup>a</sup>    | SUMZ <sup>a</sup>    |                       |  |  |  |
| CMPSUB <sup>a</sup>   | IF_AE <sup>a</sup>           | INA                       | NEGNC <sup>a</sup>     | RCSLOW <sup>S</sup> | TEST <sup>a</sup>    |                       |  |  |  |
| CMPSX <sup>a</sup>    | IF_ALWAYS <sup>a</sup>       | INB <sup>d#</sup>         | NEGNZ <sup>a</sup>     | RDBYTE <sup>a</sup> | TESTN <sup>a</sup>   |                       |  |  |  |
| CMPX <sup>a</sup>     | IF_B <sup>a</sup>            | JMP <sup>a</sup>          | NEGX <sup>d</sup>      | RDLONG <sup>a</sup> | TJNZ <sup>a</sup>    |                       |  |  |  |
| CNT <sup>d</sup>      | IF_BE <sup>a</sup>           | JMPRET <sup>a</sup>       | NEGZ <sup>a</sup>      |                     | TJZ <sup>a</sup>     |                       |  |  |  |
| COGID <sup>d</sup>    | IF_C <sup>a</sup>            | LOCKCLR <sup>d</sup>      | NEXT <sup>S</sup>      | REBOOT <sup>S</sup> | TO <sup>s</sup>      |                       |  |  |  |

a = Assembly element; s = Spin element; d = dual (available in both languages); # = reserved for future use

#### 6.1.1. Words Reserved for Future Use

- **DIRB**, **INB**, and **OUTB**: Reserved for future use with a possible 64 I/O pin model. When used with the P8X32A, these labels can be used to access Cog RAM at those locations for general-purpose use.
- ENC, MUL, MULS, ONES: Use with the current P8X32A architecture yields indeterminate results.

#### Math and Logic Operators 6.2.

| Table 17: Math and Logic Operators   Operator Constant |        |                     |                                      |                  |          |                                                    |  |  |  |
|--------------------------------------------------------|--------|---------------------|--------------------------------------|------------------|----------|----------------------------------------------------|--|--|--|
| 1                                                      | Оре    | rator               | Constant<br>Expressions <sup>3</sup> |                  |          |                                                    |  |  |  |
| Level <sup>1</sup>                                     | Normal | Assign <sup>2</sup> | Integer                              | Float            | Is Unary | Description                                        |  |  |  |
|                                                        |        | always              |                                      |                  | ✓        | Pre-decrement (X) or post-decrement (X).           |  |  |  |
|                                                        | ++     | always              |                                      |                  | ✓        | Pre-increment (++X) or post-increment (X++).       |  |  |  |
|                                                        | ~      | always              |                                      |                  | ✓        | Sign-extend bit 7 (~X) or post-clear to 0 (X~).    |  |  |  |
| Highest<br>(0)                                         | ~~     | always              |                                      |                  | ✓        | Sign-extend bit 15 (~~X) or post-set to -1 (X~~).  |  |  |  |
| (0)                                                    | ?      | always              |                                      |                  | ✓        | Random number forward (?X) or reverse (X?).        |  |  |  |
|                                                        | e      | never               | ~                                    |                  | ✓        | Symbol address.                                    |  |  |  |
|                                                        | 66     | never               |                                      |                  | ✓        | Object address plus symbol.                        |  |  |  |
|                                                        | +      | never               | ~                                    | ~                | ✓        | Positive (+X); unary form of Add.                  |  |  |  |
|                                                        | -      | if solo             | ✓                                    | ✓                | ✓        | Negate (-X); unary form of Subtract.               |  |  |  |
|                                                        | ~^     | if solo             | ~                                    | ~                | ✓        | Square root.                                       |  |  |  |
| 1                                                      | - 11   | if solo             | ~                                    | ~                | ✓        | Absolute value.                                    |  |  |  |
| -                                                      | <      | if solo             | ~                                    |                  | ✓        | Bitwise: Decode 0 – 31 to long w/single-high-bit.  |  |  |  |
|                                                        | >      | if solo             | ~                                    |                  | ✓        | Bitwise: Encode long to 0 – 32; high-bit priority. |  |  |  |
|                                                        | !      | if solo             | ~                                    |                  | ✓        | Bitwise: NOT.                                      |  |  |  |
|                                                        | <-     | <-=                 | ~                                    |                  |          | Bitwise: Rotate left.                              |  |  |  |
|                                                        | ->     | ->=                 | ~                                    |                  |          | Bitwise: Rotate right.                             |  |  |  |
| 2                                                      | <<     | <<=                 | ~                                    |                  |          | Bitwise: Shift left.                               |  |  |  |
|                                                        | >>     | >>=                 | ✓                                    |                  |          | Bitwise: Shift right.                              |  |  |  |
|                                                        | ~>     | ~>=                 | ✓                                    |                  |          | Shift arithmetic right.                            |  |  |  |
|                                                        | ><     | ><=                 | ✓                                    |                  |          | Bitwise: Reverse.                                  |  |  |  |
| 3                                                      | &      | &=                  | ✓                                    |                  |          | Bitwise: AND.                                      |  |  |  |
| 4                                                      |        | =                   | ✓                                    |                  |          | Bitwise: OR.                                       |  |  |  |
| 4                                                      | ^      | ^=                  | ✓                                    |                  |          | Bitwise: XOR.                                      |  |  |  |
|                                                        | *      | *=                  | ~                                    | ✓                |          | Multiply and return lower 32 bits (signed).        |  |  |  |
| 5                                                      | **     | **=                 | ~                                    |                  |          | Multiply and return upper 32 bits (signed).        |  |  |  |
| 5                                                      | /      | /=                  | ~                                    | ~                |          | Divide (signed).                                   |  |  |  |
|                                                        | 11     | //=                 | ~                                    |                  |          | Modulus (signed).                                  |  |  |  |
| 6                                                      | +      | +=                  | ~                                    | ~                |          | Add.                                               |  |  |  |
| 0                                                      | -      | -=                  | ~                                    | ~                |          | Subtract.                                          |  |  |  |
| 7                                                      | #>     | #>=                 | ~                                    | ~                |          | Limit minimum (signed).                            |  |  |  |
| I                                                      | <#     | <#=                 | ~                                    | ~                |          | Limit maximum (signed).                            |  |  |  |
|                                                        | <      | <=                  | ✓                                    | ✓                |          | Boolean: Is less than (signed).                    |  |  |  |
|                                                        | >      | >=                  | ~                                    | ~                |          | Boolean: Is greater than (signed).                 |  |  |  |
| 8                                                      | ~      | <>=                 | ✓                                    | ✓                |          | Boolean: Is not equal.                             |  |  |  |
| 0                                                      | ==     | ===                 | ✓                                    | ✓                |          | Boolean: Is equal.                                 |  |  |  |
|                                                        | =<     | =<=                 | ~                                    | ~                |          | Boolean: Is equal or less (signed).                |  |  |  |
|                                                        | =>     | =>=                 | ~                                    | ✓                |          | Boolean: Is equal or greater (signed).             |  |  |  |
| 9                                                      | NOT    | if solo             | ~                                    | ✓                | ~        | Boolean: NOT (promotes non-0 to -1).               |  |  |  |
| 10                                                     | and    | and=                | ~                                    | ✓                |          | Boolean: AND (promotes non-0 to -1).               |  |  |  |
| 11                                                     | OR     | OR=                 | ~                                    | ✓                |          | Boolean: OR (promotes non-0 to -1).                |  |  |  |
| Lowest                                                 | =      | always              | n/a <sup>3</sup>                     | n/a³             |          | Constant assignment (CON blocks).                  |  |  |  |
| (12)                                                   | :=     | always              | n/a <sup>3</sup>                     | n/a <sup>3</sup> |          | Variable assignment (PUB/PRI blocks).              |  |  |  |

<sup>1</sup> Precedence level: higher-level operators evaluate before lower-level operators. Operators in same level are commutable; evaluation order does not matter. <sup>2</sup> Assignment forms of binary (non-unary) operators are in the lowest precedence (level 12). <sup>3</sup> Assignment forms of operators are not allowed in constant expressions.

# 6.3. Spin Language Summary Table

| Spin Command                                                                                                                                                                                                                                                          | Returns<br>Value | Description                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RBORT (Value)                                                                                                                                                                                                                                                         | ✓                | Exit from PUB/PRI method using abort status with optional return value.                                                                                                                                                                         |
| BYTE Symbol ([Count])                                                                                                                                                                                                                                                 |                  | Declare byte-sized symbol in VAR block.                                                                                                                                                                                                         |
| ⟨Symbol⟩ BYTE Data ⟨[Count]⟩                                                                                                                                                                                                                                          |                  | Declare byte-aligned and/or byte-sized data in DRT block.                                                                                                                                                                                       |
| BYTE [BaseAddress] ([Offset])                                                                                                                                                                                                                                         | ~                | Read/write byte of main memory.                                                                                                                                                                                                                 |
| Symbol.BYTE ([Offset])                                                                                                                                                                                                                                                | ~                | Read/write byte-sized component of word/long-sized variable.                                                                                                                                                                                    |
| BYTEFILL (StartAddress, Value, Count)                                                                                                                                                                                                                                 |                  | Fill bytes of main memory with a value.                                                                                                                                                                                                         |
| BYTEMOVE (DestAddress, SrcAddress, Count)                                                                                                                                                                                                                             |                  | Copy bytes from one region to another in main memory.                                                                                                                                                                                           |
| CRSE CaseExpression<br>→ MatchExpression :<br>→ Statement(s)<br>(→ MatchExpression :<br>→ Statement(s))                                                                                                                                                               |                  | Compare expression against matching expression(s), execute code block<br>if match found.<br><i>MatchExpression</i> can contain a single expression or multiple comma-<br>delimited expressions. Expressions can be a single value (ex: 10) or a |
| <pre>〈→ OTHER :<br/>→ Statement(s)〉</pre>                                                                                                                                                                                                                             |                  | range of values (ex: 1015).                                                                                                                                                                                                                     |
| CHIPVER                                                                                                                                                                                                                                                               | ✓                | Version number of the Propeller chip (Byte at \$FFFF)                                                                                                                                                                                           |
| CLKFREQ                                                                                                                                                                                                                                                               | ✓                | Current System Clock frequency, in Hz (Long at \$0000)                                                                                                                                                                                          |
| CLKMODE                                                                                                                                                                                                                                                               | ✓                | Current clock mode setting (Byte at \$0004)                                                                                                                                                                                                     |
| CLKSET (Mode, Frequency)                                                                                                                                                                                                                                              |                  | Set both clock mode and System Clock frequency at run time.                                                                                                                                                                                     |
| CNT                                                                                                                                                                                                                                                                   | ✓                | Current 32-bit System Counter value.                                                                                                                                                                                                            |
| COGID                                                                                                                                                                                                                                                                 | ✓                | Current cog's ID number; 0-7.                                                                                                                                                                                                                   |
| <b>COGINIT</b> (CogID, SpinMethod (ParameterList)), StackPointer)                                                                                                                                                                                                     |                  | Start or restart cog by ID to run Spin code.                                                                                                                                                                                                    |
| COGINIT (CogID, AsmAddress, Parameter)                                                                                                                                                                                                                                |                  | Start or restart cog by ID to run Propeller Assembly code.                                                                                                                                                                                      |
| COGNEW (SpinMethod ( (ParameterList) ), StackPointer)                                                                                                                                                                                                                 | ~                | Start new cog for Spin code and get cog ID; 0-7 = succeeded, -1 = failed.                                                                                                                                                                       |
| COGNEW (AsmAddress, Parameter)                                                                                                                                                                                                                                        | *                | Start new cog for Propeller Assembly code and get cog ID; 0-7 = succeeded, -1 = failed.                                                                                                                                                         |
| COGSTOP (CogID)                                                                                                                                                                                                                                                       |                  | Stop cog by its ID.                                                                                                                                                                                                                             |
| $\begin{array}{l} \text{CON} \\ \text{Symbol} = Expr \left\langle ((, \Box)) \right\rangle \text{Symbol} = Expr \right\rangle \dots \\ \text{CON} \end{array}$                                                                                                        |                  | Declare symbolic, global constants.                                                                                                                                                                                                             |
| <b>#</b> <i>Expr</i> ((, $\vdash$ →)) Symbol $\langle$ [Offset] $\rangle$ $\langle$ ((, $\vdash$ →)) Symbol $\langle$ [Offset] $\rangle$                                                                                                                              |                  | Declare global enumerations (incrementing symbolic constants).                                                                                                                                                                                  |
| $\begin{array}{c} \text{CON} \\ \text{Symbol } \left< \left[ \text{Offset} \right] \right> \left< \left( \left( , \left  \begin{array}{c} {} \\ {} \end{array} \right) \right) \text{ Symbol } \left< \left[ \text{Offset} \right] \right> \right\rangle \end{array}$ |                  | Declare global enumerations (incrementing symbolic constants).                                                                                                                                                                                  |
| CONSTRNT (ConstantExpression)                                                                                                                                                                                                                                         | ~                | Declare in-line constant expression to be completely resolved at compile time.                                                                                                                                                                  |
| CTRA                                                                                                                                                                                                                                                                  | ~                | Counter A Control register.                                                                                                                                                                                                                     |
| CTRB                                                                                                                                                                                                                                                                  | ~                | Counter B Control register.                                                                                                                                                                                                                     |
| DAT<br>(Symbol) Alignment (Size) (Data) ([Count]) (,(Size) Data ([Count]))                                                                                                                                                                                            |                  | Declare table of data, aligned and sized as specified.                                                                                                                                                                                          |
| DAT<br>〈Symbol〉〈Condition〉 Instruction 〈Effect(s)〉                                                                                                                                                                                                                    |                  | Denote Propeller Assembly instruction.                                                                                                                                                                                                          |
| DIRA ([Pin(s)])                                                                                                                                                                                                                                                       | ✓                | Direction register for 32-bit port A. Default is 0 (input) upon cog startup.                                                                                                                                                                    |
| FILE "FileName"                                                                                                                                                                                                                                                       |                  | Import external file as data in DAT block.                                                                                                                                                                                                      |
| FLORT (IntegerConstant)                                                                                                                                                                                                                                               | ✓                | Convert integer constant expression to compile-time floating-point value in any block.                                                                                                                                                          |
| FRQA                                                                                                                                                                                                                                                                  | *                | Counter A Frequency register.                                                                                                                                                                                                                   |
| FRQB                                                                                                                                                                                                                                                                  | ✓                | Counter B Frequency register.                                                                                                                                                                                                                   |

| Spin Command                                                                                             | Returns<br>Value | Description                                                                                                                  |
|----------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                   | Funde            | Test condition(s) and execute block of code if valid.<br>IF and ELSEIF each test for TRUE. IFNOT and ELSEIFNOT each test for |
| → $IselfStatement(s)$<br>$\langle ELSE$<br>→ $IseStatement(s) \rangle$                                   |                  | FALSE.                                                                                                                       |
| INR $\langle [Pin(s)] \rangle$                                                                           | *                | Input register for 32-bit ports A.                                                                                           |
| LOCKCLR (ID)                                                                                             | ~                | Clear semaphore to false and get its previous state; TRUE or FALSE.                                                          |
| LOCKNEW                                                                                                  | ✓                | Check out new semaphore and get its ID; 0-7, or -1 if none were available.                                                   |
| LOCKRET (ID)                                                                                             |                  | Return semaphore back to semaphore pool, releasing it for future LOCKNEW requests.                                           |
| LOCKSET (ID)                                                                                             | ✓                | Set semaphore to true and get its previous state; <b>TRUE</b> or <b>FALSE</b> .                                              |
| LONG Symbol ([Count])                                                                                    |                  | Declare long-sized symbol in <b>VAR</b> block.                                                                               |
| <symbol> LONG Data &lt;[Count]&gt;</symbol>                                                              |                  | Declare long-aligned and/or long-sized data in DAT block.                                                                    |
| LONG [BaseAddress] ([Offset])                                                                            | 1                | Read/write long of main memory.                                                                                              |
| LONGFILL (StartAddress, Value, Count)                                                                    |                  | Fill longs of main memory with a value.                                                                                      |
| LONGMOVE (DestAddress, SrcAddress, Count)                                                                |                  | Copy longs from one region to another in main memory.                                                                        |
| LOOKDOWN (Value: ExpressionList)                                                                         | ✓                | Get the one-based index of a value in a list.                                                                                |
| LOOKDOWNZ (Value: ExpressionList)                                                                        | ✓                | Get the zero-based index of a value in a list.                                                                               |
| LOOKUP (Index: ExpressionList)                                                                           | ✓                | Get value from a one-based index position of a list.                                                                         |
| LOOKUPZ (Index: ExpressionList)                                                                          | ✓                | Get value from a zero-based index position of a list.                                                                        |
| NEXT                                                                                                     |                  | Skip remaining statements of <b>REPEAT</b> loop and continue with the next loop iteration.                                   |
| OBJ<br>Symbol 〈[Count]〉: "Object" 〈 ֒→ Symbol 〈[Count]〉: "Object"〉                                       |                  | Declare symbol object references.                                                                                            |
| OUTA ([Pin(s)])                                                                                          | ✓                | Output register for 32-bit port A. Default is 0 (ground) upon cog startup.                                                   |
| PAR                                                                                                      | ✓                | Cog Boot Parameter register.                                                                                                 |
| PHSA                                                                                                     | √                | Counter A Phase Lock Loop (PLL) register.                                                                                    |
| PHSB                                                                                                     | ✓                | Counter B Phase Lock Loop (PLL) register.                                                                                    |
| PRI Name ((Par (,Par))) (:RVal) (  LVar ([Cnt])) (,LVar ([Cnt]))<br>SourceCodeStatements                 |                  | Declare private method with optional parameters, return value and local variables.                                           |
| <b>PUB</b> Name 〈 (Par 〈, Par〉) 〉 〈: RVal〉 〈   LVar 〈 [Cnt] 〉〉 〈, LVar 〈 [Cnt] 〉<br>SourceCodeStatements |                  | Declare public method with optional parameters, return value and local variables.                                            |
| QUIT                                                                                                     |                  | Exit from <b>REPERT</b> loop immediately.                                                                                    |
| REBOOT                                                                                                   |                  | Reset the Propeller chip.                                                                                                    |
| REPEAT ⟨Count⟩<br>→I Statement(s)                                                                        |                  | Execute code block repetitively, either infinitely, or for a finite number of iterations.                                    |
| REPEAT Variable FROM Start TO Finish ⟨STEP Delta⟩<br>→I Statement(s)                                     |                  | Execute code block repetitively, for finite, counted iterations.                                                             |
| REPEAT ((UNTIL   WHILE)) Condition(s)<br>→ Statement(s)                                                  |                  | Execute code block repetitively, zero-to-many conditional iterations.                                                        |
| REPERT<br>→ Statement(s)<br>((UNTIL ¦ WHILE)) Condition(s)                                               |                  | Execute code block repetitively, one-to-many conditional iterations.                                                         |
| RESULT                                                                                                   | 1                | Return value variable for PUB/PRI methods.                                                                                   |
| RETURN (Value)                                                                                           | 1                | Exit from PUB/PRI method with optional return Value.                                                                         |
| ROUND (FloatConstant)                                                                                    | ~                | Round floating-point constant to the nearest integer at compile-time, in any block.                                          |
| SPR [Index]                                                                                              | ~                | Special Purpose Register array.                                                                                              |
| STRCOMP (StringAddress1, StringAddress2)                                                                 | ✓                | Compare two strings for equality.                                                                                            |
| STRING (StringExpression)                                                                                | 1                | Declare in-line string constant and get its address.                                                                         |

### 6.4. Propeller Assembly Instruction Table

The Propeller Assembly Instruction Table lists the instruction's 32-bit opcode, outputs and number of clock cycles. The opcode consists of the instruction bits (iiiii), the "effect" status for the Z flag, C flag, result and indirect/immediate status (zcri), the conditional execution bits (cccc), and the destination and source bits (dddddddd and sssssss). The meaning of the Z and C flags, if any, is shown in the Z Result and C Result fields; indicating the meaning of a 1 in those flags. The Result field (**R**) shows the instruction's default behavior for writing (1) or not writing (0) the instruction's result value. The Clocks field shows the number of clocks the instruction requires for execution.

- $\emptyset$  1 Zeros (0) and ones (1) mean binary 0 and 1.
- i Lower case "i" denotes a bit that is affected by immediate status.
- d s Lower case "d" and "s" indicate destination and source bits.
- ? Question marks denote bits that are dynamically set by the compiler.
- --- Hyphens indicate items that are not applicable or not important.
- .. Double-periods represent a range of contiguous values.

| iiiiii | zcri | cccc | ddddddd  | SSSSSSSS  | Instruc | tion | Description                                          | Z Result       | C Result         | R | Clocks |
|--------|------|------|----------|-----------|---------|------|------------------------------------------------------|----------------|------------------|---|--------|
| 000000 | 000i | 1111 | dddddddd | SSSSSSSS  | WRBYTE  | D,S  | Write D[70] to main memory byte S[150]               | -              | -                | 0 | 823 *  |
| 000000 | 001i | 1111 | dddddddd | SSSSSSSSS | RDBYTE  | D,S  | Read main memory byte S[150] into D (0-<br>extended) | Result = 0     | -                | 1 | 823 *  |
| 000001 | 000i | 1111 | dddddddd | SSSSSSSSS | WRWORD  | D,S  | Write D[150] to main memory word S[151]              | -              | -                | 0 | 823 *  |
| 000001 | 001i | 1111 | dddddddd | SSSSSSSSS | RDWORD  | D,S  | Read main memory word S[151] into D (0-<br>extended) | Result = 0     | -                | 1 | 823 *  |
| 000010 | 000i | 1111 | dddddddd | SSSSSSSSS | WRLONG  | D,S  | Write D to main memory long S[152]                   | -              | -                | 0 | 823 *  |
| 000010 | 001i | 1111 | dddddddd | SSSSSSSSS | RDLONG  | D,S  | Read main memory long S[152] into D                  | Result = 0     | -                | 1 | 823 *  |
| 000011 | 000i | 1111 | dddddddd | ssssssss  | HUBOP   | D,S  | Perform hub operation according to S                 | Result = 0     | -                | 0 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 000       | CLKSET  | D    | Set the global CLK register to D[70]                 | -              | -                | 0 | 823 *  |
| 000011 | 0011 | 1111 | dddddddd | 001       | COGID   | D    | Get this cog number (07) into D                      | ID = 0         | 0                | 1 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 010       | COGINIT | D    | Initialize a cog according to D                      | ID = 0         | No cog free      | 0 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 011       | COGSTOP | D    | Stop cog number D[20]                                | Stopped ID = 0 | No Cog Free      | 0 | 823 *  |
| 000011 | 0011 | 1111 | dddddddd | 100       | LOCKNEW | D    | Checkout a new LOCK number (07) into D               | ID = 0         | No lock free     | 1 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 101       | LOCKRET | D    | Return lock number D[20]                             | ID = 0         | No lock free     | 0 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 110       | LOCKSET | D    | Set lock number D[20]                                | ID = 0         | Prior lock state | 0 | 823 *  |
| 000011 | 0001 | 1111 | dddddddd | 111       | LOCKCLR | D    | Clear lock number D[20]                              | ID = 0         | Prior lock state | 0 | 823 *  |
| 000100 | 001i | 1111 | dddddddd | SSSSSSSS  | MUL     | D,S  | Multiply unsigned D[150] by S[150]                   | Result = 0     | -                | 1 | future |
| 000101 | 001i | 1111 | dddddddd | SSSSSSSS  | MULS    | D,S  | Multiply signed D[150] by S[150]                     | Result = 0     | -                | 1 | future |
| 000110 | 001i | 1111 | dddddddd | SSSSSSSS  | ENC     | D,S  | Encode magnitude of S into D, result = 031           | Result = 0     | -                | 1 | future |
| 000111 | 001i | 1111 | dddddddd | SSSSSSSS  | ONES    | D,S  | Get number of 1's in S into D, result = 031          | Result = 0     | -                | 1 | future |
| 001000 | 001i | 1111 | dddddddd | SSSSSSSS  | ROR     | D,S  | Rotate D right by S[40] bits                         | Result = 0     | D[0]             | 1 | 4      |
| 001001 | 001i | 1111 | dddddddd | SSSSSSSSS | ROL     | D,S  | Rotate D left by S[40] bits                          | Result = 0     | D[31]            | 1 | 4      |
| 001010 | 001i | 1111 | dddddddd | SSSSSSSSS | SHR     | D,S  | Shift D right by S[40] bits, set new MSB to 0        | Result = 0     | D[0]             | 1 | 4      |
| 001011 | 001i | 1111 | dddddddd | SSSSSSSSS | SHL     | D,S  | Shift D left by S[40] bits, set new LSB to 0         | Result = 0     | D[31]            | 1 | 4      |
| 001100 | 001i | 1111 | dddddddd | SSSSSSSS  | RCR     | D,S  | Rotate carry right into D by S[40] bits              | Result = 0     | D[0]             | 1 | 4      |
| 001101 | 001i | 1111 | dddddddd | SSSSSSSS  | RCL     | D,S  | Rotate carry left into D by S[40] bits               | Result = 0     | D[31]            | 1 | 4      |
| 001110 | 001i | 1111 | dddddddd | SSSSSSSSS | SAR     | D,S  | Shift D arithmetically right by S[40] bits           | Result = 0     | D[0]             | 1 | 4      |
| 001111 | 001i | 1111 | dddddddd | SSSSSSSSS | REV     | D,S  | Reverse 32–S[40] bottom bits in D and 0-<br>extend   | Result = 0     | D[0]             | 1 | 4      |
| 010000 | 001i | 1111 | dddddddd | ssssssss  | MINS    | D,S  | Set D to S if signed (D < S)                         | S = 0          | Signed (D < S)   | 1 | 4      |
| 010001 | 001i | 1111 | dddddddd | ssssssss  | MAXS    | D,S  | Set D to S if signed (D => S)                        | S = 0          | Signed (D < S)   | 1 | 4      |
| 010010 | 001i | 1111 | dddddddd | SSSSSSSSS | MIN     | D,S  | Set D to S if unsigned (D < S)                       | S = 0          | Unsigned (D < S) | 1 | 4      |
| 010011 | 001i | 1111 | dddddddd | sssssss   | MAX     | D,S  | Set D to S if unsigned (D => S)                      | S = 0          | Unsigned (D < S) | 1 | 4      |
| 010100 | 001i | 1111 | dddddddd | SSSSSSSSS | MOVS    | D,S  | Insert S[80] into D[80]                              | Result = 0     | -                | 1 | 4      |
| 010101 | 001i | 1111 | dddddddd | SSSSSSSSS | MOVD    | D,S  | Insert S[80] into D[179]                             | Result = 0     | -                | 1 | 4      |
| 010110 | 001i | 1111 | dddddddd | SSSSSSSSS | MOVI    | D,S  | Insert S[80] into D[3123]                            | Result = 0     | -                | 1 | 4      |
| 010111 | 001i | 1111 | dddddddd | SSSSSSSSS | JMPRET  | D,S  | Insert PC+1 into D[80] and set PC to S[80]           | Result = 0     | -                | 1 | 4      |
| 010111 | 000i | 1111 |          | SSSSSSSS  | JMP     | S    | Set PC to S[80]                                      | Result = 0     | -                | 0 | 4      |

#### 6.4.1. Assembly Conditions

| Condition    | Instruction Executes   |
|--------------|------------------------|
| IF_ALWAYS    | always                 |
| IF_NEVER     | never                  |
| IF_E         | if equal (Z)           |
| IF_NE        | if not equal (!Z)      |
| IF_A         | if above (!C & !Z)     |
| IF_B         | if below (C)           |
| IF_AE        | if above/equal (!C)    |
| IF_BE        | if below/equal (C   Z) |
| IF_C         | if C set               |
| IF_NC        | if C clear             |
| IF_Z         | if Z set               |
| IF_NZ        | if Z clear             |
| IF_C_EQ_Z    | if C equal to Z        |
| IF_C_NE_Z    | if C not equal to Z    |
| IF_C_AND_Z   | if C set and Z set     |
| IF_C_AND_NZ  | if C set and Z clear   |
| IF_NC_AND_Z  | if C clear and Z set   |
| IF_NC_AND_NZ | if C clear and Z clear |
| IF_C_OR_Z    | if C set or Z set      |
| IF_C_OR_NZ   | if C set or Z clear    |
| IF_NC_OR_Z   | if C clear or Z set    |
| IF_NC_OR_NZ  | if C clear or Z clear  |
| IF_Z_EQ_C    | if Z equal to C        |
| IF_Z_NE_C    | if Z not equal to C    |
| IF_Z_AND_C   | if Z set and C set     |
| IF_Z_AND_NC  | if Z set and C clear   |
| IF_NZ_AND_C  | if Z clear and C set   |
| IF_NZ_AND_NC | if Z clear and C clear |
| IF_Z_OR_C    | if Z set or C set      |
| IF_Z_OR_NC   | if Z set or C clear    |
| IF_NZ_OR_C   | if Z clear or C set    |
| IF_NZ_OR_NC  | if Z clear or C clear  |

#### 6.4.2. Assembly Directives

| Directive                   | Description                                        |  |  |
|-----------------------------|----------------------------------------------------|--|--|
| FIT 〈Address〉               | Validate previous instr/data fit below an address. |  |  |
| ORG (Address)               | Adjust compile-time cog address<br>pointer.        |  |  |
| ⟨Symbol⟩ <b>RES</b> ⟨Count⟩ | Reserve next long(s) for symbol.                   |  |  |

#### 6.4.3. Assembly Effects

| Effect                               | Results In                       |  |
|--------------------------------------|----------------------------------|--|
| WC                                   | WC C Flag modified               |  |
| WZ                                   | Z Flag modified                  |  |
| WR                                   | WR Destination Register modified |  |
| NR Destination Register not modified |                                  |  |

#### 6.4.4. Assembly Operators

Propeller Assembly code can contain constant expressions, which may use any operators that are allowed in constant expressions. The table (a subset of Table 17) lists the operators allowed in Propeller Assembly.

| Operator | Description                                                              |  |
|----------|--------------------------------------------------------------------------|--|
| +        | Add                                                                      |  |
| +        | Positive (+X); unary form of Add                                         |  |
| -        | Subtract                                                                 |  |
| -        | Negate (-X); unary form of Subtract                                      |  |
| *        | Multiply and return lower 32 bits (signed)                               |  |
| **       | Multiply and return upper 32 bits (signed)                               |  |
| /        | Divide (signed)                                                          |  |
| 11       | Modulus (signed)                                                         |  |
| #>       | Limit minimum (signed)                                                   |  |
| <#       | Limit maximum (signed)                                                   |  |
| ~~       | Square root; unary                                                       |  |
|          | Absolute value; unary                                                    |  |
| ~>       | Shift arithmetic right                                                   |  |
| <        | Bitwise: Decode value (0-31) into single-high-bit long; unary            |  |
| >        | Bitwise: Encode long into value (0 - 32) as high-<br>bit priority; unary |  |
| <<       | Bitwise: Shift left                                                      |  |
| >>       | Bitwise: Shift right                                                     |  |
| <-       | Bitwise: Rotate left                                                     |  |
| ->       | Bitwise: Rotate right                                                    |  |
| ~        | Bitwise: Reverse                                                         |  |
| &        | Bitwise: AND                                                             |  |
|          | Bitwise: OR                                                              |  |
| ^        | Bitwise: XOR                                                             |  |
| !        | Bitwise: NOT; unary                                                      |  |
| and      | Boolean: AND (promotes non-0 to -1)                                      |  |
| OR       | Boolean: OR (promotes non-0 to -1)                                       |  |
| NOT      | Boolean: NOT (promotes non-0 to -1); unary                               |  |
| ==       | Boolean: Is equal                                                        |  |
| <>       | Boolean: Is not equal                                                    |  |
| ~        | Boolean: Is less than (signed)                                           |  |
| >        | Boolean: Is greater than (signed)                                        |  |
| =<       | Boolean: Is equal or less (signed)                                       |  |
| =>       | Boolean: Is equal or greater (signed)                                    |  |
| 0        | Symbol address; unary                                                    |  |

# 7.0 ELECTRICAL CHARACTERISTICS

#### 7.1. Absolute Maximum Ratings

Stresses in excess of the absolute maximum ratings can cause permanent damage to the device. These are absolute stress ratings only. Functional operation of the device is not implied at these or any other conditions in excess of those given in the remainder of Section 0. Exposure to absolute maximum ratings for extended periods can adversely affect device reliability.

| Table 18: Absolute Maximum Ratings                                              |                                     |  |  |  |
|---------------------------------------------------------------------------------|-------------------------------------|--|--|--|
| Ambient temperature under bias                                                  | -55 °C to +125 °C                   |  |  |  |
| Storage temperature                                                             | -65 °C to +150 °C                   |  |  |  |
| Voltage on $V_{dd}$ with respect to $V_{ss}$                                    | -0.3 V to +4.0 V                    |  |  |  |
| Voltage on all other pins with respect to $V_{ss}^{*}$                          | -0.3 V to (V <sub>dd</sub> + 0.3 V) |  |  |  |
| Total power dissipation                                                         | 1 W                                 |  |  |  |
| Max. current out of V <sub>ss</sub> pins                                        | 300 mA                              |  |  |  |
| Max. current into V <sub>dd</sub> pins                                          | 300 mA                              |  |  |  |
| Max. DC current into an input pin with internal protection diode forward biased | ±500 μA                             |  |  |  |
| Max. allowable current per I/O pin                                              | 40 mA                               |  |  |  |
| ESD (Human Body Model) Supply pins                                              | 3 kV                                |  |  |  |
| ESD (Human Body Model) all non-supply pins                                      | 8 kV                                |  |  |  |

\*Note: I/O pin voltages with respect to Vss may be exceeded if internal protection diode forward bias current is not exceeded.

### 7.2. DC Characteristics

(Operating temperature range:  $-55^{\circ}$  C < T<sub>a</sub>  $< +125^{\circ}$  C unless otherwise noted)

| Symbol                           | Parameter                 | Conditions                                           | Min                                    | Тур <sup>*</sup> | Max                                    | Units  |
|----------------------------------|---------------------------|------------------------------------------------------|----------------------------------------|------------------|----------------------------------------|--------|
| V <sub>dd</sub>                  | Supply Voltage            |                                                      | 2.7                                    | -                | 3.6                                    | V      |
| V <sub>ih,</sub> V <sub>il</sub> | Logic High<br>Logic Low   |                                                      | 0.6 V <sub>dd</sub><br>V <sub>ss</sub> |                  | V <sub>dd</sub><br>0.3 V <sub>dd</sub> | V<br>V |
| lil                              | Input Leakage Current     | V <sub>in</sub> = V <sub>dd</sub> or V <sub>ss</sub> | -1.0                                   |                  | +1.0                                   | μA     |
| V <sub>oh</sub>                  | Output High Voltage       | I <sub>oh</sub> = 10 mA, V <sub>dd</sub> = 3.3 V     | 2.85                                   |                  |                                        | V      |
| V <sub>ol</sub>                  | Output Low Voltage        | I <sub>ol</sub> = 10 mA, V <sub>dd</sub> = 3.3 V     |                                        |                  | 0.4                                    | V      |
| I <sub>BO</sub>                  | Brownout Detector Current |                                                      |                                        | 3.8              |                                        | μA     |
| Ι                                | Quiescent Current         | $RESn = 0V, BOEn = V_{dd}, P_0-P_{31}=0V$            |                                        | 600              |                                        | nA     |

\*Note: Data in the Typical ("Typ") column is  $T_a = 25$  °C unless otherwise stated.

### 7.3. AC Characteristics

(Operating temperature range:  $-55^{\circ}C < T_a < +125^{\circ}C$  unless otherwise noted)

| Symbol          | Parameter             | Min                | Тур*               | Max                 | Units                    | Condition                                                      |
|-----------------|-----------------------|--------------------|--------------------|---------------------|--------------------------|----------------------------------------------------------------|
| Fosc            | External XI Frequency | DC                 | -                  | 80                  | MHz                      |                                                                |
|                 | Oscillator Frequency  | DC<br>13<br>8<br>4 | -<br>20<br>12<br>- | 80<br>33<br>20<br>8 | MHz<br>kHz<br>MHz<br>MHz | Direct drive (no PLL)<br>RCSLOW<br>RCFAST<br>Crystal using PLL |
| C <sub>in</sub> | Input Capacitance     |                    | 6                  | -                   | pF                       |                                                                |

\*Note: Data in the Typical ("Typ") column is T<sub>a</sub> = 25 °C unless otherwise stated.

# 8.0 CURRENT CONSUMPTION CHARACTERISTICS

### 8.1. Typical Current Consumption of 8 Cogs

This figure shows the typical current consumption of the Propeller under various operating conditions duplicated across all cogs. Brown out circuitry and the Phase-Locked Loop were disabled for the duration of the test. Current consumption is substantially constant over the operational temperature range.





#### 8.4. Typical Crystal Drive Current

This graph shows the current consumption of the crystal driver over a range of crystal frequencies and crystal settings, all data points above 25 MHz were obtained by using a resonator since the driver does not perform 3<sup>rd</sup> harmonic overtone driving required for crystals over 25 MHz.



### 8.5. Cog and I/O Pin Relationship

The figure below illustrates the physical relationship between the cogs and I/O pins. While there can be a 1 to 1.5 ns propagation delay in output transitions between the shortest and longest paths, the purpose of the figure is to illustrate the length of leads and their associated parasitic capacitance. This capacitance increases the amount of energy required to transition a pin's state and therefore increases the current draw for toggling a pin. So, the current consumed by Cog 7 toggling P0 at 20 MHz will be greater than Cog 0 toggling P7 at 20 MHz. The amount of current consumed by transitioning a pin's state is dependent on many factors including: temperature, frequency of transitions, external load, and internal load. As mentioned, the internal load is dependent upon which cog and pin are used. Internal load current for room temperature toggling of a pin at 20 MHz for a Propeller in a DIP package varies on the order of 300  $\mu$ A.



### 8.6. Current Profile at Various Startup Conditions

The diagrams below show the current profile for various startup conditions of the Propeller chip dependent upon the presence of an EEPROM and PC.



# 9.0 TEMPERATURE CHARACTERISTICS

# 9.1. Internal Oscillator Frequency as a Function of Temperature

While the internal oscillator frequency is variable due to process variation, the rate of change as a function of temperature when normalized provides a chip invariant ratio which can be used to calculate the oscillation frequency when the ambient temperature is other than 25 °C (the temperature to which the graph was normalized). The absolute frequency at 25 °C varied from 13.26 to 13.75 MHz in the sample set. The section of the graph which has a white background is the military range of temperature; the sections in grey represent data which is beyond military temperature specification.



# RCFAST Normalized Frequency vs Temperature

### 9.2. Fastest Operating Frequency as a Function of Temperature

The following graph represents a small sample average of a Propeller chip's fastest operating range. The test was performed in a forced air chamber using code run on all eight cogs, multiple video generators, and counter modules. A frequency was considered successful if the demo ran without fault for one minute. The curves represent an aggressive testing procedure (averaged, forced air, one minute time limit); therefore the designer must de-rate the curve to arrive at a stable frequency for a particular application. Again the grayed regions represent temperatures beyond the military temperature range.



# Fastest Frequency vs Temperature

# **10.0 PACKAGE DIMENSIONS**

### 10.1. P8X32A-D40 (40-pin DIP)





### 10.2. P8X32A-Q44 (44-pin LQFP)









# 11.0 MANUFACTURING INFO

#### 11.1. Reflow Peak Temperature

| Package Type | Reflow Peak Temp. |
|--------------|-------------------|
| DIP          | 255+5/-0 °C       |
| LQFP         | 255+5/-0 °C       |
| QFN          | 255+5/-0 °C       |

#### 11.2. Green/RoHS Compliance

All Parallax Semiconductor Propeller P8X32A chip models are certified Green/RoHS Compliant. RoHS, Green, and ISO certificates are available online at www.parallaxsemiconductor.com.

# 12.0 REVISION HISTORY

#### 12.1.1. Changes for Version 1.1:

Section 10.3: P8X32A-M44 (44-pin QFN). Image replaced to add stencil pattern diagram. New section inserted: 4.8 Assembly Instruction Execution Stages. Contact Information updated.

#### 12.1.2. Changes for Version 1.2:

Section 6.4: Modified table entries for ADD, ADDABS, ADDS, ADDSX, ADDX, CMP, CMPS, CMPSX, CMPX, COGID, COGINIT, COGSTOP, LOCKCLR, LCOKNEW, LOCKRET, LOCKSET, MAX, MAXS, MIN, MINS, SUB, SUBABS, SUBS, SUBSX, SUBX, SUMC, SUMNC, SUMNZ, SUMZ, TEST, TJNZ, TJZ. Section 4.5 updated. Section 5.1: new sentence added at end of paragraph. Section 5.2: new sentence added at end of first paragraph.

#### 12.1.3. Changes for Version 1.3

Throughout: updated logo and contact information for Parallax Inc., dba Parallax Semiconductor. Section 7.1: footnote added to Table 18: Absolute Maximum Ratings.

#### 12.1.4. Changes for Version 1.4

Section 1.0 changes: 1.3: Key Features and Benefits revised; former sections 1.4, 1.6 removed. Section 4.4: updated all references to hub timing and replaced both timing diagrams. Section 4.8: reference to hub timing updated. Section 6.4: timing for hub instructions and WAITxxx instructions revised. Former Section 7.0: Propeller Demo Board schematic removed.

# Parallax Semiconductor Contact Information

Parallax Semiconductor 599 Menlo Drive Rocklin, CA 95765 USA Phone: (916) 632-4664 Fax: (916) 624-8003 sales@parallaxsemiconductor.com support@parallaxsemiconductor.com www.parallaxsemiconductor.com http://obex.parallax.com

Parallax, Inc., dba Parallax Semiconductor, makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Parallax, Inc., dba Parallax Semiconductor, assume any liability arising out of the application or use of any product, and specifically disclaims any and all liability, including without limitation consequential or incidental damages even if Parallax, Inc., dba Parallax Semiconductor, has been advised of the possibility of such damages. Reproduction of this document in whole or in part is prohibited without the prior written consent of Parallax, Inc., dba Parallax Semiconductor.

Copyright © 2011 Parallax, Inc. dba Parallax Semiconductor. All rights are reserved.

Propeller and Parallax Semiconductor are trademarks of Parallax, Inc.