



# ChipSat – a System-on-a-chip for Small Satellite Data Processing and Control Architectural Study and FPGA Implementation

Dr Tanya Vladimirova Leader of the VLSI Systems Research Group Surrey Space Centre, University of Surrey Alex da Silva Curiel Head of R & D Surrey Satellite Technology Ltd.

**Microelectronics Presentation Days, 4-5 February 2004, ESTEC** 







- □ Single chip implementation of an on-board command and data handling subsystem for a low-cost small satellite mixed-mode ASIC.
- SoC design of an on-board computer for a small satellite based on integration of soft IP cores, compatible with the LEON microprocessor core.
- Downsized on-board computer implementation on a single programmable logic chip and a low-cost CCSDS-based communication system.
- Design and integration of a mathematical floating-point co-processor core, based on the CORDIC algorithm.
- □ Credit-card size on-board computer system using the SoC.
- □ DMA controller and DDR SDRAM Controller core for the LEON CPU.
- □ Aspects of reconfigurability.



## SoC Research at SSC

### Long-term

### **Miniaturisation of the Small Satellite Platform**





Surrey Satellite Technology's (SSTL) On-Board Computer (OBC)



2) Credit-Card Size OBC System



# 





Four subsystems:

- a 32-bit RISC processor core modified for space use;
- an image handling subsystem capable of capturing and compressing still or videorate images;
- a communication
   subsystem for the satellite
   uplink and downlink
   connection; and
- a supporting peripheral subsystem.



System-on-a-Chip OBC





XILINX Virtex XCV800 FPGA



### Integration of CAN, EDAC and LEON





# **FPGA Chip Usage**



### Virtex XCV-800 FPGA



**Based on Synthesis Results** 

- □ Synthesis Tool: Synplify 6.0 +
- □ LEON IP core + CAN IP core + EDAC IP core => 43% of XCV800
- **QPRO XILINX Virtex family of radiation hardened FPGAs:** 
  - qualified for space use
  - guaranteed total ionising dose to 100K Rad (si)
  - latch-up immune to LET > 125 Mev cm<sup>2</sup>/mg @ +125 °C







- Implementation of a simplified yet RELIABLE Consultative Committee of Space Data Systems (CCSDS) TLM & TC space communication system satisfying the needs of a single chip on-board computer (OBC) of a small satellite.
- Simulation of the operation of the software on a single-chip OBC prototype.





# CCSDS



- Standard space industry communication protocol.
- Employed on numerous missions ranging from relatively simple low earth missions to deep space probes.
- Could lead to spacecraft interoperability, re-usable systems and mission cross support – not just for in-house missions but across the CCSDS space agencies members.



Structure and Interfaces of the CCSDS Software Package



### **Simulation Scheme**





T.Vladimirova, A da Silva Curiel, MPD'04, ESTEC





# Downsized FPGA Implementation Summary

- □ Processor LEON 2-1.0.2a VHDL IP core (SPARC V8) (ESA)
  - Working Frequency 25 MHz
  - UART Baud Rate 38,400 bps
  - Internal S-Record Boot Loader
- □ On-Board Network (Node 1) HurriCANe VHDL IP core (ESA)
  - Baud Rate: 312,500 bps
- EDAC EDAC VHDL IP core (SSTL)
  - Double-bit correcting Quasi-Cyclic (16,8) shortened EDAC code
- Prototyping Board XESS XSV800 (Xilinx Virtex XCV800 FPGA)
  - Up to 100 MHz programmable oscillator
  - 16M Bits SRAM (two banks 512K x 16)
  - 16M Bits flash RAM
- □ On-Board Application Program S-Record File
  - 160K Bytes (CCSDS\_SC Software Package)





# The CORDIC Algorithm



#### **CORDIC equations:**

$$[x_0, y_0]^T \qquad \theta = \sum_{i=0}^{n-1} \delta_i \alpha_i \qquad \delta_i \in \{ -1, 1 \}$$

$$\begin{cases} x_{i+1} = x_i - m y_i \delta_i 2^{-i} \\ y_{i+1} = y_i + x_i \delta_i 2^{-i} \\ z_{i+1} = z_i - \delta_i \alpha_i \end{cases}$$

$$\delta_i = sign(z_i)$$
  $i = 0, 1, 2, ..., n-1$ 

#### **Composite functions:**

 $\tan z = \sin z / \cos z$   $\tanh = \sinh z / \cosh z$   $\exp z = \sinh z + \cosh z$   $\ln w = 2 \tanh^{-1}(y/x) \text{ where } x = w + 1 \text{ and } y = w - 1$  $\sqrt{w} = \sqrt{(x^2 - y^2)} \text{ where } x = w + 1/4 \text{ and } y = w - 1/4$ 







| Idenitity                                                                                                                      | Domain                                         |
|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| sin(Q 90 + D) = { sin D if Q mod 4 = 0 }<br>{ cos D if Q mod 4 = 1 }<br>{ -sin D if Q mod 4 = 2 }<br>{ -cos D if Q mod 4 = 3 } | D  < 90                                        |
| cos(Q 90 + D) = { cos D if Q mod 4 = 0 }<br>{ -sin D if Q mod 4 = 1 }<br>{ -cos D if Q mod 4 = 2 }<br>{ sin D if Q mod 4 = 3 } | <b>D</b>   < 90                                |
| $\tan(Q \ 90 + D) = \sin(Q \ 90 + D) / \cos(Q \ 90 + D)$                                                                       | D  < 90                                        |
| $\tan^{-1}(1/y) = 90 - \tan^{-1}(y)$                                                                                           | y  < 1                                         |
| $\sinh(Q \log_e 2 + D) = (2^Q/2)[\cosh D + \sinh D - 2^{-2Q}(\cosh D - \sinh D)]$                                              | <b>D</b>   < log <sub>e</sub> 2                |
| $\cosh(Q \log_e 2 + D) = (2^Q / 2)[\cosh D + \sinh D + 2^{-2Q}(\cosh D - \sinh D)]$                                            | $ \mathbf{D}  < \log_{\mathrm{e}} 2$           |
| $tanh(Q \log_e 2 + D) = sinh(Q \log_e 2 + D) / cosh(Q \log_e 2 + D)$                                                           | $ \mathbf{D}  < \log_{\mathrm{e}} 2$           |
| $tanh^{-1}(1 - M2^{-E}) = tanh^{-1}(T) + (E/2) \log_{e} 2$<br>where $T = (2 - M - M2^{-E}) / (2 + M - M2^{-E})$                | 0.17 < T < 0.75<br>for 0.5 ≤ M < 1, E ≥1       |
| $\exp(Q \log_e 2 + D) = 2^Q(\cosh D + \sinh D)$                                                                                | $ \mathbf{D}  < \log_{\mathrm{e}} 2$           |
| $\log_{e} (M2^{E}) = \log_{e} M + E \log_{e} 2$                                                                                | $0.5 \le M < 1.0$                              |
| $sqrt(M2^{E}) = \{ 2^{E/2} sqrt(M) & \text{if } E \mod 2 = 0 \} \\ \{ 2^{(E+1)/2} sqrt(M/2) \text{ if } E \mod 2 = 1 \}$       | $\{0.5 \le M < 1.0 \\ \{0.25 \le M/2 < 0.5 \}$ |
| $(M_x 2^{Ex})(M_z 2^{Ez}) = (M_x M_z) 2^{Ex + Ez}$                                                                             | $0.5 \le M_z < 1.0$                            |
| $(M_y 2^{Ey}) / (M_x 2^{Ex}) = (M_y / 2M_x) 2^{Ey - Ex + 1}$                                                                   | $0.25 \le M_y / 2M_x < 1.0$                    |



### 32-Bit Floating Point Co-Processor Design



### **Grouping of Functions**



#### **IEEE 754 standard compliance**

| Sign bit | Exponent | Mantissa | Number represented |
|----------|----------|----------|--------------------|
| 0        | 0        | 0        | Zero               |
| 0        | 255      | 0        | +∞                 |
| 1        | 255      | 0        | -∞                 |
| 0 or 1   | 255      | Not 0    | Not-a-number (NaN) |

| Function           | Group | Number |  |
|--------------------|-------|--------|--|
| sin                | 000   | 000    |  |
| cos                | 000   | 001    |  |
| tan                | 000   | 010    |  |
| sinh               | 000   | 100    |  |
| cosh               | 000   | 101    |  |
| tanh               | 000   | 110    |  |
| exp                | 000   | 111    |  |
| sin <sup>-1</sup>  | 001   | 000    |  |
| cos-1              | 001   | 010    |  |
| tan <sup>-1</sup>  | 010   | 000    |  |
| tanh <sup>-1</sup> | 011   | 000    |  |
| sqrt               | 100   | 000    |  |
| multiplication     | 101   | 000    |  |
| division           | 110   | 000    |  |
| log                | 111   | 000    |  |

### 4 arithmetic + 13 elementary functions

# CP Integration with LEON SPARC V8 SPACE CENTRE

### The LEON IP core





The Real Time Executive for Multiprocessor Systems (RTEMS) is an open source real-time operating system (RTOS), which provides a high performance environment for embedded systems



#ifdef CP\_ENABLE a = cpmul(t,

# Interface with the LEON IP Core



#### Enabling co-processor support in a user program

cpdiv(cpcos(x),

```
cpatan(cpmul( t2,
   cpmul(cpsin(x),
```

| Command | 31-30 | 29-25 | 24-19  | 18-14 | 13-5 | 4-0 |
|---------|-------|-------|--------|-------|------|-----|
| срор1   | 10    | rd    | 110110 | rs1   | орс  | rs2 |
| cpop2   | 10    | rd    | 110111 | rs1   | орс  | rs2 |

Format of the co-processor operate instructions

b = cpmul(t, cpatan(cpmul( t2, cpmul(cpsin(y), cpdiv(cpcos(y), (cpadd(cpcos(cpadd(x,y)), (cpsub(cpcos(cpsub(x,y)), 1.0)))))))));

#### #else

```
c = t * atan(t2*sin(x)*cos(x) / (cos(x+y)+cos(x-y)-1.0));
d = t * atan(t2*sin(y)*cos(y) / (cos(x+y)+cos(x-y)-1.0));
#endif
```

### Math Library Example - module 7 of the Whetstone program

(cpadd(cpcos(cpadd(x,y)),

(cpsub(cpcos(cpsub(x,y)), 1.0)))))))));





### **CP Performance Results**





#### XSV800 board

|             | LEON        |            | LEON/RTEMS  |            |
|-------------|-------------|------------|-------------|------------|
|             | cp-disabled | cp-enabled | cp-disabled | cp-enabled |
| time (in s) | 65.75       | 53.70      | 106.47      | 60.05      |
| KWIPS       | 15.21       | 18.62      | 9.39        | 16.12      |
| improvment  | 22.42%      |            | 71.6        | 67%        |

| $\operatorname{simulation}$ |       |            |
|-----------------------------|-------|------------|
|                             | LEON  | LEON/RTEMS |
| time (in $s$ )              | 43.50 | 133.88     |
| KWIPS                       | 22.99 | 7.47       |





# **Co-processor Summary**

- A 32-bit maths co-processor VHDL core is developed for a SoC OBC based on the LEON SPARC V8 IP core -
  - aimed at speeding up computationally intensive on-board applications, traditionally implemented in software, e.g ADCS.
- The co-processor is fully compliant with the IEEE 754 floating-point standard and implements 17 functions:
  - add, sub, mul, div, + sqrt, + sin, cos, tan + sin<sup>-1</sup>, cos<sup>-1</sup>, tan<sup>-1</sup> + sinh, cosh, tanh, + tanh<sup>-1</sup> + exp, In.
- The co-processor occupies half the size of a Virtex XCV800 chip.
- The co-processor operates at 2.5MHz, when integrated with the LEON IP core, at 25 MHz when standalone.
- The co-processor accelerates execution of floating-point calculations on the Leon processor:
  - the Whetstone benchmark runs 70% faster on Leon+RTEMS+CP compared with the time it takes on Leon+RTEMS.







Credit-Card Size OBC System Detailed Diagram

**IP Cores** 

LEON-2 CPU v.1.0.13 Math Co-processor DMA Controller CAN Controller/Switch EDAC Unit HDLC Interface RS422 Interface SpaceWire Interface Boot Loader



**DMA Controller** 





M - width of AMBA AHB

### **Virtex-II V2MB1000 development board from Memec:**

- •XC2V1000-4FG456C FPGA
- 32 MByte DDR SDRAM (MT46V16M16TG-75 IC from Micron)
- 24 & 100 MHz clock generator



### **DMA Controller - Features**



- Variable number of independent DMA channels (1 up to 32) priority of the channels is fix; Channel 0 has the highest priority.
- Supports single transfer and block transfer
- Supports burst transfer with programmable burst length to maximize data bandwidth
- **Programmable data width**
- Supports both hardware initiated transfer and software initiated transfer
- Several transfer types:
  - Peripheral → Memory
  - Memory  $\rightarrow$  Peripheral
  - Peripheral  $\rightarrow$  Peripheral
  - Memory  $\rightarrow$  Memory
- □ Interrupt generation on transfer completion or on transfer error
- □ Handles wait state insertion by any slave devices
- Supports all slave device responses: OKAY, RETRY, SPLIT, and ERROR
- Designed for the AMBA® 2.0 Bus.





# **DMA Controller Integration Test**





# **LEON-2 IP Core and DDR SDRAM**





The memory controller integrated in the LEON core does not support DDR SDRAM memory.

### DDR SDRAM controller from Array Electronics, Germany

(OpenIPCore General Public License)

Integrated bank management; it does not need the CPU to initialise the memory IC.
Adjusted to the LEON memory interface via addition of a glue logic unit.



# **DDR SDRAM Controller**





The glue logic output signals to the memory controller are synchronous with a 100 MHz clock. The glue logic output signals to the LEON CPU are synchronous with a 24 MHz clock. Two finite state machines are included in the glue logic block to match the frequencies.



- The SoC-OBC can be reconfigured remotely if implemented on a Virtex FPGA.
- The Java Runtime Environment JBits is used communicating with the ground station via Internet protocols (TCP/IP).
- The RSC-OBC acts as an equivalent to an application server allowing client Java programs to run on the server and use its resource. 26



# Summary of SoC Research



- High-density FPGAs can serve as an appropriate medium for SoC implementation.
- A downsized configuration of the single-chip OBC consisting of LEON+CAN+EDAC has been implemented on a Virtex FPGA.
- The developed CCSDS s/w + single-chip OBC + a thin-layer h/w interface can provide a cost-effective and flexible communication solution for low-cost small satellites.
- A 32-bit floating-point co-processor based on the CORDIC algorithm which is IEEE 754 compliant has been developed and integrated with the LEON CPU:
  - 17 functions add, sub, mul and div + 13 elementary functions
- A credit-card size OBC system based on the SoC OBC has been specified.
- A 32-channel DMA controller has been designed and incorporated with the LEON CPU together with a DDR SDRAM controller.
- A feasibility study on the SoC remote reconfigurability via TCP/IP protocols using JBits is in progress.
- Specialised peripheral cores e.g, an image compression core, are in a process of development.

06/02/2004





# Acknowledgements

- The research results included in this presentation would not have been achieved without the financial support received from the following sponsors:
  - ESA
  - SSTL
- Thanks are due to the following individuals for their help and encouragement:
  - Hans Tiggeler Saros Technology Ltd.
  - Sandi Habinc Gaisler Research
  - Roland Weigand ESA
- The following past and present students have contributed to this research during their project work at the Surrey Space Centre, University of Surrey:
  - Jackie Rutter
  - Daixun Zheng
  - David Eamey
  - Sven Keller
  - Michael Meier



### References



- 1. H.Tiggeler, T.Vladimirova, J.Gaisler. "*Designing a System-on-a-chip for Small Satellite Data Processing and Control*", IIE Magazine on Engineering Technology, vol. 4, N 6, June 2001, pp. 38-42
- 2. I.Rutter, T.Vladimirova, H.Tiggeler. "A CCSDS Software System for a Single-Chip On-Board Computer of a Small Satellite" – 15<sup>th</sup> AIAA/Utah Sate University Conference on Small Satellites, Utah, USA, August 13-16 2001, SSC01-VI-4
- 3. D. Zheng, T. Vladimirova and Prof Sir M. Sweeting. "A CCSDS-Based Communication System for Single Chip On-Board Computer", MAPLD'02 Conference, D5, September 2002
- 4. D.Zheng, T.Vladimirova, H.Tiggeler, M.N.Sweeting. "*Reconfigurable Single-Chip On-Board Computer for a Small Satellite*", 52nd International Astronautical Congress, 2001, IAF-01-U3.09.
- 5. T. Vladimirova, D. Eamey, S. Keller and Prof Sir M. Sweeting. "Floating-Point Mathematical Co-Processor for a Single-Chip On-Board Computer", MAPLD'03 Conference, D5, September 2003
- 6. T. Vladimirova, Prof Sir M. Sweeting. "System-on-a-Chip Development for Small Satellite Onboard Data Handling," JACIC, AIAA, January 2004
- 7. M. Meier. "*Credit-Card Size Onboard Computer*", Internal Report, SSC/SSTL, September 2003
- 8. M. Meier. "DMA Controller for a SoC OBC", Internal Report, SSC/SSTL, 2003





