ARM Cortex Core Microcontrollers: Requirements

Download as pdf or txt
Download as pdf or txt
You are on page 1of 32

ARM Cortex core microcontrollers

Requirements

Balázs Scherer

Budapest University of Technology and Economics


Department of Measurement and Information Systems
© BME-MIT 2018
Homework
 Possibilities:
o Usable hardware
 Silabs: Energy Micro series, TI MSP432 line, STM32F429i board, LPC
1768 mbed, Your preferred hardware
o Topic
 Individual or group
 Your own topic, or a given one
 Conformance levels
o OK: a low complexity homework to full fit the requirements
o Good: More complex software, or some self made hardware
extension
o Very good: Using high complexity software library-s like USB stack,
or TCP/IP stack.
o Outstanding: very high level work

© BME-MIT 2018 2.
Homework: deadlines
 Selecting a topic
o 31th of March
o An email to me, with the sort description of the selected
topic and used hardware
 Presentation of Homework
o Last lecture
 Documentation of the homework
o 1 page summary: a brief general description of the tool
you have made. The description includes the picture and
photo of the device!
o Documentation: Standard Technical Documentation 10
to 15 pages.

© BME-MIT 2018 3.
Resources, Exam
• Resources: Lecture ppt-s
• Exam
• Given list of questions: ~40 questions
• Exam: Randomly selected 10 question from the list
• Exam points:
• Each question is 10 points: 100 points exam
• Grade 1: 0 - 40 points
• Grade 2: 41 - 55 points
• Grade 3: 56 – 70 points
• Grade 4: 71 – 85 points
• Grade 5: 86 – 100 points
• Effect of the HW level
• OK: 1 selected question is taken into account with maximum points.
• Good: 2 selected questions …
• Very Good: 3 selected question …
• Outstanding: 4 selected question …

© BME-MIT 2018 4.
ARM Cortex core microcontrollers

1st Introduction: Brief history of microcontrollers

Balázs Scherer

Budapest University of Technology and Economics


Department of Measurement and Information Systems
© BME-MIT 2018
The first microcontrollers (Intel MCS-48)
 1976: Intel introduce a 8 bit microcontroller the
MCS-48/49 (8048, 8049). In that year 251.000
pieces are sold from that series.
o Internal 1-2k ROM, internal 64-256 bytes RAM
o About 10 MHz clock speed
o Many embedded control device and future PC
peripheral used it.

Budapest University of Technology and Economics


Department of Measurement and Information Systems
© BME-MIT 2018
Internal architecture of Intel MCS-48

Budapest University of Technology and Economics


Department of Measurement and Information Systems
© BME-MIT 2018
Intel 8051
 1980: Intel introduce the 8051 line. An 8 bit
microcontroller with EPROM memory
o https://www.youtube.com/watch?v=_sSuzDg4ntA
 1983: 91 million of 8051 is sold
o The most widespread line of the 80-s and 90-s
o 8 bit ALU
o 8 bit data bus
o 16 bit address range: 64k RAM and ROM
o On-chip RAM - 128 bytes
o On-chip ROM - 4 kbytes
o 4*8 bit bi-directional I/O port
o UART
o Two 16 bit Counter/timer
o Power saving mode
© BME-MIT 2018 8.
1993: PIC 16C84
 PIC: Peripheral Interface Controller / Programmable Intelligent
Computer
o Originally designed by General Instruments to supports their 16
bit processor
o In 1985 the General Instruments wind-up their uC design
o Microchip redesign the line
 1993 Microchip introduce the first PIC16C84 line
microcontroller
o Novelty: EEPROM.
o Development is cheaper and faster
o Small companies can use it
o EEPROM program memory: 1k
o EEPROM 64 byte, 36 byte SRAM data
© BME-MIT 2018 9.
1997: Atmel ISP Flash based micro
 1993 Atmel introduce the first Flash based microcontroller
o Based on the 8051 core
o Needs a Flash burner to program it
 1997 Atmel introducing the their own AVR core microcontroller
o In-System programable: there is no need for a separate flash burner
o AT90S8515
• 8 kByte Flash
• 512 Byte SRAM
• 512 Byte EEPROM
• UART
• SPI
• PWM
• 32 I/O line

© BME-MIT 2018 10.


2003: Philips (NXP) LCP210x line
 2003 Philips introduce the first 32 bit ARM 7 core
microcontroller with in chip program and data
memoryNXP:
• LPC2104,LPC2105, LPC2106
 All the other manufacturers introduce their ARM 7 core
micro
o NXP: LPC2xxx line
o Atmel: AT91SAM7
o Texas Instruments: TMS470
o Analog Devices: ADuC70xx
o STMicroelectonics: STM7
 2005 Introduction of the first ARM9 micro
© BME-MIT 2018 11.
Why ARM?
 ARM is founded in 1990 as a joint venture by Acorn
Computers, Apple Computer and VLSI Technology
 Az Advanced RISC Machines Ltd (ARM) design IPs, mainly
processor cores. There is no such as ARM microcontroller.
 Many microcontroller or chip manufacturers uses the
ARM cores and ARM IPs (NXP, ST, Texas, Atmel, OKI,
Samsung, Sony stb.).
 The most known processor core provider.

© BME-MIT 2018 12.


Comparing ARM to other architectures (2007)

© BME-MIT 2018 13.


Traditional ARM cores

© BME-MIT 2018 14.


2003: LPC2106

 128 kByte Flash


 64 kSRAM
 60 MHz
 2 SPI
 UART
 I2C

© BME-MIT 2018 15.


Snapshot of the microcontroller market in 2003

Microcontroller PIC18F452/PIC ATmega128/AVR LPC2106/ARM

Flash/ SRAM/ 32k / 1,5k / 256 128k / 4k / 4k 128k / 64k


EEPROM
MIPS 10 16 50
Adatszélesség
Data bus 8 8 32
GPIO 36 53 32
ADC 10bit 8 channel 10bit 8 channel 0
SPI, I2C,UART, 2 SPI, 2UART,
SPI, I2C,UART,
Perifériák
Peripherals 8bit Timer, 2 16bit I2C, 2 32bit
4 Timer
Timer Timer
Power 25-30mA (4.5V) 40-50mA
15-25mA (4.2V)
Fogyasztás
consumption (3.3/1.8V)
~105mW ~135mW
~125mW
Price
Ár/db(for
(100
100
dbpieces)
ét tel) $6.51 $8.81 $9.48

© BME-MIT 2018 16.


Market prognosis in 2003

© BME-MIT 2018 17.


Market prognosis in 2006

© BME-MIT 2018 18.


The ARM 7 core

© BME-MIT 2018 19.


The ARM 7 core (ARMv4)
 Reduced instruction set, small complexity
o Fast, and power efficient
 Pipeline based instruction execution
o 3 stage pipeline
o Most instruction has 1 clock edge execution

© BME-MIT 2018 20.


Load and Store architecture
 First the data needs to be loaded from the
memory to a register, then the operation can be
executed using the data in the registers, then the
result is written back to the memory

© BME-MIT 2018 21.


Register set
 General purpose registers
o 16 general purpose register
o CPSR
• Operating mode
• IT enable
• Thumb/ARM
• Conditions
– Zero
– Negativ
– Carry
– Overflow

© BME-MIT 2018 22.


Operating modes

© BME-MIT 2018 23.


Event handling
 Very basic event handling
o Vector interrupt controllers were provided by the
microcontrollers manufacturers
o Not efficient, and hard to port the code from one uC
to another

© BME-MIT 2018 24.


ARM instructionset

 Little-endian/Big-endian: hard wired configuration


(microcontrollers are usually Little-endians)
 32 bits ARM,16 bits THUMB instruction set (Thumb is 30%
smaller, but 40% slower)
 Every arithmetic instruction is conditionally executed.
 Make the assembly coding a nightmare
 Help feeding the pipeline and enables a fast instruction
execution

© BME-MIT 2018 25.


Data processing ARM instructions
 Data processing
o Using registers as operands
o AND, OR, XOR, ADD, SUB, CMP…
o If (z==1) R1 = R2+(R3x4)
o EQADDS R1,R2,R3,LSR #2

© BME-MIT 2018 26.


ARM instruction and compilers

© BME-MIT 2018 27.


New generation of ARM cores

ARM11

Cortex-A

ARM10

Cortex-R
ARM9

Cortex-M
ARM7

© BME-MIT 2018 28.


ARM Cortex
 Cortex-M3, the first line, introduced in 2006
o Luminary Micro: Stellaris – Bought up by Texas Instruments
o STMicroelectronics: STM32F1xx
o NXP: LPC17xx
o Atmel Cortex sorozat
 Cortex-M0, M0+ introduced in 2009
o NXP, LPC11xx
o STMicro: STM32F0xx
 Cortex-M4 introduced in 2010
o NXP, LPC4xxx
o STMicro: STM32F4xx
 Cortex-M7 introduced in 2015
o STMicro: STM32F7xx

© BME-MIT 2018 29.


Current market trends (2017)

© BME-MIT 2018 30.


Most widespread 32 bit lines

© BME-MIT 2018 31.


Most widespread 32 bit lines

© BME-MIT 2018 32.

You might also like