summaryrefslogtreecommitdiff
path: root/en/hardware/supported/arm.xml
blob: b2de0bfecfef8c10e22f10e2081faf29e8318ecd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
<!-- retain these comments for translator revision tracking -->
<!-- $Id$ -->

  <sect2 arch="arm"><title>Three different ARM ports</title>

<para>
The ARM architecture has evolved over time and modern ARM processors
provide features which are not available in older models.  &debian;
therefore provides three ARM ports to give the best support for a very
wide range of different machines:
<itemizedlist>
  <listitem><para>
    &debian;/armel targets older 32-bit ARM processors without support
    for a hardware floating point unit (FPU),
  </para></listitem>
  <listitem><para>
    &debian;/armhf works only on newer 32-bit ARM processors which
    implement at least the ARMv7 architecture with version 3 of the
    ARM vector floating point specification (VFPv3). It makes use of
    the extended features and performance enhancements available on
    these models.
  </para></listitem>
  <listitem><para>
    &debian;/arm64 works on 64-bit ARM processors which implement at
    least the ARMv8 architecture.
  </para></listitem>
</itemizedlist>
</para>

<para>
Technically, all currently available ARM CPUs can be run in either
endian mode (big or little), but in practice the vast majority use
little-endian mode. All of &debian;/arm64, &debian;/armhf and
&debian;/armel support only little-endian systems.
</para>

  </sect2>

  <sect2 arch="arm"><title>Variations in ARM CPU designs and support complexity</title>

<para>
ARM systems are much more heterogeneous than those based on the
i386/amd64-based PC architecture, so the support situation can be much
more complicated.
</para>

<para arch="armel;armhf">
The ARM architecture is used mainly in so-called
<quote>system-on-chip</quote> (SoC) designs. These SoCs are designed
by many different companies with vastly varying hardware components
even for the very basic functionality required to bring the system
up. System firmware interfaces have been increasingly standardised
over time, but especially on older hardware firmware/boot interfaces
vary a great deal, so on these systems the Linux kernel has to take
care of many system-specific low-level issues which would be handled
by the mainboard's BIOS/UEFI in the PC world.
</para>

<para arch="armel;armhf">
At the beginning of the ARM support in the Linux kernel, the hardware
variety resulted in the requirement of having a separate kernel for
each ARM system in contrast to the <quote>one-fits-all</quote> kernel
for PC systems.  As this approach does not scale to a large number of
different systems, work was done to allow booting with a single ARM
kernel that can run on different ARM systems.  Support for newer ARM
systems is now implemented in a way that allows the use of such a
multiplatform kernel, but for several older systems a separate
specific kernel is still required. Because of this, the standard
&debian; distribution only supports installation on a selected number
of such older ARM systems, alongside the newer systems which are
supported by the ARM multiplatform kernels (called <quote>armmp</quote>) in
&debian;/armhf.
</para>

<para arch="arm64">
The ARM architecture is used mainly in so-called
<quote>system-on-chip</quote> (SoC) designs. These SoCs are designed
by many different companies, often with vastly varying hardware
components even for the very basic functionality required to bring the
system up. Older versions of the ARM architecture have seen massive
differences from one SoC to the next, but ARMv8 (arm64) is much more
standardised and so is easier for the Linux kernel and other software
to support.
</para>

<para arch="arm64">
Server versions of ARMv8 hardware are typically configured using the
Unified Extensible Firmware Interface (UEFI) and Advanced
Configuration and Power Interface (ACPI) standards. These two provide
common, device-independent ways to boot and configure computer
hardware. They are also common in the x86 PC world.
</para>

  </sect2>

<sect2 arch="arm64" id="arm64-supported-platforms"><title>Platforms supported by Debian/arm64</title>

  <para>
    Arm64/AArch64/ARMv8 hardware became available quite late in the
    &debian; &releasename-cap; release cycle so not many platforms had
    support merged in the mainline kernel version by the time of this
    release; this is the main requirement to have &d-i; working on
    them. The following platforms are known to be supported by
    &debian;/arm64 in this release. There is only one kernel image,
    which supports all the listed platforms.
  </para>

  <variablelist>
      <varlistentry>
        <term>Applied Micro (APM) Mustang/X-Gene</term>
        <listitem>
          <para>
	    The APM Mustang was the first Linux-capable ARMv8 system
	    available. It uses the X-gene SoC, which has since also
	    been used in other machines. It is an 8-core CPU, with
	    ethernet, USB and serial. A common form-factor looks just
	    like a desktop PC box, but many other versions are
	    expected in the future. Most of the hardware is supported
	    in the mainline kernel, but at this point USB support is
	    lacking in the &releasename-cap; kernel.
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>ARM Juno Development Platform</term>
        <listitem>
          <para>	    
	    Juno is a capable development board with a 6-core (2xA57,
	    4xA53) ARMv8-A 800Mhz CPU, Mali (T624) graphics, 8GB DDR3
	    RAM, Ethernet, USB, Serial. It was designed for system
	    bring-up and power testing so is neither small nor cheap,
	    but was one of the first boards available. All the
	    on-board hardware is supported in the mainline kernel and
	    in &releasename-cap;.
          </para>
        </listitem>
      </varlistentry>

  </variablelist>

  <para>
    When using &d-i; on non-UEFI systems, you may have to manually
    make the system bootable at the end of the installation, e.g. by
    running the required commands in a shell started from within
    &d-i;. flash-kernel knows how to set up an X-Gene system booting
    with U-Boot.
  </para>

  <sect3 arch="arm64" id="arm64-other-platforms"><title>Other platforms</title>
  <para>
    The multiplatform support in the arm64 Linux kernel may also allow
    running &d-i; on arm64 systems not explicitly listed above. So
    long as the kernel used by &d-i; has support for the target
    system's components, and a device-tree file for that target is
    available, a new target system may work just fine.  In these
    cases, the installer can usually provide a working installation,
    and so long as UEFI is in use, it should be able to make the
    system bootable as well. If UEFI is not used you may also need to
    perform some manual configuration steps to make the system
    bootable.
  </para>
  </sect3>
</sect2>


<sect2 arch="armhf" id="armhf-armmp-supported-platforms"><title>Platforms supported by Debian/armhf</title>

  <para>
  The following systems are known to work with &debian;/armhf using the
  multiplatform (armmp) kernel:

  <variablelist>

      <varlistentry>
        <term>Freescale MX53 Quick Start Board (MX53 LOCO Board)</term>
        <listitem>
          <para>   
            The IMX53QSB is a development board based on the i.MX53 SoC.
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>Versatile Express</term>
        <listitem>
          <para>   
            The Versatile Express is a development board series from ARM
            consisting of a baseboard which can be equipped with various CPU
            daughter boards.
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>Certain Allwinner sunXi-based development boards and embedded
        systems</term>
        <listitem>
          <para>   
            The armmp kernel supports several development boards and
            embedded systems based on the Allwinner A10 (architecture
            codename <quote>sun4i</quote>), A10s/A13 (architecture
            codename <quote>sun5i</quote>), A20 (architecture
            codename <quote>sun7i</quote>), A31/A31s (architecture
            codename <quote>sun6i</quote>) and A23/A33 (part of the
            <quote>sun8i</quote> family) SoCs.
            
            Full installer support (including provision of ready-made
            SD card images with the installer) is currently available
            for the following sunXi-based systems:

            <itemizedlist>
             <listitem><para>
               Cubietech Cubieboard 1 + 2 / Cubietruck
             </para></listitem>
             <listitem><para>
               LeMaker Banana Pi and Banana Pro
             </para></listitem>
             <listitem><para>
               LinkSprite pcDuino and pcDuino3
             </para></listitem>
             <listitem><para>
               Olimex A10-Olinuxino-LIME / A20-Olinuxino-LIME /
               A20-Olinuxino-LIME2 / A20-Olinuxino Micro / A20-SOM-EVB          
             </para></listitem>
             <listitem><para>
               Xunlong OrangePi Plus
             </para></listitem>
            </itemizedlist>  
          </para>
            
          <para>
            System support for Allwinner sunXi-based devices is
            limited to drivers and device-tree information available
            in the mainline Linux kernel. Vendor-specific kernel
            trees (such as the Allwinner SDK kernels) and the
            android-derived linux-sunxi.org kernel 3.4 series are not
            supported by &debian;.
          </para> 
          <para>
            The mainline Linux kernel generally supports serial
            console, ethernet, SATA, USB and MMC/SD-cards on
            Allwinner A10, A10s/A13, A20, A23/A33 and A31/A31s SoCs. 
            The level of support for local display (HDMI/VGA/LCD) and
            audio hardware varies between individual systems.  For
            most systems, the kernel doesn't have native graphics
            drivers but instead uses the <quote>simplefb</quote>
            infrastructure in which the bootloader initializes the
            display and the kernel just re-uses the pre-initialized
            framebuffer. This generally works reasonably well,
            although it results in certain limitations (the display
            resolution cannot be changed on the fly and display
            powermanagement is not possible).
          </para>
          <para>
            Onboard flash memory intended to be used as a mass
            storage device generally exists in two basic variants on
            sunXi-based systems: raw NAND flash and eMMC flash.  Most
            older sunXi-based boards with onboard flash storage use
            raw NAND flash for which support is not generally
            available in the mainline kernel and therefore also not
            in Debian.  A number of newer systems use eMMC flash
            instead of raw NAND flash.  An eMMC flash chip basically
            appears as a fast, non-removable SD card and is supported
            in the same way as a regular SD card.
          </para>
          
          <para>
            The installer includes basic support for a number of
            sunXi-based systems not listed above, but it is largely
            untested on those systems as the &debian; project doesn't
            have access to the corresponding hardware.  No pre-built
            SD card images with the installer are provided for those
            systems.  Development boards with such limited support
            include:
            <itemizedlist>
              <listitem><para>
                Olimex A10s-Olinuxino Micro / A13-Olinuxino / 
                A13-Olinuxino Micro
              </para></listitem>
              <listitem><para>
                Sinovoip BPI-M2 (A31s-based)
              </para></listitem>
              <listitem><para>
                Xunlong Orange Pi (A20-based) / Orange Pi Mini (A20-based)
              </para></listitem>
            </itemizedlist>
          </para>
          <para>
            In addition to the SoCs and systems listed above, the
            installer has very limited support for the Allwinner H3
            SoC and a number of boards based on it.  Mainline kernel
            support for the H3 is still largely work in progress at
            the time of the Debian 9 release freeze, so the installer
            only supports serial console, MMC/SD and the USB host
            controller on H3-based systems.  There is no driver for
            the on-board ethernet port of the H3 yet, so networking
            is only possible with a USB ethernet adaptor or a USB
            wifi dongle.  Systems based on the H3 for which such very
            basic installer support is available include:
            <itemizedlist>
              <listitem><para>
                FriendlyARM NanoPi NEO
              </para></listitem>
              <listitem><para>
                Xunlong Orange Pi Lite / Orange Pi One / Orange Pi PC /
                Orange Pi PC Plus / Orange Pi Plus / Orange Pi Plus 2E /
                Orange Pi 2
              </para></listitem>
            </itemizedlist>
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>NVIDIA Jetson TK1</term>
        <listitem>
          <para>
            The NVIDIA Jetson TK1 is a developer board based on the Tegra
            K1 chip (also known as Tegra 124).  The Tegra K1 features a
            quad-core 32-bit ARM Cortex-A15 CPU and Kepler GPU (GK20A)
            with 192 CUDA cores.  Other systems based on the Tegra 124
            may work, too.
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>Seagate Personal Cloud and Seagate NAS</term>
        <listitem>
          <para>
            The Seagate Personal Cloud and Seagate NAS are NAS devices
            based on Marvell's Armada 370 platform.  Debian supports the
            Personal Cloud (SRN21C), Personal Cloud 2-Bay (SRN22C),
            Seagate NAS 2-Bay (SRPD20) and Seagate NAS 4-Bay (SRPD40).
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>SolidRun Cubox-i2eX / Cubox-i4Pro</term>
        <listitem>
          <para>
            The Cubox-i series is a set of small, cubical-shaped systems
            based on the Freescale i.MX6 SoC family.  System support for
            the Cubox-i series is limited to drivers and device-tree
            information available in the mainline Linux kernel; the
            Freescale 3.0 kernel series for the Cubox-i is not supported by
            &debian;.  Available drivers in the mainline kernel include
            serial console, ethernet, USB, MMC/SD-card and display
            support over HDMI (console and X11). In addition to that,
            the eSATA port on the Cubox-i4Pro is supported.
          </para>
        </listitem>
      </varlistentry>

      <varlistentry>
        <term>Wandboard</term>
        <listitem>
          <para>
            The Wandboard Quad, Dual and Solo are development boards based on the Freescale
            i.MX6 Quad SoC.  System support is limited to drivers and
            device-tree information available in the mainline Linux kernel;
            the wandboard-specific 3.0 and 3.10 kernel series from
            wandboard.org are not supported by &debian;.  The mainline kernel
            includes driver support for serial console, display via HDMI
            (console and X11), ethernet, USB, MMC/SD, SATA (Quad only) and analog audio.  Support for
            the other audio options (S/PDIF, HDMI-Audio) and for
            the onboard WLAN/Bluetooth module is untested or not available in &debian;
            9.
          </para>
        </listitem>
      </varlistentry>

    </variablelist>
  </para>

  <para>
    
    Generally, the ARM multiplatform support in the Linux kernel
    allows running &d-i; on armhf systems not explicitly listed above,
    as long as the kernel used by &d-i; has support for the target
    system's components and a device-tree file for the target is
    available.  In these cases, the installer can usually provide a
    working installation, but it may not be able to automatically make
    the system bootable. Doing that in many cases requires
    device-specific information.
   
  </para>
  <para>
    When using &d-i; on such systems, you may have to manually make
    the system bootable at the end of the installation, e.g. by
    running the required commands in a shell started from within
    &d-i;.
  </para>

</sect2>

<sect2 arch="armhf" id="armhf-unsupported-platforms"><title>Platforms no longer supported by Debian/armhf</title>

<variablelist>
<varlistentry>
<term>EfikaMX</term>
<listitem><para>

The EfikaMX platform (Genesi Efika Smartbook and Genesi EfikaMX
nettop) was supported in &debian; 7 with a platform-specific kernel,
but is no longer supported from &debian; 8 onwards.  The code required
to build the formerly used platform-specific kernel has been removed
from the upstream Linux kernel source in 2012, so &debian; cannot
provide newer builds. Using the armmp multiplatform kernel on the
EfikaMX platform would require device-tree support for it, which is
currently not available.

</para></listitem>
</varlistentry>
</variablelist>

</sect2>


<sect2 arch="armel" id="armel-supported-platforms"><title>Platforms supported by Debian/armel</title>

<para>

The following platforms are supported by &debian;/armel; they require
platform-specific kernels.

<variablelist>

<varlistentry>
<term>Kirkwood</term>
<listitem><para>

Kirkwood is a system-on-chip (SoC) from Marvell that integrates an ARM
CPU, Ethernet, SATA, USB, and other functionality in one chip.
&debian; currently supports the following Kirkwood based devices:

    <itemizedlist>
     <listitem><para>
       <ulink url="&url-arm-cyrius-sheevaplug;">Plug computers (SheevaPlug,
       GuruPlug, DreamPlug and Seagate FreeAgent DockStar)</ulink>
     </para></listitem>
     <listitem><para>
     <ulink url="&url-arm-cyrius-qnap-kirkwood;">QNAP Turbo Station</ulink>
      (all TS-11x/TS-12x, HS-210, TS-21x/TS-22x and TS-41x/TS-42x models)
     </para></listitem>
     <listitem><para>
      LaCie NASes (Network Space v2, Network Space Max v2, Internet
      Space v2, d2 Network v2, 2Big Network v2 and 5Big Network v2)
     </para></listitem>
     <listitem><para>
       OpenRD (OpenRD-Base, OpenRD-Client and OpenRD-Ultimate)
     </para></listitem>
    </itemizedlist>

</para></listitem>
</varlistentry>

<varlistentry>
<term>Orion5x</term>
<listitem><para>

Orion is a system-on-chip (SoC) from Marvell that integrates an ARM
CPU, Ethernet, SATA, USB, and other functionality in one chip. There
are many Network Attached Storage (NAS) devices on the market that are
based on an Orion chip. &debian; currently supports the following
Orion based devices: <ulink url="&url-arm-cyrius-kuroboxpro;">Buffalo
Kurobox</ulink> and <ulink url="&url-arm-cyrius-mv2120;">HP
mv2120</ulink>.

</para></listitem>
</varlistentry>

<varlistentry>
<term>Versatile</term>
<listitem><para>

The Versatile platform is emulated by QEMU and is therefore a nice way
to test and run &debian; on ARM if you don't have real hardware.

</para></listitem>
</varlistentry>

</variablelist>

</para>
</sect2>

<sect2 arch="armel" id="armel-unsupported-platforms"><title>Platforms and devices no longer supported by Debian/armel</title>

<variablelist>
<varlistentry>
<term>IXP4xx</term>
<listitem><para>

Support for the Intel IXP4xx platform has been dropped in &debian; 9.
The Linksys NSLU2 device is based on IXP4xx and is therefore no longer
supported.

</para></listitem>
</varlistentry>

<varlistentry>
<term>Orion5x</term>
<listitem><para>

Support for the D-Link DNS-323 and Conceptronic CH3SNAS devices has been
dropped from the Orion5x platform in &debian; 9.  The Linux kernel no
longer fits into the flash on these devices.  Other Orion devices, such
as Buffalo Kurobox and HP mv2120, are still supported.

</para></listitem>
</varlistentry>

</variablelist>

</sect2>