# **Overview of On-Board Computing Subsystem**



**Manoj S, Sannidhi Kasturi, Chandrakala G. Raju, H. N. Suma, and Jayanthi K. Murthy** 

**Abstract** In the era of wireless communication, satellites play a very important role in making wireless communication feasible. Satellite comprises many subsystems such as On-Board Computing, Power, Telemetry Tracking and Control, Structure, Payload, Thermal, etc. On-Board Computing handles all communication between each subsystem and is also responsible for data processing and data handling. The Field Programmable Gate Array (FPGA)-based On-board Computing (OBC) boards are being designed with the microcontroller instead of the traditional OBC design which included a single standard microcontroller. These FPGAs also provide lower power consumption and are also fault-tolerant. Different interface protocols can be designed within the FPGA such as Universal Asynchronous Receiver-Transmitter (UART), Serial Peripheral Interface (SPI), Inter-integrated Circuits (I2C) for interfacing different sensors into the OBC board. This paper is a detailed survey regarding the overview of the On-Board Computing subsystem.

**Keywords** On-board computer · Field programmable gate array · Modes of operation · Data handling · Sensor interfacing

Manoj S  $(\boxtimes) \cdot$  J. K. Murthy

S. Kasturi

Department of Computer Science and Engineering, BMSCE, Bangalore, India

C. G. Raju Department of Information Science Engineering, BMSCE, Bangalore, India

H. N. Suma Department of Medical Electronics, BMSCE, Bangalore, India

© The Author(s), under exclusive license to Springer Nature Singapore Pte Ltd. 2023 C. Prakash et al. (eds.), *Smart Small Satellites: Design, Modelling and Development*, Lecture Notes in Electrical Engineering 963, [https://doi.org/10.1007/978-981-19-7198-3\\_3](https://doi.org/10.1007/978-981-19-7198-3_3)

23

Department of Electronics and Communication Engineering, BMSCE, Bangalore, India e-mail: [manoj.ec19@bmsce.ac.in](mailto:manoj.ec19@bmsce.ac.in) 

## **1 Introduction**

A satellite is a combination of different subsystems, each working to perform specific tasks. On-Board Computer (OBC) is the brain of the satellite which is responsible for monitoring temperature, pressure, direction, all telemetry and telecommand signals, and memory management [[1\]](#page-7-0). The main function of the OBC is to communicate with different subsystems and also to the ground station. OBC subsystems carry out the processing of science data (such as payload data), and housekeeping data and send it to the ground station when requested through tele commands. The next section of this paper provides the design of the onboard computing subsystem. The different modes of operation and interfacing of different sensors are discussed in Sects. [3](#page-3-0) and [4](#page-4-0) of this document, respectively. Section [5](#page-4-1) shows us the data handling done by the OBC. Sections [6](#page-4-2) and [7](#page-5-0) depict the common problems encountered during the development of the OBC, and some of the proposed solutions for the same, respectively.

## **2 Design of OBC**

OBC can be designed using an FPGA-based model, which helps all subsystems to run parallelly in a hierarchical relationship. The design using the FPGA can be done in the form of a finite state machine working in major and minor cycles. The goal is to design a system that uses the same power provided by the satellite but fits in a smaller fixed space and also interface with the control signals of the satellite that are already present [[2\]](#page-7-1).

## *2.1 Hardware Architecture*

The OBC subsystem hardware is realized either using a System On-Chip (SOC) FPGA or using a microprocessor/microcontroller. The efficient hardware design is to use both FPGA and a microprocessor running in parallel as shown in Fig. [1.](#page-2-0) The FPGA is used to interface different sensors using different protocols into the OBC. The microprocessor is used for processing housekeeping data. The microprocessor initializes and transfers the control to the processor present in the FPGA.

- **SOC FPGA**. Main processing unit responsible for data handling and interfacing different sensors
- **Microprocessor**. For housekeeping inside the OBC
- **Rx, Tx**. Receiver and Transmitter
- **Analog Sensors**. Includes Course analog sun sensors, thermistors, solar panels and battery sensors
- **Analog Interface**. Interfacing all analog sensors to the OBC board
- **Digital Sun Sensors, GPS**. For location and altitude adjustment.



<span id="page-2-0"></span>**Fig. 1** Depicts the overview of OBC subsystem

- **UART Interface**. Interfacing digital sensors and GPS to the OBC board
- **IMU and Magnetometer**. For monitoring the orientation and angular velocity of the satellite
- **Payload**. Payload sensors like camera and IR imaging devices.
- **SRAM**. For storing temporary data during data processing
- **EEPROM**. Storing parametric data of the system

**Microprocessor Selection**. The microprocessor for the OBC needs to be selected keeping different aspects such as power consumption, operating temperature, operating voltage, packaging I/O, and serial bus compatibility into consideration. Following steps are followed to select the best-suited microprocessor for our mission-

- The first step is to shortlist different core design manufacturers such as Atmel, ARM, Texas Instruments, etc.
- Based on the above-mentioned parameters microprocessors are selected and compared with different manufacturers.
- The last step is to compare each shortlisted microprocessor individually and select the best suited for our requirements [[3\]](#page-7-2).

#### **Different microprocessors used in different missions**

- Atmel 32-bit microcontroller AVR32- AT32UC3A0512 is used as the main processing unit in the Cube Sat developed by the Cape Peninsula University of Technology, South Africa [[3\]](#page-7-2).
- Norwegian University of Science and Technology (NTNU) Test Satellite uses ATSAMV71Q21 microcontroller in the UHF radio range and AT32UC3C0512C microcontroller in the VHF radio range [\[4](#page-7-3)].

• The PISAT Nano satellite launched by the Crucible of Research and Innovation Laboratory of PESIT, India, used an Atmel 32-bit microcontroller AVR32-AT32UC3A0512 with a clock speed of 12 MHz [[5\]](#page-7-4).

# *2.2 Software Architecture*

**Attributes of a good software**. The OBC software requirements specification is the most crucial part of the OBC software. Following are the characteristics to adhere to while designing the software [\[4](#page-7-3)]–

- Minimal complexity
- Ease of maintenance
- Loose coupling/high cohesion
- Extensibility, Reusability and portability.

**Onboard autonomy**. The onboard autonomy in any satellite can be distinguished in three different ways as shown below-

- The commanding level can be set such that only low-level commands are executed in the initial phase of the mission. The commanding level is increased after testing the satellite in the orbit. The high-level commands are converted into sequential low-level commands on the satellite for execution.
- The intelligent payload data processing is considered as the second autonomy wherein a particular data is selected, stored, and processed by the data processing algorithm.
- The highest autonomy is the artificial intelligence of the satellite to carry out its instructions and self-decision-making without relying on the ground station or any other system [[2\]](#page-7-1).

**Mission control system**. The mission control system looks after the satellite from the point of launch till the end of the mission. The mission control system is a part of the ground station which monitors all aspects of the machine by sending telemetry and telecommand data from the ground station to the satellite. The most common mission control system (MCS) software is the satellite control and operation system 2000 (SCOS 2000). The SCOS has been used by the European space agency in several space missions like Cryosat, Galileo FOC, and MetOp-A [[6\]](#page-7-5).

# <span id="page-3-0"></span>**3 Modes of Operation**

## *3.1 Modes of Operation Based on Battery Capacity*

As proposed by Arnesan and Kiaer, the modes of operation can be divided into three sections–

**Critical Mode**. The OBC switches to the critical mode when the battery capacity is less than 25% of the maximum battery capacity.

**Avoidance Mode**. The OBC switches to the critical mode when the battery capacity is between 25 and 50% of the maximum battery capacity.

**Normal Mode**. The OBC switches to the critical mode when the battery capacity is between 50 and 100% of the maximum battery capacity [[4\]](#page-7-3).

#### <span id="page-4-0"></span>*3.2 Modes of Operation Based on Contingency*

The contingency operation as seen in the Flying Laptop satellite developed from Institute of Space Systems, Universität Stuttgart, can be classified as follows–

**Level I Contingency (Idle Mode)**. The satellite enters the idle mode due to insufficient battery charge as mentioned above.

**Level II Contingency (Safe Mode)**. The satellite enters into the safe mode due to the failure of any primary sensors such as altitude determination sensors. This mode triggers the altitude control system into the detumbling mode [[2\]](#page-7-1).

#### <span id="page-4-1"></span>**4 Interfacing of Different Sensors to OBC**

Interfacing different sensors into the OBC is the major aspect in the development of an On-Board Computing subsystem of a nanosatellite. For interfacing different sensors we use different protocols based on the sensor datasheet. The different protocols include SPI, I2C, and UART.

Inter-integrated circuit (I2C) bus is generally used for communicating with different sensors and for data read operation. Serial-peripheral interface (SPI) bus is usually used where the data is of a larger magnitude that needs to be transferred. SPI can also be used in the interface between the OBC and the Power subsystem [\[7](#page-7-6)]. Universal Asynchronous Receiver Transmitter (UART) protocol is used for digital sun sensor and GPS interface.

#### <span id="page-4-2"></span>**5 Data Handling**

The majority of the data coming into the OBC subsystem comprises science data which includes data coming from payloads and other sensors onboard. OBC also receives housekeeping data continuously from communication devices.

#### *5.1 Payload Data Processing*

The main purpose of a satellite is to gather data, process it, and send it back to the ground station. The data gathering is generally carried out by the payloads present onboard. This data coming from the payload needs to be reduced so that there is an efficient transfer from the satellite to the ground station. The processing of the data can be done in any of the following methods–

- The redundancies in the data are removed by compressing the data by various methods.
- The data can be analyzed on the satellite before sending it to the ground station. This process takes up a long implementation time and also affects computational performance.
- The data can be screened such that only a particular part of the data is extracted and sent to the ground station [[2\]](#page-7-1).

## <span id="page-5-0"></span>**6 Common Obstacles Encountered While Designing OBC**

### *6.1 Reliability*

Reliability is always an important requirement on a space mission because if a failure occurs in space it cannot be repaired and usually results at the end of the mission, although increasing the reliability of the system is directly proportional to the increase in the cost.

#### *6.2 Space Radiation*

When the satellite is in space, radiation produced by particles emitted from either the sun (solar radiation) or from outside of the solar system, Galactic Cosmic Rays (GCRs) can cause degradation of the satellite, ultimately leading to the failure of the electronic and electrical systems in either the space vehicle or the satellite. Single event upsets (SEU) are the errors caused by radiations in microelectronic components. Single Event latch-ups (SEL) indicate the failure of a semiconductor device in responding to any input signals [[4\]](#page-7-3).

## *6.3 EEPROM Errors*

Errors observed in the microcontroller EEPROM in the OBC affect the log register of the commands processed by the OBC, whose origin is suspected to be related to

single event upsets (SEU), which can cause an increase in the OBC resets. These errors and OBC resets bring about change in the satellite time and result in the loss of the last received commands [\[8](#page-7-7)].

## **7 Fault Tolerance Methods**

#### *7.1 Watchdog Timer*

A hardware timer is set on-board which resets itself at a particular predefined interval of times is known as the Watchdog timer. This timer is used for fault isolation and to safeguard the OBC from failures such as interface bus failures.

Watchdog can be used in a hierarchical order for better implementation. Software Watchdog threads are used OBC software [[7\]](#page-7-6).

#### *7.2 Radiation Associated with Fault Tolerance for FPGA*

The SEU and SEL are caused due to radiation effects. The SRAM-based FPGAs such as ZYNC 7000 are very sensitive to radiations. The upsets associated with PL fabric can be removed by resetting the memory configurations of the upsets followed by a whole system resets. The operation of FPGA in a radiation environment can be carried out with techniques such as mitigation and scrubbing [\[7](#page-7-6)].

# *7.3 Radiation Associated with Fault Tolerance for Flash Memory*

Flash memories are generally susceptible to radiation; therefore, an additional boot image is stored in n EEPROM. This allows updating the software on flash while there is a fallback in the EEPROM. Memory scrubbing can be included in the flash memory with the help of error-correcting codes such as Hamming codes [\[7](#page-7-6)].

# *7.4 Multilevel Reset Mechanism*

A multilevel reset scheme is used to remove SEU and SEL problems. The resets can be done in different ways such as autonomous reset of just the OBC's system on module. The reset can also be done to the entire spacecraft by sending a signal to the power subsystem. The reset is also done by sending a command from the ground station using a telecommand [\[9](#page-7-8)].

## **8 Conclusion**

The overview of the On-Board Computing subsystem of a Cube Sat is discussed in this paper which includes the design of the hardware using a SOC FPGA and microprocessor. The working of satellites in different modes and data handling capability is key in the functional aspect of the OBC subsystem. Some of the obstacles encountered in designing OBC are discussed with the possible solutions for the same.

#### **References**

- <span id="page-7-0"></span>1. Ahmed HEH, Kamal E, Elsayed A (2009) Telemetry microcomputer application in satellites OBC. In: 1st South Cent. Asian Himalayas Reg. IEEE/IFIP International Conference on Internet, AH-ICI 2009, no November. <https://doi.org/10.1109/AHICI.2009.5340347>
- <span id="page-7-1"></span>2. Kuwahara T, Böhringer F, Falke A, Eickhoff J, Huber F, Röser HP (2009) FPGA-based operational concept and payload data processing for the Flying Laptop satellite. Acta Astronaut 65(11–12):1616–1627
- <span id="page-7-2"></span>3. Lwabanji L (2013) Development of an onboard computer (OBC) for a CubeSat, no May, pp 1–178
- <span id="page-7-3"></span>4. Normann MA, Birkeland R (2016) Software design of an onboard computer for a nanosatellite. [https://brage.bibsys.no/xmlui/bitstream/handle/11250/2413318/14533\\_FUL](https://brage.bibsys.no/xmlui/bitstream/handle/11250/2413318/14533_FULLTEXT.pdf?sequence=1&isAllowed=y) [LTEXT.pdf?sequence=1&isAllowed=y](https://brage.bibsys.no/xmlui/bitstream/handle/11250/2413318/14533_FULLTEXT.pdf?sequence=1&isAllowed=y)
- <span id="page-7-4"></span>5. [https://directory.eoportal.org/web/eoportal/satellitemissions/p/pisat#:~:text=OBC%20\(On%](https://directory.eoportal.org/web/eoportal/satellitemissions/p/pisat#:~:text=OBC%20(On%20Board%20Computer)%3A,all%20subsystems%20of%20the%20satellite) [20Board%20Computer\)%3A,all%20subsystems%20of%20the%20satellite](https://directory.eoportal.org/web/eoportal/satellitemissions/p/pisat#:~:text=OBC%20(On%20Board%20Computer)%3A,all%20subsystems%20of%20the%20satellite)
- <span id="page-7-5"></span>6. Venkata CL (2016) Integration of mission control system, on-board computer core and spacecraft simulator for a satellite test bench
- <span id="page-7-6"></span>7. Raje SM, Goel A, Sharma S, Aggarwal K, Mantri D, Kumar T (2017) Development of on board computer for a nanosatellite. Proc Int Astronaut Congr IAC 18(November):11773–11778
- <span id="page-7-7"></span>8. Fajardo I et al (2019) Design, implementation, and operation of a small satellite mission to explore the space weather effects in leo. Aerospace 6(10)
- <span id="page-7-8"></span>9. D. Power-efficient, L. Cost, and F. F. Based, "SSC21-S1–50," no January 2021, pp 2–6