#### Mikroupravljači Arduino Uno Rev3 Micro AREF GND SPI PB5 D SCK IOREF Micro PB4 D CIPO RESET PB3 D COPI PB2 PB1 Analog ADC[0] PC0 A0 D14 PD5 ADC[1] D A1 D15 A2 D16 ADC[2] D ADC[3] D PC3 A3 D17 PD2 PD1 C[5] **D** PC5 ♠ LED\_BUILTIN TOP VIEW RX LED PD4 Power Digital Legend: I2C Power Analog SPI ARDUINO UNO REV3 SKU code: A000066 Ground Main Part Analog Pinout Last update: 6 Oct, 2022 (PCINT14/RESET) PC6 28 PC5 (ADC5/SCL/PCINT13) (PCINT16/RXD) PD0 2 27 PC4 (ADC4/SDA/PCINT12) (PCINT17/TXD) PD1 26 PC3 (ADC3/PCINT11) (PCINT18/INT0) PD2 25 PC2 (ADC2/PCINT10) (PCINT19/OC2B/INT1) PD3 24 PC1 (ADC1/PCINT9) (PCINT20/XCK/T0) PD4 6 23 PC0 (ADC0/PCINT8) Power VCC 22 GND Ground GND 21 8 AREF Programming/debug Digital (PCINT6/XTAL1/TOSC1) PB6 20 AVCC (PCINT7/XTAL2/TOSC2) PB7 10 19 PB5 (SCK/PCINT5) Crystal/Osc (PCINT21/OC0B/T1) PD5 PB4 (MISO/PCINT4) 11 18 (PCINT22/OC0A/AIN0) PD6 12 17 PB3 (MOSI/OC2A/PCINT3) (PCINT23/AIN1) PD7 13 16 PB2 (SS/OC1B/PCINT2) (PCINT0/CLKO/ICP1) PB0 15 14 PB1 (OC1A/PCINT1)

www.microchip.com

### SREG - Status register

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| I | T | Н | S | ٧ | N | Z | С |

### Bit 7 – I: Global Interrupt Enable

- sei(); postavlja 7. bit SREG registra omogućuje globalne prekide
- cli(); briše 7. bit SREG registra onemogućuje globalne prekide

Bit 6 - T: Bit Copy Storage

Bit 5 - H: Half Carry Flag

Bit 4 - S: Sign Bit - (EX-OR) between N and V

Bit 3 – V: Two's Complement Overflow Flag

Bit 2 – N: Negative Flag

Bit 1 – Z: Zero Flag

Bit 0 - C: Carry Flag

Ostali statusni bitovi koji se postavljaju ovisno o rezultatu kada ALU izvrši aritmetičke i logičke operacije

### Digitalni ulazi i izlazi:

AVR arhitektura je 8 bitna, stoga su svi vanjski priključci (I/O pinovi) grupirani i upravljani 8-bitnim registrima – tzv. PORT-ovi. Priključak (pin) može biti ulaz ili izlaz, a neki od priključaka imaju i druge funkcije. PORT je kontroliran sa tri registra:

DDRx (read/write) – koristi se za konfiguraciju priključka (pin) kao ulaza ('0') ili izlaza ('1')

PORTx (read/write)

- **1.** Ako je priključak (pin) konfiguriran kao <u>izlaz</u>, tada se PORTx registar koristi za postavljanje izlaznog priključak u stanje HIGH ('1') ili stanje LOW ('0').
- 2. Ako je priključak (pin) konfiguriran kao <u>ulaz</u>, tada se PORTx registar koristi za postavljanje unutarnjeg otpornika prema napajanju (pull-up) ('1' aktiviran, '0' deaktiviran).

**PIN**x (read only) – koristi se za čitanje i pohranu podataka na <u>ulaznim priključcima</u> (pinovima pojedinog PORT-a) (pohranjuje '0' i '1').

### x može biti:

- B (Arduino DIGITAL pinovi 8 do 13)
- C (Arduino ANALOG pinovi A0 do A5, ili DIGITAL 14 do 19)
- D (Arduino DIGITAL pinovi 0 do 7)



I/O PORT i pull-up otpornik

|       | <b>2</b> <sup>7</sup> | 26  | 25  | 24  | 23  | <b>2</b> <sup>2</sup> | 21  | 20  |
|-------|-----------------------|-----|-----|-----|-----|-----------------------|-----|-----|
| PORTB | PB7                   | PB6 | PB5 | PB4 | PB3 | PB2                   | PB1 | PB0 |
| PORTC | PC7                   | PC6 | PC5 | PC4 | PC3 | PC2                   | PC1 | PC0 |
| PORTD | PD7                   | PD6 | PD5 | PD4 | PD3 | PD2                   | PD1 | PD0 |
|       | MSB                   |     |     |     |     |                       |     | LSB |

|        |             | Bitwise of             | operatori                   |     |     |  |  |
|--------|-------------|------------------------|-----------------------------|-----|-----|--|--|
| ula    | azi         | AND                    | OR                          | XOR | NOT |  |  |
| а      | b           | a <mark>&amp;</mark> b | a b a^b                     |     | ~ b |  |  |
| 0      | 0           | 0                      | 0                           | 0   | 1   |  |  |
| 0      | 1           | 0                      | 1                           | 1   | 0   |  |  |
| 1      | 0           | 0                      | 1                           |     |     |  |  |
| 1      | 1           | 1                      | 1                           | 0   |     |  |  |
| posmal | k ulijevo   | <b>&lt;&lt;</b>        | podatak << broj bitova      |     |     |  |  |
| posmak | udesno      | <b>&gt;&gt;</b>        | podatak >> broj bitova      |     |     |  |  |
|        |             | Logički                | operatori                   |     |     |  |  |
|        | logički AND |                        | a <mark>&amp;&amp;</mark> b |     |     |  |  |
|        | logički OR  |                        | a    b                      |     |     |  |  |
|        | logički NOT |                        |                             | !a  |     |  |  |

AVR-GCC prevoditelj ne podržava pristup samo jednom bitu (pinu) registra (PORT) izravno, bez utjecaja na ostale bitove PORT registra, stoga moramo koristiti tzv. bitwise operatore.

# <u>Prekidi (Interrupt) – vanjski (External Interrupt):</u>

# **EICRA** - External Interrupt Control Register A – bitovi za kontrolu prekida

| 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|---|---|---|---|-------|-------|-------|-------|
|   |   |   |   | ISC11 | ISC10 | ISC01 | ISC00 |

| ISC11/ISC01 | ISC10/ISC00 | Opis (EICRA)                                                      |
|-------------|-------------|-------------------------------------------------------------------|
| 0           | 0           | Zahtjev za prekid generira niska razina na INT1/INT0              |
| 0           | 1           | Zahtjev za prekid generira bilo koja promjena logike na INT1/INT0 |
| 1           | 0           | Zahtjev za prekid generira padajući brid na INT1/INT0             |
| 1           | 1           | Zahtjev za prekid generira rastući brid na INT1/INT0              |

### EIMSK - External Interrupt Mask Register - postavljanje (sa I-bitom SREG) prekida

| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|---|---|---|---|---|---|------|------|
|   |   |   |   |   |   | INT1 | INT0 |

### EIFR - External Interrupt Flag Register - obavijest o zahtjevu prekida

| 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|---|---|---|---|---|---|-------|-------|
|   |   |   |   |   |   | INTF1 | INTF0 |

# Vanjski prekidi na promjenu logike (PCINT):

Osim vanjskih prekida INT1/INT0, ATmega328 ima 23 (PCINT0 to PCINT23) ulaza na kojima promjena logike može generirati prekid – <u>PCINT (Pin Change Interrupt):</u>

PCICR – Pin Change Interrupt Control Register - postavljanje (sa I-bitom SREG) PCINT - PCMSK2/1/0

| 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|---|---|---|---|---|-------|-------|-------|
|   |   |   |   |   | PCIE2 | PCIE1 | PCIE0 |

# PCIFR - Pin Change Interrupt Flag Register - obavijest o PCINT zahtjevu prekida

| 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|---|---|---|---|---|-------|-------|-------|
|   |   |   |   |   | PCIF2 | PCIF1 | PCIF0 |

PCMSK2 – Pin Change Mask Register 2 – postavljanje individualnih PCINT pinova

| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|---------|---------|---------|---------|---------|---------|---------|---------|
| PCINT23 | PCINT22 | PCINT21 | PCINT20 | PCINT19 | PCINT18 | PCINT17 | PCINT16 |

PCMSK1 – Pin Change Mask Register 1 – postavljanje individualnih PCINT pinova

| 7 | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
|---|---------|---------|---------|---------|---------|--------|--------|
|   | PCINT14 | PCINT13 | PCINT12 | PCINT11 | PCINT10 | PCINT9 | PCINT8 |

PCMSK0 – Pin Change Mask Register 0 – postavljanje individualnih PCINT pinova

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| PCINT7 | PCINT6 | PCINT5 | PCINT4 | PCINT3 | PCINT2 | PCINT1 | PCINT0 |

### Tablica prekidnih vektora

| broj prekida | adresa | definicija prekida             | naziv vektora     |
|--------------|--------|--------------------------------|-------------------|
| 1.           | 0x0000 | RESET                          | <del>-</del>      |
| 2.           | 0x0002 | External Interrupt Request 0   | INT0_vect         |
| 3.           | 0x0004 | External Interrupt Request 1   | INT1_vect         |
| 4.           | 0x0006 | Pin Change Interrupt Request 0 | PCINT0_vect       |
| 5.           | 0x0008 | Pin Change Interrupt Request 1 | PCINT1_vect       |
| 6.           | 0x000A | Pin Change Interrupt Request 2 | PCINT2_vect       |
| 7.           | 0x000C | Watchdog Time-out Interrupt    | WDT_vect          |
| 8.           | 0x000E | Timer/Counter2 Compare Match A | TIMER2_COMPA_vect |
| 9.           | 0x0010 | Timer/Counter2 Compare Match B | TIMER2_COMPB_vect |
| 10.          | 0x0012 | Timer/Counter2 Overflow        | TIMER2_OVF_vect   |
| 11.          | 0x0014 | Timer/Counter1 Capture Event   | TIMER1_CAPT_vect  |
| 12.          | 0x0016 | Timer/Counter1 Compare Match A | TIMER1_COMPA_vect |
| 13.          | 0x0018 | Timer/Counter1 Compare Match B | TIMER1_COMPB_vect |
| 14.          | 0x001A | Timer/Counter1 Overflow        | TIMER1_OVF_vect   |
| 15.          | 0x001C | Timer/Counter0 Compare Match A | TIMER0_COMPA_vect |
| 16.          | 0x001E | Timer/Counter0 Compare Match B | TIMER0_COMPB_vect |
| 17.          | 0x0020 | Timer/Counter0 Overflow        | TIMER0_OVF_vect   |
| 18.          | 0x0022 | SPI Serial Tranfer Complete    | SPI_STC_vect      |
| 19.          | 0x0024 | USART Rx Complete              | USART_RX_vect     |
| 20.          | 0x0026 | USART Data Registry Empty      | USART_UDRE_vect   |
| 21.          | 0x0028 | USART Tx Complete              | USART_TX_vect     |
| 22.          | 0x002A | ADC Convesion Complete         | ADC_vect          |
| 23.          | 0x002C | EEPROM Ready                   | EE_READY_vect     |
| 24.          | 0x002E | Analog Comparator              | ANALOG_COMP_vect  |
| 25.          | 0x0030 | Two-wire Serial Interface      | TWI_vect          |
| 26.          | 0x0032 | Store Program Memory Read      | SPM_READY_vect    |

# Timer/Counter1 - 16 bitni registar

## Odabir sinkronog izvora takta - vrši se u TCCR1B registru bitovima 0, 1 i 2:

| CS12 | CS11 | CS10 | Opis                                           |
|------|------|------|------------------------------------------------|
| 0    | 0    | 0    | Nema takta, timer zaustavljen                  |
| 0    | 0    | 1    | Clk <sub>I/O</sub> /1 bez podijele frekvencije |
| 0    | 1    | 0    | Clk <sub>I/O</sub> /8                          |
| 0    | 1    | 1    | Clk <sub>I/O</sub> /64                         |
| 1    | 0    | 0    | Clk <sub>I/O</sub> /256                        |
| 1    | 0    | 1    | Clk <sub>I/O</sub> /1024                       |
| 1    | 1    | 0    | Vanjski izvor na T1, padajući brid             |
| 1    | 1    | 1    | Vanjski izvor na T1, rastući brid              |



### Timer/Counter1 načini rada:

- Normal mode
- CTC mode
- Fast PWM (Pulse Width Modulation)
- Phase Correct PWM Mode
- Phase and Frequency Correct

### Timer/Counter1 registri:

TCNT - Timer/Counter register – registar pohrane impulsa takta

TCCR – Timer/Counter Control Register - postavljanje modova rada i ostalih opcija

(GTCCR - General TCCR)

**OCR – Output Compare Registe** - koristi se za generiranje prekida nakon što se odbroje impulsi upisani u njemu.

ICR – Input Capture Register - koristi se za mjerenje vremena između impulsa spojena na ICP pin (samo za Timer1 – 16 bitni)

TIMSK (Timer Interrupt Mask Register) i TIFR (Timer Interrupt Flag Register) - kontrola prekid

# Načini rada Timer/Counter1 (Waveform Generation Mode) registri TCCR1A i TCCR1B:

| MO<br>DE | WGM13 | WGM12<br>(CTC1) | WGM11<br>(PWM11) | WGM10<br>(PWM10) | Timer/Counter1 način rada             | TOP (vršna<br>vrijednost) | Promjena<br>vrijednosti<br>OCR1 | Postavljanje<br>zastavice<br>na TOV1 |
|----------|-------|-----------------|------------------|------------------|---------------------------------------|---------------------------|---------------------------------|--------------------------------------|
| 0        | 0     | 0               | 0                | 0                | Normalni                              | 0xFFFF<br>(65535)         | trenutno                        | MAX                                  |
| 1        | 0     | 0               | 0                | 1                | PWM, fazno korektivni, 8 bitni        | 0x00FF<br>(255)           | TOP                             | воттом                               |
| 2        | 0     | 0               | 1                | 0                | PWM, fazno korektivni, 9 bitni        | 0x01FF<br>(511)           | TOP                             | воттом                               |
| 3        | 0     | 0               | 1                | 1                | PWM, fazno korektivni, 10 bitni       | 0x03FF<br>(1023)          | TOP                             | воттом                               |
| 4        | 0     | 1               | 0                | 0                | CTC                                   | OCR1A                     | Trenutno                        | MAX                                  |
| 5        | 0     | 1               | 0                | 1                | PWM, brzi, 8 bitni                    | 0x00FF<br>(255)           | воттом                          | TOP                                  |
| 6        | 0     | 1               | 1                | 0                | PWM, brzi, 9 bitni                    | 0x01FF<br>(511)           | воттом                          | TOP                                  |
| 7        | 0     | 1               | 1                | 1                | PWM, brzi, 10 bitni                   | 0x03FF<br>(1023)          | воттом                          | TOP                                  |
| 8        | 1     | 0               | 0                | 0                | PWM, fazno i frekvencijski korektivni | ICR1                      | воттом                          | воттом                               |
| 9        | 1     | 0               | 0                | 1                | PWM, fazno i frekvencijski korektivni | OCR1A                     | воттом                          | воттом                               |
| 10       | 1     | 0               | 1                | 0                | PWM, fazno korektivni                 | ICR1                      | TOP                             | ВОТТОМ                               |
| 11       | 1     | 0               | 1                | 1                | PWM, fazno korektivni                 | OCR1A                     | TOP                             | воттом                               |
| 12       | 1     | 1               | 0                | 0                | СТС                                   | ICR1                      | Trenutno                        | MAX                                  |
| 13       | 1     | 1               | 0                | 1                | (rezervirano)                         | -                         | -                               | -                                    |
| 14       | 1     | 1               | 1                | 0                | PWM, brzi                             | ICR1                      | ВОТТОМ                          | TOP                                  |
| 15       | 1     | 1               | 1                | 1                | PWM, brzi                             | OCR1A                     | ВОТТОМ                          | TOP                                  |

# TCCR1A – Timer/Counter1 Control Register A – postavljanje načina rada Timer/Counter1

|       | 7                                                                                    | 6      | 5      | 4      | 3     | 2    | 1     | 0     |  |  |
|-------|--------------------------------------------------------------------------------------|--------|--------|--------|-------|------|-------|-------|--|--|
|       | COM1A1                                                                               | COM1A0 | COM1B1 | COM1B0 |       |      | WGM11 | WGM10 |  |  |
| TCCR1 | TCCR1B – Timer/Counter1 Control Register B - postavljanje načina rada Timer/Counter1 |        |        |        |       |      |       |       |  |  |
|       | 7                                                                                    | 6      | 5      | 4      | 3     | 2    | 1     | 0     |  |  |
|       | ICNC1                                                                                | ICES1  |        | WGM13  | WGM12 | CS12 | CS11  | CS10  |  |  |

|                                                                                                                |                                                                               |               |               |                        |                 | ,         | ,      |          |  |  |
|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------|---------------|------------------------|-----------------|-----------|--------|----------|--|--|
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                | FOC1A                                                                         | FOC1B         |               |                        |                 |           |        |          |  |  |
| <u>TIMSK1 – Timer/Counter1 Interrupt Mask Register</u> – postavljanje (sa I-bitom SREG) prekida Timer/Counter1 |                                                                               |               |               |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               |               | ICIE1         |                        |                 | OCIE1B    | OCIE1A | TOIE1    |  |  |
| TIFR1 -                                                                                                        | TIFR1 – Timer/Counter1 Interrupt Flag Register – obavijest o zahtjevu prekida |               |               |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               |               | ICF1          |                        |                 | OCF1B     | OCF1A  | TOV1     |  |  |
| GTCCF                                                                                                          | R – General Ti                                                                | mer/Counter   | Control Regis | <u>ster</u> – T/C sinl | kronizacija (da | atasheet) |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                | TSM                                                                           |               |               |                        |                 |           | PSRASY | PSRASYNC |  |  |
| TCNT1                                                                                                          | – Timer/Coun                                                                  | ter Register  |               |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               | -             |               |                        | IT1H            | -         | -      |          |  |  |
|                                                                                                                |                                                                               |               |               | TCN                    | IT1L            |           |        |          |  |  |
| <u>ICR1 –</u>                                                                                                  | Input Capture                                                                 | Register      |               |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               |               |               | ICF                    | R1H             |           |        |          |  |  |
|                                                                                                                |                                                                               |               |               | ICI                    | R1L             |           |        |          |  |  |
| OCR1A                                                                                                          | . – Output Cor                                                                | mpare Registe | er <b>A</b>   |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               |               |               |                        | R1AH            |           |        |          |  |  |
|                                                                                                                |                                                                               |               |               | OCF                    | R1AL            |           |        |          |  |  |
| OCR1B – Output Compare Register B                                                                              |                                                                               |               |               |                        |                 |           |        |          |  |  |
|                                                                                                                | 7                                                                             | 6             | 5             | 4                      | 3               | 2         | 1      | 0        |  |  |
|                                                                                                                |                                                                               |               |               | -                      | R1BH            |           |        |          |  |  |
|                                                                                                                |                                                                               |               |               | OCF                    | R1BL            |           |        |          |  |  |
|                                                                                                                |                                                                               |               |               |                        |                 |           |        |          |  |  |

TCCR1C - Timer/Counter1 Control Register C - aktivan kod ne-PWM moda (datasheet)

# Timer/Counter1 – izlazni komparatorski način rada u CTC načinu rada, registar TCCR1A – NE PWM

| COM1A1/COM1B1 | COM1A0/COM1B0 | Opis                                                                 |
|---------------|---------------|----------------------------------------------------------------------|
| 0             | 0             | Normalni I/O priključak, OC1A/OC1B nisu spojeni                      |
| 0             | 1             | Izmjenični (Toggle) OC1A/OC1B rad na komparacijski signal            |
| 1             | 0             | Briše OC1A/OC1B na komparacijski signal (Postavlja izlaz u LOW)      |
| 1             | 1             | Postavlja OC1A/OC1B na komparacijski signal (Postavlja izlaz u HIGH) |

Frekvenciju računamo prema:  $f_{OCnA} = \frac{f_{clk\_I/O}}{2N*(1+OCR1A)}$ 

# Timer/Counter1 - Brzi (Fast) PWM mod (registar TCCR1A)

Duty cycle: Frekvencija (Fast PWM):

Neinvertirajući mod: Duty Cycle =  $\frac{oCR1X+1}{TOP+1} * 100$   $f_{OCnxPWM} = \frac{f_{clk\_I/O}}{N \cdot (1 + TOP)}$ 

Invertirajući mod: Duty Cycle =  $\frac{TOP - OCR1X}{TOP+1} * 100$ 

| COM1A1/COM1B1 | COM1A0/COM1B0 | Opis                                                                                                                          |
|---------------|---------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0             | 0             | Normalni I/O priključak, OC1A/OC1B nisu spojeni                                                                               |
| 0             | 1             | U MODU 14 ili 15: izmjenični način OC1A na komparacijski signal (OC1B nije spojen). U ostalim modovima OC1A/OC1B nisu spojeni |
| 1             | 0             | Briše OC1A/OC1B na komparacijski signal, postavlja OC1A/OC1B na BOTTOM (neinvertirajući mod)                                  |
| 1             | 1             | Postavlja OC1A/OC1B na komparacijski signal, briše OC1A/OC1B na BOTTOM (invertirajući mod)                                    |

# <u>Timer/Counter1 - fazno korektivni (Phase Correct) PWM mod (registar TCCR1A)</u>

Duty cycle: <u>Frekvencija (fazno-korektivni PWM):</u>

Neinvertirajući mod: Duty Cycle =  $\frac{ocr1A}{TOP} * 100$   $f_{OCnxPCPWM} = \frac{f_{clk\_l/O}}{2 \cdot N \cdot TOP}$ 

Invertirajući mod: Duty Cycle =  $\frac{TOP - OCR1A}{TOP} * 100$ 

| COM1A1/COM1B1 | COM1A0/COM1B0 | Opis                                                                                                                         |
|---------------|---------------|------------------------------------------------------------------------------------------------------------------------------|
| 0             | 0             | Normalni I/O priključak, OC1A/OC1B nisu spojeni                                                                              |
| 0             | 1             | U MODU 9 ili 11: izmjenični način OC1A na komparacijski signal (OC1B nije spojen). U ostalim modovima OC1A/OC1B nisu spojeni |
| 1             | 0             | Briše OC1A/OC1B na komparacijski signal, postavlja OC1A/OC1B na BOTTOM (neinvertirajući mod)                                 |
| 1             | 1             | Postavlja OC1A/OC1B na komparacijski signal, briše OC1A/OC1B na BOTTOM (invertirajući mod)                                   |

### Analogno-digitalni pretvornik

Analogni ulazni kanale odabiremo u ADMUX registru, bitovma MUX0, MUX1, MUX2 i MUX3

### **ADMUX – ADC Multiplexer Selection Register**

| 7     | 6     | 5     | 4 | 3    | 2    | 1    | 0    |
|-------|-------|-------|---|------|------|------|------|
| REFS1 | REFS0 | ADLAR |   | MUX3 | MUX2 | MUX1 | MUX0 |

| REFS1 | REFS0 | Odabir referentnog napona                                     |
|-------|-------|---------------------------------------------------------------|
| 0     | 0     | AREF, unutarnji U <sub>ref</sub> isključen                    |
| 0     | 1     | AV <sub>CC</sub> sa vanjskim kondenzatorom na AREF priključku |
| 1     | 0     | Rezervirano                                                   |
| 1     | 1     | Unutarnji 1.1V sa vanjskim kondenzatorom na AREF priključku   |

ADLAR – bit za postavljanje opcije spremanja rezultata AD pretvorbe u ADC registar

Ako je na AREF priključak spojen stalni izvor napona, ne mogu se koristiti druge opcije za referentni napon!

| ULAZ        |
|-------------|
| ADC0        |
| ADC1        |
| ADC2        |
| ADC3        |
| ADC4        |
| ADC5        |
| ADC6        |
| ADC7        |
| ADC8        |
| rezervirano |
| 1.1V (Vbg)  |
| 0V (GND)    |
|             |

ADC8 - za temperaturni senzor

### ADCSRA - ADC Control and Status Register A

| 7    | 6    | 5     | 4    | 3    | 2     | 1     | 0     |
|------|------|-------|------|------|-------|-------|-------|
| ADEN | ADSC | ADATE | ADIF | ADIE | ADPS2 | ADPS1 | ADPS0 |

**ADC** omogućujemo postavljanjem **ADEN** bita u **ADCSRA** registru. Za uštedu energije (ukoliko ne koristimo ADC) preporuka je isključiti ADC postavljanjem ADEN bita u '0' (primjer: štedni način rada).

ADSC - ADC Start Conversion - početak AD pretvorbe

ADATE – ADC Auto Trigger Enable – omogućuje automatsko okidanje AD pretvornika - ADC obavlja uzastopne pretvorbe (Izvor signala za ovaj automatski mod odabire se ADTS2:0 bitovima u ADCSRB registru)

ADIF – ADC Interrupt Flag – postavlja se kada se AD pretvorba završi i rezultat bude upisan u ADC registar.

ADIE – ADC Interrupt Enable – kada je postavljen (uz I-bit SREG registra) omogućen je prekid vezan za ADC.

### Djelitelj odabiremo ADPS2, ADPS1 i ADPS0 bitovima

# Rezultat AD pretvorbe računamo:

$$ADC = \frac{U_{IN} \cdot 1024}{U_{REF}}$$

| ADPS2 | ADPS1 | ADPS0 | Djelitelj |
|-------|-------|-------|-----------|
| 0     | 0     | 0     | 2         |
| 0     | 0     | 1     | 2         |
| 0     | 1     | 0     | 4         |
| 0     | 1     | 1     | 8         |
| 1     | 0     | 0     | 16        |
| 1     | 0     | 1     | 32        |
| 1     | 1     | 0     | 64        |
| 1     | 1     | 1     | 128       |

### Analogni komparator

- AIN0 (pozitivni) neinvertirajući ulaz
- AIN1 (negativni) invertirajući ulaz

Kada je AIN0 > AIN1, postavlja se izlaz Analognog komparatora - ACO.

| ACIS1 | ACIS0 | Interrupt mode                                  |
|-------|-------|-------------------------------------------------|
| 0     | 0     | Prekid na svaku promjenu stanja izlaza (TOGGLE) |
| 0     | 1     | rezervirano                                     |
| 1     | 0     | Prekid na padajući brid                         |
| 1     | 1     | Prekid na rastući brid                          |

ACSR - Analog Comparator Control and Status Register

| 7   | 6 5  |     | 4   | 3    | 2    | 1     | 0     |  |
|-----|------|-----|-----|------|------|-------|-------|--|
| ACD | ACBG | ACO | ACI | ACIE | ACIC | ACIS1 | ACIS0 |  |

ACD - Analog Comparator Disable – analogni komparator je isključen kada je ACD bit postavljen u logičku'1' (smanjuje potrošnju mikroupravljača). Kod promjene ACD bita treba prekid analognog komparatora biti onemogućen (ACIE bit u '0' u ACSR registru), inače će doći do prekida kod izmjene stanja ACD bita.

**ACBG - Analog Comparator Bandgap Select** – Ako je u bit u logičkoj '1' na pozitivni ulaz dovodi se fiksni pojasni referentni napon, a ako bit u logičkoj '0' na pozitivni ulaz dovodi se vanjski napon.

ACO - Analog Comparator Output – Izlaz analognog komparatora je sinkroniziran i izravno spojen na ACO.

**ACI - Analog Comparator Interrupt** Flag - Bit se postavlja hardverski u logičku '1' kada se dogodi prekid. Prekidna rutina vezana uz analogni komparator izvršava se ako je postavljen ACIE bit (zajedno sa I-bitom SREG registra). ACI se briše hardverski nakon izvršenja prekidne rutine. Alternativno, ACI se briše upisivanje logičke '1' na mjesto bita zastavice.

**ACIE - Analog Comparator Interrupt Enable** – Kada je ACIE '1', omogućen je prekid analognog komparatora (ali samo ako je i I-bit SREG registra postavljen u '1'). Prekid analognog komparatora možemo onemogućiti postavljanjem ACIE u '0'.

**ACIC - Analog Comparator Input Capture Enable** – Upisivanjem logičke '1' omogućuje se korištenje analognog komparatora kao okidača za ulaznu jedinicu za hvatanje signala (Input Capture Unit - Timer/Counter1). Da bi se omogućilo hvatanje impulsa iz analognog komparatora potrebno je postaviti ICIE1 bit u TIMSK1 registru.

ACIS1, ACIS0 - Analog Comparator Interrupt Mode Select - Bitovi koji određuju na koji će se način generirati prekidna rutina analognog komparatora.

### ACSRB - ADC Control and Status Register B

| 7 | 6    | 5 | 4 | 3 | 2     | 1     | 0     |
|---|------|---|---|---|-------|-------|-------|
|   | ACME |   |   |   | ADTS2 | ADTS1 | ADTS0 |

**ACME – Analog Comparator Multiplexer Enable** – ako je ACME '1' i ADC je isključen

(ADEN=0 u ADCSRA) omogućen je odabir priključka na negativni (invertirajući)

operacijskog pojačala. Ako je ACME '0', AIN1 je priključen na negativni ulaz. Za negativni priključak AIN1 moguće je odabrati bilo koji od priključaka ADC7...0, s tim da AD pretvorba mora biti omogućena.

| ACME | ADEN | MUX20 | Negativni<br>ulaz<br>analognog<br>komparatora |
|------|------|-------|-----------------------------------------------|
| 0    | Х    | xxx   | AIN1                                          |
| 1    | 1    | xxx   | AIN1                                          |
| 1    | 0    | 000   | ADC0                                          |
| 1    | 0    | 001   | ADC1                                          |
| 1    | 0    | 010   | ADC2                                          |
| 1    | 0    | 011   | ADC3                                          |
| 1    | 0    | 100   | ADC4                                          |
| 1    | 0    | 101   | ADC5                                          |
| 1    | 0    | 110   | ADC6                                          |
| 1    | 0    | 111   | ADC7                                          |

### ADMUX – ADC Control and Status Register B

| 7     | 6     | 5     | 4 | 3    | 2    | 1    | 0    |  |
|-------|-------|-------|---|------|------|------|------|--|
| REFS1 | REFS0 | ADLAR |   | MUX3 | MUX2 | MUX2 | MUX0 |  |

### **USART** (Universal Synchronous and Asynchronous serial Receiver/Transmitter)

| Način rada                             | Izračun za Baud Rate                | Izračun UBRRn vrijednosti           |
|----------------------------------------|-------------------------------------|-------------------------------------|
| Asinkroni normalni<br>(U2Xn=0)         | $BAUD = \frac{fosc}{16(UBRRn+1)}$   | $UBRRn = \frac{fosc}{16BAUD} - 1$   |
| Asinkroni dvostruke<br>brzine (U2Xn=1) | $BAUD = \frac{f_{OSC}}{8(UBRRn+1)}$ | $UBRRn = \frac{f_{OSC}}{8BAUD} - 1$ |
| Sinkroni Master                        | $BAUD = \frac{fosc}{2(UBRRn+1)}$    | $UBRRn = \frac{f  osc}{2BAUD} - 1$  |

| Baud<br>Rate | fosc<br>U2Xn |       | 0000 <i>MHz</i><br>U2Xn = 1 |       |  |  |
|--------------|--------------|-------|-----------------------------|-------|--|--|
| [bps]        | UBRRn        | Error | UBRRn                       | Error |  |  |
|              |              |       |                             |       |  |  |
| 9600         | 103          | 0.2%  | 207                         | 0.2%  |  |  |
|              |              |       |                             |       |  |  |
| 115200       | 8            | -3.5% | 16                          | 2.1%  |  |  |
|              |              |       |                             |       |  |  |

 $\begin{array}{c} \textit{Error}[\%] \text{=} (\frac{\textit{BaudRate}_{\textit{približna\_vrijednost}} - 1) * 100\% \\ \underline{\textit{UBR0L and UBBR0H}} - \textit{USART Baud Rate 0} \text{ Registers: LOW and HIGH} \\ \end{array}$ 

| 7          | 6 | 5 | 4 | 3          | 2 | 1 | 0 |  |  |  |
|------------|---|---|---|------------|---|---|---|--|--|--|
|            |   |   |   | UBRR0[3:0] |   |   |   |  |  |  |
| UBRR0[7:0] |   |   |   |            |   |   |   |  |  |  |

UDR0 - USART I/O Data Register - dva shift registra (full-duplex) dijele istu I/O adresu



UCSR0A - USART Control and Status Register 0 A

| 7    | 6    | 5 4   |     | 3    | 2    | 1    | 0     |
|------|------|-------|-----|------|------|------|-------|
| RXC0 | TXC0 | UDRE0 | FE0 | DOR0 | UPE0 | U2X0 | MPCM0 |

**RXC0** – USART Receive Complete Flag – postavlja se kada je byte (nepročitanih) podataka primljen u UDR0 registar, a briše se kada je UDR0 prazan. Može se koristiti za generiranje prekida (RXCIE0 bit UCSR0B registra)

**TXC0** – USART Transmit Complete Flag – postavlja se kada je byte poslan i nema novih podataka u UDR0 registru. Može generirati prekid (TXCIE0 bit UCSR0B registra). Briše se automatski po završetku prekida ili upisivanjem logičke '1' na bit lokacije. **UDRE0** – USART Data Register Empty – postavlja se kada je TXB UDR0 prazan. Može generirati prekid (UDRIE0 bit UCSR0B registra)

FEO – Frame Error – postavlja se ako podatak u RXB ima pogrešku okvira

**DOR0** – Data Overrun Error – postavlja se kada je RXB pun.

**PE0 –** Parity Error – postavlja se ako podatak u RXB ima pogrešku pariteta (ako je paritet uključen – UPM01=1)

**U2X0** – Double Transmission Speed – postavlja se ako želimo aktivirati dvostruku brzinu asinkronog načina rada.

**MPCM0** – Multi-Processor Communication Mode – bit se postavlja ako želimo uključiti MPCM0 mod-svi primljeni okviri koji ne sadrže adresne informacije bit će ignorirani (koristi se kada prijamnik prima pakete od više predajnika)

### UCSR0B - USART Control and Status Register 0 B

| 7      | 6      | 5      | 4     | 3     | 2 1 UCSZ02 RXB80 | 1     | 0     |
|--------|--------|--------|-------|-------|------------------|-------|-------|
| RXCIE0 | TXCIE0 | UDRIE0 | RXEN0 | TXEN0 | UCSZ02           | RXB80 | TXB80 |

**RXCIEO** – RX Complete Interrupt Enable – postavlja se za omogućavanje (RX) Receive interrupt – prekid na RXC zastavicu, uz omogućen globalni prekid - I bit SREG registra.

**TXCIE0** – TX Complete Interrupt Enable – postavlja se za omogućavanje (TX) Transmit interrupt – prekid na TXC zastavicu, uz omogućen globalni prekid - I bit SREG registra.

**UDRIEO –** USART Data Register Empty Interrupt Enable – postavlja se za omogućavanje prekida na UDRE zastavicu, tj. TXB prazan, uz omogućen globalni prekid - I bit SREG registra.

**RXEN0** – Receiver Enable - postavljanjem bita omogućujemo USART prijamnik (engl .receiver)

**TXEN0** – Transmitter Enable - postavljanjem bita omogućujemo USART predajnik (engl . transmitter)

UCSZ20 – Character Size – zajedno sa bitovima UCSZ1 i UCSZ0 u registru UCSRnC određuje broj podatkovnih bitova u okviru.

**RXB80** – Receive Data Bit 8 – RXB je deveti bit primljenog znaka (u načinu rada s 9-bitnim podatkovnim okvirom)

**TXB80** – Transmit Data Bit 8 – TXB je deveti bit primljenog znaka (u načinu rada s 9-bitnim podatkovnim okvirom)

### UCSROC - USART Control and Status Register 0 C

|            | 7       |     | 6           | 5           | 5          | 4     | l          | 3   | }      | 2    |      | 1           | 0            |     |
|------------|---------|-----|-------------|-------------|------------|-------|------------|-----|--------|------|------|-------------|--------------|-----|
|            | UMSEL01 |     | UMS         | EL00        | UPM01      | UPN   | <b>100</b> | USE | 350    | UCSZ | 01   | UCSZ00      | UCPOL0       |     |
| UMS        | EL01    | UMS | SEL00       | Način       | rada       |       |            |     | UCSZ02 | UC   | SZ01 | UCSZ00      | Veličina zna | aka |
|            | 0       |     | 0           | Asinkr      | oni USART  |       |            |     | 0      |      | 0    | 0           | 5 bitova     |     |
|            | 0       |     | 1           | Sinkro      | ni USART   |       |            |     | 0      |      | 0    | 1           | 6 bitova     |     |
|            | 1       |     | 0           | rezervirano |            |       |            |     | 0      |      | 1    | 0           | 7 bitova     |     |
|            | 1       |     | 1           | MAST        | ER SPI (MS | SPIM) |            |     | 0      |      | 1    | 1           | 8 bitova     |     |
|            |         |     |             |             |            |       |            |     | 1      |      | 0    | 0           | rezervirano  |     |
| <b>UPM</b> | 01 UPI  | M00 | Paritet     |             |            |       |            |     | 1      |      | 0    | 1           | rezervirano  |     |
| 0          |         | 0   | onemogućen  |             |            |       |            | 1   |        | 1    | 0    | rezervirano |              |     |
| 0          |         |     | rezervirano |             |            |       |            | 1   |        | 1    | 1    | 9 bitova    |              |     |

| 1   | 1   | omogućen, NEPARAN |                   |
|-----|-----|-------------------|-------------------|
|     |     |                   |                   |
|     |     |                   |                   |
| UCP | OL0 | Izlaz na TxD pinu | Ulaz na RxD pinu  |
|     | 0   | Rastući XCK brid  | Padajući XCK brid |

Rastući XCK brid

| USBS0 | STOP bit(ovi) |
|-------|---------------|
| 0     | 1 bit         |
| 1     | 2 bita        |

UCPOI0 – koristi se samo u sinkronom načinu rada

Rastući XCK brid

omogućen, PARAN