Differences between revisions 39 and 40
Revision 39 as of 2015-08-18 15:46:13
Size: 9520
Editor: ?IgorStoppa
Comment: Removed incorrect statement about BTRFS vs wear leveling. It is done by the uController in the card.
Revision 40 as of 2015-08-18 15:53:07
Size: 8356
Editor: ?IgorStoppa
Comment: Removing false claim about btrfs performance improvement - see disproval here: https://delightlylinux.wordpress.com/2015/03/12/which-is-faster-btrfs-or-ext4/
Deletions are marked like this. Additions are marked like this.
Line 107: Line 107:

== Improving sdcard performance ==

You can double the response of applications loading and general filesystem I/O throughput by [[https://btrfs.wiki.kernel.org/index.php/Conversion_from_Ext3|converting the root filesystem to btrfs]]. Before doing so, you must '''first''' install DebianPkg:btrfs-tools and '''update the initramfs''' as stated above. If you don't do this first, your system may become unbootable.

You can use an external PC with Linux to do so, or the Raspberry Pi itself booting from another '''updated''' sdcard and attaching the one you are converting to a sdcard reader connected to a USB port. The partition you must convert is {{{/dev/mmcblkXp2}}}, being X the device related to that card, but an also be {{{/dev/sdX2}}}, being X the card reader number (you may check what X is by mounting and unmount different partitions and check the contents).

After that and before the first reboot, change the {{{/etc/fstab}}} of the partition you are going to convert to this: {{{
/dev/mmcblk0p2 / btrfs noatime,space_cache,autodefrag,commit=2,nodiratime,compress=lzo,ssd,ssd_spread,thread_pool=4 0 1

See also: [[Btrfs]].

Can I put Debian on my Raspberry Pi?


Raspberry Pi 1 (A, B, A+, B+)

Debian armel will work (with a custom kernel), but will not make best use of the floating point hardware on the first version although it will work with the second version. Debian armhf will not work (see below) for the first version but does work with the second one.

Generally, your best bet is to use Raspbian - which is (mostly) Debian armhf rebuilt by members of Debian for the RPi's ARMv6+VFP2 ARM variant. Raspbian releases usually follow the corresponding Debian release but do deviate in a handful of cases for various reasons.

Be aware that the Raspbian images distributed by the Raspberry Pi Foundation contain additional packages supplied by them including updated versions of some software and the addition of non-free software including Oracle Java and Wolfram Mathematica.

Raspberry Pi 2

Debian armhf will work (with a custom kernel). See the blog posting Debian Jessie on Raspberry Pi 2 by Sjoerd Simons of Collabora for details.

RaspberryPi2 aims to collect information how to run Debian nicely on this hardware.

Should I buy a Raspberry Pi?

That is a decision that you will have to make given your application, below are some pros and cons that you should consider.


  • Large and active community
  • Low price for the capabilities offered


  • The Raspberry Pi 1's processor falls uncomfortably between the processor families that Debian has chosen to target. While Raspbian solves this to some degree an unofficial port will always give less certainty than an official one. (This doesn' stand anymore for the Raspberry Pi 2)
  • 3D acceleration is not integrated with X or other standard mechanisms and the Raspberry Pi Foundation don't seem to show any interest in doing so. Therefore 3D applications will require Pi specific builds.
  • A binary blob used by the GPU must be present on the SD card for the system to boot.
  • While some hardware documentation has been released the documentation is sorely lacking.
  • While schematics are available the board design is closed and the main processor is not available for purchase by the general public.

A number of similar boards are available, generally at slightly higher prices but also usually with more powerful processors. Some examples are given below, more can be found in the FreedomBox targetted hardware list.

Raspberry Pi issues

The Raspberry Pi issues relate to technical problems, software freedom and hype:

  • The CPU in the Raspberry Pi 1 implements the ARMv6 ISA (with VFP2) and is thus incompatible with the Debian armhf port baseline of ARMv7+VFP3 and ARM hardware-floating-point ports for other distributions, which all have the same baseline. It is compatible with Debian armel (armv4t, soft(emulated) FP), but floating-point tasks will be slow when running the Debian armel port. (This doesn't stand for the Raspberry Pi 2)
  • The Raspberry Pi boots from its GPU and only non-free software is currently available for the GPU, even starting the machine requires a large (2MB) blob of non-free, unsupportable software
  • The 3D driver for the Raspberry Pi, while Free Software, is just a shim that passes OpenGL commands directly to the non-free software running on the GPU. This means that any issues with OpenGL cannot be fixed nor performance improved. This is better than some other GPUs because the ARM part can be rebuilt. More recently an alternative driver has become available that drives the 3D core in the GPU directly from the ARM rather than passing messages to the VPU core in the GPU which in turn drove the 3D core.

Binary blob needed to boot

The binary blob needed to boot the Raspberry Pi can be downloaded using the rpi-update script available from https://raw.githubusercontent.com/Hexxeh/rpi-update/master/rpi-update. It can be used with vmdebootstrap to create a bootable SD card image, according to a recipe from Petter Reinholdtsen. No known effort to reverse engineer the blob is known as of 2013-10-30.

QEMU User Emulation for Raspberry Pi Development

See RaspberryPi/qemu-user-static for information on how you can mount, edit, and run a Raspberry Pi disk image on a host Debian machine using QemuUserEmulation (much faster/simpler than than full system emulation)


Initramfs for custom loading of modules at boot does work, but you must update it everytime you use rpi-update, this way:

mkinitramfs -o /boot/initrd

In the Raspberry Pi 2 you must also include this in /boot/config.txt:

initramfs initrd followkernel

And this is /boot/cdmline.txt:

root=/dev/mmcblk0p2 initrd=-1 dwc_otg.lpm_enable=0 console=ttyAMA0,115200 console=tty1 elevator=deadline rootwait

Because rpi-update is not the official way that Debian updates the Initramfs, you may find weird things happening when you update rpi, so if your system becomes unbootable because there is a needed module in the initrd that you need (like encryption), you must boot with another up to date sdcard, chroot into the new environment, mounting first /boot and /dev, and then update the initrd manually. This just happens because of the privative special way of booting of the Raspberry Pi, out of any reasonable standard.

Overclocking Pi 2

Overclocking is quite easy and convenient, and doesn't invalidate your warranty if you don't change voltage. It happens that the actual L2 speed of the Raspberry Pi 2 is severelly underclocked, making the device much more slower that it should actually be. There has been reports of users using overclocked speeds of the processor and the L2 for months without a single issue, but you must be carefull in respecting a good proportion between L2 speed and processor, and overclocking the RAM is generally not recommended.

Try this setting, it has demonstrated to be stable and doubles the speed of this small machine in general. Edit /boot/config.txt and substitute or add these lines:


Unfortunatelly, the options shown when running raspi-config are not quite stable even they are slower than this recommended option.

Giving more power to the USB devices

If you are running a lot of devices, you may need a lot of power. Actually, the Pi 2 can give up to 1.2A to the devices, but it is severely limited by default to 600mA, so if you connect a lot of devices, they are going to be reseting themselves or limiting in some ways because of lack of energy. There is an option to actually double the amount of energy you can give to the devices, but you must also use a good 2A adapter. Just edit /boot/config.txt and add this:


This way I am able to run a very energy consuming 4G modem and a Wifi dongle at the same time without issues.

Also, you not only need a good and reliable adapter, but also a good cable. The shorter and thicker the better.