## SVEUČILIŠTE U ZAGREBU FAKULTET ELEKTROTEHNIKE I RAČUNARSTVA

ZAVRŠNI RAD br. 2021-72

# Programska potpora za upravljanje kamerom na CubeSat nanosatelitu

Nikola Gudan

Umjesto ove stranice umetnite izvornik Vašeg rada.

Da bi ste uklonili ovu stranicu obrišite naredbu \izvornik.

Hannon le.

## SADRŽAJ

| 1.  | Uvod                                                        | 1  |
|-----|-------------------------------------------------------------|----|
| 2.  | I <sup>2</sup> C sučelje                                    | 5  |
|     | 2.1. I <sup>2</sup> C protokol                              | 5  |
|     | 2.1.1. Opis komunikacije i vremenski dijagram               | 6  |
|     | 2.2. Razlika I <sup>2</sup> C periferije na STM32L471VGT6 i |    |
|     | STM32F407VGT6 mikrokontrolerima                             | 8  |
| 3.  | SPI sučelje i DMA prijenos                                  | 12 |
|     | 3.1. SPI protokol                                           |    |
|     | 3.1.1. Opis sučelja                                         | 12 |
|     | 3.1.2. Način rada                                           | 14 |
| 4.  | Zaključak                                                   | 18 |
| Lii | teratura                                                    | 19 |

## 1. Uvod

Projekt FERSAT, koji se od 2018. godine provodi na Fakultetu elektrotehnike i računarstva, uključuje izradu, lansiranje i korištenje jednog nanosatelita CubeSat. Satelit u izradi dimenzija je približno 10 cm x 10 cm x 10 cm, volumena jedne litre i ne teži od 4/3 kilograma, što ga svrstava u skupinu satelita formata CubeSat 1U [8]. Očekivani životni vijek satelita je 3 godine, a bit će postavljen u Zemljinoj orbiti na visini između 500 i 600 kilometara. Planirani korisni teret (engl. *payload*) FERSAT-a podijeljen je na tri podsustava:

- kamera za snimanje površine Zemlje i zemaljskog horizonta,
- detektori svjetla u vidljivom i ultraljubičastom dijelu spektra za mjerenje svjetlosnog onečišćenja i debljine stupca ozona,
- komunikacijski sustav u radijskom X-pojasu (10.45 GHz) za prijenos podataka na Zemlju.

Radom korisnog tereta upravlja *Payload Data Handler* (PDH) računalo. Zadaća je PDH računala prikupiti podatke iz senzorskog podsustava i kamere, pohraniti ih u trajnu memoriju (engl. *non-volatile memory*) te poslati te podatke na Zemlju korištenjem komunikacijskog podsustava. Kao PDH računalo odabran je mikrokontroler STM32L471VGT6 proizvođača ST Microelectronics.

Za rad ostalih podsustava satelita koji nisu direktno vezani uz koristan teret (npr. upravljanje položajem satelita, slanje telemetrijskih podataka na Zemlju) brine se *Command and Data Handler* (CDH) računalo. CDH računalo također upravlja napajanjem korisnog tereta i šalje naredbe PDH računalu. Komunikacija CDH i PDH računala odvija se korištenjem sučelja CAN (*Controller Area Network*). Konkretno CDH računalo u trenutku pisanja ovog teksta još nije odabrano.

Slika 1.1 prikazuje blok dijagram cijelog sustava. U okviru ovog rada razvijena je programska potpora PDH računala za upravljanje kamerom i *flash* memorijom.



Slika 1.1: Blok dijagram FERSAT-a i komunikacija sa zemaljskom postajom [3]

Sustav za upravljanje kamerom se sastoji od Arducam Mini 5MP Plus kamere. Upravljanje kamerom se sastoji od konfiguracije kamere i samog korištenja kamere, odnosno slikanja i spermanja slike. Konfiguracija kamere je nužna kako bi se ispravno podesili parametri trajanja ekspozicije, pojačanje i formata u kojem se slika želi spremiti.

Slanjem određenog signala na sklop za kameru može se uslikati slika, a nakon slikanja slika se spremi na vlastiti međuspremnik kamere. Cilj je spremljenu kameru pročitati iz međuspremnika kamere i spremiti ju na *flash* memoriju koja se nalazi na pločici PDH-a, gdje može biti spremljena dok se ne zatraži slanje slike preko X-band predajnika na Zemlju.

*Flash* memorija, osim što služi za pohranu slike, služi i za pohranu podataka sa drugih senzora. Ona prima i šalje podatke ovisno o poslanoj naredbi putem SPI komunikacije sa mikrokontrolerom.

Upravljačko sklopovlje PDH računala se sastoji od STM32F471VGT6 mikrokontrolera, spomenute vanjske *flash* memorije, konektora za povezivanje s ostalim dijelovima sustava (uključujući i konektor za povezivanje s kamerom), sustava za napajanje, upravljačkog sklopovlja za CAN komunikaciju i sklopa za kontrolu izvođenja programa (engl. *watchdog*) [1]. Izgled tiskane pločice upravljačkog sklopovlja PDH računala prikazan je na slikama 1.2 i 1.3. Konektor X1 služi za povezivanje sustava sa kamerom.



Slika 1.2: Prikaz gornje strane tiskane pločice upravljačkog sklopovlja PDH računala [1]



Slika 1.3: Prikaz donje strane tiskane pločice upravljačkog sklopovlja PDH računala [1]

Programska podrška za PDH računalo već je razvijena [3]. Međutim, u međuvre-

menu je došlo do promjene izbora mikrokontrolera PDH računala, te je stoga postojeću programsku podršku bilo potrebno prilagoditi trenutačnom sklopovlju.

S obzirom na prirodu ovog završnog projekta, gdje je naglasak bio na prilagođavanju postojeće programske podrške, u ovom radu će biti raspravljeni izazovi i razlike do kojih je došlo tijekom prilagođavanja programske podrške. U poglavlju 2 dan je detaljan opis I<sup>2</sup>C komunikacije, te su istaknute razlike između starog i novog sklopovlja koje su bile ključne za prilagođavanje programske podrške. Na isti način opsani su SPI komunikacija i DMA prijenos u poglavlju x. Detaljan pregled razvijene programske podrške dan je u poglavlju y, gdje je opisana integracija programske podrške za kameru i *flash* memorija u FreeRTOS operacijski sustav za rad u stvarnom vremenu.

## 2. I<sup>2</sup>C sučelje

Za konfiguraciju kamere Arducam 5MP Mini Plus PDH računalo koristi I<sup>2</sup>C komunikaciju. S obzirom na to da se za razvoj programske potpore PDH računala koriste *Low-Layer* biblioteke, potrebno je razumijevanje načina rada I<sup>2</sup>C periferije odabranog mikrokontrolera kako bi se ispravno implementirali upravljački programi. U nastavku slijedi općenit opis I<sup>2</sup>C komunikacije kao i razlike između periferija na starom (STM32F407VGT6) i novom (STM32L471VGT6) mikrokontroleru.

## 2.1. I<sup>2</sup>C protokol

I<sup>2</sup>C (*Inter-Integrated Circuit*) je jednostavna dvosmjerna sinkrona serijska sabirnica razvijena od strane *Philips Semiconductors* (sada *NXP Semiconductors*) 1982 [6]. godine. Koristi dvije linije:

- serijska podatkovna linija (SDA, Serial Data Line),
- serijska taktna linija (SCL, Serial Clock Line),

obje linije su pritegnute na visoku logičku razinu preko *pull-up* otpornika. Moguće brzine prijenosa su:

- do 100 kbit/s u Standard-mode načinu rada,
- do 400 kbit/s u Fast-mode načinu rada,
- do 1 Mbit/s u Fast-mode Plus načinu rada,
- do 3.4 Mbit/s u *High-speed* načinu rada.

Navedene brzine se koriste kod dvosmjernog prijenosa, a moguća je i brzina do 5 Mbit/s u jednosmjernom prijenosu. Više uređaja se može spojiti na jednu sabirnicu, a svaki uređaje je prepoznatljiv po svojoj jedinstvenoj adresi i može se ponašati kao prijamnik ili odašiljač, ovisno o funkciji uređaja [2]. Protokol najčešće, a tako i u ovom slučaju, koristi 7-bitno adresiranje, a moguće je i korištenje 10-bitnog adresiranja. Uz prijamnike i odašiljače uređaj također može biti upravljač ili meta tijekom prijenosa

podataka. Upravljač je uređaj koji inicijalizira prijenos podataka na sabirnici i generira signal takta kako bi omogućio prijenos. U tom trenutku, bilo koji uređaj koji je adresiran smatra se metom.

Na I<sup>2</sup>C sabirnicu se također može spojiti više upravljača, a primjer jednog takvog spoja sa dva mikrokontrolera dan je na slici 2.1. Prijenos podataka bi možda mogao



Slika 2.1: Primjer I<sup>2</sup>C sabirnice sa spojena dva mikrokontrolera [2]

izgledati ovako:

- 1. Mikrokontroler A želi poslati podatke mikrokontroleru B:
  - mikrokontroler A (upravljač) adresira mikrokontroler B (meta)
  - mikrokontroler A (upravljač-odašiljač) šalje podatke mikrokontroleru B (meta-prijamnik)
  - mikrokontroler A prekida prijenos
- 2. Mikrokontroler A želi primiti podatke sa mikrokontrolera B:
  - mikrokontroler A (upravljač) adresira mikrokontroler B (meta)
  - mikrokontroler A (upravljač-prijamnik) prima podtke sa mikrokontrolera B (meta-odašiljač)
  - mikroknotroler A prekida prijenos.

U svakom od navedenih slučajeva mikrokontroler A je generirao takt i prekidao prijenos. Upravljač uvijek generira takt na I<sup>2</sup>C sabirnici kod prijenosa podataka. U ovom radu korišten je samo jedan mikrokontroler, odnosno upravljač, pa ćemo se dalje usredotočiti samo na taj slučaj.

### 2.1.1. Opis komunikacije i vremenski dijagram

I<sup>2</sup>C komunikacija započinje sa *start* simbolom i završava sa *stop* simbolom. Komunikacijom se može čitati ili pisati ovisno o R\W bitu u adresi. Struktura adresiranja kod

7-bitne adrese je prikazana u tablici 2.1.

|                       |     | A | dre | sno | polj | e |     | R\W             |
|-----------------------|-----|---|-----|-----|------|---|-----|-----------------|
| Pozicija bita u bajtu | 7   | 6 | 5   | 4   | 3    | 2 | 1   | 0               |
| Značenje              | MSB |   |     |     |      |   | LSB | 1=READ, 0=WRITE |

**Tablica 2.1:** Struktura adresiranja kod 7-bitne adrese [6]

Iz tablice je vidljivo da najmanje značajan bit označava želi li se nešto čitati ili pisati. Imajući na umu izgled adresnog bajta, vremenski dijagram tipčne I<sup>2</sup>C komunikacije prikazan je na slici 2.2.



Slika 2.2: Vremenski dijagram I<sup>2</sup>C komunikacije [6]

- Prijenos podataka se inicijalizira start uvjetom (S) tako da SDA linija prijeđe u nisku logičku razinu dok SCL linija ostaje u visokoj logičkoj razini.
- (Plavo područje) SCL prelazi u nisku logičku razinu i SDA postavlja prvi podatkovni bit dok je SCL u niskoj logičkoj razini.
- (Zeleno područje) Podaci se primaju dok SCL poraste za prvi bit (B<sub>1</sub>). Kako bi
  podaci bili valjani, SDA se ne smije promijeniti između rastućeg brida SCL-a i
  sljedećeg padajućeg brida.
- Postupak se ponavlja, SDA se postavlja dok je SCL u niskoj razini, a podaci se čitaju dok je SCL u visokoj razini (B<sub>2</sub> do B<sub>n</sub>).
- Nakon posljednjeg bita slijedi taktni impuls, tijekom kojeg SDA prelazi u nisku razinu pripremajući se za *stop* uvjet.
- Signalizira se *stop* uvjet kada SCL poraste, nakon čega slijedi porast SDA-a.

Start i stop uvjete uvijek generira upravljač. Nakon svakog bajta prijamnik šalje odašiljaču ACK bit kojim se signalizira uspješno primanje podatka, odnosno NACK bit kojim se signalizira neuspješno primanje podatka. ACK i NACK bitovi se nazivaju signalom potvrde i definiraju sljedeći način: odašiljač otpušta SDA liniju tijekom potvrdnog takta kako bi prijamnik mogao spustiti SDA na nisku razinu na kojoj i ostaje tijekom visoke razine takta. Ako SDA ostaje u visokoj razini tijekom devete periode takta, to predstavlja NACK (engl. *Not Acknowledge*) signal, a suprotan slučaj predstavlja ACK (engl. *Acknowledge*) signal. Ako je došlo do NACK signala, upravljač može generirati *stop* uvjet kako bi prekinuo prijenos ili može ponovno generirati *start* uvjet kako bi započeo nov prijenos. Vremenski dijagram cijele komunikacije sa potvrdnim signalima prikazan je na slici 2.3



Figure 6. Data transfer on the I<sup>2</sup>C-bus

**Slika 2.3:** Prijenos podataka na I<sup>2</sup>C sabirnici [2]

## 2.2. Razlika I<sup>2</sup>C periferije na STM32L471VGT6 i STM32F407VGT6 mikrokontrolerima

Tijekom prijenosa koda sa starog mikrokontrolera na novi, primjećeno je da postoji razlika između struktura I<sup>2</sup>C periferija. Točnije, postoji razlika između registarskih mapa na dvama periferijama, koje su vidljive usporedbom slika 2.4, 2.5 i 2.6.

| Offset | Register<br>name | 31     | 30   | 29   | 28   | 27   | 26      | 25      | 24     | 23    | 22      | 21         | 20     | 19   | 18        | 11        | 16   | 15       | 14      | 13      | 12       | 11     | 10      | 6           | 8      | 7     | 9    | 2      | 4      | က      | 2    | ,    | 0    |
|--------|------------------|--------|------|------|------|------|---------|---------|--------|-------|---------|------------|--------|------|-----------|-----------|------|----------|---------|---------|----------|--------|---------|-------------|--------|-------|------|--------|--------|--------|------|------|------|
| 0×0    | I2C_CR1          | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | PECEN | ALERTEN | SMBDEN     | SMBHEN | GCEN | WUPEN     | NOSTRETCH | SBC  | RXDMAEN  | TXDMAEN | Res.    | ANFOFF   |        | NF      | [3:0        | ]      | ERRIE | TCIE | STOPIE | NACKIE | ADDRIE | RXIE | TXIE | PE   |
|        | Reset value      |        |      |      |      |      |         |         |        | 0     | 0       | 0          | 0      | 0    | 0         | 0         | 0    | 0        | 0       |         | 0        | 0      | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0x4    | I2C_CR2          | Res.   | Res. | Res. | Res. | Res. | PECBYTE | AUTOEND | RELOAD |       |         | NB         | YTI    | ES[7 | 7:0]      |           |      | NACK     | STOP    | START   | HEAD 10R | AD D10 | RD WRN  |             |        |       | s    | ADI    | 0[9:   | 0]     |      |      |      |
|        | Reset value      | L      |      |      |      |      | 0       | 0       | 0      | 0     | 0       | 0          | 0      | 0    | 0         | 0         | 0    | 0        | 0       | 0       | 0        | 0      | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0x8    | I2C_OAR1         | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | Res.  | Res.    | Res.       | Res.   | Res. | Res.      | Res.      | Res. | OA1EN    | Res.    | Res.    | Res.     | Res.   | OA1MODE |             |        |       | (    | OA1    | [9:0   | 1      |      |      |      |
|        | Reset value      |        |      |      |      |      |         |         |        |       |         |            |        |      |           |           |      | 0        |         |         |          |        | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0xC    | I2C_OAR2         | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | Res.  | Res.    | Res.       | Res.   | Res. | Res.      | Res.      | Res. | OA2EN    | Res.    | Res.    | Res.     | Res.   |         | A2N<br>[2:0 |        |       |      | O/     | 12[7:  | 1]     |      |      | Res. |
|        | Reset value      |        |      |      |      |      |         |         |        |       |         |            |        |      |           |           |      | 0        |         |         |          |        | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    |      |
| 0x10   | I2C_<br>TIMINGR  | PF     | RES  | C[3  | :0]  | Res. | Res.    | Res.    | Res.   | 97    |         | DEI<br>:0] | L      | 97   | SDA<br>[3 |           | L    |          |         | S       | CLH      | 1[7:0  | 0]      |             |        |       |      | S      | CLL    | [7:0   | ]    |      |      |
|        | Reset value      | 0      | 0    | 0    | 0    |      |         |         |        | 0     | 0       | 0          | 0      | 0    | 0         | 0         | 0    | 0        | 0       | 0       | 0        | 0      | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0x14   | I2C_<br>TIMEOUTR | TEXTEN | Res. | Res. | Res. |      |         |         | т      | IME   | OU      | тв         | [11:0  | 0]   |           |           |      | TIMOUTEN | Res.    | Res.    | TIDLE    |        |         |             |        | ТІМ   | EOL  | JTA[   | 11:0   | 1      |      |      |      |
|        | Reset value      | 0      |      |      |      | 0    | 0       | 0       | 0      | 0     | 0       | 0          | 0      | 0    | 0         | 0         | 0    | 0        |         |         | 0        | 0      | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0x18   | I2C_ISR          | Res    | Res  | Res  | Res  | Res  | Res     | Res     | Res    |       | ΑI      | DDC        | OD     | E[6  | :0]       |           | DIR  | BUSY     | Res.    | ALERT   | TIMEOUT  | PECERR | OVR     | ARLO        | BERR   | TCR   | TC   | STOPF  | NACKF  | ADDR   | RXNE | TXIS | TXE  |
|        | Reset value      |        |      |      |      |      |         |         |        | 0     | 0       | 0          | 0      | 0    | 0         | 0         | 0    | 0        |         | 0       | 0        | 0      | 0       | 0           | 0      | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 1    |
| 0x1C   | I2C_ICR          | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | Res.  | Res.    | Res.       | Res.   | Res. | Res.      | Res.      | Res. | Res.     | Res.    | ALERTCF | TIMOUTCF | PECCF  | OVRCF   | ARLOCF      | BERRCF | Res.  | Res. | STOPCF | NACKCF | ADDRCF | Res. | Res. | Res. |
|        | Reset value      |        |      |      |      |      |         |         |        |       |         |            |        |      |           |           |      |          |         | 0       | 0        | 0      | 0       | 0           | 0      |       |      | 0      | 0      | 0      |      |      |      |
| 0×20   | I2C_PECR         | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | Res.  | Res.    | Res.       | Res.   | Res. | Res.      | Res.      | Res. | Res.     | Res.    | Res.    | Res.     | Res.   | Res.    | Res.        | Res.   |       |      | F      | EC     | [7:0   | l    |      |      |
|        | Reset value      |        |      |      |      |      |         |         |        |       |         |            |        |      |           |           |      |          |         |         |          |        |         |             |        | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |
| 0x24   | I2C_RXDR         | Res.   | Res. | Res. | Res. | Res. | Res.    | Res.    | Res.   | Res.  | Res.    | Res.       | Res.   | Res. | Res.      | Res.      | Res. | Res.     | Res.    | Res.    | Res.     | Res.   | Res.    | Res.        | Res.   |       |      | RX     | DAT    | A[7    | :0]  | _    |      |
|        | Reset value      |        |      |      |      |      |         |         |        |       |         |            |        |      |           |           |      |          |         |         |          |        |         |             |        | 0     | 0    | 0      | 0      | 0      | 0    | 0    | 0    |

**Slika 2.4:** Registarska mapa I<sup>2</sup>C periferije STM32L471VGT6 mikrokontrolera [5]

| Offset | Register<br>name | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 11   | 16   | 15   | 14   | 13   | 12   | 11   | 10   | 6    | 8    | 7 | 9 | 2  | 4   | 3    | 2   | - | 0 |
|--------|------------------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|---|---|----|-----|------|-----|---|---|
| 0x28   | I2C_TXDR         | Res. |   |   | тх | DAT | A[7: | :0] |   |   |
|        | Reset value      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 0 | 0 | 0  | 0   | 0    | 0   | 0 | 0 |

**Slika 2.5:** Registarska mapa I<sup>2</sup>C periferije STM32L471VGT6 mikrokontrolera - nastavak [5]

| Offset | Register    | 26 29 29 29 29 29 29 29 29 29 29 29 29 29 | 15       | 14       | 13       | 12     | 11    | 10      | 6       | 8       | 7         | 9                                        | 2         | 4       | 3        | 2        | -     | 0      |
|--------|-------------|-------------------------------------------|----------|----------|----------|--------|-------|---------|---------|---------|-----------|------------------------------------------|-----------|---------|----------|----------|-------|--------|
| 0x00   | I2C_CR1     | Reserved                                  | SWRST    | Reserved | ALERT    | PEC    | POS   | ACK     | STOP    | START   | NOSTRETCH | ENGC                                     | ENPEC     | ENARP   | SMBTYPE  | Reserved | SMBUS | 掘      |
|        | Reset value |                                           | 0        | 1        | 0        | 0      | 0     | 0       | 0       | 0       | 0         | 0                                        | 0         | 0       | 0        |          | 0     | 0      |
| 0x04   | 12C_CR2     | Reserved                                  |          |          |          | LAST   | DMAEN | ITBUFEN | ITEVTEN | ITERREN | Postorood | na n |           |         |          | 0[5:0    |       |        |
|        | Reset value |                                           |          |          |          | 0      | 0     | 0       | 0       | 0       | _         | _                                        | 0         | 0       | 0        | 0        | 0     | 0      |
| 0x08   | I2C_OAR1    | Reserved                                  | ADDMODE  |          | Re       | esen   | /ed   |         | ADD     | [9:8]   |           |                                          | AD        | D[7     | 7:1]     |          |       | ADD0   |
|        | Reset value |                                           | 0        |          |          |        |       |         | 0       | 0       | 0         | 0                                        | 0         | 0       | 0        | 0        | 0     | 0      |
| 0x0C   | I2C_OAR2    | Reserved                                  |          |          |          |        |       |         |         |         |           |                                          | AD        | D2[     | 7:1]     |          |       | ENDOAL |
| '      | Reset value |                                           |          |          |          |        |       |         |         |         | 0         | 0                                        | 0         | 0       | 0        | 0        | 0     | 0      |
| 0x10   | I2C_DR      | Reserved                                  |          |          |          |        |       |         |         |         |           |                                          |           | DR      | [7:0]    |          |       |        |
| '      | Reset value |                                           |          |          |          |        |       |         |         |         | 0         | 0                                        | 0         | 0       | 0        | 0        | 0     | 0      |
| 0x14   | I2C_SR1     | Reserved                                  | SMBALERT | TIMEOUT  | Reserved | PECERR | OVR   | AF      | ARLO    | BERR    | TXE       | RXNE                                     | Reserved  | STOPF   | ADD 10   | BTF      | ADDR  | SB     |
| ,      | Reset value |                                           | 0        | 0        |          | 0      | 0     | 0       | 0       | 0       | 0         | 0                                        |           | 0       | 0        | 0        | 0     | 0      |
| 0x18   | I2C_\$R2    | Reserved                                  |          |          |          | PE     | :C[7  | :0]     |         |         | DUALF     | SMBHOST                                  | SMBDEFAUL | GENCALL | Reserved | TRA      | BUSY  | MSL    |
|        | Reset value |                                           | 0        | 0        | 0        | 0      | 0     | 0       | 0       | 0       | 0         | 0                                        | 0         | 0       |          | 0        | 0     | 0      |
| 0x1C   | I2C_CCR     | Reserved                                  | E/S      | TUG      |          | served |       |         |         |         | CC        | R[1                                      | 1:0]      |         |          |          |       |        |
| '      | Reset value |                                           | 0        | 0        | d        | 2      | 0     | 0       | 0       | 0       | 0         | 0                                        | 0         | 0       | 0        | 0        | 0     | 0      |
| 0x20   | I2C_TRISE   | Reserved                                  | •        |          |          |        |       |         |         |         |           |                                          |           | Т       | RIS      | E[5:0    | ]     |        |
|        | Reset value |                                           |          |          |          |        |       |         |         |         |           |                                          | 0         | 0       | 0        | 0        | 1     | 0      |
| 0x24   | I2C_FLTR    | Reserved                                  | d        |          |          |        |       |         |         |         |           |                                          |           | ANOFF   |          | )NF[     |       |        |
|        | Reset value |                                           |          |          |          |        |       |         |         |         |           |                                          |           | 0       | 0        | 0        | 0     | 0      |

**Slika 2.6:** Registarska mapa I<sup>2</sup>C periferije STM32F407VGT6 mikrokontrolera[4]

Vidljiva je razlika između količine registara, raspodjele i značenja njihovih bitova, kao i njihovih imena, što implicira različite funkcionalnosti pojedinih registara. Tako, npr. I<sup>2</sup>C periferija kod STM32F407VGT6 sadržava 2 status registra: I2C\_SR1 i I2C\_SR2, dok kod STM32L471VGT6 postoji samo jedan status registar I2C\_ISR. Ta razlika je bitna iz razloga što se tijekom prijenosa podataka na I<sup>2</sup>C sabirnici trebaju provjeravati razne zastavice koje se mijenjaju tijekom komunikacije, kao što je npr. zastavica za prazni odašiljački registar (STM32F407VGT6: registar I2C\_SR1 bit 7, STM32L471VGT6: bit 0), zastavica za puni prijamnički registar (STM32F407VGT6: registar I2C\_SR1, bit 6, STM32L471VGT6: bit 2), zastavica za završetak prijenosa

(STM32F407VGT6: ne postoji, STM32L471VGT6: bit 6) itd.

Vidljivo je također da kod STM32L471VGT6 postoji zastavica ADDR, koja inače kod STM32F407VGT6 signalizira uspješan primitak adrese uređaja mete, a kod STM32L471VGT6 ta zastavica se koristi isključivo u *slave* načinu rada, tako da ta zastavica nije bitna za ovaj projekt. Kako onda mikrokontroler zna da je poslana adresa točna? Naime, STM32L471VGT6 ima poseban registar za pohranu adrese uređaja mete, pa kada mikrokontroler pošalje *start* uvjet on automatski nakon završetka *start* uvjeta pošalje i adresu uređaja mete, a uspješan primitak adrese signalizira zastavica I2C\_ISR\_TXIS kod slanja podataka, odnosno I2C\_ISR\_RXNE zastavica kod primitka podataka.

Vidljive su i razlike u raspodjeli zastavica u registrima, kao i razlike u funkcijama koje zastavice signaliziraju. Inače bi te razlike stvarale probleme kod konfiguracije I<sup>2</sup>C periferije, no, kako je tu brigu rješio kod generator ugrađen u STM32CubeIDE razvojno okruženje, nije bila posvećena pažnja tim razlikama. Način implementacije spomenutih razlika u programsku podršku opisan je u poglavlju z.

## 3. SPI sučelje i DMA prijenos

SPI protokol se koristi za prijenos podataka između *flash* memorije i mikrokontrolera, odnosno međuspremnika kamere. Kako bi se oslobodili resursi na mikrokontroleru, za prijenos podataka između kamere i *flash* memorije se, u kombinaciji s SPI protokolom, koristi i DMA prijenos. S obzirom da se koriste *Low-Layer* biblioteke, potrebno je razumijeti način rada SPI i DMA periferija mikrokontrolera. U ovom poglavlju biti će opisan SPI protokol i DMA prijenos i biti će istaknute razlike i problemi kod prilagođavanja programske podrške na STM32L471VGT6 mikrokontroler.

### 3.1. SPI protokol

SPI (engl. *Serial Peripheral Interface* je sinkrono serijsko komunikacijsko sučelje koje se koristi za komunikaciju na kratkim udaljenostima, pretežito u ugradbenim računalnim sustavima [7].

SPI uređaji komuniciraju u *full-duplex* načinu rada koristeći *master-slave* arhitekturu, obično sa jednim *master* uređajem. *Master* (upravljač) uređaj proizvodi okvir za čitanje i pisanje. Više *slave* uređaja može biti spojeno na jedan upravljač tako da se aktivira određeni *chip select* signal za pojedini uređaj.

### 3.1.1. Opis sučelja

SPI sabirnica se sastoji od četiri signala:

- SCLK: Serijski takt (izvor je *master* uređaj)
- MOSI: Master Output Slave Input (izvor podataka iz master uređaja)
- MISO: Master Input Slave Output (izvor podataka iz slave uređaja)
- CS/SS: *Chip/Slave Select* (aktivan nisko, signal iz *master* uređaja, označava da se prenose podaci)

MOSI na *master* uređaju se spaja na MOSI na *slave* uređaju, dok se MISO na *master* uređaju se spaja na MISO na *slave* uređaju. CS/SS se koristi za pokretanje komuni-kacije između *slave* i *master* uređaja. Za svaki *slave* uređaj postoji zaseban CS/SS priključak na *master* uređaju. Takav način spajanja se naziva neovisni *slave* uređaj. Primjer spajanja tri *slave* uređaja na jedan *master* uređaj u konfiguraciji neovisnog *slave* uređaja prikazan je na slici 3.1.



**Slika 3.1:** Spoj tri *slave* uređaja na jedan *master* uređaj u konfiguraciji neovisnog *slave* uređaja. Vidljivo je da *master* uređaj ima tri SS priključka, a svaki odgovara jednom *slave* uređaju, dok se SCLK, MOSI i MISO linije međusobno dijele između *slave* uređaja [7]

Moguće je još spojiti uređaje u kofiguraciju ulančavanog *slave* uređaja. U toj konfiguraciji *slave* uređaji dijele isi CS/SS, a ulančavanjem preko MISO/MOSI linija podaci se prenose prema načelu posmačnog registra, koji je objašnjen u sljedećoj sekciji. Prikaz spajanja tri *slave* uređaja se nalazi na slici 3.2



**Slika 3.2:** Spoj tri *slave* uređaja na jedan *master* uređaj u konfiguraciji ulančavanog *slave* uređaja [7]

#### 3.1.2. Način rada

SPI sabirnica radi sa jednim *master* uređajem i jednim ili više *slave* uređaja. Ako se koristi jedan *slave* uređaj, onda CS stezaljka može biti cijelo vrijeme postavljena u niskom logičkom stanju, ako *slave* uređaj to dopušta. Neki *slave* uređaji zahtijevaju padajući brid CS signala kako bi započeča komunikacija. Ako se koristi više *slave* uređaja potreban je zaseban CS signal *master* uređaja za svaki *slave* uređaj.

#### Prijenos podataka

Za početak komunikacije *master* uređaj konfigurira takt koristeći frekvenciju koju podržava *slave* uređaj, obično do nekoliko MHz. *Master* uređaj zatim odabire *slave* uređaj postavljanjem CS linije u nisko logičko stanje. Ako je potreban period čekanja, npr. za ADC konverziju, *master* uređaj mora pričekati minimalno taj period vremena prije puštanja takta.

Tijekom svakog perioda takta obavlja se prijenos podataka u *full-duplex* načinu prijenosa. To znači da *master* uređaj pošalje jedan bit na MOSI liniju, kojega *slave* uređaj pročita, dok u isto vrijeme *slave* uređaj šalje jedan bit na MISO liniju, kojega *master* uređaj pročita. Takva sekvenca se održava čak i kada se izvađa jednosmjeran prijenos podataka.

Prijenosi podataka uključuju dva posmačna registra zadane veličine, npr. 8 bitova, jedan u *master* i drugi u *slave* uređaju. Registri su spojeni u topologiji virtualnog

prstena (slika 3.3).



Slika 3.3: Tipičan spoj dvaju posmačna registra koji formiraju kružni međuspremnik [7]

Podaci se obično pomiču na način da se prvo pomakne najznačajniji bit. Na brid takta, *master* i *slave* uređaj pomaknu bit i pošalju ga na prijenosnu liniju. Na sljedeći brid takta, na svakom prijamniku bit se uzorkuje sa prijenosne linije i postavlja se kao novi najmanje značajni bit u posmačnom registru. *Master* i *slave* uređaji u potpunosti razmjene podatke u registrima nakon što se svi bitovi u registrima prebace. Ako je potrebno razmjeniti još podataka, posmačni registri se ponovno napune te se postupak ponavlja, a prijenos se može obavljati za bilo koji broj perioda takta. Kada je prijenos dovršen, *master* uređaj prestaje davati takt i obično isključi CS signal, odnosno postavi ga na visoku razinu.

Prijenos se obično obavlja u širinama podataka od 8 bitova, no moguć je i 16 bitni prijenos, ili čak 12 bitni prijenos, koji se koristi za DAC i ADC konvertere.

#### Polaritet takta i faza

Osim što mora podesiti frekvenciju takta, *master* uređaj mora isto tako podesiti polaritet takta (CPOL, engl. *Clock Polarity*) i fazu (CPHA, engl. *Clock Phase*) ovisno o podacima. Vremenski dijagram je prikazan na slici 3.4.



**Slika 3.4:** Vremenski dijagram koji pokazuje polaritet takta i fazu. Crvene linije označuju vodeće bridove, a plave linije označuju prateće bridove.

CPOL određuje polaritet kanala. Polaritet može biti invertiran sa jednostavnim inverterom.

- Ako je CPOL = 0, onda takt miruje u niskom logičkom stanju, a svaki period se sastoji od impulsa visokog logičkog stanja. To znači da je vodeći brid rastući brid, a prateći brid padajući brid.
- Ako je CPOL = 1, onda takt miruje u visokom logičkom stanju, a svaki period se sastoji od impulsa niskog logičkog stanja. To znači da je vodeći brid padajući brid, a prateći brid rastući brid.

CPHA određuje fazu podatkovnih bitova u odnosu na takt.

- Ako je CPHA = 0, "izlazna" strana mijenja podatak na prateći brid prethodnog perioda takta, dok "ulazna" strana prihvaća podatak na (ili ubrzo nakon) vodeći brid perioda takta. Izlazna strana zadržava valjani podatak sve do pojave pratećeg brida trenutnog perioda takta.
- Ako je CPHA = 1, "izlazna" strana mijenja podatak na vodeći brid trenutnog perioda takta, dok "ulazna" strana prihvaća podatak na (ili ubrzo nakon) pratećeg brida perioda takta. Izlazna strana zadržava valjani podatak do pojave vodećeg brida sljedećeg perioda takta. Na zadnji period, slave uređaj zadržava valjani podatak na MISO liniji sve dok slave uređaj ne bude deselektiran.

MOSI i MISO signali su obično stabilni za vrijeme pola perioda takta, sve do sljedeće promjene takta. SPI *master* i *slave* uređaji mogu uzorkovati podatke u bilo kojem vremenu unutar te polovice periode takta.

Kombinacije različitih konfiguracija CPOL i CPHA bitova predstavljaju *modove*. Konvnecija je da CPOL predstavlja viši bit, dok CPHA predstavlja niži bit. *Modovi* kod ARM-ovih mikrokontrolera su prikazani u tablici 3.1

| SPI mod | CPOL | СРНА |
|---------|------|------|
| 0       | 0    | 0    |
| 1       | 0    | 1    |
| 2       | 1    | 0    |
| 3       | 1    | 1    |

Tablica 3.1: SPI *Modovi* kod ARM-ovih mikrokontrolera [7]

## 4. Zaključak

Zaključujem ovaj projekt.

## LITERATURA

- [1] Filip Jurić. Upravljačko sklopovlje za prikupljanje i obradu senzorskih signala na CubeSat nanosatelitu. Završni rad, Sveučilište u Zagrebu, Fakultet elektrotehnike i računarstva, 2021.
- [2] *UM10204 I<sup>2</sup>C-bus specification and user manual*. NXP Semiconductors, 2021. Rev. 7.0.
- [3] Goran Petrak. Programska potpora ugradbenog računalnog sustava za udaljeno prikupljanje fotografija putem satelita. Diplomski rad, Sveučilište u Zagrebu, Fakultet elektrotehnike i računarstva, 2021.
- [4] RM0090 Reference manual STM32F405/415, STM32F407/417, STM32F427/437 and STM32F429/439 advanced Arm®-based 32-bit MCUs. ST Microelectronics, 2021. Rev. 9.
- [5] RM0351 Reference manual STM32L47xxx, STM32L48xxx, STM32L49xxx and STM32L4Axxx, advanced Arm®-based 32-bit MCUs. ST Microelectronics, 2021. Rev. 9.
- [6] Wikipedia. I<sup>2</sup> c, 2022. URL https://en.wikipedia.org/wiki/I%C2% B2C. Preuzeto: 30.05.2022.
- [7] Wikipedia. Serial peripheral interface, 2022. URL https://en.wikipedia.org/wiki/Serial\_Peripheral\_Interface. Preuzeto: 20.06.2022.
- [8] FER ZKIST. FERSAT opis projekta, 2022. URL https://www.fer.unizg.hr/zkist/FERSAT/projekt. Preuzeto: 18.06.2022.

| Programely notners                   | a unravljanja kamaram na CuhaSat nana  |
|--------------------------------------|----------------------------------------|
| i rogramska potpora z                | a upravljanje kamerom na CubeSat nano  |
|                                      | Sažetak                                |
| Sažetak na hrvatskom jez             | iku.                                   |
| <b>Iljučne riječi:</b> Ključne riječ | i, odvojene zarezima.                  |
|                                      |                                        |
|                                      |                                        |
|                                      |                                        |
|                                      |                                        |
|                                      |                                        |
|                                      |                                        |
|                                      |                                        |
| Software for C                       | amera Control on CubeSat Nanosatellite |
|                                      | Abstract                               |
| Abstract.                            |                                        |
|                                      |                                        |