# Software development for nanosatellite microcontrollers

# Microcomputer



# Main problems

- What tasks has our computer to execute?
- What kind of processor is the most suitable for us?
- Do we need an operating system?
- What language will we use for programming?

#### Approaches:

- User's specific solution
- Embedded computer
- Mezzanine boards

# Embedded computer

# Extreme Rugged™ PCI-104 Single Board Computer with Intel Atom® Processor SoC

#### **Features**

- Quad-core Intel Atom® Processor SoC
- Up to 4GB DDR3L at 1333MHz
- Supports VGA and LVDS
- 2x GbE
- 1x SATA 3Gb/s (optional 2x SATA), 3x USB 2.0, 8x GPIO
- Extreme Rugged™ operating temperature: -40°C to +85°C
- Supports Smart Embedded Management Agent (SEMA) functions





# Composition

#### CMx-BTx



# Specifications

#### Specifications

I/O Interfaces

USB

3x USB 2.0 (1x on mSATA)

SATA

1x SATA 3Gb/s shared with mSATA (optional 2nd SATA 3GB/s port w/o mSATA support)

**GPIO** 

8x

Serial

2x RS-232/422 (with full handshake) + 2x RS-232/422 (TX,RX,CTS,RTS only)

Power

Standard Input

 $ATX = 5V\pm5\% / 5Vsb \pm 5\%$  or  $AT = 5V\pm5\%$ 

Management

ACPI 5.0 compliant

Power States

C1-C6, S0, S3, S4, S5 (Wake on USB S3/S4, Wake on LAN S3/S4/S5)

ECO mode

supports deep S5 for power saving

Operation System

Standard Support

Windows® 7/8 32/64-bit, Linux 32/64-bit

Extended Support (BSP)

WES7/8, WEC7, Linux, QNX, VxWorks

Mechanical and Environmental

Form Factor

PC/104 Version 2.6

Dimension

90 mm x 96 mm

Operating Temperature

Standard: 0°C to +60°C

Extended Temperature: -40°C to 85°C (SKU dependent, by screening)

Humidity

5-90% RH operating, non-condensing

5-95% RH storage (and operating with conformal coating)

Shock and Vibration

IEC 60068-2-64 and IEC-60068-2-27

MIL-STD-202F, Method 213B, Table 213-I, Condition A and Method 214A, Table 214-I, Condition D

HALT

Thermal Stress, Vibration Stress, Thermal Shock and Combined Test

 Intelligent Middleware SEMA®



Local management, control of embedded computer systems
Extended EAPI for monitoring, controlling and analytics applications
Multiple OS support and across platforms (x86, ARM)

### Mezzanine boards



#### **Key Features**

- Rabbit® 3000 microprocessor @ 44.2 MHz
- 32 MB NAND Flash
- Supports up to 128 MB of hot-swappable memory
- 512K Flash/512K SRAM
- · 10/100Base-T, RJ-45 port
- 52 parallel digital I/O
- 6 serial ports
- · 3.3 V (with 5 V-tolerant I/O)
- · Small footprint

| Power                 | 3.15–3.45 V DC 250 mA @ 44.2 MHz, 3.3 V                                                                        |  |  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|
| Operating Temperature | 0° C to +70° C                                                                                                 |  |  |  |
| Humidity              | 5% to 95%, non-condensing                                                                                      |  |  |  |
| Connectors            | Two 2 × 17, 2 mm pitch One 2 × 5 for programming with 1.27 mm pitch One xD-Picture Card slot (RCM3365/RCM3375) |  |  |  |

### **CPUs and MCUs**

# ARM (Advanced RISC Machines )

- Founded in 1990 as a joint venture of Apple Computer and Acorn Computer
- In 1991 displated ARM6™ (Armv3)
- In 2006 ARMv7-M (CORTEX-M3)



### ARM ARCHITECTURES



# MIPS Cores (Microchip)



# Maybe DSP?



# Or FPGA?

#### MicroBlaze Architecture



MicroBlaze Core Block Diagram

### Zynq-7000 AP SoC Block Diagram



### Zynq-7000 configuration



#### ZYNQ ULTRASCALE



### Configuration



# **CORTEX FAMILY**



#### Processor

| ,                                    | Cortex-A5        | Cortex-A7          | Cortex-A8               | Cortex-A9           | Cortex-A12         | Cortex-A15         |
|--------------------------------------|------------------|--------------------|-------------------------|---------------------|--------------------|--------------------|
| Release date                         | Dec 2009         | Oct 2011           | July 2006               | March 2008          | June 2013          | April 2011         |
| Typical clock<br>speed               | ~1GHz            | ~1GHz on<br>28nm   | ~1GHz on<br>65nm        | ~2GHz on<br>40nm    | ~2GHz on<br>28nm   | ~2.5GHz on<br>28nm |
| Execution order                      | In-order         | In-order           | In-order                | Out of order        | Out of order       | Out of order       |
| Cores                                | 1 to 4           | 1 to 4             | 1                       | 1 to 4              | 1 to 4             | 1 to 4             |
| Peak integer<br>throughput           | 1.6DMIPS/<br>MHz | 1.9DMIPS/<br>MHz   | 2DMIPS/MHz              | 2.5DMIPS/M<br>Hz    | 3.0DMIPS/<br>MHz   | 3.5DMIPS/<br>MHz   |
| Pipeline stages                      | 8                | 8                  | 13                      | 9 to 12             | 11                 | 15+                |
| Instructions<br>decoded per<br>cycle | 1                | Partial dual issue | 2<br>(Superscalar)      | 2<br>(Superscalar)  | 2<br>(Superscalar) | 3<br>(Superscalar  |
| Floating Point<br>Unit               | Optional         | Yes                | Yes                     | Optional            | Yes                | Optional           |
| AMBA<br>interface                    | 64-bit<br>AMBA 3 | 128-bit<br>AMBA 4  | 64 or 128-bit<br>AMBA 3 | 2× 64-bit<br>AMBA 3 | 128-bit<br>AMBA 4  | 128-bit<br>AMBA 4  |

### **CORTEX MCU Modes**



#### **CORTEX Operation modes**



Switching of Operation Mode by Programming the Control Register or by Exceptions.



User thread

# Instruction pipeline

- Each instruction is processed in a number of discrete steps
- Multiple instructions can be processed simultaneously by starting processing of the next instruction before the last has finished.



#### Load-And-Store Architecture

The Cortex CPU is a RISC processor which has a load and store architecture. In order to perform data processing instructions, the operands must be loaded into a central register file, the data operation must be performed on these registers and the results then saved back to the memory store.



# ARM Memory organisation



#### Phase Locked Loop



# Programming tips



# Programming tips



# Programming tips



# Sharing functionality



 Do we need an operating system?

# Operating systems

#### **Advantages:**

- Developer can use built-in features;
- Less software dependency on hardware;
- Interfaces;
- Multitasking and protection.

#### **Drawbacks:**

- Code size increases;
- Efficiency can decrease;
- Dependency on OS principles and features.

# Operating systems

- General purpose operating systems (GPOS) – Windows, Unix, etc.
- Real-time operating systems (RTOS) –
   QNX, FreeRTOS, Salvo, uC/OS etc.

| Operating systems                                                                       |                                                                                     |           |  |  |  |
|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------|--|--|--|
| General purpose operating                                                               | Real-time operating systems (RTOS)                                                  |           |  |  |  |
| Windows, Unix, Linux, etc.                                                              | QNX, FreeRTOS, Salvo, uC/OS etc.                                                    |           |  |  |  |
| Designed to do many things designed to offer strict guara • availability (how often the | <ul><li>Engineered to guarantee:</li><li>availability</li><li>reliability</li></ul> |           |  |  |  |
| to reques • reliability correct)  Tasks Priority 2  Tasks Priority 1  Tasks             | FIQ                                                                                 |           |  |  |  |
| Priority 0                                                                              | Z (27/400)                                                                          | —————Time |  |  |  |