Bering-uClibc 5.x - User Guide - Appendices - Hardware-Specific Guides

From bering-uClibc
Revision as of 14:40, 6 April 2012 by Davidmbrooke (Talk | contribs) (Created)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

ARM CPU Architecture

ARM Versatile Platform Baseboards

Overview

The ARM® Versatile™ system boards are primarily relevant to Bering-uClibc because they are well supported and tested targets for the QEMU ARM emulator which is invaluable when developing Bering-uClibc 5.x implementations which target physical ARM processor hardware.

Several different CPU variants are available:

  • ARM926EJ-S
  • ARM1176JZF-S
    • Same processor as the Raspberry Pi but only supported by very recent versions of QEMU; confirmed as present in QEMU 1.0.1
  • ARM11MPCore
  • Coretex-A8

Hardware / Driver Details

  • The network controller chip is an SMSC LAN91C11x (SMC91C11xFD) and needs kernel Module smc91x.ko
  • The disk controller chip is an LSI Logic / Symbios Logic 53C895a and needs kernel Module sym53c8xx.ko
    • This is a SCSI disk controller. Disk devices appear as e.g. /dev/sda


Raspberry Pi

Overview

The Raspberry Pi is a physically small and very low-cost single board computer. It has a Broadcom BCM2835 "system on a chip" integrated circuit containing an ARM1176JZF-S CPU which implements the ARMv6 architecture standard. The BCM2835 contains a variety of devices. Many of these seem to be identified with the string BCM2708 rather than BCM2835. The Raspberry Pi foundation have added a specific bcm2708 "platform" to a branch of the Linux kernel source. See the Raspberry Pi Git Hub repository

Hardware / Driver Details

Refer to the example boot log here

  • The network controller chip is an ???
  • The disk controller chip is an ???

Boot Disk Layout

The Raspberry Pi must boot from its SD card and some vital files must be present in the right location.

The first disk partition must be formatted as a FAT-32 filesystem which must contain:

  • A file called start.elf which contains the GPU binary driver
  • A file called bootcode.bin which is presumably referenced by the GPU binary driver
  • A file called loader.bin which is presumably referenced by the GPU binary driver
  • A file called kernel.img which is the Linux kernel
    • This seems to be a standard Linux kernel Image file with a special 32KB prefix. See here
  • A file called cmdline.txt containing the kernel command line

There does not seem to be any standard provision for loading an initramfs (initrd) file. We probably need to embed the initrd into the kernel.

It seems customary to put the files relating to a particular Linux distribution on a second disk partition. We therefore need a second FAT-32 disk partition for leaf.cfg, all the .lrp Package files etc.

Note that the Raspberry Pi references the first disk partition as /dev/mmcblk0p1 and the second disk partition as /dev/mmcblk0p2.