Kërceni tek përmbajtja

Arkitektura ARM

Nga Wikipedia, enciklopedia e lirë


ARM-ja është një arkitekture me instruksione (instruction set architecture (ISA)) RISC (reduced instruction set computer) 32-bit e krijuar nga ARM Holdings. Ishte e njohur si Makineria RISC e avancuar, dhe përpara kësaj si Acorn RISC Machine. Arkitektura ARM është ISA 32-bit me e përdorur sipas sasisë së prodhuar.[1][2] Fillimisht u konceptua si një procesor për kompjutera personal me desktop nga Acorn Computers, një treg tashmë i zotëruar nga familja x86 e përdorur nga kompjutera te pajtueshëm me platformën IBM PC. Thjeshtësia relative e procesorëve ARM i beri ato te përshtatshëm për aplikacione me fuqi të vogël. Kjo i bëri ato zotërues në tregun e celularëve dhe elektronikës së ngulitur si mikroprocesore dhe microcontrollues relativisht te vegjël dhe me çmim te ulët.

Në 2007, rreth 98 % e më shumë se një bilion celulareve të shitur përdorin të paktën një procesor ARM.[3] Në 2009, procesorët ARM japin llogari për afërsisht 90 % të të gjithë procesorëve te ngulitur RISC 32-bit. Procesorët ARM përdoren gjerësisht në elektronikën e konsumit, duke përfshirë PDA-të, celularët, median digjitale, konzolat e lojërave që mbahen në dorë, makinave llogaritëse dhe për hard drive-t dhe router-et.

Arkitektura ARM është e licensueshme. Kompanitë që kanë ose kanë patur licencën ARM përfshijnë Alcatel-Lucent, Apple Inc., Atmel, Broadcom, Cirrus Logic, Digital Equipment Corporation, Freescale, Intel (përmes DEC), LG, Marvell Technology Group, NEC, Nuvoton, NVIDIA, NXP (më parë e quajtur Philips), Oki, Qualcomm, Samsung, Sharp, STMicroelectronics, Symbios Logic, Texas Instruments, VLSI Technology, Yamaha dhe ZiiLABS.

Procesorët ARM krijohen nga ARM dhe të licencuarit e ARM-së. Shembujt më të njohur të familjeve të procesorëve ARM të ARM Holdings përfshijnë ARM7, ARM9, ARM11 dhe Cortex. Shembuj të procesorëve ARM të krijuar nga të licencuarit e rëndësishëm përfshijnë DEC StrongARM, Freescale i.MX, Marvell (më parë e quajtur Intel) XScale, Nintendo, NVIDIA Tegra, ST-Ericsson Nomadik, Qualcomm Snapdragon, dhe linjës se produkteve Texas Instruments OMAP.


Pasi arritën ca sukses me kompjuterin BBC Micro, Acorn Computers Ltd konsideruan si të ecnin përpara nga procesori MOS Technology 6502 relativisht i thjeshtë për të adresuar tregjet e biznesit si ai që së shpejti do zotërohej nga IBM PC, i filluar në 1981. Plani Acorn Business Computer (ABC) kërkonte një numër procesorësh të dytë të bëhen të punojnë me platformën BBC Micro, por procesorët si Motorola 68000 dhe National Semiconductor 32016 ishin të papërshtatshëm, dhe 6502 nuk kishte fuqi të mjaftueshme për një shpërfaqje grafike për përdoruesit.

Acorn-it do t'i duhej një arkitekture e re, pasi testoi të gjithë procesorët e disponueshëm dhe vuri re që i mungonin gjëra. Acorn-i pastaj konsideroi seriozisht projektimin e një procesori të vetin, dhe inxhinierët e tyre gjetën ca letra mbi projektin Berkeley RISC. Ata ndjenë se në qoftë se një klase studentësh te diplomuar mund të krijonin një procesor 32-bit konkurrues, atëherë Acorn nuk do e kishte fare problem. Një udhëtim tek Western Design Center në Phoenix i tregoi inxhinierëve te Acorn-it Steve Furber dhe Sophie Wilson që nuk kishin nevojë për burime masive.

Wilson vendosi të krijonte kompletin e instruksioneve, duke shkruar një simulim te procesorit ne BBC Basic që përdorej në BBC Micro me një procesor të dyte 6502. Kjo ia mbushi mendjen inxhinierëve te Acorn-it se ishin ne rrugën e duhur. Gjithsesi, para se të shkonin më larg, do kishin nevojë për më shumë burime. Erdhi koha për Wilson-in t'i afrohej shefit ekzekutiv te Acorn-it, Hermann Hauser, dhe t'i shpjegonte çfarë ishte në përgatitje e sipër. Pasi të merrte konfirmimin, një skuadër e vogël u krijua për të zbatuar modelin e Wilson-it në hardware.

A Conexant ARM processor used mainly in routers

Makineria Acorn RISC: ARM2

[Redakto | Redakto nëpërmjet kodit]

Projekti zyrtar Makineria Acorn RISC filloi në tetor 1983. Projektimi drejtohej nga Wilson dhe Furber, me një qellim projektimi kryesor për te arritur trajtimin e hyrjes dhe daljes se te dhënave me sa më pak vonese si MOS Technology 6502 që u përdor në projektimet ekzistuese kompjuterike te Acorn. Arkitektura e hyrjes në memorie e 6502 kishte lejuar krijuesit të prodhojnë makineri të shpejta pa përdorimin e hardware-ve të kushtueshme për hyrje direkte në memorie. VLSI prodhoi silikonin e pare ARM me 26 prill 1985 – u njoh si ARM1 ne prill 1985.[4] Sistemet e para te "vërteta" të prodhimit të quajtur ARM2 ishin te disponueshëm vitin pasardhës.

Aplikacioni i tij i parë praktik ishte si një procesor i dytë për BBC Micro-n, ku u përdor për të krijuar software-t e simulimit për të përfunduar punën mbi çipet mbështetëse (VIDC, IOC, MEMC) dhe të shpejtonte operimin e software-it CAD të përdorur ne krijimin e ARM2. Më pas Wilson kodoi BBC Basic në gjuhën assembly, dhe njohuritë e thella të përfituara nga projektimi i kompletit të instruksioneve lejoi kodin të bëhej shumë i dendur, duke bërë ARM BBC Basic një testim ekstremisht të mirë për çfarëdo emulatori ARM. Qëllimi origjinal i një kompjuteri të bazuar kryesisht në ARM u arrit në 1987 me daljen e Acorn Archimedes.

Kaq e madhe ishte fshehtësia rreth projektit ARM CPU sa që kur Olivetti po diskutonin për të kontrolluar një pjesë te Acorn-it në 1985, atyre nuk i treguan për skuadrën e krijimit derisa bisedimet u kryen. Ne 1992 Acorn fitoi përsëri çmimin Queen's Award for Technology për ARM.

ARM2 paraqiti një transportues te dhënash me 32-bit, një hapësire adresash me 26-bit dhe 16 regjistra me 32-bit. Kodi i programit duhet të ishte brenda 64 Mb memorie, sepse program counter-i ishte i limituar deri në 26-bit sepse 4 bit-at e pare dhe 2 te fundit të regjistrit 32-bit shërbejnë si flamuj për status. ARM2 ishte mikroprocesori më i thjeshtë i dobishëm 32-bit në të gjithë botën, me vetëm 30,000 tranzistore (krahaso numrin e transistoreve me modelin 6 vjet më të vjetër të Motorola-s, Motorola 68000 me rreth 70,000 transistorë). Shumë prej kësaj thjeshtësie vjen ngaqë nuk ka mikrokod (që përfshin rreth një-te-katërtën deri në një-të-tretën e 68000) dhe, si shumica e CPU-ve të sotshëm, nuk përmban cache. Kjo thjeshtësi coi ne harxhimin e vogël të energjisë, duke performuar më mirë se Intel 80286.[5] Një pasardhës, ARM3, u prodhua me cache 40 Kb, që e përmirësoi edhe më tepër performancën.

Apple, DEC, Intel: ARM6, StrongARM, XScale

[Redakto | Redakto nëpërmjet kodit]

Rreth fundit te viteve 80, Apple Computer dhe VLSI Technology filluan te punonin me Acorn ne versione me te reja te ARM. Puna ishte aq e rëndësishme saqe Acorn krijoi një kompani te re me skuadrën e krijimit ne 1990, dhe e quajti Advanced RISC Machines Ltd. Për këtë arsye, fjala ARM nganjëherë zgjerohet si Advanced RISC Machine ne vend te Acorn RISC Machine. Advanced RISC Machine u be ARM Ltd kur kompania prind, ARM Holdings plc, u hodh ne London Stock Exchange dhe NASDAQ ne 1998.[6]

Puna e re Apple-ARM përfundimisht do kthehej në ARM6, fillimisht i dalë në treg në fillim të 1992. Apple përdorte ARM 610 të bazuar në ARM6, si bazë për PDA-ne Apple Newton. Në 1994, Acorn përdori ARM 610 si CPU kryesore në kompjuterët e tyre Risc PC. DEC licencoi arkitekturën ARM6 (gjë që shkaktoi konfusion sepse ato gjithashtu prodhonin mikroprocesorë Alpha)[nevojitet citimi] dhe prodhoi StrongARM. Ne 233 MHz kjo CPU harxhonte vetëm 1 Watt energji (versionet e mëvonshme harxhonin shumë më pak).

Rritje e Licencës

[Redakto | Redakto nëpërmjet kodit]

Bërthama e ARM-së ka qëndruar pothuajse e njëjta në madhësi gjatë këtyre ndryshimeve. ARM2 kishte 30.000 transistorë, ndërsa ARM6 shkoi vetëm deri në 35.000. Biznesi i ARM-së gjithmonë ka qenë te shesë IP cores, që të licencuarit i përdorin për te krijuar mikrokontrolluesit dhe CPU-të e bazuara në këtë bërthamë. Implementimi më i suksesshëm është ARM7TDMI me qindra miliona shitje. Idea është qe Original Design Manufacturer të kombinojë bërthamën ARM me një numër pjesësh jo të detyrueshme për të prodhuar një CPU të plotë, një që të mund të ndërtohet në semiconductor fabs të vjetra dhe prapë të ketë performancë të konsiderueshme me çmim të ulët. Atmel ka qenë një qendër projektimi pararendëse në Sistemin e Ngulitur të bazuar në ARM7TDMI.

ARM licencoi rreth 1,6 bilion bërthama në 2005. Në 2005, rreth 1 bilion bërthama ARM u futen në celulare.[7] Stampa:Ne, më shumë se 10 bilion bërthama ARM janë ndërtuar, dhe iSuppli parashikon që 5 bilion në vit do të transportohen në 2011.[8]

Arkitektura e smartphones, personal digital assistants dhe aparaturave të tjera që mbahen në dorë është ARMv5. Procesorët XScale dhe ARM926 janë ARMv5TE, dhe tashmë janë më të shumtë në aparatura high-end se sa StrongARM, ARM9TDMI dhe ARM7TDMI te bazuar ne procesorë ARMv4, por aparaturat lower-end mund te përdorin bërthama më të vjetra me çmime më të ulëta licencimi. Procesorët ARMv6 paraqitën një hap më lartë në performancë se sa nga bërthamat standarde ARMv5, dhe janë përdorur në disa raste, por procesorët Cortex (ARMv7) tashmë sigurojnë opsione më të shpejta se te gjithë brezat e mëparshëm. Cortex-A ka objektiv procesorët e aplikacioneve, siç i nevojiten smartphone-ve që më përpara përdornin ARM9 ose ARM11. Cortex-R ka objektiv aplikacionet në kohë reale, dhe Cortex-M ka objektiv mikrokontrolluesit.

Ne 2009, disa prodhues prezantuan netbook-et bazuar në CPU me arkitekture ARM, në konkurencë direkte me netbook-et e bazuar në Intel Atom.[9]

ARM siguron një përmbledhje te shitësve të shumtë të cilët implementojnë bërthamat ARM në projektimet e tyre (shiko 2003 Line Card). KEIL gjithashtu siguron një përmbledhje pak më të re për shitësit e procesorëve te bazuar ne ARM.

Familja Versioni i Arkitekturës Bërthama Tipar Cache (I/D)/MMU MIPS @ MHz tipike Ne aplikacion
ARM1 ARMv1 (jashtë përdorimi) ARM1 Asnjë ARM Evaluation System procesor i dyte për BBC Micro
ARM2 ARMv2 (jashtë përdorimi) ARM2 Arkitektura 2 shtoi instruksionin MUL (shumëzim) Asnje 4 MIPS @ 8 MHz
0.33 DMIPS/MHz
Acorn Archimedes, Chessmachine
ARMv2a (jashte perdorimi) ARM250 MEMC e integruar (MMU), Procesor grafik dhe IO. Arkitektura 2a shtoi instruksionet SWP dhe SWPB. Asnje, MEMC1a 7 MIPS @ 12 MHz Acorn Archimedes
ARM3 ARMv2a (jashtë përdorimi) ARM2a Përdorimi i pare i një cache procesori ne ARM. 4K i unifikuar 12 MIPS @ 25 MHz
0.50 DMIPS/MHz
Acorn Archimedes
ARM6 ARMv3 (jashtë përdorimi) ARM60 arkitektura v3 e para që mbështeti adresimin e 32-bit memorie (ndryshe nga 26 bit) Asnjë 10 MIPS @ 12 MHz 3DO Interactive Multiplayer, Marres GPS Zarlink
ARM600 Si ARM60, cache dhe coprocessor bus (për njësite FPA10 floating-point). 4K i unifikuar 28 MIPS @ 33 MHz
ARM610 Si ARM60, cache, pa coprocessor bus. 4K i unifikuar 17 MIPS @ 20 MHz
0.65 DMIPS/MHz
Acorn Risc PC 600, Apple Newton 100 series
ARM7 ARMv3 (jashtë përdorimi) ARM700 8 KB i unifikuar 40 MHz Acorn Risc PC karte CPU-je prototip
ARM710 Si ARM700 8 KB i unifikuar 40 MHz Acorn Risc PC 700
ARM710a Si ARM700 8 KB i unifikuar 40 MHz
0.68 DMIPS/MHz
Acorn Risc PC 700, Apple eMate 300
ARM7100 Si ARM710a, SoC i integruar. 8 KB i unifikuar 18 MHz Psion Series 5
ARM7500 Si ARM710a, SoC i integruar. 4 KB i unifikuar 40 MHz Acorn A7000
ARM7500FE Si ARM7500, "FE" Shtoi kontrolluesin e memories FPA and EDO. 4 KB i unifikuar. 56 MHz
0.73 DMIPS/MHz
Acorn A7000+ Network Computer
ARM7TDMI ARMv4T ARM7TDMI(-S) 3-stage pipeline, Thumb asnje 15 MIPS @ 16.8 MHz
63 DMIPS @ 70 MHz
Game Boy Advance, Nintendo DS, Apple iPod, Lego NXT, Atmel AT91SAM7, Juice Box, NXP Semiconductors LPC2000 dhe LH754xx, Actel's CoreMP7 Arkivuar 18 korrik 2011 tek Wayback Machine
ARM710T Si ARM7TDMI, cache 8 KB i unifikuar, MMU 36 MIPS @ 40 MHz Psion Series 5mx, Psion Revo/Revo Plus/Diamond Mako
ARM720T Si ARM7TDMI, cache 8 KB i unifikuar, MMU me Fast Context Switch Extension 60 MIPS @ 59.8 MHz Zipit Wireless Messenger, NXP Semiconductors LH7952x
ARM740T Si ARM7TDMI, cache MPU
ARMv5TEJ ARM7EJ-S 5-stage pipeline, Thumb, Jazelle DBX, intruksione te avancuara DSP asnje
StrongARM ARMv4 SA-110 16 KB/16 KB, MMU 203 MHz
1.0 DMIPS/MHz
Apple Newton 2x00 series, Acorn Risc PC, Rebel/Corel Netwinder, Chalice CATS
SA-1100 Si SA-110, SoC i integruar 16 KB/8 KB, MMU 203 MHz Psion netBook
SA-1110 Si SA-110, SoC i integruar 16 KB/8 KB, MMU 206 MHz LART (computer), Intel Assabet, Ipaq H36x0, Balloon2, Zaurus SL-5x00, HP Jornada 7xx, Jornada 560 series, Palm Zire 31
ARM8 ARMv4 ARM810[10] 5-stage pipeline, static branch prediction, double-bandwidth memory 8 KB i unifikuar, MMU 84 MIPS @ 72 MHz
1.16 DMIPS/MHz
Acorn Risc PC karte CPU prototip
ARM9TDMI ARMv4T ARM9TDMI 5-stage pipeline, Thumb asnje
ARM920T Si ARM9TDMI, cache 16 KB/16 KB, MMU me FCSE (Fast Context Switch Extension)[11] 200 MIPS @ 180 MHz Armadillo, Atmel AT91SAM9, GP32, GP2X (first core), Tapwave Zodiac (Motorola i. MX1), Hewlet Packard HP-49/50 Calculators, Sun SPOT, Cirrus Logic EP9302, EP9307, EP9312, EP9315, Samsung S3C2442 (HTC TyTN, FIC Neo FreeRunner[12]), Samsung S3C2410 (TomTom navigation devices)[13]
ARM922T Si ARM9TDMI, cache 8 KB/8 KB, MMU NXP Semiconductors LH7A40x
ARM940T Si ARM9TDMI, cache 4 KB/4 KB, MPU GP2X (berthama e dyte), Meizu M6 Mini Player[14][15]
ARM9E ARMv5TE ARM946E-S Thumb, Enhanced DSP instructions, caches ndryshore, memorje te ciftuara ngusht, MPU Nintendo DS, Nokia N-Gage, Canon PowerShot A470, Canon EOS 5D Mark II[16], Conexant 802.11 chips, Samsung S5L2010
ARM966E-S Thumb, Enhanced DSP instructions no cache, TCMs ST Micro STR91xF, includes Ethernet[17]
ARM968E-S Si ARM966E-S pa cache, TCMs NXP Semiconductors LPC2900
ARMv5TEJ ARM926EJ-S Thumb, Jazelle DBX, Enhanced DSP instructions ndryshore, TCMs, MMU 220 MIPS @ 200 MHz, Celularet: Sony Ericsson (K, W series); Siemens dhe Benq (serite x65 dhe me te reja); LG Arena; Texas Instruments OMAP1710, OMAP1610, OMAP1611, OMAP1612, OMAP-L137, OMAP-L138; Qualcomm MSM6100, MSM6125, MSM6225, MSM6245, MSM6250, MSM6255A, MSM6260, MSM6275, MSM6280, MSM6300, MSM6500, MSM6800; Freescale i.MX21, i.MX27, Atmel AT91SAM9, NXP Semiconductors LPC3000, GPH Wiz, NEC C10046F5-211-PN2-A SoC – berthame e padokumentuar ne ATi Hollywood çipin e grafikes te perdorur ne Wii,[18] Samsung S3C2412 perdorur ne kontrolluesin e Squeezebox Duet. Squeezebox Radio; NeoMagic MiMagic Family MM6, MM6+, MM8, MTV; Buffalo TeraStation Live (NAS); Telechips TCC7801, TCC7901;ZiiLABS' ZMS-05 sistem ne nje çip; Western Digital MyBook I World Edition.
ARMv5TE ARM996HS Procesor pa ore, si ARM966E-S pa caches, TCMs, MPU
ARM10E ARMv5TE ARM1020E 6-stage pipeline, Thumb, Enhanced DSP instructions, (VFP) 32 KB/32 KB, MMU
ARM1022E Si ARM1020E 16 KB/16 KB, MMU
ARMv5TEJ ARM1026EJ-S Thumb, Jazelle DBX, intruksione te avancuara DSP, (VFP) ndryshore, MMU ose MPU Western Digital MyBook II World Edition;Conexant so4610 dhe so4615 ADSL SoC
XScale ARMv5TE 80200/IOP310/IOP315 I/O Processor, Thumb, intruksione te avancuara DSP
80219 400/600 MHz Thecus N2100
IOP321 600 BogoMips @ 600 MHz Iyonix
IOP33x
IOP34x 1–2 core, RAID Acceleration 32K/32K L1, 512K L2, MMU
PXA210/PXA250 Procesor aplikacionesh, 7-stage pipeline PXA210: 133 and 200 MHz, PXA250: 200, 300, and 400 MHz Zaurus SL-5600, iPAQ H3900, Sony CLIÉ NX60, NX70V, NZ90
PXA255 32KB/32KB, MMU 400 BogoMips @ 400 MHz; 371–533 MIPS @ 400 MHz[19] Gumstix basix & connex, Palm Tungsten E2, Zaurus SL-C860, Mentor Ranger & Stryder, iRex ILiad
PXA263 200, 300 and 400 MHz Sony CLIÉ NX73V, NX80V
PXA26x default 400 MHz, up to 624 MHz Palm Tungsten T3
PXA27x Procesor aplikacionesh 32 KB/32 KB, MMU 800 MIPS @ 624 MHz Gumstix verdex,"Trizeps-Modules" Arkivuar 28 korrik 2011 tek Wayback Machine PXA270 COM, HTC Universal, HP hx4700, Zaurus SL-C1000, 3000, 3100, 3200, Dell Axim serite x30, x50, dhe x51, Motorola Q, Balloon3, Trolltech Greenphone, Palm TX, Motorola Ezx Platform A728, A780, A910, A1200, E680, E680i, E680g, E690, E895, Rokr E2, Rokr E6, Fujitsu Siemens LOOX N560, Toshiba Portégé G500, Trēo 650-755p, Zipit Z2, HP iPaq 614c Business Navigator.
PXA800(E)F
PXA3XX (emri i koduar "Monahans") 32KB/32KB L1, TCM, MMU 1000 MIPS @ 1.25 GHz Samsung Omnia
PXA900 Blackberry 8700, Blackberry Pearl (8100)
IXC1100 Control Plane Processor
IXP2400/IXP2800
IXP2850
IXP2325/IXP2350
IXP42x NSLU2 IXP460/IXP465
ARM11 ARMv6 ARM1136J(F)-S[20] 8-stage pipeline, SIMD, Thumb, Jazelle DBX, (VFP), instruksione te avancuara DSP ndryshore, MMU 740 @ 532–665 MHz (i.MX31 SoC), 400–528 MHz Texas Instruments OMAP2420 (Nokia E90, Nokia N93, Nokia N95, Nokia N82), Zune, BUGbase[1], Nokia N800, Nokia N810, Qualcomm MSM7200 (with integrated ARM926EJ-S Coprocessor@274 MHz, perdorur ne Eten Glofiish, HTC TyTN II, HTC Nike), Freescale i.MX31 (used in the original Zune 30gb and Toshiba Gigabeat S), Freescale MXC300-30 (Nokia E63, Nokia E71, Nokia 5800, Nokia E51, Nokia 6700 Classic, Nokia 6120 Classic, Nokia 6210 Navigator, Nokia 6220 Classic, Nokia 6290, Nokia 6710 Navigator, Nokia 6720 Classic, Nokia E75, Nokia N97, Nokia N81), Qualcomm MSM7201A sic u pa tek HTC Dream, HTC Magic, Motorola Z6, HTC Hero, & Samsung SGH-i627 (Propel Pro), Qualcomm MSM7227 used in ZTE Link,[21][22]
ARMv6T2 ARM1156T2(F)-S 9-stage pipeline, SIMD, Thumb-2, (VFP), instruksione te avancuara DSP ndryshore, MPU
ARMv6KZ ARM1176JZ(F)-S Si ARM1136EJ(F)-S ndryshore, MMU+TrustZone Apple iPhone (original and 3G), Apple iPod touch (1st and 2nd Generation), Conexant CX2427X, Motorola RIZR Z8, Motorola RIZR Z10, NVIDIA GoForce 6100[23]; Telechips TCC9101, TCC9201, TCC8900, Fujitsu MB86H60, Samsung S3C6410 (e.g. Samsung Moment, SmartQ 5), S3C6430[24]
ARMv6K ARM11 MPCore As ARM1136EJ(F)-S, 1–4 core SMP variable, MMU Nvidia APX 2500
Family Architecture Version Core Feature Cache (I/D)/MMU Typical MIPS @ MHz In application
Cortex ARMv7-A Cortex-A5 VFP, NEON, Jazelle RCT and DBX, Thumb-2, 8-stage pipeline, 1–4 core SMP variable (L1), MMU+TrustZone up to 1500 (1.5 DMIPS/MHz) "Sparrow" (ARM code name)[25][26][27]
Cortex-A8 VFP, NEON, Jazelle RCT, Thumb-2, 13-stage superscalar pipeline variable (L1+L2), MMU+TrustZone up to 2000 (2.0 DMIPS/MHz in speed from 600 MHz to greater than 1 GHz) Texas Instruments OMAP3xxx series, SBM7000, Oregon State University OSWALD, Gumstix Overo Earth, Pandora, Apple iPhone 3GS, Apple iPod touch (3rd Generation), Apple iPad (Apple A4 processor), Apple iPhone 4 (Apple A4 processor), Archos 5, FreeScale i.MX51-SOC, BeagleBoard, Motorola Droid, Palm Pre, Rockchip RK2806 and RK2808, Samsung i8910, Sony Ericsson Satio, Touch Book, Nokia N900, Meizu M9, ZiiLABS ZMS-08 system on a chip.
Cortex-A9 Application profile, (VFP), (NEON), Jazelle RCT and DBX, Thumb-2, Out-of-order speculative issue superscalar MMU+TrustZone 2.5 DMIPS/MHz
Cortex-A9 MPCore As Cortex-A9, 1–4 core SMP MMU+TrustZone 10,000 DMIPS @ 2 GHz on Performance Optimized TSMC 40G (dual core) (2.5 DMIPS/MHz per core) Texas Instruments OMAP4430/4440, ST-Ericsson U8500, Nvidia Tegra2
ARMv7-R Cortex-R4(F) Embedded profile, Thumb-2, (FPU) variable cache, MPU optional 600 DMIPS @ 475 MHz Broadcom is a user, TMS570 from Texas Instruments
ARMv7-ME Cortex-M4 (codenamed "Merlin")[28] Microcontroller profile, both Thumb and Thumb-2, FPU. Hardware MAC, SIMD and divide instructions. MPU optional. 1.25 DMIPS/MHz
ARMv7-M Cortex-M3 Microcontroller profile, Thumb-2 only. Hardware divide instruction. no cache, MPU optional. 125 DMIPS @ 100 MHz Texas Instruments Stellaris microcontroller family, ST Microelectronics STM32, NXP Semiconductors LPC1700, Toshiba TMPM330FDFG Arkivuar 14 qershor 2011 tek Wayback Machine, Ember's EM3xx Series, Atmel AT91SAM3, Europe Technologies EasyBCU, Energy Micro's EFM32, Actel's SmartFusion Arkivuar 18 qershor 2013 tek Wayback Machine
ARMv6-M Cortex-M0 (codenamed "Swift")[29] Microcontroller profile, Thumb-2 subset (16-bit Thumb instructions & BL, MRS, MSR, ISB, DSB, and DMB). No cache. 0.9 DMIPS/MHz NXP Semiconductors NXP LPC1100[30], Triad Semiconductor [31], Melfas[32], Chungbuk Technopark [33], Nuvoton [34], austriamicrosystems [35], Rhom [36]
Cortex-M1 FPGA targeted, Microcontroller profile, Thumb-2 subset (16-bit Thumb instructions & BL, MRS, MSR, ISB, DSB, and DMB). None, tightly coupled memory optional. Up to 136 DMIPS @ 170 MHz[37] (0.8 DMIPS/MHz,[38] MHz achievable FPGA-dependent) Actel ProASIC3, ProASIC3L, IGLOO and Fusion PSC devices Arkivuar 7 korrik 2011 tek Wayback Machine, Altera Cyclone III, other FPGA products are also supported e.g. Synplicity

[39]

Family Architecture Version Core Feature Cache (I/D)/MMU Typical MIPS @ MHz In application

Për një kohë të gjate ka qenë një "Manual referimi për arkitekturën ARM", duke dalluar ndërfaqet që të gjithë procesorët ARM duhet të mbajnë (si psh semantikat e udhëzimit) nga detajet e implementimit që mund të ndryshojnë. Arkitektura ka evoluar me kalimin e kohës, dhe duke filluar me arkitekturën v7, janë përcaktuar tre "profile": "A"-ja (aplikacion), "R"-ja (ne kohe reale), dhe "M"-ja (mikrokontrollues).

Profilet lejohen të ndajnë arkitekturën. Për shembull profili ARMv7-M është i dalluar sepse mban vetëm modën Thumb processor dhe prandaj ekzekuton instruksione Thumb2, dhe profili ARMv6-M është një nënndarje e profilit ARMv7-M (duke mbajtur më pak instruksione).

Kompleti i instruksioneve

[Redakto | Redakto nëpërmjet kodit]

Për t'a mbajtur projektimin të pastër, te thjeshtë dhe të shpejtë, implementimi origjinal i ARM-së u vendos pa mikrokod, si procesori shumë më i thjeshtë 8-bit 6502 i përdorur në mikrokompjuterat e mëparshëm Acorn.

Arkitektura ARM ka këto tipare RISC:

  • Ngarkon/ruan arkitekturën.
  • Nuk mbështet akses te padrejtuar në memorie (që tani mbështetet në bërthamat ARMv6, me disa përjashtime të lidhur me ngarkimin/ruajtjen e instruksioneve me shumë fjale).
  • File regjistri uniformë 16 × 32-bit.
  • Është rregulluar gjerësia 32 bit e instruksionit për të lehtësuar deshifrimin dhe pipelining, duke ulur dendësinë e kodit. Më vonë, "Thumb mode" rriti dendësinë e kodit.
  • Më së shumti ekzekutim një-ciklik.

Për të kompensuar për projektimin e thjeshtë, krahasuar me procesorët bashkëkohor si Intel 80286 dhe Motorola 68020, disa tipare të tjera projektimi u përdoren:

  • Ekzekutim i kushtezuar i shumicës se instruksioneve, duke kompensuar për mungesën e një parashikues degëzimi.
  • Instruksionet aritmetike ndryshojnë kodet e kushtëzimit vetëm kur dëshirohen.
  • Barrel shifter 32-bit që mund të përdoret pa ç'avantazh në performancë me shumicën e instruksioneve aritmetike dhe llogaritjeve të adresave.
  • Mënyra adresimi të fuqishme me indekse.
  • Një rregjister lidhjesh për thirrje të shpejtë të funksioneve.
  • Nënsistem ndërprerjeje i thjeshtë por i shpejtë i nivelit të dytë të përparësisë me banka regjistri të ndryshuara.

Ekzekutimi i kushtezuar

[Redakto | Redakto nëpërmjet kodit]

Tipari i ekzekutimit të kushtëzuar (i quajtur predication) është implementuar me një selektorë kodi kushtëzimi 4-bit (i quajtur predicate) për çdo instruksion; një nga kodet 4-bit rezervohet si "kod daljeje" për të specifikuar disa instruksione të pakushtëzuara, por pothuajse të gjithë instruksionet e zakonshme janë të kushtëzuara. Shumica e arkitekturave të CPU-ve kanë vetëm kode te kushtëzuara në instruksionet e degëzuara.

Kjo pakëson në mënyrë të konsiderueshme bit-et e kodimit te disponueshme për zhvendosje në instruksionet e aksesit në memorie, por nga ana tjetër shmang instruksionet e degëzuara gjatë gjenerimit të kodit për statement-et e vegjël "if". Shembulli standard për këtë është algoritmi Euklidian i bazuar në zbritje:

Ne gjuhen e programimit C, cikli është:

    while (i != j)
    {
       if (i > j)
           i -= j;
       else
           j -= i;
    }

Ne assembly-n e ARM-se, cikli është:

 loop   CMP    Ri, Rj       ; vendos kushtin "NE" nëse (i != j),
                            ;               "GT" nëse (i > j),
                            ;            ose "LT" nëse (i < j)
        SUBGT  Ri, Ri, Rj   ; nëse "GT" (me e madhe se), i = i-j;
        SUBLT  Rj, Rj, Ri   ; nëse "LT" (me e vogle se), j = j-i;
        BNE    loop         ; nëse "NE" (jo e barabarte), atëherë cikli

i cili shmang degëzimet rreth pjesëzave then dhe else. Vini re se nëse Ri dhe Rj janë te barabarta atëherë asnjë prej instruksioneve SUB nuk do ekzekutohet, duke optimizuar nevojën për një degëzim të kushtëzuar për të implementuar kontrollin me while në fillim të ciklit, për shembull nëse do ishte përdorur SUBLE (më e vogël ose e barabartë).

Një nga mënyrat që kodi Thumb përdor për të siguruar një kodim më të dendur është të heqë selektorin 4-bit nga instruksionet e padegëzuara.

Procesori ARM ka gjithashtu disa tipare që shihen shumë rrallë në arkitektura të tjera RISC, siç është adresimi PC-relativ (në të vërtete, tek ARM-ja PC është një nga 16 regjistrat e saj) dhe mënyrat e adresimit pre- dhe post-increment.

Një tjetër gjë për t'u vërejtur është se ARM ka ekzistuar për një farë kohe, me kompletin e instruksioneve duke u rritur me kalimin e kohës. Disa procesore më të hershëm ARM (para ARM7TDMI), për shembu ll, nuk kanë instruksion për të ruajtur një sasi 2-byte, pra, për to nuk është e mundur te krijojnë kod efikas qe sillet në mënyre të njëjtë me objektet e C të tipit "volatile int16_t".

Bashkëprocesorët

[Redakto | Redakto nëpërmjet kodit]

Arkitektura siguron një mënyre jo-intrusive për të zgjeruar kompletin e instruksioneve duke përdorur "bashkëprocesoret" që mund të adresohen duke përdorur MCR, MRC, MRRC, MCRR, dhe instruksione të tjera të ngjashme. Hapësira e bashkëprocesorit ndahet logjikisht ne 16 bashkëprocesorë me numra 0 deri ne 15, ku bashkëprocesori 15 (cp15) është i rezervuar pvr disa funksione kontrolli tipike si menaxhimi i cache-ve dhe operimin e MMU (te procesorët që e kanë një të tillë).

Në aparaturat e bazuara në ARM, pajisjet periferike janë zakonisht të lidhura me procesorin duke hartuar regjistrat e tyre fizike në hapësirën e memories ARM ose në hapësirën e bashkëprocesorit ose duke lidhur një tjetër pajisje e cila pastaj lidhet me procesorin. Hyrjet ne bashkëprocesor kanë vonesë më te vogël kështu që disa periferike (për shembull kontrolluesi i ndërprerjeve XScale) janë projektuar që të jenë të arritshëm në të dy mënyrat (përmes memories dhe përmes bashkëprocesorëve). Në raste të tjera, projektuesit e çipeve integrojnë hardware vetëm duke përdorur mekanizmin e bashkëprocesorit. Për shembull, një motor për përpunim imazhesh mund të jetë një bërthamë e vogël ARM7TDMI e kombinuar me një bashkëprocesor që ka veprime të specializuara për të mbajtur një komplet specifik primitivësh transkodimi HDTV.

Për të përmirësuar dendësinë e kodit të kompiluar, procesorët nga ARM7TDMI e më pas kanë paraqitur modën Thumb. ("T"-ja në "TDMI" tregon tiparin Thumb.) Në këtë modë, procesori ekzekuton instruksione 16-bit. Shumica e këtyre instruksioneve Thumb 16 bit hartohen direkt me instruksionet ARM. Kursimi i hapësirës vjen duke bërë të nënkuptueshme disa madhësi të instruksioneve dhe duke limituar numrin e mundësive krahasuar me instruksionet e plota në modën ARM.

Në Thumb, kodet më të vogla të operimit kanë më pak funksionalitet. Për shembull, vetëm degëzimet mund të jenë të kushtëzuara, dhe shumë kode operimi kanë akses të kufizuar vetëm në gjysmën e regjistrave të CPU-se. Kodet e shkurtra të operimit japin përmirësim të përgjithshëm të dendësisë së kodit, edhe pse disa veprime kërkojnë instruksione ekstra. Në situata ku gjerësia e portës së memories është më pak se 32-bit, kodet e shkurtra Thumb të operimit japin performancë në rritje në krahasim me kodin 32-bit të ARM, meqë më pak kod programi ka nevojë të ngarkohet në procesor përmes gjerësisë së vogël të memories.

Hardware-t e ngulitur, si Game Boy Advance, zakonisht kanë një sasi të vogël të RAM-it të arritshëm me një datapath të plotë 32-bit; shumica arrihet me një datapath dytësor 16-bit ose më të ngushtë. Në këtë situatë, zakonisht kodi Thumb kompilohet dhe optimizohen manualisht disa nga sektorët me më shumë punë intensive të CPU, duke përdorur instruksione ARM të plota 32-bit, duke vendosur këto instruksione më të gjera në memorie 32-bit të arritshme nga cdo bus.

Procesori i parë me një ckodues instruksionesh Thumb ishte ARM7TDMI. Të gjithë ARM9 dhe familjet e mëvonshme, duke përfshirë XScale, kanë përmbajtur një ckodues instruksionesh Thumb.

Instruksionet e përmirësimit të DSP

[Redakto | Redakto nëpërmjet kodit]

Për të përmirësuar arkitekturën ARM për perpunim sinjalesh digjitale dhe aplikacioneve të multimedias, disa instruksione të reja iu shtuan kompletit.[40] Këto tregohen me një "E" në emrat e arkitekturave ARMv5TE dhe ARMv5TEJ. Variantet E përfshijnë gjithashtu T, D, M, dhe I.

Jazelle është një teknikë që lejon Java Bytecode të ekzekutohet direkt në arkitekturën ARM si një gjendje (dhe komplet instruksionesh) e tretë ekzekutimi së bashku me ARM dhe Thumb-mode. Kjo gjendje tregohet me "J" në arkitekturën, dhe në emrat e bërthamave ARM9EJ-S dhe ARM7EJ-S. Mbështetja për këtë gjendje është e nevojshme duke filluar nga ARMv6 (përvec profilit ARMv7-M), edhe pse bërthamat më të reja përfshijnë vetëm një implementim të thjeshtë që nuk siguron përshpejtim hardware.

Teknologjia Thumb-2 u shfaq në berthamën ARM1156, e shpallur në 2003. Thumb-2 zgjeron kompletin e intruksioneve Thumb të limituar në 16-bit me më tepër intruksione 32-bit për t'i dhënë kompletit të instruksioneve një shkallë më të lartë. Një qëllim i caktuar për Thumb-2 është të arrijë dendësi kodi të ngjashme me atë të Thumb-it me performancë të ngjashme me atë te kompletit te instruksioneve të ARM-së në memorje 32-bit. Mund të themi se në ARMv7, ky qëllim u arrit.

Thumb-2 zgjeron kompletin e instruksioneve ARM dhe Thumb me edhe më shumë instruksione, duke përfshirë manipulimin e bit-field, degëzimeve të tabelave, dhe ekzekutimit të kushtëzuar. Një "Gjuhë Assembly e Unifikuar" (UAL) mbështet edhe brezin e instruksioneve të ARM, edhe të Thumb-2 nga i njëjti kod burim; versionet e Thumb të parë në procesorët ARMv7 janë aq të afta sa kodi ARM (duke përfshirë aftësinë për të shkruar manovruesa ndërpresish). Kjo kërkon pak kujdes, dhe përdorim të një instruksioni të ri "IT" (if-then), që lejon deri në 4 instruksione të njëpasnjëshme të ekzekutohen bazuar në një kusht të testuar. Gjatë kompilimit në kod ARM, kjo dhe injorohet, por gjatë kompilimit në Thumb-2 kjo krijon një intruksion. Per shembull:

; nqs (r0 == r1)
CMP r0, r1
ITE EQ        ; ARM: nuk është kod ... Thumb: instruksion IT
; atehere r0 = r2;
MOVEQ r0, r2  ; ARM: e kushtezuar; Thumb: kusht nepermjet ITE 'T' (atehere)
; perndryshe r0 = r3;
MOVNE r0, r3  ; ARM: e kushtezuar; Thumb: kusht nepermjet ITE 'e' (perndryshe)
; kujtoni se instruksioni MOV ne Thumb nuk ka asnje bit per te koduar "EQ" ose "NE"

Te gjithë çipet ARMv7 mbështesin kompletin e instruksioneve Thumb-2. Disa çipe, si Cortex-M3, mbështesin vetëm kompletin e instruksioneve Thumb-2. Çipe të tjerë në seritë Cortex dhe ARM11 mbështesin edhe "modën me komplet instruksionesh ARM" dhe "modën me komplet instruksionesh Thumb-2".[41][42][43]

Mjedisi i ekzekutimit te Thumb-it (ThumbEE)

[Redakto | Redakto nëpërmjet kodit]

ThumbEE, i njohur gjithashtu si Thumb-2EE, dhe i tregtuar si Jazelle RCT (Runtime Compilation Target), u shpall në 2005, dhe u shfaq për herë të parë në procesorin Cortex-A8. ThumbEE është një modë e katërt procesori, duke bërë ndryshime të vogla në kompletin e instruksioneve Thumb të zgjeruar nga Thumb-2. Këto ndryshime e bëjnë kompletin e instruksioneve vecanërisht të përshtatshëm për kod të krijuar gjatë ekzekutimit të programit (p.sh. nga kompilimi JIT) në Mjediset e menaxhuara të ekzekutimit. ThumbEE është një objektiv për gjuhet si Limbo, Java, C#, Perl dhe Python, dhe lejon kompajlerat JIT të nxjerrë kod te kompiluar më të vogël pa ndikuar në performancë.

Tiparet e reja të ThumbEE përfshijnë kontrolle automatike të pointer-ave null në cdo instruksion ngarkimi dhe ruajtjeje, një instruksion për të kontrolluar kufijtë e array, akses në regjistrat r8-r15 (ku mbahet gjendja Jazelle/DBX Java VM), dhe instruksione speciale që thërrasin një manovrues(handler).[44] Manovruesit janë sektorë të vegjël kodi që thërritet shpesh, zakonisht i përdorur për të implementuar një tipar të një gjuhe programimi të nivelit të lartë, si psh rezervimi i memorjes për një objekt të ri.

Advanced SIMD (NEON)

[Redakto | Redakto nëpërmjet kodit]

Shtojca Advanced SIMD, e tregtuar si teknologjia NEON, është një komplet instruksionesh SIMD i kombinuar 64- dhe 128-bit, që siguron përshpejtim të standartizuar për aplikacionet e përpunimit të medias dhe të sinjaleve. NEON mund të ekzekutojë ckodim audio-je MP3 në CPU me 10 MHz dhe mund të ekzekutojë codec-un e të folurit GSM AMR me më pak se 13 MHz. Ka një komplet instruksionesh të hollesishëm, file regjistrash të ndara dhe hardware ekzekutimi të pavarura. NEON mban numra të plotë 8-, 16-, 32- dhe 64-bit dhe punon në operime SIMD për të manovruar përpunimin e audios dhe videos si dhe përpunimin e grafikës dhe te lojërave. Në NEON, SIMD mban deri në 16 punë në të njëjtën kohë.

Teknologjia VFP (Vector Floating Point) është një shtojcë bashkëprocesori në arkitekturën ARM. Siguron përpunim numrash me presje me një-precision dhe dopjo-precision me pak shpenzim. VFP siguron përpunim numrash me presje të përshtatshëm për një spektrum të gjerë aplikacionesh si PDA, smartphone, kompresim dhe dekompresim zëri, grafika tre-dimensionale dhe audio digjitale, printera, dhe aplikacione automotive. Arkitektura VFP gjithashtu mund të ekzekutojë instruksione të shkurtra vektore por këto punojnë në cdo element vektor njëri pas tjetrit dhe nuk ofrojnë performancën e vërtetë të paralelizmit SIMD. Kjo modë mund të jetë akoma e dobishme në aplikacione për procesim grafikash dhe sinjalesh meqë lejon një reduktim në madhësinë e kodit.

  1. ^ "ARM Cores Climb Into 3G Territory" Arkivuar 7 qershor 2011 tek Wayback Machine by Mark Hachman, 2002.
  2. ^ "The Two Percent Solution" Arkivuar 26 shtator 2007 tek Wayback Machine by Jim Turley 2002.
  3. ^ "ARMed for the living room".
  4. ^ "Some facts about the Acorn RISC Machine" Roger Wilson posting to comp.arch, Nov 2 1988, Accessed 25 May 2007.
  5. ^ Patterson, Jason. The Acorn Archimedes", The History Of Computers During My Lifetime – The 1980's by (accessed 12 March 2008)].
  6. ^ "ARM Corporate Backgrounder", ARM Technology.
  7. ^ "ARMed for the living room" by Tom Krazit 2006.
  8. ^ "ARM Achieves 10 Billion Processor Milestone", ARM Technology, 22 January 2008.
  9. ^ ""ARM netbook ships with detachable tablet"" (në anglisht). Arkivuar nga origjinali më 3 janar 2013. Marrë më 25 qershor 2010. by Eric Brown 2009
  10. ^ "ARM810 – Dancing to the Beat of a Different Drum" ARM Holdings presentation at Hot Chips 1996-08-07.
  11. ^ Register 13, FCSE PID register ARM920T Technical Reference Manual
  12. ^ "Neo1973: GTA01Bv4 versus GTA02 comparison" (në anglisht). Arkivuar nga origjinali më 18 mars 2012. Marrë më 2007-11-15.
  13. ^ "S3C2410" (në anglisht). Marrë më 2010-01-13.
  14. ^ "Rockbox Samsung SA58xxx series" (në anglisht). Arkivuar nga origjinali më 20 korrik 2008. Marrë më 2008-02-22.
  15. ^ "Rockbox Meizu M6 Port – Hardware Information" (në anglisht). Arkivuar nga origjinali më 12 maj 2008. Marrë më 2008-02-22.
  16. ^ Datasheets - Magic Lantern Firmware Wiki
  17. ^ "STR9 – STR912 – STR912FW44 microcontroller – documents and files download page". Mcu.st.com. Marrë më 2009-04-18. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  18. ^ Starlet.
  19. ^ "Benchmarks – Albatross" (në anglisht). Albatross-uav.org. 2005-06-18. Arkivuar nga origjinali më 2 gusht 2009. Marrë më 2009-04-18.
  20. ^ "ARM1136J(F)-S – ARM Processor" (në anglisht). Arm.com. Marrë më 2009-04-18.
  21. ^ "Qualcomm chips kernel ARM - from phones to laptops". xi0.info. Marrë më 2010-05-08. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  22. ^ "Qualcomm MSM7227 RISC Chipset". pdadb.net. Marrë më 2010-05-08. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  23. ^ "GoForce 6100" (në anglisht). Nvidia.com. Marrë më 2009-04-18.
  24. ^ "Samsung S3C6410 and S3C6430 Series ARM Proccessors". Samsung. Marrë më 2009-10-08. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!), and the Qualcomm MSM7627 as seen in the Palm Pixi and Motorola Calgary/Devour
  25. ^ Merrit, Rick (2009-10-21). ""ARM stretches out with A5 core, graphics, FPGAs"". EE Times. Arkivuar nga origjinali më 13 mars 2012. Marrë më 2009-10-28. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  26. ^ Clarke, Peter (2009-02-03). "ARM tips plans for Swift and Sparrow processor cores". EE Times. Arkivuar nga origjinali më 13 mars 2012. Marrë më 2009-04-18. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  27. ^ Segan, Sascha (2009-04-09). "ARM's Multicore Chips Aim for Netbooks" (në anglisht). PC Magazine. Marrë më 2009-04-18.
  28. ^ Benz, Benjamin (2010-02-02). "Cortex Nachwuchs bei ARM". Heise.de. Marrë më 2010-05-03. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  29. ^ Clarke, Peter (2009-02-23). "ARM preps tiny core for low-power microcontrollers". EE Times. Arkivuar nga origjinali më 13 mars 2012. Marrë më 2009-11-30. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  30. ^ Walko, John (2009-03-23). "NXP first to demo ARM Cortex-M0 silicon". EE Times. Arkivuar nga origjinali më 15 qershor 2011. Marrë më 2009-06-29. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  31. ^ "ARM Powered VCAs". Arkivuar nga origjinali më 16 korrik 2011. Marrë më 25 qershor 2010. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  32. ^ Cortex-M0 used in low power touch controller - 6/10/2009 - Electronics Weekly
  33. ^ Chungbuk Technopark Chooses ARM Cortex-M0 Processor
  34. ^ "Kopje e arkivuar". Arkivuar nga origjinali më 22 janar 2020. Marrë më 28 dhjetor 2021. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)Mirëmbajtja CS1: Archived copy si titull (lidhja)
  35. ^ "Austriamicrosystems Chooses ARM Cortex-M0 Processor For Mixed Signal Applications". Arkivuar nga origjinali më 22 korrik 2011. Marrë më 25 qershor 2010. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  36. ^ Rohm Licenses ARM Cortex-M0 Processor - ARM
  37. ^ "ARM Extends Cortex Family with First Processor Optimized for FPGA", ARM press release, March 19, 2007. Retrieved April 11, 2007.
  38. ^ "ARM Cortex-M1", ARM product website. Retrieved April 11, 2007.
  39. ^ ARM Extends Cortex Family with First Processor Optimized for FPGA.
  40. ^ "ARM DSP Instruction Set Extensions" (në anglisht). Arm.com. Marrë më 2009-04-18.
  41. ^ "ARM Processor Instruction Set Architecture" (në anglisht). Arm.com. Marrë më 2009-04-18.
  42. ^ "ARM aims son of Thumb at uCs, ASSPs, SoCs" (në anglisht). Linuxdevices.com. Arkivuar nga origjinali më 9 dhjetor 2012. Marrë më 2009-04-18.
  43. ^ "ARM Information Center". Infocenter.arm.com. Marrë më 2009-04-18. {{cite web}}: Mungon ose është bosh parametri |language= (Ndihmë!)
  44. ^ "Arm strengthens Java compilers: New 16-Bit Thumb-2EE Instructions Conserve System Memory" by Tom R. Halfhill 2005.

Stampa:Linkfarm

Stampa:RISC-based processor architectures