Tuesday, October 18, 2016

Registers ARM

Processor Modes

The ARM has six operating modes:
  • User (unprivileged mode under which most tasks run)
  • FIQ (entered when a high priority (fast) interrupt is raised)
  • IRQ (entered when a low priority (normal) interrupt is raised)
  • Supervisor (entered on reset and when a Software Interrupt instruction is executed)
  • Abort (used to handle memory access violations)
  • Undef(used to handle undefined instructions)

ARM Architecture Version 4 adds a seventh mode:
System (privileged mode using the same registers as user mode)

The Registers


  • ARM has 37 registers in total, all of which are 32-bits long.
  1 dedicated program counter
  1 dedicated current program status register
  5 dedicated saved program status registers
  30 general purpose registers

  • However these are arranged into several banks, with the accessible bank being governed by the processor mode. Each mode can access
a particular set of r0-r12 registers
a particular r13 (the stack pointer) and r14 (link register)
r15 (the program counter)
cpsr (the current program status register)
and privileged modes can also access
    a particular spsr (saved program status register)

Register Organisation

Accessing Registers using ARM Instructions


  • No breakdown of currently accessible registers.
  • All instructions can access r0-r14 directly.
  • Most instructions also allow use of the PC.
  • Specific instructions to allow access to CPSR and SPSR.
  • Note : When in a privileged mode, it is also possible to load / store the (banked out) user mode registers to or from memory.

The Program Status Registers (CPSR and SPSRs):


Condition Code Flags:
N = Negative result from ALU flag.
Z = Zero result from ALU flag.
C = ALU operation Carried out
V = ALU operation oVerflowed

Interrupt Disable bits.
I = 1, disables the IRQ.
F = 1, disables the FIQ.

Mode Bits
M[4:0] define the processor mode.

T Bit      (Architecture v4T only)
T = 0, Processor in ARM state
T = 1, Processor in Thumb state


Introduction to ARM

Introduction:

ARM: Advance RISC Machine

  • ARM was established as a joint venture between Acorn,Apple and VLSI between Acorn, Apple and VLSI in November 1990.
  • ARM is the industry's leading provider of 16/32-bit embedded RISC microprocessor solutions
  • The company licenses its high-performance, low-cost, power-efficient RISC processors  peripherals  and system chip efficient RISC processors,peripherals,and system-chip designs to leading international electronics companies
  • ARM provides comprehensive support required in developing a complete system.

Role of ARM :

  • ARM Holdings is a technology company headquartered in Cambridge  England  UK Cambridge , England,UK.
  • The company is best known for its processors, although it also designs, licenses and sells software development tools under designs,licenses and sells software development tools under the RealView and KEIL brands, systems and platforms, system-on-a-chip infrastructure and software.
  • ARM do not make ICs
  • ARM grant license of core to different silicon vendors like ATMEL, TI, STM etc
  • These companies make ICs
  • Examples are: KL25Z128VLK from freescale,  Atmel ATSAM3X8E , LM4F120 TI.

Where ARM processors are used:

  • ARM processors can be used in any domain™
  • Mainly ARM processors are used in Handheld devices,Robotics, Automation, Consumer Electronics.
  • But ARM processors are available for almost every domain™.

ARM Based Products: Inside the processors


ARM Features:

  • ARM are RISC (Reduced Instruction Set Computation) processor
  • ARM is not 100 % RISC  some amendment to meets requirement of Embedded System
  • Large Register file R0 to R16 (against RISC)
  • Load and Store architecture - data processing is only in register contents
  • Uniform and fixed length instructions
  • 32 bit processor
  • Good speed and power consumption ratio
  • High code density
  • Mostly single-cycle execution
  • Speed 1Mhz to 1.25Ghz
  • ARM support JAVA jezelle DBX (Direct Byte code execution)
  • DSP Enhanced Instructions
  • Support for TrustZone technology additional security core
  • Conditional execution of all instructions (against RISC)
  • 32 bit barrel shifter(against RISC)
  • In build circuit for debugging

ARM Processor Family:

ARM7TDMI     
ARM9
ARM9TDMI
ARM9E
ARM10E
ARM11
Cortex
XScale

ARM Nomenclature:

ARMxyzTDMIEJFS
  • X: series
  • y: MMU
  • z: cache
  • T: Thumb
  • D: debugger
  • M: Multiplier : ARM processors has hardware multiplier unit doing multiplication
  • I: Embedded ICE Macrocel: This is the hardware circuit which is used to generate traceinformation. This feature is used in advance debugging and very useful in bug fixing.
  • E: Enhanced Instructions: Enhanced instruction set,may be for DSP
  • J: Java acceleration by Jazelle: Hardware circuit which is used to run JAVA byte code
  • F: Vector Floating-point : This is the hard wired implementaton of floating operations
  • S :Synthesizable Version : It means ARM architecture can be modified. Because it will comes in terms of soft processor core

ARM Processor


ARM Processor Architecture (ARM core)

ARM Inside:

  • ARM processor are widely used Embedded Systems
  • ARM has good support of RTOS like Linux,QNX, VxWorks,FreeRTOS etc.
  • ARM processor are best know for their low power consumptions and high end processing
  • ARM has proprietary and open source development tools
  • Proprietary tools:
•Windriver workbench
•Codesourcery
•Green Hills
•KEIL
•Realview
•IAR Workbench
  • FreeOpen Source tools
•GNUARM
•Yagarto

Embedded ARM Development Tools:

ARM Development Tools include
•IDE
•Compiler  Suite
•Debugger
•Simulator
•JTAG Debugging Probe(Hardware)
•Development Board (Hardware)
  • Both Open Source and Proprietary tools are available in market

Open Source | Freeware Tools:

IDE: Eclipse IDE (http://www.eclipse.org/)
Compiler Suite: GCC Compiler for ARM(http://www.gnuarm.com/) (http://www.yagarto.org/)
Debugger:GNU Debugger (http://www.gnu.org/software/gdb/)
Simulator: Insight Debugger (http://sourceware.org/insight/)

Proprietary Tools (1):

  • IAR Workbench for ARM(http://www.iar.com/)
  • Complete toolchain including IDE, Compiler, Debugger,Simulator
  • Evaluation / Kickstart version are available for free download
  • IAR also provide IAR PowerPac RTOS for ARM

Proprietary Tools (2):

  • Keil for ARM(http://www.keil.com/arm/)
  • Complete toolchain include uvision IDE,Compiler(armcc),Debugger and Simulator
  • KEIL also provide RTX RTOS for ARM
  • Evaluation version is also available for download

JTAG Debugging Probe:

  • Olimex (http://www.segger.com/cms/jlink.html)
  • This is USB Powered JTAG In circuit emulator
  • This can be used with various tools like IAR, KEIL, Sourcery++ etc
  • Generally ARM JTAG Debugger is a 20 Pin Interface

RTOS for ARM | Proprietary

  • Vxworks from Windriver         ( http://www.windriver.com/)
  • Threadx from Express Logic    ( http://www.rtos.com/)
  • μC/OS II from Micrium            ( http://micrium.com)
  • Montavista Linux from Montavista( http://www.mvista.com)
  • QNX from QNX software system   (http://www.qnx.com/)

RTOS for ARM | Free and Open Source

  • Linux       (https://www.rtai.org/)
  • uClinux   (http://www.uclinux.org/)
  • Ecos      (http://ecos.sourceware.org/)
  • CooCox  (http://www.coocox.org)
  • freeRTOS  (http://www.freertos.org/)