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
|
<!-- 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</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>) and A20 (architecture codename
<quote>sun7i</quote>) SoCs. Full installer support 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>
Mele A1000
</para></listitem>
<listitem><para>
Miniand Hackberry
</para></listitem>
<listitem><para>
Olimex A10-Olinuxino-LIME / A10s-Olinuxino Micro /
A13-Olinuxino / A13-Olinuxino Micro /
A20-Olinuxino-LIME / A20-Olinuxino-LIME2 / A20-Olinuxino Micro
</para></listitem>
<listitem><para>
PineRiver Mini X-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. The android-derived linux-sunxi.org 3.4 kernel
series is 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
and A20 SoCs, but it does not have native drivers for the
display (HDMI/VGA/LCD) and audio hardware in these SoCs. The
NAND flash memory that is built into some sunXi-based systems is
not supported.
</para>
<para>
Using a local display is technically possible without native
display drivers via the <quote>simplefb</quote> infrastructure
in the mainline kernel, which relies on the
<quote>U-Boot</quote> bootloader for initialising the display
hardware, but this is not supported by the U-Boot version in
&debian; 8.
</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 Quad</term>
<listitem>
<para>
The Wandboard Quad is a development board based on the Freescale
i.MX6 Quad SoC. System support for it 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 and SATA. Support for
the onboard audio options (analog, S/PDIF, HDMI-Audio) and for
the onboard WLAN/Bluetooth module is not available in &debian;
8.
</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>IXP4xx</term>
<listitem><para>
The Intel IXP4xx processor series is used in commonly used network
attached storage (NAS) devices like the Linksys NSLU2.
</para><para>
While there is kernel support for this platform in &debian; 8, it is
not supported by the &d-i;. It is possible to do a
<quote>dist-upgrade</quote> from &debian; 7 to &debian; 8 for existing
installations, though. Due to the small amount of RAM that systems
based on the IXP4xx typically have, this requires that swap space is
enabled prior to upgrading. Support for the IXP4xx platform will be
dropped completely in &debian; 9.
</para></listitem>
</varlistentry>
<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:
OpenRD (OpenRD-Base, OpenRD-Client and OpenRD-Ultimate), <ulink
url="&url-arm-cyrius-sheevaplug;">plug computers (SheevaPlug, GuruPlug
and DreamPlug)</ulink>, <ulink
url="&url-arm-cyrius-qnap-kirkwood;">QNAP Turbo Station</ulink> (all
TS-11x, TS-21x and TS-41x models), and LaCie NASes (Network Space v2,
Network Space Max v2, Internet Space v2, d2 Network v2, 2Big Network
v2 and 5Big Network v2).
</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-dns323;">D-Link
DNS-323</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 no longer supported by Debian/armel</title>
<variablelist>
<varlistentry>
<term>IOP32x</term>
<listitem><para>
Intel's I/O Processor (IOP) line is found in a number of products
related to data storage and processing, such as the <ulink
url="&url-arm-cyrius-glantank;">GLAN Tank</ulink> from IO-Data and the
<ulink url="&url-arm-cyrius-n2100;">Thecus N2100</ulink>. &debian;
has supported the IOP32x platform in &debian; 7, but does not support
it any longer from version 8 on due to hardware constraints of the
platform which make it unsuitable for the installation of newer
&debian; releases.
</para></listitem>
</varlistentry>
<varlistentry>
<term>MV78xx0</term>
<listitem><para>
The MV78xx0 platform has been used on the Marvell DB-78xx0-BP
development board. It was supported in &debian; 7 with a
platform-specific kernel (based on the Linux kernel version 3.2), but
is not supported any more from &debian; 8 onwards.
</para></listitem>
</varlistentry>
</variablelist>
</sect2>
|