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
519
|
<!-- 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 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>, <ulink url="&url-arm-cyrius-mv2120;">HP
mv2120</ulink> and <ulink url="&url-arm-cyrius-qnap;">QNAP TS-109,
TS-209, TS-409 and TS-409U and variants</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>
|