Lecture 07 AVR Module 1
Lecture 07 AVR Module 1
Instructor:
          Dr. Ahmed Shalaby
          http://bu.edu.eg/staff/ahmedshalaby14#
Course Book
   Embedded Systems
www. Micro Digital Ed. com
                                                                                                                                                  BIHE university
                                                   Introduction to Computing
                                                                                   Chapter 0
                             AVR Microcontroller and Embedded System Using Assembly and C                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                                      Topics
www. Micro Digital Ed. com
                                                                                                                                                  BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                     Internal organization of computers
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • CPU
                             • Memory
                             • I/O
                                   – Input
                                           • E.g. Keyboard, Mouse, Sensor
                                   – Output
                                           • E.g. LCD, printer, hands of a robot
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                                   Memory
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                        Memory characteristics
www. Micro Digital Ed. com
                                                                                                                                                      BIHE university
                             • Capacity
                                   – The number of bits that a memory can store.
                                           • E.g. 128 Kbits, 256 Mbits
                             • Organization
                                                                                                                                         4 bits
                                   – How the locations are organized                                                                              0
                                                                                                                         128 locations
                                                                                                                                                  1
                                           • E.g. a 128 x 4 memory has 128 locations,                                                             2
4 bits each
                                                                                                                                           …
                                                                                                                                                  127
                             • Access time
                                   – How long it takes to get data from memory
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                    Semiconductor memories
www. Micro Digital Ed. com
                                                                                                                                                          BIHE university
                             • ROM                                                          • RAM
                                   – Mask ROM                                                 – SRAM (Static RAM)
                                   – PROM (Programmable                                       – DRAM (Dynamic RAM)
                                        ROM)                                                  – NV-RAM (Nonvolatile
                                   – EPROM (Erasable                                            RAM)
                                     PROM)
                                   – EEPROM (Electronic
                                     Erasable PROM)
                                   – Flash EPROM
                             AVR Microcontroller and Embedded System Using Assembly and C                              © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                               Memory\ROM\                  Mask ROM
www. Micro Digital Ed. com
                                                                                                                                                     BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                         © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                             Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Memory\ROM\                 PROM (Programmable ROM)
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
             Memory\ROM\                      EPROM (Erasable Programmable ROM)
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • UV-EPROM
                                   – You can shine ultraviolet (UV) radiation
                                     to erase it
                                   – Erasing takes up to 20 minutes
                                   – The entire contents of ROM are erased
2764
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                   Memory\ROM\               EEPROM (Electrically Erasable
www. Micro Digital Ed. com
                                                              Programmable ROM)                                                                BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                               Memory\ROM\                  Flash ROM
www. Micro Digital Ed. com
                                                                                                                                                      BIHE university
                             • Erased in a Flash
                             • the entire device is erased at once
                             AVR Microcontroller and Embedded System Using Assembly and C                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                    Semiconductor memories
www. Micro Digital Ed. com
                                                                                                                                                          BIHE university
                             • ROM                                                          • RAM
                                   – Mask ROM                                                 – SRAM (Static RAM)
                                   – PROM (Programmable                                       – DRAM (Dynamic RAM)
                                        ROM)                                                  – NV-RAM (Nonvolatile
                                   – EPROM (Erasable                                            RAM)
                                     PROM)
                                   – EEPROM (Electronic
                                     Erasable PROM)
                                   – Flash EPROM
                             AVR Microcontroller and Embedded System Using Assembly and C                              © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                Memory\RAM\                 SRAM (Static RAM)
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
– Faster SRAM
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                          Memory\RAM\                  DRAM (Dynamic RAM)
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Made of capacitors
                             • Advantages:
                                   – Less power consumption
                                   – Cheaper
                                   – High capacity
                             • Disadvantages:
                                   – Slower
                                   – Refresh needed
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Memory\RAM\                  NV-RAM (Nonvolatile RAM)
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                         Internal parts of computers\CPU
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Tasks:
                                   – It should execute instructions
                                           • It should recall the instructions one after another
                                             and execute them
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                Connecting memory to CPU
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
VCC
GND VCC
                                                                                            8
                                                                                                    D0-D7
                                                                                            n
                                                                                                    A0-An-1
                                                                                                    WE
                                                                                                    OE
                                                                                                    CS
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                Connecting memory to CPU
www. Micro Digital Ed. com
                                                                                                                                                            BIHE university
VCC
GND VCC
                                                                                            8
                                                                                                    D0-D7
                                                                CPU                             n
                                                                                                    A0-An-1
WE
                                                                                                    OE
                                                                                                    CS
                             AVR Microcontroller and Embedded System Using Assembly and C                                © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                    Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                Connecting    memory to CPU
                                                         Writing to memory
                                                   Address
www. Micro Digital Ed. com
                                                                                                                                                            BIHE university
                                                           CS
                                                         Data
WE
Time
VCC
GND VCC
                                                                                            8
                                                                                                    D0-D7
                                                                 CPU                            n
                                                                                                    A0-An-1
WE
                                                                                                    OE
                                                                                                    CS
                             AVR Microcontroller and Embedded System Using Assembly and C                                © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                    Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                Connecting    memory
                                                         Writing
                                                      Reading        memory to CPU
                                                                  to memory
                                                               from
                                                  Address
www. Micro Digital Ed. com
                                                 Address
                                                                                                                                                             BIHE university
                                                     CS
                                                      CS
                                                     OE
                                                     Data
                                                   Data
                                                         WE
                                                        WE
                                                                                                           Time
                                                                                                         Time
VCC
GND VCC
                                                                                            8
                                                                                                    D0-D7
                                                                 CPU                            n
                                                                                                    A0-An-1
WE
                                                                                                    OE
                                                                                                    CS
                             AVR Microcontroller and Embedded System Using Assembly and C                                 © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                     Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Connecting I/Os to CPU
www. Micro Digital Ed. com
                                                                                                                                                         BIHE university
                                  Network
                                                                                       CPU                                  Keyboard
                                                                                                                   Sound Card
                                                                                       Graphic Card
                             AVR Microcontroller and Embedded System Using Assembly and C                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                                     Connecting I/Os to CPU using bus
www. Micro Digital Ed. com
                                                                                                                                                        BIHE university
Address bus
                                               Data bus
                                                        Write
                               Control bus Read
                                    CPU
                                                                                     I/O 0   I/O 1      I/O 2                       I/O n
                             AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                Connecting I/Os and Memory to CPU
www. Micro Digital Ed. com
                                                                                                                                                                 BIHE university
Address bus
                                               Data bus
                                                         Write
                               Control bus Read
GND VCC
                                                                                n
                                                                                      A0-An-1
                                                                            8
                                                                                      D0-D7
WE
                                                                                      OE
                                                                                      CS
                             AVR Microcontroller and Embedded System Using Assembly and C                                     © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                         Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and memory to CPU using bus
www. Micro Digital Ed. com
                                                                                                                                                                                         BIHE university
                                                                                              VCC
                                                                                                                      1
                                                                                                                      2
                                                                                                                      3
                                                                                                    A0-An-1
                                                                                              GND
D0-D7
WE
                                                                                                                               OE
                                                                                                                                     CS
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                                I/O 0                   I/O 1                       I/O 2                     I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                           © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and memory to CPU using bus
www. Micro Digital Ed. com
                                                                                                                                                                                         BIHE university
                                                                                              VCC
                                                                                                                      1
                                                                                                                      2
                                                                                                                      3
                                                                                                    A0-An-1
                                                                                              GND
D0-D7
WE
                                                                                                                               OE
                                                                                                                                     CS
                                                                      0
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                                I/O 0                   I/O 1                       I/O 2                     I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                           © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and memory to CPU using bus
www. Micro Digital Ed. com
                                                                                                                                                                                         BIHE university
                                                                                              VCC
                                                                                                                      1
                                                                                                                      2
                                                                                                                      3
                                                                                                    A0-An-1
                                                                                              GND
D0-D7
WE
                                                                                                                               OE
                                                                                                                                     CS
                                                                      0
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                                I/O 0                   I/O 1                       I/O 2                     I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                           © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and memory to CPU using bus
www. Micro Digital Ed. com
                                                                                                                                                                                         BIHE university
                                                                                              VCC
                                                                                                                      1
                                                                                                    A0-An-1
                                                                                              GND
D0-D7
WE
                                                                                                                               OE
                                                                                                                                     CS
                                                                      0
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                                I/O 0                   I/O 1                       I/O 2                     I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                           © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                            (Peripheral I/O)                                                                                                                        BIHE university
                                                                                         VCC
                                                                                                                 0
                                                                                                                 1
                                                                                                                 ..
                                                                                                                 63
                                                                                               A0-An-1
                                                                                         GND
D0-D7
WE
                                                                                                                           OE
                                                                                                                                CS
                                  Address bus
                                         Data bus
                           Write
             Control bus   Read
                         IO/MEM
                                CPU
                                                                               I/O 0                I/O 1                       I/O 2                    I/O n
                              AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                                                                                                                  ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                                                                                          GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                               I/O 16             I/O 17                     I/O 18                       I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                               I/O 16             I/O 17                     I/O 18                       I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                          Data bus
                                         Write
                             Control bus Read
                                  CPU
                                                                               I/O 16             I/O 17                     I/O 18                       I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                       Data bus
                                     Solution
                             Control 1.
                                     bus   Write
                                        Write the address range in binary
                                           Read
                                  CPU
                                                                               I/O 16             I/O 17                     I/O 18                       I/O n
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                       Data bus
                                     Solution
                             Control 1.
                                     bus   Write
                                        Write the address range in binary
                                           Read
                                  CPU
                                From address 0 ➔ 0 0 0 0 0 0 0 0
                                                        I/O 16                                    I/O 17                     I/O 18                       I/O n
                                  To address15 ➔ 0 0 0 0 1 1 1 1
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                       Data bus
                                     Solution
                             Control 1.
                                     bus   Write
                                        Write the address range in binary
                                           Read
                                     2. Separate the fixed part of address
                                  CPU
                                                                    a7 a6 a5 a4 a3 a2 a1 a0
                                From address 0 ➔ 0 0 0 0 0 0 0 0
                                                        I/O 16                                    I/O 17                     I/O 18                       I/O n
                                  To address15 ➔ 0 0 0 0 1 1 1 1
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                       Data bus
                                     Solution
                             Control 1.
                                     bus   Write
                                        Write the address range in binary
                                           Read
                                     2. Separate the fixed part of address
                                  CPU
                                    3. Using a NAND, design a logic circuit whose output
                                  activates when the fixed address is given to it.
                                                                    a7 a6 a5 a4 a3 a2 a1 a0
                                From address 0 ➔ 0 0 0 0 0 0 0 0
                                                        I/O 16                                    I/O 17                     I/O 18                       I/O n
                                  To address15 ➔ 0 0 0 0 1 1 1 1
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                             Connecting I/Os and Memory to CPU using bus
www. Micro Digital Ed. com
                                         (Memory Mapped I/O)                                                                                                                         BIHE university
                                                                                          VCC
                                                                                                                  0
                                                                                                                  1                          enables CS
                              How could we make the logic                                                         ..
                                                                                                                  15
                                                                                                                                           when address is
                                                                                                                                           between 0 and
                                                                                                A0-An-1
                             circuit?
GND
D0-D7
WE
                                                                                                                            OE
                                                                                                                                 CS
                                                                                                                                                 15
                                                                                                                             Logic circuit
                                   Address bus
                                       Data bus
                                     Solution
                             Control 1.
                                     bus   Write
                                        Write the address range in binary
                                           Read
                                     2. Separate the fixed part of address
                                  CPU
                                    3. Using a NAND, design a logic circuit whose output
                                  activates when the fixed address is given to it.
                                                                    a7 a6 a5 a4 a3 a2 a1 a0
                                From address 0 ➔ 0 0 0 0 0 0 0 0                                                                 a4
                                                        I/O 16                                    I/O 17                     I/O a5
                                                                                                                                  18
                                                                                                                                 a6
                                                                                                                                                          I/OCS
                                                                                                                                                              n
                                  To address15 ➔ 0 0 0 0 1 1 1 1                                                                 a7
                               AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                                   Solution
                                       1. Write the address range in binary
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0
                                  To address 3FFH ➔   001111111111
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0
                                  To address 3FFH ➔   001111111111
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                      3. Design the logic circuit.
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0
                                  To address 3FFH ➔   001111111111
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                      3. Design the logic circuit.
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0       a8
                                                                                                                          a9
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0                                            a10                           CS
                                                                                                                         a11
                                  To address 3FFH ➔   001111111111
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                      3. Design the logic circuit.
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0       a8
                                                                                                                          a9
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0                                            a10                           CS
                                                                                                                         a11
                                  To address 3FFH ➔   001111111111
                               An easy way of
                                  designing
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Another example for address decoder
www. Micro Digital Ed. com
                                                                                                                                                                         BIHE university
                                   Solution
                                      1. Write the address range in binary
                                      2. Separate the fixed part of address
                                      3. Design the logic circuit.
                                                                              a11 a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0       a8
                                                                                                                          a9
                                  From address 300H ➔ 0 0 1 1 0 0 0 0 0 0 0 0                                            a10                           CS
                                                                                                                         a11
                                  To address 3FFH ➔   001111111111
                               An easy way of
                                  designing
                             AVR Microcontroller and Embedded System Using Assembly and C                                             © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                 Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                      Inside the CPU
www. Micro Digital Ed. com
                                                                                                                                                                 BIHE university
                             •   PC (Program Counter)
                             •   Instruction decoder
                             •   ALU (Arithmetic Logic Unit)
                             •   Registers
                                                                                                         PC                         A
                                                                                             ALU                                   B
                                                                                                      CPU                          C
                                                                                                                                   D
                                                                                            Instruction decoder           registers
                             AVR Microcontroller and Embedded System Using Assembly and C                                     © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                         Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                             How computers work                                                                      0   31h
                                                                                                                                                         31
                                                                                                                                                     1   C4h      A [17]
                                                                                                                                                                   BA
www. Micro Digital Ed. com
                                                                                                                                                                             BIHE university
2 26h
                                                                                                  VCC
                                                                                                                                                     3   81h      A  [6]
                                                                                                                                                         EAh
                                                                                                                                                                  AA+B
                                                                                                                                                     4
                                                                                                                                                                   [7]A
                                                                                                                                                     5   0h
                                                                                                        A0-An-1
                                                                                                                                                         5h
                                                                                                  GND
                                                                                                                                                     6
                                                                                                                  D0-D7
                                                                                                                                                     7
WE
                                                                                                                               OE
                                                                                                                                    CS
                                                                                                                                 Logic circuit
                                              Address bus
                                                       Data bus
                                                 Write
                                     Control bus Read
                             ALU
                                    CPU                        A
                                                               B
                                        PC:        0           C
                                                               D                             I/O 16        I/O 17                I/O 18                        I/O n
                              Inst. Dec.                    registers
                              AVR Microcontroller and Embedded System Using Assembly and C                                                © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                                    Upper Saddle River, NJ 07458. • All Rights Reserved.
                                            How Instruction decoder works
www. Micro Digital Ed. com
                                                                                                                                                                 BIHE university
Instruction
Instruction
                              AVR Microcontroller and Embedded System Using Assembly and C                                    © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                               Von Neumann vs. Harvard architecture
                                                                                             Harvard architecture has separate data and
www. Micro Digital Ed. com
                                                                                                                                                                     BIHE university
                              AVR Microcontroller and Embedded System Using Assembly and C                                        © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                            Upper Saddle River, NJ 07458. • All Rights Reserved.
www. Micro Digital Ed. com
                                                                                                                                                    BIHE university
                                                               Introduction to AVR
                                                                                     Chapter 1
                             AVR Microcontroller and Embedded System Using Assembly and C                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                            Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                                      Topics
www. Micro Digital Ed. com
                                                                                                                                                  BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                      General Purpose Microprocessors vs.
www. Micro Digital Ed. com
                                                Microcontrollers                                                                                              BIHE university
                                      General                                                                       Serial
                                                                                                                                       IO
                                     Purpose                                          RAM     ROM       Timer       COM
                                                                                                                                       Port
                                       Micro                                                                         Port
                                     processor              Address BUS
Control BUS
• Microcontrollers
                                                                               Serial
                                                                                      Timer       I/O
                                                                                Port
                             AVR Microcontroller and Embedded System Using Assembly and C                                  © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                      Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Most common microcontrollers
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • 8-bit microcontrollers
                                   –    AVR
                                   –    PIC
                                   –    HCS12
                                   –    8051
                             • 32-bit microcontrollers
                                   – ARM
                                   – PIC32
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                     AVR internal architecture
www. Micro Digital Ed. com
                                                                                                                                                                    BIHE university
                                        PROGRAM
                                          ROM
                                                   Program
                                                     Bus                         Bus
                                                                     CPU
                                                                                            Interrupt                           Other
                                                                    OSC                                  Ports
                                                                                              Unit                            Peripherals
                                                                                                          I/O
                                                                                                         PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                            Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                     AVR internal architecture
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                                                                               40 PIN DIP
                                                                        (XCK/T0) PB0     1                  40   PA0 (ADC0)
                                                                              (T1) PB1   2     RAM          39     EEPROM
                                                                                                                 PA1 (ADC1)                 Timers
                                                                     (INT2/AIN0) PB2     3                  38   PA2 (ADC2)
                                                                     (OC0/AIN1) PB3      4    MEGA32        37   PA3 (ADC3)
                                        PROGRAM                              (SS) PB4    5                  36   PA4 (ADC4)
                                          ROM                             (MOSI) PB5     6                  35   PA5 (ADC5)
                                                                          (MISO) PB6     7                  34   PA6 (ADC6)
                                                   Program                 (SCK) PB7     8                  33   PA7 (ADC7)
                                                                                RESET    9                  32   AREF
                                                     Bus                          Bus
                                                                                  VCC    10                 31   AGND
                                                                     CPU          GND    11                 30   AVCC
                                                                                XTAL2    12                 29   PC7 (TOSC2)
                                                                                XTAL1    13                 28   PC6 (TOSC1)
                                                                           (RXD) PD0     14                 27   PC5 (TDI)
                                                                           (TXD) PD1     15                 26   PC4 (TDO)
                                                                          (INT0) PD2     16                 25   PC3 (TMS)
                                                                          (INT1) PD3     17                 24   PC2 (TCK)
                                                                         (OC1B) PD4      18
                                                                                              Interrupt     23   PC1 (SDA)
                                                                                                                                              Other
                                                                    OSC  (OC1A) PD5      19                 22         Ports
                                                                                                                 PC0 (SCL)
                                                                            (ICP) PD6    20     Unit        21   PD7 (OC2)                  Peripherals
                                                                                                                         I/O
                                                                                                                        PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                             AVR different groups
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Classic AVR
                                   – e.g. AT90S2313, AT90S4433
                             • Mega
                                   – e.g. ATmega8, ATmega32, ATmega128
                             • Tiny
                                   – e.g. ATtiny13, ATtiny25
                             • Special Purpose AVR
                                   – e.g. AT90PWM216,AT90USB1287
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                             AVR different groups
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Classic AVR
                                   – e.g. AT90S2313, AT90S4433
                             • Mega
                                   – e.g. ATmega8, ATmega32, ATmega128
                             • Tiny
                                   – e.g. ATtiny13, ATtiny25
                             • Special Purpose AVR
                                   – e.g. AT90PWM216,AT90USB1287
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                             AVR different groups
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Classic AVR
                                   – e.g. AT90S2313, AT90S4433
                             • Mega
                                   – e.g. ATmega8, ATmega32, ATmega128
                             • Tiny
                                   – e.g. ATtiny13, ATtiny25
                             • Special Purpose AVR
                                   – e.g. AT90PWM216,AT90USB1287
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                             AVR different groups
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Classic AVR
                                   – e.g. AT90S2313, AT90S4433
                             • Mega
                                   – e.g. ATmega8, ATmega32, ATmega128
                             • Tiny
                                   – e.g. ATtiny13, ATtiny25
                             • Special Purpose AVR
                                   – e.g. AT90PWM216,AT90USB1287
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
        Let’s get familiar with the AVR part numbers
www. Micro Digital Ed. com
                                                                                                                                                                   BIHE university
ATmega128
                                                                             Atmel          group
                                                                                                    Flash =128K
ATtiny44 AT90S4433
                             Atmel
                                           Tiny             Flash =4K                         Atmel   Classic
                                                                                                                    Flash =4K
                                           group                                                      group
                             AVR Microcontroller and Embedded System Using Assembly and C                                       © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
www. Micro Digital Ed. com
                                                                                                                                                   BIHE university
                                                      Introduction to Assembly
                                                                                    Chapter 2
                             AVR Microcontroller and Embedded System Using Assembly and C                       © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                                      Topics
www. Micro Digital Ed. com
                                                                                                                                                                       BIHE university
                             • AVR’s CPU
                                   – Its architecture
                                   – Some simple programs
                             • Data Memory access
                             • Program memory                                                                             RAM        EEPROM           Timers
                                                                                                  Program         Data
                                                                                                    Bus           Bus
                                                                                                            CPU
                                                                                                                         Interrupt                      Other
                                                                                                            OSC                         Ports
                                                                                                                            Unit                      Peripherals
                                                                                                                                         I/O
                                                                                                                                        PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                           © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                              AVR’s CPU
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                             • AVR’s CPU
                                – ALU
                                – 32 General Purpose
                                                                                                                                                   R0
                                  registers (R0 to R31)                                                                                            R1
                                                                                                 ALU
                                – PC register                                                                                                      R2
                                                                                                                                                     …
                                – Instruction decoder                                        SREG:   I   T H S V     N Z     C
                                                                                                                                                  R15
                                                                                                               CPU                                R16
                                                                                                                                                  R17
                                                                                                                                                     …
                                                                                                            PC
                                                                                                                                                  R30
                                                                                                Instruction decoder
                                                                                                                                                  R31
                                                                                                     Instruction Register
                                                                                                                                           registers
                              AVR Microcontroller and Embedded System Using Assembly and C                                         © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                             Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                            Some simple instructions
                                      1. Loading values into the general purpose registers
www. Micro Digital Ed. com
                                                                                                                                                          BIHE university
                                                                                                                                           …
                                        • R16 = 53                                            SREG: I T H S V N Z C
                                                                                                           CPU
                                                                                                                                         R15
                                – LDI R19,132                                                                                            R16
                                                                                                                                         R17
                                – LDI R23,0x27                                                            PC
                                                                                                                                           …
                                        • R23 = 0x27                                          Instruction decoder
                                                                                                                                         R30
                                                                                                                                         R31
                                                                                                   Instruction Register
                                                                                                                                     registers
                               AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                            Some simple instructions
                                                                        2. Arithmetic calculation
www. Micro Digital Ed. com
                                                                                                                                                          BIHE university
                                                                                                                                           …
                                – ADD R25, R9                                                 SREG: I T H S V N Z C
                                                                                                           CPU
                                                                                                                                         R15
                                        • R25 = R25 + R9                                                                                 R16
                                                                                                                                         R17
                                – ADD R17,R30                                                             PC
                                                                                                                                           …
                                        • R17 = R17 + R30                                     Instruction decoder
                                                                                                                                         R30
                                                                                                                                         R31
                                                                                                   Instruction Register
                                                                                                                                     registers
                               AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                               Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  A simple program
www. Micro Digital Ed. com
                                                                                                                                                        BIHE university
                                                                                                                                        R0
                                                                                               ALU                                      R1
                                                                                                                                        R2
                                                                                                                                         …
                                                                                            SREG: I T H S V N Z C
                                                                                                         CPU
                                                                                                                                       R15
                                                                                                                                       R16
                                                                                                                                       R17
                                                                                                        PC
                                                                                                                                         …
                                                                                                                                       R30
                                                                                            Instruction decoder
                                                                                                                                       R31
                                                                                                 Instruction Register
                                                                                                                                   registers
                             AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  A simple program
www. Micro Digital Ed. com
                                                                                                                                                        BIHE university
                                                                                                                                        R0
                                                                                               ALU                                      R1
                                                                                                                                        R2
                                                                                                                                         …
                                                                                            SREG: I T H S V N Z C
                                                                                                         CPU
                                                                                                                                       R15
                                                                                                                                       R16
                                                                                                                                       R17
                                                                                                        PC
                                                                                                                                         …
                                                                                                                                       R30
                                                                                            Instruction decoder
                                                                                                                                       R31
                                                                                                 Instruction Register
                                                                                                                                   registers
                             AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  A simple program
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  A simple program
www. Micro Digital Ed. com
                                                                                                                                                           BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                               © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                   Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  A simple program
www. Micro Digital Ed. com
                                                                                                                                                           BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                               © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                   Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                           Some simple instructions
                                                                       2. Arithmetic calculation
www. Micro Digital Ed. com
                                                                                                                                                         BIHE university
                             • SUB Rd,Rs
                               – Rd = Rd - Rs
                             • Example:
                               – SUB R25, R9
                                       • R25 = R25 - R9                                                                                  R0
                                                                                                ALU                                      R1
                               – SUB R17,R30                                                                                             R2
                                                                                                                                          …
                                       • R17 = R17 - R30                                     SREG: I T H S V N Z C
                                                                                                          CPU
                                                                                                                                        R15
                                                                                                                                        R16
                                                                                                                                        R17
                                                                                                         PC
                                                                                                                                          …
                                                                                                                                        R30
                                                                                             Instruction decoder
                                                                                                                                        R31
                                                                                                  Instruction Register
                                                                                                                                    registers
                              AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                           Some simple instructions
                                                                       2. Arithmetic calculation
www. Micro Digital Ed. com
                                                                                                                                                         BIHE university
                             • INC Rd
                               – Rd = Rd + 1
                             • Example:
                               – INC R25
                                       • R25 = R25 + 1                                                                                   R0
                                                                                                ALU                                      R1
                                                                                                                                         R2
                                                                                                                                          …
                             • DEC Rd                                                        SREG: I T H S V N Z C
                                                                                                          CPU
                                                                                                                                        R15
                               – Rd = Rd - 1                                                                                            R16
                                                                                                                                        R17
• Example: PC
                                                                                                                                          …
                                                                                                                                        R30
                               – DEC R23                                                     Instruction decoder
                                                                                                                                        R31
                                                                                                  Instruction Register
                                       • R23 = R23 - 1                                                                              registers
                              AVR Microcontroller and Embedded System Using Assembly and C                            © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                                                   8 bit
                             Data Address
                                   Space                            R0
                                                                    R1
                                                                    R2
                                    $0000                                                                          Interrupt                                  Other
                                    $0001    General                                                OSC                                  Ports
                                                                                                                      Unit                                  Peripherals
                                                                   ...
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                   I/O
                                    $0020                          TWBR     $00                                                          PINS
                                                                   TWSR     $01
                                            Standard I/O
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General
                                              purpose
                                     ...
                                               RAM
                                              (SRAM)
$FFFF
                                     AVR Microcontroller and Embedded System Using Assembly and C                                              © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                      BIHE university
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                       I/O
                                    $0020                          TWBR     $00                                                              PINS
                                                                   TWSR     $01
                                            Standard I/O
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General
                                              purpose
                                     ...
                                               RAM
                                              (SRAM)
                                     AVR Microcontroller and Embedded System Using Assembly and C                                                  © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                      Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                      Name
                                                                                    PINB
                                                                                              Address
                                                                                             I/O
                                                                                             $2B
                                                                                                     Mem.
                                                                                                     $4B
                                                                                                            Name
                                                                                                          OCR1AH
                                   $01     $21   TWSR          $17        $37      DDRB      $2C     $4C  TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                I/O
                                  $0020                          TWBR           $00                                                      PINS
                                                                 TWSR           $01
                                          Standard I/O
                                                                                                     LDS (Load direct from data space)
                                                                  ...
                                   ...
                                           Registers
                                                                  SPH           $3E
                                  $005F                          SREG
                                                                                                   LDS Rd, addr              ;Rd = [addr]
                                                                                $3F
                                  $0060
                                            General
                                            purpose
                                   ...
                                             RAM
                                            (SRAM)                                                 Example:
                                                                                                       LDS R1, 0x60
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                    Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                      Name
                                                                                    PINB
                                                                                              Address
                                                                                             I/O
                                                                                             $2B
                                                                                                     Mem.
                                                                                                     $4B
                                                                                                            Name
                                                                                                          OCR1AH
                                   $01     $21   TWSR          $17        $37      DDRB      $2C     $4C  TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                I/O
                                  $0020                          TWBR           $00                                                      PINS
                                                                 TWSR           $01
                                          Standard I/O
                                                                                                     LDS
                                                                                                      STS(Load
                                                                                                          (Storedirect
                                                                                                                  directfrom  dataspace)
                                                                                                                          to data  space)
                                                                  ...
                                   ...
                                           Registers
                                                                  SPH           $3E
                                  $005F                          SREG
                                                                                                   LDS
                                                                                                   STS Rd, addr              ;Rd = [addr]
                                                                                $3F
                                  $0060                                                                addr,Rd              ;[addr]=Rd
                                            General
                                            purpose
                                   ...
                                             RAM
                                            (SRAM)                                                 Example:
                                                                                                       LDS
                                                                                                       STS R1, 0x60
                                                                                                           0x60,R15                 ; [0x60] = R15
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                    Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                      Name
                                                                                    PINB
                                                                                                   Address
                                                                                                  I/O
                                                                                                  $2B
                                                                                                        Mem.
                                                                                                        $4B
                                                                                                               Name
                                                                                                              OCR1AH
                                   $01     $21   TWSR          $17        $37      DDRB           $2C   $4C   TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                    I/O
                                  $0020                          TWBR           $00                                                          PINS
                                                                 TWSR           $01
                                          Standard I/O
                                                                                  LDS
                                                                                    STS
                                                             Example: Write a program  (Load
                                                                                        (Store
                                                                                      that    direct
                                                                                                   55from
                                                                                                direct
                                                                                           stores          data
                                                                                                       to data
                                                                                                      into      space)
                                                                                                               space)
                                                                                                           location 0x80 of RAM.
                                                                  ...
                                   ...
                                           Registers
                                                                  SPH           $3E
                                  $005F                          SREG
                                                                                                        LDS
                                                                                                        STS Rd, addr             ;Rd = [addr]
                                                                                $3F
                                  $0060                                                                     addr,Rd             ;[addr]=Rd
                                            General
                                            purpose               Solution:
                                   ...
                                             RAM
                                            (SRAM)                             LDI           R20, 55    Example:
                                                                                                          ;R20 =      55
                                                                               STS           0x80, R20    LDS
                                                                                                          STS  R1,
                                                                                                          ;[0x80] =0x60
                                                                                                               0x60,R15    ; [0x60] = R15
                                                                                                                    R20 = 55
$FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                    © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                      Name
                                                                                    PINB
                                                                                                  Address
                                                                                                  I/O
                                                                                                  $2B
                                                                                                        Mem.
                                                                                                        $4B
                                                                                                               Name
                                                                                                              OCR1AH
                                   $01     $21   TWSR          $17        $37      DDRB           $2C   $4C   TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                    I/O
                                  $0020                          TWBR           $00                                                          PINS
                                                                 TWSR           $01
                                          Standard I/O
                                                             Example: Write            LDS
                                                                                        STS
                                                                         Write aa program
                                                                                  program   (Load
                                                                                             (Store
                                                                                           that    direct
                                                                                                stores  55from
                                                                                                     direct to
                                                                                                           into data
                                                                                                               data  space)
                                                                                                                    space)
                                                                                                                location  0x80 of RAM.
                                                                  ...
                                           Registers
                                                                 SPH $3E
                                  $005F
                                  $0060
                                                             of RAM $3F
                                                                SREG
                                                                      into location 0x81.
                                                                                     LDS
                                                                                     STS Rd,    addr ;[addr]=Rd
                                                                                            addr,Rd       ;Rd = [addr]
                                            General
                                            purpose               Solution:
                                   ...
                                             RAM
                                            (SRAM)                Solution:
                                                                      LDI R20,                   55     Example:
                                                                                                          ;R20 =       55
                                                                               STS
                                                                               LDS           0x80, R20
                                                                                             R20, 0x80    LDS
                                                                                                          STS  R1,
                                                                                                          ;[0x80] =0x60
                                                                                                               0x60,R15
                                                                                                                ;R20 R20    ; [0x60] = R15
                                                                                                                         = 55
                                                                                                                      = [0x80]
                                                                               STS           0x81, R20                ;[0x81] = R20 = [0x80]
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                    © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                  Name
                                                                                   PINB
                                                                                                   Address
                                                                                                   I/O
                                                                                                   $2B
                                                                                                         Mem.
                                                                                                         $4B
                                                                                                                Name
                                                                                                              OCR1AH
                                   $01     $21   TWSR          $17        $37     DDRB             $2C   $4C  TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                     I/O
                                  $0020                      Example:
                                                               TWBR
                                                               TWSR
                                                                      $00 Add contents of location 0x90 to contents
                                                                      $01
                                                                                                                   PINS of location 0x95
                                          Standard I/O       and store the result in location
                                                                                       LDS       0x313.
                                                                                             (Load  direct
                                                             Example:     Write a       STS
                                                                                  program     (Store
                                                                                            that stores  55from
                                                                                                      direct to
                                                                                                            into data
                                                                                                                data  space)
                                                                                                                     space)
                                                                                                                 location  0x80 of RAM.
                                                                  ...
                                           Registers
                                                                  Solution:
                                                                 SPH  $3E
                                  $005F
                                  $0060
                                                             of RAM
                                                                SREG
                                                                       into location 0x81.
                                                                      $3F
                                                                                     LDS
                                                                                     STS Rd,     addr ;[addr]=Rd
                                                                                             addr,Rd       ;Rd = [addr]
                                            General                   LDS R20,                    0x90                 ;R20 = [0x90]
                                            purpose               Solution:
                                   ...
                                             RAM
                                            (SRAM)
                                                                      LDS R20,
                                                                  Solution:
                                                                      LDI   R21,                  55  Example:
                                                                                                   0x95  ;R20 =;R21
                                                                                                                55 = [0x95]
                                                                               ADD           R20, R21
                                                                                                    R20 LDS    ;R20  = R20 + R21
                                                                               STS
                                                                               LDS           0x80,
                                                                                             R20, 0x80  STS   R1,
                                                                                                        ;[0x80]  =0x60
                                                                                                              0x60,R15
                                                                                                               ;R20 R20    ; [0x60] = R15
                                                                                                                        = 55
                                                                                                                     = [0x80]
                                                                               STS           0x313, R20        ;[0x313] = R20
                                                                               STS           0x81, R20         ;[0x81] = R20 = [0x80]
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                    © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                  Name
                                                                                   PINB
                                                                                                  Address
                                                                                                  I/O
                                                                                                  $2B
                                                                                                        Mem.
                                                                                                        $4B
                                                                                                               Name
                                                                                                             OCR1AH
                                   $01     $21   TWSR          $17        $37     DDRB            $2C   $4C  TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                    I/O
                                  $0020                      Example:
                                                               TWBR
                                                               TWSR
                                                                      $00 Add contents of location 0x90 to contents
                                                                      $01
                                                                                                                    PINS of location 0x95
                                          Standard I/O       Example:
                                                             and store What     doesinthe
                                                                          the result      following
                                                                                        location
                                                                                         LDS
                                                                                          STS (Load
                                                                                               (Store instruction
                                                                                                  0x313.
                                                                                                     direct from
                                                                                                       direct to   do?space)
                                                                                                                  data
                                                                                                                 data  space)
                                                             Example:     Write a program    that stores  55 into location  0x80 of RAM.
                                                                  ...
                                           Registers
                                                                  Solution:
                                                                LDS      R20,2
                                                                 SPH  $3E
                                  $005F
                                  $0060
                                                             of RAM
                                                                SREG
                                                                       into location 0x81.
                                                                      $3F
                                                                                      LDS
                                                                                      STS Rd,     addr ;[addr]=Rd
                                                                                              addr,Rd       ;Rd = [addr]
                                            General                  LDS R20, 0x90           ;R20 = [0x90]
                                            purpose             Solution:
                                                               Answer:
                                   ...
                                             RAM
                                            (SRAM)
                                                                     LDS R20,
                                                                 Solution:
                                                                     LDI   R21, 55  Example:
                                                                                 0x95  ;R20 =;R21
                                                                                              55 = [0x95]
                                                                It copies
                                                                     ADD the  contents
                                                                           R20,  R21   of R2 ;R20
                                                                                             into R20;
                                                                                                   = R20as+ 2R21
                                                                                                              is the address of R2.
                                                                     LDS R20, 0x80 LDS
                                                                     STS   0x80,  R20 STS R1,
                                                                                      ;[0x80]  =0x60
                                                                                            0x60,R15
                                                                                             ;R20 R20 =  ; [0x60] = R15
                                                                                                        55
                                                                                                   = [0x80]
                                                                               STS           0x313, R20               ;[0x313] = R20
                                                                               STS           0x81, R20                ;[0x81] = R20 = [0x80]
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                   © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                  Address
                                    I/O
                                   $00
                                          Mem.
                                           $20
                                                  Name
                                                 TWBR
                                                               Address
                                                               I/O
                                                               $16
                                                                        Data Address Space
                                                                         Mem.
                                                                          $36
                                                                                  Name
                                                                                   PINB
                                                                                                  Address
                                                                                                  I/O
                                                                                                  $2B
                                                                                                        Mem.
                                                                                                        $4B
                                                                                                               Name
                                                                                                             OCR1AH
                                   $01     $21   TWSR          $17        $37     DDRB            $2C   $4C  TCNT1L
www. Micro Digital Ed. com
$02 $22 TWAR $18 $38 PORTB $2D $4D TCNT1H BIHE university
                                           Purpose
                                   ...
                                           Registers              R31
                                  $001F                                        I/O Address                                                    I/O
                                  $0020                      Example:
                                                               TWBR
                                                               TWSR
                                                                      $00 Add contents
                                                                      $01
                                                                                          of location
                                                                                       Example:         0x90
                                                                                                    Store    to contents
                                                                                                           0x53  into PINS  of location
                                                                                                                      the SPH           0x95
                                                                                                                                 register.
                                          Standard I/O       Example:
                                                             and store What     doesinthe
                                                                          the result       following
                                                                                        location
                                                                                       The
                                                                                         LDS
                                                                                          STS  (Load
                                                                                                (Store instruction
                                                                                                   0x313.
                                                                                              address   of SPH
                                                                                                      direct        do?space)
                                                                                                                isdata
                                                                                                             from
                                                                                                        direct to  0x5E
                                                                                                                   data  space)
                                                             Example:     Write a program     that stores  55 into location    0x80 of RAM.
                                                                  ...
                                           Registers
                                                                  Solution:
                                                                LDS      R20,2
                                                                 SPH  $3E
                                  $005F
                                  $0060
                                                             of RAM
                                                                SREG
                                                                       into location 0x81.
                                                                      $3F
                                                                                      LDS
                                                                                      STS Rd,      addr ;[addr]=Rd
                                                                                               addr,Rd       ;Rd = [addr]
                                            General                  LDS R20, 0x90 Solution:  ;R20 = [0x90]
                                            purpose             Solution:
                                                               Answer:
                                   ...
                                             RAM
                                            (SRAM)
                                                                     LDS R20,
                                                                 Solution:
                                                                     LDI   R21, 55  Example:
                                                                                 0x95   LDI =;R21
                                                                                       ;R20    R20,= 0x53
                                                                                               55      [0x95]         ;R20 = 0x53
                                                                It copies
                                                                     ADD the  contents
                                                                           R20,  R21   of
                                                                                        STSR2 ;R20
                                                                                              into R20;
                                                                                               0x5E,= R20
                                                                                                       R20as+ 2R21
                                                                                                                is the;SPH
                                                                                                                       address
                                                                                                                           = R20of R2.
                                                                     LDS R20, 0x80 LDS
                                                                     STS   0x80,  R20 STS R1,
                                                                                      ;[0x80]   =0x60
                                                                                            0x60,R15
                                                                                              ;R20 R20  =  ; [0x60] = R15
                                                                                                          55
                                                                                                    = [0x80]
                                                                               STS           0x313, R20               ;[0x313] = R20
                                                                               STS           0x81, R20                ;[0x81] = R20 = [0x80]
                                  $FFFF
                                   AVR Microcontroller and Embedded System Using Assembly and C                                                   © 2011 Pearson Higher Education,
                                   Mazidi, Naimi, and Naimi                                                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                   I/O
                                    $0020                          TWBR     $00                                                          PINS
                                                                   TWSR     $01
                                            Standard I/O
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General
                                              purpose
                                     ...
                                               RAM
                                              (SRAM)
$FFFF
                                     AVR Microcontroller and Embedded System Using Assembly and C                                              © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                   I/O
                                                                   TWBR     $00                                                          PINS
                                                                                                     IN Rd,IOaddress ;Rd = [addr]
                                    $0020
                                                                   TWSR     $01
                                            Standard I/O
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General
                                              purpose
                                                                                                     Example:
                                     ...
                                               RAM
                                              (SRAM)                                                       IN R1, 0x3F              ;R1 = SREG
                                                                                                           IN R17,0x3E ;R17 = SPH
                                   $FFFF
                                     AVR Microcontroller and Embedded System Using Assembly and C                                              © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                   I/O
                                                                   TWBR     $00                                                          PINS
                                    $0020
                                            Standard I/O
                                                                   TWSR     $01
                                                                                                     OUT  IOAddr,Rd ;Rd
                                                                                                     IN Rd,IOaddress  ;[addr]=Rd
                                                                                                                         = [addr]
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General                                                Example:
                                              purpose
                                     ...
                                               RAM
                                              (SRAM)                                                      OUT  0x3F,R12
                                                                                                          IN R1,        ;SREG
                                                                                                                 0x3F ;R1      = R12
                                                                                                                          = SREG
                                                                                                          OUT  0x3E,R15;R17
                                                                                                          IN R17,0x3E    ;SPH  = R15
                                                                                                                            = SPH
                                   $FFFF
                                     AVR Microcontroller and Embedded System Using Assembly and C                                              © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                                  BIHE university
                                             Purpose
                                     ...
                                             Registers             R31
                                   $001F                                    I/O Address                                                   I/O
                                                                   TWBR     $00                                                          PINS
                                    $0020
                                            Standard I/O
                                                                   TWSR     $01
                                                                                                     OUT  IOAddr,Rd
                                                                                                     IN Rd,IOaddress
                                                                                                        Using           ;[addr]=Rd
                                                                                                              Names of;Rd
                                                                                                                       IO  = [addr]
                                                                                                                           registers
                                                                   ...
                                     ...
                                             Registers
                                                                    SPH     $3E
                                   $005F                           SREG     $3F
                                    $0060
                                              General                                               Example:
                                                                                                      Example:
                                              purpose
                                     ...
                                               RAM
                                              (SRAM)
                                                                                                     OUTOUT
                                                                                                        IN SPH,R12
                                                                                                             0x3F,R12
                                                                                                           R1,        ;OUT
                                                                                                               0x3F ;R1;SREG0x3E,R12
                                                                                                                              = R12
                                                                                                                         = SREG
                                                                                                      IN        R15,SREG             ;IN           R15,0x3F
                                                                                                           OUT  0x3E,R15;R17
                                                                                                           IN R17,0x3E    ;SPH  = R15
                                                                                                                             = SPH
                                   $FFFF
                                     AVR Microcontroller and Embedded System Using Assembly and C                                              © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                                  Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                         Data Address Space
www. Micro Digital Ed. com
                                                                                                                                                                        BIHE university
                                             Registers            R31
                                   $001F                                    I/O Address                                         I/O
                                                                   TWBR
                                                                         Solution:
                                                                            $00
                                                                                                     OUT  IOAddr,Rd
                                                                                                                               PINS
                                                                                                                        ;[addr]=Rd
                                                                                                     IN Rd,IOaddress
                                                                                                              Names of;Rd  = [addr]
                                    $0020
                                                                   TWSR     $01
                                            Standard I/O                                                Using          IO  registers
                                                                   ...
                                     ...
                                     AVR Microcontroller and Embedded System Using Assembly and C                                    © 2011 Pearson Higher Education,
                                     Mazidi, Naimi, and Naimi                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                                 BIHE university
                                         SREG:        I      T    H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                                                                                        $0000
                                                                                                        $0001    General
                                                                                                                 Purpose
                                                                                                         ...
                                                                                                                 Registers
                                                                             R0                        $001F                                                   IO Address
                                   ALU                                       R1                         $0020                                     TWBR         $00
                                                                                                                                                  TWSR         $01
                                                                             R2                                 Standard IO
                                                                                                                                                   ...
                                                                                                         ...
                                                                                                                 Registers
                                                                             …
                                                                                                                                                   SPH
                              SREG: I T H S V N Z C                                                    $005F                                      SREG
                                                                                                                                                               $3E
                                                                                                                                                               $3F
                                              CPU
                                                                             R15                        $0060
                                                                             R16                                 General
                                                                             R17                                 purpose
                                                                                                         ...
                                                                                                                  RAM
                                              PC
                                                                             …
                                                                                                                 (SRAM)
                                                                             R30
                               Instruction decoder
                                                                             R31
                                      Instruction Register
                                                                       registers
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                                     © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                         Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                                 BIHE university
                                         SREG:        I      T    H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                                                                                         ...
                                              LDI         R16, 0x38R0                              0x38 Registers
                                                                                            ;R16 = $001F
                                                                                                                                                               IO Address
                                   ALU                            R1                                                                              TWBR         $00
                                              LDI         R17, 0x2F                         ;R17 = $0020
                                                                                                   0x2F                                           TWSR         $01
                                                                  R2                                            Standard IO
                                              ADD         R16, R17                          ;add R17 to Registers
                                                                                                         R16
                                                                                                                                                   ...
                                                                                                         ...
                                                                              …
                                                                                                                                                   SPH
                              SREG: I T H S V N Z C                                                    $005F                                      SREG
                                                                                                                                                               $3E
                                                                                                                                                               $3F
                                              CPU
                                           Solution:                         R15 1                      $0060
                                                                             R16
                                                            $38              0011  1000                      General
                                                                             R17                             purpose
                                                                                                         ...
                                                          + $2F              0010 1111                        RAM
                                              PC
                                                                              …
                             AVR Microcontroller and Embedded System Using Assembly and C                                                     © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                         Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                                         SREG:        I     T     H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                          Example:
                                          Example: Show
                                                    Show the
                                                         the status
                                                              status of
                                                                      of the
                                                                         the C,
                                                                             C, H, and
                                                                                    and ZZ flags
                                                                                H,$0000    flags after
                                                                                                 after the
                                                                                                       the addition
                                                                                                           addition
                                                                                 $0001   General
                                          of
                                          of 0x9C     0x64 in the following instructions:
                                             0x38 and 0x2F                               Purpose
                                                                                                         ...
                                              LDI         LDI    R20,
                                                                  R0 0x9C
                                                          R16, 0x38            0x38 Registers
                                                                        ;R16 = $001F
                                                                                                                                                    IO Address
                                   ALU                    LDI     R1 0x64
                                                                 R21,                                                                  TWBR         $00
                                              LDI         R17, 0x2F     ;R17 = $0020
                                                                               0x2F                                                    TWSR         $01
                                                                  R2                 Standard IO
                                              ADD         ADD
                                                          R16, R17R20, R21;add R17;add  R21 to R20
                                                                                    to Registers
                                                                                        R16
                                                                                                                                        ...
                                                                                                         ...
                                                                             …
                                                                                                                                        SPH
                              SREG: I T H S V N Z C                                                    $005F                           SREG
                                                                                                                                                    $3E
                                                                                                                                                    $3F
                                              CPU
                                          Solution:
                                          Solution:                         R15 11                      $0060
                                                                            R16
                                                     $38
                                                    $9C                     0011
                                                                            1001   1000
                                                                                   1100                      General
                                                                            R17                              purpose
                                                                                                         ...
                                                 + +$64
                                                     $2F    0010 0100
                                                           0110  1111                                         RAM
                                              PC
                                                                             …
                                                     $67 1 0000
                                                  $100      01100000
                                                                 0111                                    R16 (SRAM)
                                                                                                         R20 == 00
                                                                                                                0x67
                                          C = 1 because there isR30
                                      C = 0 decoder                a carry beyond the D7 bit.
                                            because there is no carry beyond the D7 bit.
                               Instruction
                                      H = 1 because there is a carry from the D3 to the D4 bit.
                                           H = 1 because there isR31a carry from the D3 to the D4 bit.
                                          ZZ = 0 because the R16 (the result)
                                             =  1
                                      Instruction because
                                                  Register the R20 (the result) has
                                                                                has aa value
                                                                                       value 0other
                                                                                               in it after
                                                                                                     than 0the addition.
                                                                                                             after the addition.
                                                                       registers
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                                         SREG:        I     T     H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                          Example:
                                          Example:  Show
                                          Example: Show   the
                                                    Show the  status
                                                          the status  of
                                                              status of  the
                                                                      of the  C,
                                                                         the C,  H,
                                                                              C, H,  and
                                                                                    and
                                                                                 H,$0000
                                                                                     and ZZ
                                                                                          Z flags
                                                                                            flags
                                                                                            flags after
                                                                                                  after
                                                                                                  after the
                                                                                                        the
                                                                                                        the addition
                                                                                                            addition
                                          subtraction of 0x23 from  0xA5   in the $0001   General
                                                                                  following    instructions:
                                          of
                                          of 0x9C     0x64 in the following instructions:
                                             0x38 and 0x2F                                Purpose
                                                                                                         ...
                                                   LDI
                                             LDI LDI
                                                   R16, 0x38 R20, 0x9C
                                                            R20,    0xA5;R16 = 0x38 Registers
                                                                  R0           $001F                                                                IO Address
                                   ALU                    LDI
                                                          LDI     R1 0x64
                                                                 R21,
                                                                 R21, 0x23                                                             TWBR         $00
                                              LDI         R17, 0x2F     ;R17 = $0020
                                                                               0x2F                                                    TWSR         $01
                                                                  R2                 Standard IO
                                              ADD         SUB
                                                          ADD     R20, R21
                                                          R16, R17R20, R21;add R17;add
                                                                                  ;subtract
                                                                                        R21 toR21
                                                                                    to Registers
                                                                                        R16      R20from R20
                                                                                                                                        ...
                                                                                                         ...
                                                                             …
                                                                                                                                        SPH
                              SREG: I T H S V N Z C                                                    $005F                           SREG
                                                                                                                                                    $3E
                                                                                                                                                    $3F
                                              CPU
                                          Solution:
                                          Solution:                         R15 11                      $0060
                                                     $A5                    R16 0101
                                                                            1010
                                                      $38
                                                     $9C                    0011
                                                                            1001   1000
                                                                                   1100                      General
                                                                            R17                              purpose
                                                                                                         ...
                                                 +- +$64
                                                     $23
                                                      $2F    0010 0100
                                                            0110  0011
                                                                  1111                                        RAM
                                              PC
                                                                             …
                                                     $82     1000
                                                      $67 1 0000
                                                   $100           0010
                                                             01100000
                                                                  0111                                   R20 == 00
                                                                                                                $82
                                                                                                         R16 (SRAM)
                                                                                                         R20    0x67
                                          CC == 10 because
                                                   because there
                                                            R21 isisnot   bigger
                                                                      a carry
                                                                     R30         than R20
                                                                               beyond       andbit.
                                                                                       the D7    there is no borrow from D8 bit.
                                      C == 1
                               Instruction
                                      Z=   00 decoder
                                              because the
                                              because there
                                                          R20is no carry beyond the D70 bit.
                                      H    H  because
                                              =  1    there
                                                   because  is ahas
                                                            there
                                                                    a value
                                                                 carry
                                                                   is  fromother
                                                                     R31
                                                                       a
                                                                                 than
                                                                            the D3      after
                                                                                   to the     the subtraction.
                                                                                          D4 bit.
                                          ZH  =  0 because  there  is  nocarry from
                                                                          borrow     the D4
                                                                                   from  D3 to
                                                                                             to D3.
                                                                                                the D4 bit.
                                           Z = 0 because the R16 (the result) has a value 0other
                                             =  1  because
                                      Instruction Register the R20    (the result)
                                                                       registers
                                                                                   has a  value   in it after
                                                                                                        than 0the addition.
                                                                                                                after the addition.
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                                         SREG:        I     T     H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                          Example:
                                          Example:
                                          Example:  Show
                                          Example:Show
                                                    Show  the
                                                    Showthe
                                                          the status
                                                           thestatus
                                                              status  of
                                                               statusof
                                                                      of the
                                                                      ofthe
                                                                         the  C,
                                                                          theC,
                                                                              C, H,
                                                                              C,H,   and
                                                                                      andZZ
                                                                                 H,$0000
                                                                                 H, and
                                                                                     and    flags
                                                                                          Zflags
                                                                                          Z        after
                                                                                             flagsafter
                                                                                            flags        the
                                                                                                    afterthe
                                                                                                   after  theaddition
                                                                                                         the addition
                                          subtraction
                                          subtraction of
                                                      of 0x23
                                                         0x73 from
                                                               from 0xA5
                                                                    0x52   in the $0001   General
                                                                                  following     instructions:
                                          of
                                          of 0x9C     0x64 in the following instructions:
                                             0x38 and 0x2F                                Purpose
                                                                                                         ...
                                                   LDI
                                             LDI LDILDI 0x38
                                                   R16,      R20,
                                                             R20,   0xA5
                                                              R20, 0x9C
                                                                    0x52;R16 = 0x38 Registers
                                                                  R0           $001F                                                                IO Address
                                   ALU                    LDI
                                                          LDI     R1 0x64
                                                                R21,
                                                          LDI 0x2F
                                                                 R21,
                                                                R21,  0x23
                                                                      0x73                                                             TWBR         $00
                                              LDI         R17,          ;R17 = $0020
                                                                               0x2F                                                    TWSR         $01
                                                                  R2                 Standard IO
                                              ADD         SUB
                                                          ADD
                                                          R16,   R20,
                                                          SUB R17R20, R21
                                                                 R20, R21        ;subtract
                                                                      R21;add R17;add  R21 toR21
                                                                                 ;subtract
                                                                                   to Registers
                                                                                       R16        R20from
                                                                                                R21  from R20
                                                                                                          R20
                                                                                                                                        ...
                                                                                                         ...
                                                                             …
                                                                                                                                        SPH
                              SREG: I T H S V N Z C                                                                                                 $3E
                                      Solution:                                                        $005F                           SREG         $3F
                                              CPU
                                          Solution:
                                          Solution:                         R15 11  $0060
                                                       $52
                                                      $A5                   0101
                                                                            R16 0010
                                                                            1010   0101
                                                       $38
                                                      $9C                   0011
                                                                            1001   1000
                                                                                   1100    General
                                                    - $23
                                                       $73                  0111
                                                                            R17 0011       purpose
                                                                                                         ...
                                                  +- +$64
                                                       $2F      0010 0100
                                                                0110   0011
                                                                       1111                  RAM
                                             PC       $DF       1101   1111           R20   = $DF
                                                                             …
                                                      $82
                                                       $67
                                                     $100   1   1000
                                                                0110
                                                               0000    0010
                                                                       0111
                                                                      0000            R20
                                                                                      R16
                                                                                     R20   == 00
                                                                                              $82
                                                                                              0x67
                                                                                           (SRAM)
                                           C = 1 because R21 is bigger than R20 and there is a borrow from D8 bit.
                                          CC == 10 because
                                                   because there
                                                            R21 isisnot   bigger
                                                                      a carry
                                                                     R30         than R20
                                                                               beyond       andbit.
                                                                                       the D7    there is no borrow from D8 bit.
                                      Z
                                      C == 00 decoder
                                              because
                                              because the R20
                                                      there  is has a value
                                                                no carry    otherthe
                                                                         beyond   than
                                                                                     D7zero    after the subtraction.
                               Instruction
                                      Z=
                                      H =1 0 because
                                              because the R20
                                                      there is ahas a value
                                                                 carry fromother  than
                                                                             the D3     0 bit.
                                                                                    to theafter  the subtraction.
                                                                                            D4 bit.
                                           H = 1 because there isR31   a borrow
                                                                         carry   from
                                                                               from    D4D3
                                                                                     the   toto
                                                                                              D3.
                                                                                                the D4 bit.
                                          ZH  =  0 because  there  is  no borrow   from  D4  to D3.
                                           Z = 0 because the R16 (the result) has a value 0other
                                             =  1  because
                                      Instruction Register the R20    (the result)
                                                                       registers
                                                                                   has a  value   in it after
                                                                                                        than 0the addition.
                                                                                                                after the addition.
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                                         SREG:        I     T     H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                          Example:Show
                                          Example:
                                          Example:
                                          Example:  Showthe
                                                    Show
                                                    Show   thestatus
                                                          the
                                                          the  status of
                                                               status
                                                               status ofthe
                                                                      of
                                                                      of  theC,
                                                                          the
                                                                          the   C,H,
                                                                               C,
                                                                               C, H,$0000
                                                                                  H,
                                                                                  H,  andZZ
                                                                                      and
                                                                                      and
                                                                                      and ZZflags
                                                                                             flagsafter
                                                                                             flags
                                                                                             flags  afterthe
                                                                                                    after
                                                                                                    after theaddition
                                                                                                          the
                                                                                                          the addition
                                          subtraction
                                          subtraction
                                          of
                                          of 0x9C     of
                                                      of 0x9C
                                                         0x23
                                                         0x73   from
                                                               from
                                                               from  0x9C
                                                                    0xA5
                                                                     0x52    in
                                                                            in  the
                                                                               the   following
                                                                                    $0001
                                                                                   following
                                                      0x64 in the following instructions:
                                             0x38 and 0x2F                                       instructions:
                                                                                           General
                                                                                                instructions:
                                                                                           Purpose
                                                                                                         ...
                                             LDI LDILDI 0x38
                                                   LDI
                                                   R16,       R20, 0x9C
                                                             R20,
                                                             R20,    0x9C
                                                                     0xA5
                                                                     0x52;R16 = 0x38 Registers
                                                                  R0           $001F                                                                IO Address
                                   ALU                    LDI 0x2F
                                                          LDI
                                                          LDI     R1 0x64
                                                                 R21,
                                                                R21,
                                                                R21,  0x9C
                                                                      0x23
                                                                      0x73                                                             TWBR         $00
                                              LDI         R17,          ;R17 = $0020
                                                                               0x2F                                                    TWSR         $01
                                                                  R2                 Standard IO
                                              ADD         SUB R17R20,
                                                          SUB
                                                          ADD
                                                          R16,   R20, R21
                                                                 R20, R21;add R17;add
                                                                      R21        ;subtract
                                                                                 ;subtract
                                                                                       R21 toR21
                                                                                   to Registers
                                                                                       R16      R21  from R20
                                                                                                  R20from R20
                                                                                                                                        ...
                                                                                                         ...
                                                                             …
                                                                                                                                        SPH
                              SREG: I T H S V N Z C                                                                                                 $3E
                                      Solution:
                                          Solution:
                                                                                                       $005F                           SREG         $3F
                                              CPU
                                          Solution:
                                          Solution:                         R15 11  $0060
                                                        $52
                                                        $9C
                                                       $A5                  0101
                                                                            R16    0010
                                                                            1001 1100
                                                                            1010   1100
                                                                                   0101
                                                        $38
                                                       $9C                  0011
                                                                            1001   1000    General
                                                    - $23
                                                        $73                 0111
                                                                            R17 0011       purpose
                                                  +-- +$64
                                                       $9C       10010100
                                                                        1100
                                                                                                         ...
                                                        $2F     0010
                                                                0110   0011
                                                                       1111                  RAM
                                             PC        $DF      1101   1111           R20   = $DF
                                                                             …
                                                        $00
                                                       $82
                                                        $67
                                                     $100   1    0000
                                                                1000
                                                                0110
                                                               0000     0000
                                                                       0010
                                                                       0111
                                                                      0000            R20
                                                                                      R20
                                                                                      R16
                                                                                     R20   ==  $00
                                                                                            = 00
                                                                                              $82
                                                                                              0x67
                                                                                           (SRAM)
                                           C = 1 because R21 is bigger than R20 and there is a borrow from D8 bit.
                                          CC===100because
                                           C       becausethere
                                                   because  R21 is
                                                            R21  is  not
                                                                  isnot   bigger
                                                                          bigger
                                                                      a carry
                                                                     R30          than R20
                                                                                 than
                                                                               beyond  R20   andbit.
                                                                                            and
                                                                                       the D7    there is
                                                                                                 there   is no
                                                                                                            no borrow
                                                                                                                borrow from
                                                                                                                         from D8
                                                                                                                              D8 bit.
                                                                                                                                  bit.
                                      Z
                                      C  == 00 decoder
                                               because
                                               because the
                                                       thereR20
                                                              is has
                                                                 no   a value
                                                                     carry    otherthe
                                                                           beyond   than
                                                                                       D7zero    after the subtraction.
                               Instruction
                                      ZZ =
                                      H  == 1
                                            01 because
                                               because there
                                               because  the R20
                                                       the  R20  iscarry
                                                             is ahaszero after
                                                                      a value
                                                                         from  the D3
                                                                              other
                                                                               the  than  0 bit.
                                                                                   subtraction.
                                                                                      to theafter  the subtraction.
                                                                                              D4 bit.
                                           H = 1 because there isR31   a borrow
                                                                         carry   from
                                                                               from    D4D3
                                                                                     the   toto
                                                                                              D3.
                                                                                                the D4 bit.
                                          ZH
                                           H  =
                                              = 00 because
                                                   because  there
                                                            there   is
                                                                   is  no
                                                                       no  borrow
                                                                          borrow   from
                                                                                   from  D4
                                                                                         D4  to
                                                                                             to D3.
                                                                                                D3.
                                           Z = 0 because the R16 (the result) has a value 0other
                                             =  1 because
                                      Instruction Register the R20    (the result)
                                                                       registers
                                                                                   has a  value    in it after
                                                                                                         than 0the addition.
                                                                                                                 after the addition.
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                       Status Register (SREG)
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
                                         SREG:        I     T     H     S     V     N       Z    C
                                                                                                           Carry
                                     Interrupt                           oVerflow               Zero
                                          Temporary                               Negative
                                                                      Sign
                                                                                                 Data Address
                                                Half carry            N+V                              Space
                                          Example:Show
                                          Example:
                                          Example:
                                          Example:  Showthe
                                                    Show
                                                    Show   thestatus
                                                          the
                                                          the  status of
                                                               status
                                                               status  ofthe
                                                                       of
                                                                       of theC,
                                                                          the
                                                                          the   C,H,
                                                                               C,
                                                                               C, H,$0000
                                                                                  H,
                                                                                  H,  andZZ
                                                                                      and
                                                                                      and
                                                                                      and ZZflags
                                                                                             flagsafter
                                                                                             flags
                                                                                             flags  afterthe
                                                                                                    after
                                                                                                    after theaddition
                                                                                                          the
                                                                                                          the addition
                                          subtraction
                                          subtraction
                                          of
                                          of 0x9C     of
                                                      of 0x9C
                                                         0x23
                                                         0x73   from
                                                               from
                                                                from  0x9C
                                                                     0xA5
                                                                     0x52    in
                                                                            in  the
                                                                               the   following
                                                                                    $0001
                                                                                   following
                                                      0x64 in the following instructions:
                                             0x38 and 0x2F                                       instructions:
                                                                                           General
                                                                                                instructions:
                                                                                           Purpose
                                                                                                         ...
                                             LDI LDILDI 0x38
                                                   LDI
                                                   R16,       R20, 0x9C
                                                             R20,
                                                             R20,    0x9C
                                                                     0xA5
                                                                     0x52;R16 = 0x38 Registers
                                                                  R0           $001F                                                                IO Address
                                   ALU                    LDI 0x2F
                                                          LDI
                                                          LDI     R1 0x64
                                                                 R21,
                                                                R21,
                                                                R21,  0x9C
                                                                      0x23
                                                                      0x73                                                             TWBR         $00
                                              LDI         R17,          ;R17 = $0020
                                                                               0x2F                                                    TWSR         $01
                                                                  R2                 Standard IO
                                              ADD         SUB R17R20,
                                                          SUB
                                                          ADD
                                                          R16,   R20, R21
                                                                 R20, R21;add R17;add
                                                                      R21        ;subtract
                                                                                 ;subtract
                                                                                       R21 toR21
                                                                                   to Registers
                                                                                       R16      R21  from R20
                                                                                                  R20from R20
                                                                                                                                        ...
                                                                                                         ...
                                                                             …
                                                                                                                                        SPH
                              SREG: I T H S V N Z C                                                                                                 $3E
                                      Solution:
                                          Solution:
                                                                                                       $005F                           SREG         $3F
                                              CPU
                                          Solution:
                                          Solution:                         R15 11  $0060
                                                        $52
                                                        $9C
                                                       $A5                  0101
                                                                            R16    0010
                                                                            1001 1100
                                                                            1010   1100
                                                                                   0101
                                                        $38
                                                       $9C                  0011
                                                                            1001   1000    General
                                                    - $23
                                                        $73                 0111
                                                                            R17 0011       purpose
                                                  +-- +$64
                                                       $9C       10010100
                                                                        1100
                                                                                                         ...
                                                        $2F     0010
                                                                0110   0011
                                                                       1111                  RAM
                                             PC        $DF      1101   1111           R20   = $DF
                                                                             …
                                                        $00
                                                       $82
                                                        $67
                                                     $100   1    0000
                                                                1000
                                                                0110
                                                               0000     0000
                                                                       0010
                                                                       0111
                                                                      0000            R20
                                                                                      R20
                                                                                      R16
                                                                                     R20   ==  $00
                                                                                            = 00
                                                                                              $82
                                                                                              0x67
                                                                                           (SRAM)
                                           C = 1 because R21 is bigger than R20 and there is a borrow from D8 bit.
                                          CC===100because
                                           C       becausethere
                                                   because  R21 is
                                                            R21  is  not
                                                                  isnot   bigger
                                                                          bigger
                                                                      a carry
                                                                     R30          than R20
                                                                                 than
                                                                               beyond  R20   andbit.
                                                                                            and
                                                                                       the D7    there is
                                                                                                 there   is no
                                                                                                            no borrow
                                                                                                                borrow from
                                                                                                                         from D8
                                                                                                                              D8 bit.
                                                                                                                                  bit.
                                      Z
                                      C  == 00 decoder
                                               because
                                               because the
                                                       thereR20
                                                              is has
                                                                 no   a value
                                                                     carry    otherthe
                                                                           beyond   than
                                                                                       D7zero    after the subtraction.
                               Instruction
                                      ZZ =
                                      H  == 1
                                            01 because
                                               because there
                                               because  the R20
                                                       the  R20  iscarry
                                                             is ahaszero after
                                                                      a value
                                                                         from  the D3
                                                                              other
                                                                               the  than  0 bit.
                                                                                   subtraction.
                                                                                      to theafter  the subtraction.
                                                                                              D4 bit.
                                           H = 1 because there isR31   a borrow
                                                                         carry   from
                                                                               from    D4D3
                                                                                     the   toto
                                                                                              D3.
                                                                                                the D4 bit.
                                          ZH
                                           H  =
                                              = 00 because
                                                   because  there
                                                            there   is
                                                                   is  no
                                                                       no  borrow
                                                                          borrow   from
                                                                                   from  D4
                                                                                         D4  to
                                                                                             to D3.
                                                                                                D3.
                                           Z = 0 because the R16 (the result) has a value 0other
                                             =  1 because
                                      Instruction Register the R20    (the result)
                                                                       registers
                                                                                   has a  value    in it after
                                                                                                         than 0the addition.
                                                                                                                 after the addition.
                                                                                                       $FFFF
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                Assembler Directives
                                                                                .EQU and .SET
www. Micro Digital Ed. com
                                                                                                                                                       BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                           © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                               Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                Assembler Directives
                                                                                      .INCLUDE
www. Micro Digital Ed. com
                                                                                                                                                    BIHE university
• .INCLUDE “filename.ext”
                             AVR Microcontroller and Embedded System Using Assembly and C                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                            Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                Assembler Directives
                                                                                      .INCLUDE
www. Micro Digital Ed. com
                                                                                                                                                                  BIHE university
• .INCLUDE “filename.ext”
                                                                                            M32def.inc
                                           .equ            SREG            = 0x3f
                                           .equ            SPL             = 0x3d
                                           .equ            SPH             = 0x3e
                                           ....
                                           .equ            INT_VECTORS_SIZE = 42                         ; size in words
                                                                                       Program.asm
                                           .INCLUDE “M32DEF.INC”
                                               LDI   R20, 10
                                               OUT   SPL, R20
                             AVR Microcontroller and Embedded System Using Assembly and C                                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                Assembler Directives
                                                                                            .ORG
www. Micro Digital Ed. com
                                                                                                                                                              BIHE university
• .ORG address
                                                                                                                         00    E205
                                                                                                                         01    0000
                                                            Program.asm                                                  02    0000
.ORG 0 03 0000
                             AVR Microcontroller and Embedded System Using Assembly and C                                  © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                      Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                              Assembler
www. Micro Digital Ed. com
                                                                                                                                                                      BIHE university
Assembly
                                                                                     EDITOR
                                                                                    PROGRAM                                             assembler
                                                                                            myfile.asm
                                                                                  ASSEMBLER
                                                                                   PROGRAM                                             Machine
                                                                                                                                       Language
                                        DOWNLOAD TO                DOWNLOAD TO
                                        AVR’s EEPROM                AVR ’s FLASH
                             AVR Microcontroller and Embedded System Using Assembly and C                                          © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                              Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
16-bit
                                                                                      PROGRAM
                                                                                      Flash ROM               ALU
                                                                                                      PC:                Data
                                                                                                            CPU          Bus
                                                                                                      Instruction dec.
                                                                                            Program
                                                                                              Bus
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
16-bit
                                                                                      PROGRAM
                                                                                      Flash ROM               ALU
                                                                                                      PC:                Data
                                                                                              16bit
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
                                                                                    00      E205
                                                                                    01      E314
                                                                                    02      E321
                                                                                    03      0F01
                                                                                    04      0F02
                                                                                    0516-bit
                                                                                        E01B
                                                                                    06      0F01
                                                                                    07      9300
                                                                                    08      0300                             RAM           EEPROM               Timers
                                                                                    09      940C
                                                                                     PROGRAM
                                                                                    0A
                                                                                     Flash0009
                                                                                           ROM                ALU
                                                                                                      PC:                Data
                                                                                              16bit
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
                                                                                    00      E205
                                                                                            E205
                                       LDI R16,               0x25                  01      E314
                                       LDI R17,               $34                   02      E321
                                       LDI R18,               0x31
                                                                                    03      0F01
                                       ADD R16,               R17
                                       ADD R16,               R18                   04      0F02
                                       LDI R17,               11                    0516-bit
                                                                                        E01B
                                       ADD R16,               R17
                                                                                    06      0F01
                                       STS SUM,               R16
                                  HERE:JMP HERE                                     07      9300
                                                                                    08      0300                             RAM           EEPROM               Timers
                                                                                    09      940C
                                                                                     PROGRAM
                                                                                    0A
                                                                                     Flash0009
                                                                                           ROM                ALU
                                                                                              16bit
                                                                                                      PC:         0      Data
                                                                                             16bit          CPU          Bus
                                                                                                      Instruction dec.
                                                                                            Program
                                                                                              Bus
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
                                                                                    00      E205
                                                                                            E205
                                       LDI R16,               0x25                  01      E314
                                       LDI R17,               $34                   02      E321
                                       LDI R18,               0x31
                                                                                    03      0F01
                                       ADD R16,               R17
                                       ADD R16,               R18                   04      0F02
                                       LDI R17,               11                    0516-bit
                                                                                        E01B
                                       ADD R16,               R17
                                                                                    06      0F01
                                       STS SUM,               R16
                                  HERE:JMP HERE                                     07      9300
                                                                                    08      0300                             RAM           EEPROM               Timers
                                                                                    09      940C
                                                                                     PROGRAM
                                                                                    0A
                                                                                     Flash0009
                                                                                           ROM                ALU
                                                                                              16bit
                                                                                                      PC:         0      Data
                                                                                             16bit          CPU          Bus
                                                                                                      Instruction dec.
                                                                                            Program
                                                                                              Bus
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                           Flash memory and PC register
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
                                                                                    00      E205
                                                                                            E205
                                       LDI R16,               0x25                  01      E314
                                       LDI R17,               $34                   02      E321
                                       LDI R18,               0x31
                                                                                    03      0F01
                                       ADD R16,               R17
                                       ADD R16,               R18                   04      0F02
                                       LDI R17,               11                    0516-bit
                                                                                        E01B
                                       ADD R16,               R17
                                                                                    06      0F01
                                       STS SUM,               R16
                                  HERE:JMP HERE                                     07      9300
                                                                                            9300
                                                                                    08      0300
                                                                                            0300                             RAM           EEPROM               Timers
                                                                                    09      940C
                                                                                            940C
                                                                                     PROGRAM
                                                                                    0A
                                                                                     Flash0009
                                                                                          0009
                                                                                           ROM                ALU
                                                                                              16bit
                                                                                                      PC:         3
                                                                                                                  0
                                                                                                                  1
                                                                                                                  5
                                                                                                                  2
                                                                                                                  4      Data
                                                                                             16bit          CPU          Bus
                                                                                                      Instruction dec.
                                                                                            Program
                                                                                              Bus
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                 Fetch and execute
www. Micro Digital Ed. com
                                                                                                                                                                                    BIHE university
                                                                                     00      E205
                             • Old Architectures                                     01      E314
                                                                                     02      E321
                                           Instruct 4
                                                                                     03      0F01
                                           Instruct 3
                                                                                     04      0F02
                                           Instruct 2
                                                                                     0516-bit
                                                                                         E01B
                                           Instruct 1
                                                                                     06      0F01
                                                                                     07      9300
                                                                                     08      0300                             RAM           EEPROM               Timers
                                              Fetch
                                                                                     09      940C
                                                                                      PROGRAM
                                                                                     0A
                                                                                      Flash0009
                                                                                            ROM                ALU
                                                                                                       PC:                Data
                                                                                                             CPU          Bus
                                            Execute
                                                                                                       Instruction dec.
                                                                                             Program
                                                                                               Bus
                                                                                                                           Interrupt                              Other
                                                                                                        OSC                                    Ports
                                                                                                                              Unit                              Peripherals
                                                                                                                                                I/O
                                                                                                                                               PINS
                              AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                                 Pipelining
www. Micro Digital Ed. com
                                                                                                                                                                                    BIHE university
                                                                                     00      E205
                             • Pipelining                                            01      E314
                                                                                     02      E321
                                       Instruct 4                                    03      0F01
                                       Instruct 3                                    04      0F02
                                       Instruct 2                                    0516-bit
                                                                                         E01B
                                       Instruct 1                                    06      0F01
                                                                                     07      9300
                                                                                     08      0300                             RAM           EEPROM               Timers
                                           Fetch                                     09      940C
                                                                                      PROGRAM
                                                                                     0A
                                                                                      Flash0009
                                                                                            ROM                ALU
                                                                                                       PC:                Data
                                                                                                             CPU          Bus
                                         Execute                                             Program   Instruction dec.
Bus
                                                                                                                           Interrupt                              Other
                                                                                                        OSC                                    Ports
                                                                                                                              Unit                              Peripherals
                                                                                                                                                I/O
                                                                                                                                               PINS
                              AVR Microcontroller and Embedded System Using Assembly and C                                                        © 2011 Pearson Higher Education,
                              Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                   How to speed up the CPU
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                         Changing the architecture
www. Micro Digital Ed. com
                                                             RISC vs. CISC                                                                     BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                                                  BIHE university
                             • Feature 1
                                   – RISC processors have a fixed instruction size. It
                                     makes the task of instruction decoder easier.
                                           • In AVR the instructions are 2 or 4 bytes.
                                   – In CISC processors instructions have different
                                     lengths
                                           • E.g. in 8051
                                                   – CLR C                                  ; a 1-byte instruction
                                                   – ADD A, #20H                            ; a 2-byte instruction
                                                   – LJMP HERE                              ; a 3-byte instruction
                             AVR Microcontroller and Embedded System Using Assembly and C                                      © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                          Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                                                                   BIHE university
                             • Feature 4: Load/Store
                                        LDS     R20, 0x200
                                        LDS     R21, 0x220
                                        ADD     R20, R21
                                        STS     0x230, R20
                                                                                     PROGRAM
                                                                                     Flash ROM                ALU
                                                                                                      PC:                Data
                                                                                                            CPU          Bus
                                                                                                      Instruction dec.
                                                                                            Program
                                                                                              Bus
                                                                                                                          Interrupt                              Other
                                                                                                       OSC                                    Ports
                                                                                                                             Unit                              Peripherals
                                                                                                                                               I/O
                                                                                                                                              PINS
                             AVR Microcontroller and Embedded System Using Assembly and C                                                       © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                                           Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                                                BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                                    © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                                                BIHE university
                             • Feature
                                LDS R20, 5 (Harvard
                                         0x100 ; R20 = architecture):
                                                       [0x100]        separate buses for
                                                                         ADD R20, R21
                               opcodes    and operands
                                ADD R20,R21    ; R20 = R20 + R21
                                                                        LDS R20, 0x100
                                   – Advantage: opcodes and operands can go in and out of the CPU
                                     together.
                                   – Disadvantage: leads to more cost in generalFetch
                                                                                 purpose computers.
Execute
                             AVR Microcontroller and Embedded System Using Assembly and C                                    © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                                        Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.
                                                                  RISC architecture
www. Micro Digital Ed. com
                                                                                                                                               BIHE university
                             • Feature 7
                                   – RISC processors have at least 32 registers.
                                     Decreases the need for stack and memory
                                     usages.
                                           • In AVR there are 32 general purpose registers (R0
                                             to R31)
                             AVR Microcontroller and Embedded System Using Assembly and C                   © 2011 Pearson Higher Education,
                             Mazidi, Naimi, and Naimi                                       Upper Saddle River, NJ 07458. • All Rights Reserved.