| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | The Intel Assabet (SA-1110 evaluation) board | 
 | 2 | ============================================ | 
 | 3 |  | 
 | 4 | Please see: | 
 | 5 | http://developer.intel.com/design/strong/quicklist/eval-plat/sa-1110.htm | 
 | 6 | http://developer.intel.com/design/strong/guides/278278.htm | 
 | 7 |  | 
 | 8 | Also some notes from John G Dorsey <jd5q@andrew.cmu.edu>: | 
 | 9 | http://www.cs.cmu.edu/~wearable/software/assabet.html | 
 | 10 |  | 
 | 11 |  | 
 | 12 | Building the kernel | 
 | 13 | ------------------- | 
 | 14 |  | 
 | 15 | To build the kernel with current defaults: | 
 | 16 |  | 
 | 17 | 	make assabet_config | 
 | 18 | 	make oldconfig | 
 | 19 | 	make zImage | 
 | 20 |  | 
 | 21 | The resulting kernel image should be available in linux/arch/arm/boot/zImage. | 
 | 22 |  | 
 | 23 |  | 
 | 24 | Installing a bootloader | 
 | 25 | ----------------------- | 
 | 26 |  | 
 | 27 | A couple of bootloaders able to boot Linux on Assabet are available: | 
 | 28 |  | 
| Erik Mouw | c8c4b93 | 2006-03-27 15:32:30 +0100 | [diff] [blame^] | 29 | BLOB (http://www.lartmaker.nl/lartware/blob/) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 |  | 
 | 31 |    BLOB is a bootloader used within the LART project.  Some contributed | 
 | 32 |    patches were merged into BLOB to add support for Assabet. | 
 | 33 |  | 
 | 34 | Compaq's Bootldr + John Dorsey's patch for Assabet support | 
 | 35 | (http://www.handhelds.org/Compaq/bootldr.html) | 
 | 36 | (http://www.wearablegroup.org/software/bootldr/) | 
 | 37 |  | 
 | 38 |    Bootldr is the bootloader developed by Compaq for the iPAQ Pocket PC. | 
 | 39 |    John Dorsey has produced add-on patches to add support for Assabet and | 
 | 40 |    the JFFS filesystem. | 
 | 41 |  | 
 | 42 | RedBoot (http://sources.redhat.com/redboot/) | 
 | 43 |  | 
 | 44 |    RedBoot is a bootloader developed by Red Hat based on the eCos RTOS | 
 | 45 |    hardware abstraction layer.  It supports Assabet amongst many other | 
 | 46 |    hardware platforms. | 
 | 47 |  | 
 | 48 | RedBoot is currently the recommended choice since it's the only one to have | 
 | 49 | networking support, and is the most actively maintained. | 
 | 50 |  | 
 | 51 | Brief examples on how to boot Linux with RedBoot are shown below.  But first | 
 | 52 | you need to have RedBoot installed in your flash memory.  A known to work | 
 | 53 | precompiled RedBoot binary is available from the following location: | 
 | 54 |  | 
 | 55 | ftp://ftp.netwinder.org/users/n/nico/ | 
 | 56 | ftp://ftp.arm.linux.org.uk/pub/linux/arm/people/nico/ | 
 | 57 | ftp://ftp.handhelds.org/pub/linux/arm/sa-1100-patches/ | 
 | 58 |  | 
 | 59 | Look for redboot-assabet*.tgz.  Some installation infos are provided in | 
 | 60 | redboot-assabet*.txt. | 
 | 61 |  | 
 | 62 |  | 
 | 63 | Initial RedBoot configuration | 
 | 64 | ----------------------------- | 
 | 65 |  | 
 | 66 | The commands used here are explained in The RedBoot User's Guide available | 
 | 67 | on-line at http://sources.redhat.com/ecos/docs-latest/redboot/redboot.html. | 
 | 68 | Please refer to it for explanations. | 
 | 69 |  | 
 | 70 | If you have a CF network card (my Assabet kit contained a CF+ LP-E from | 
 | 71 | Socket Communications Inc.), you should strongly consider using it for TFTP | 
 | 72 | file transfers.  You must insert it before RedBoot runs since it can't detect | 
 | 73 | it dynamically. | 
 | 74 |  | 
 | 75 | To initialize the flash directory: | 
 | 76 |  | 
 | 77 | 	fis init -f | 
 | 78 |  | 
 | 79 | To initialize the non-volatile settings, like whether you want to use BOOTP or | 
 | 80 | a static IP address, etc, use this command: | 
 | 81 |  | 
 | 82 | 	fconfig -i | 
 | 83 |  | 
 | 84 |  | 
 | 85 | Writing a kernel image into flash | 
 | 86 | --------------------------------- | 
 | 87 |  | 
 | 88 | First, the kernel image must be loaded into RAM.  If you have the zImage file | 
 | 89 | available on a TFTP server: | 
 | 90 |  | 
 | 91 | 	load zImage -r -b 0x100000 | 
 | 92 |  | 
 | 93 | If you rather want to use Y-Modem upload over the serial port: | 
 | 94 |  | 
 | 95 | 	load -m ymodem -r -b 0x100000 | 
 | 96 |  | 
 | 97 | To write it to flash: | 
 | 98 |  | 
 | 99 | 	fis create "Linux kernel" -b 0x100000 -l 0xc0000 | 
 | 100 |  | 
 | 101 |  | 
 | 102 | Booting the kernel | 
 | 103 | ------------------ | 
 | 104 |  | 
 | 105 | The kernel still requires a filesystem to boot.  A ramdisk image can be loaded | 
 | 106 | as follows: | 
 | 107 |  | 
 | 108 | 	load ramdisk_image.gz -r -b 0x800000 | 
 | 109 |  | 
 | 110 | Again, Y-Modem upload can be used instead of TFTP by replacing the file name | 
 | 111 | by '-y ymodem'. | 
 | 112 |  | 
 | 113 | Now the kernel can be retrieved from flash like this: | 
 | 114 |  | 
 | 115 | 	fis load "Linux kernel" | 
 | 116 |  | 
 | 117 | or loaded as described previously.  To boot the kernel: | 
 | 118 |  | 
 | 119 | 	exec -b 0x100000 -l 0xc0000 | 
 | 120 |  | 
 | 121 | The ramdisk image could be stored into flash as well, but there are better | 
 | 122 | solutions for on-flash filesystems as mentioned below. | 
 | 123 |  | 
 | 124 |  | 
 | 125 | Using JFFS2 | 
 | 126 | ----------- | 
 | 127 |  | 
 | 128 | Using JFFS2 (the Second Journalling Flash File System) is probably the most | 
 | 129 | convenient way to store a writable filesystem into flash.  JFFS2 is used in | 
 | 130 | conjunction with the MTD layer which is responsible for low-level flash | 
 | 131 | management.  More information on the Linux MTD can be found on-line at: | 
 | 132 | http://www.linux-mtd.infradead.org/.  A JFFS howto with some infos about | 
 | 133 | creating JFFS/JFFS2 images is available from the same site. | 
 | 134 |  | 
 | 135 | For instance, a sample JFFS2 image can be retrieved from the same FTP sites | 
 | 136 | mentioned below for the precompiled RedBoot image. | 
 | 137 |  | 
 | 138 | To load this file: | 
 | 139 |  | 
 | 140 | 	load sample_img.jffs2 -r -b 0x100000 | 
 | 141 |  | 
 | 142 | The result should look like: | 
 | 143 |  | 
 | 144 | RedBoot> load sample_img.jffs2 -r -b 0x100000 | 
 | 145 | Raw file loaded 0x00100000-0x00377424 | 
 | 146 |  | 
 | 147 | Now we must know the size of the unallocated flash: | 
 | 148 |  | 
 | 149 | 	fis free | 
 | 150 |  | 
 | 151 | Result: | 
 | 152 |  | 
 | 153 | RedBoot> fis free | 
 | 154 |   0x500E0000 .. 0x503C0000 | 
 | 155 |  | 
 | 156 | The values above may be different depending on the size of the filesystem and | 
 | 157 | the type of flash.  See their usage below as an example and take care of | 
 | 158 | substituting yours appropriately. | 
 | 159 |  | 
 | 160 | We must determine some values: | 
 | 161 |  | 
 | 162 | size of unallocated flash:	0x503c0000 - 0x500e0000 = 0x2e0000 | 
 | 163 | size of the filesystem image:	0x00377424 - 0x00100000 = 0x277424 | 
 | 164 |  | 
 | 165 | We want to fit the filesystem image of course, but we also want to give it all | 
 | 166 | the remaining flash space as well.  To write it: | 
 | 167 |  | 
 | 168 | 	fis unlock -f 0x500E0000 -l 0x2e0000 | 
 | 169 | 	fis erase -f 0x500E0000 -l 0x2e0000 | 
 | 170 | 	fis write -b 0x100000 -l 0x277424 -f 0x500E0000 | 
 | 171 | 	fis create "JFFS2" -n -f 0x500E0000 -l 0x2e0000 | 
 | 172 |  | 
 | 173 | Now the filesystem is associated to a MTD "partition" once Linux has discovered | 
 | 174 | what they are in the boot process.  From Redboot, the 'fis list' command | 
 | 175 | displays them: | 
 | 176 |  | 
 | 177 | RedBoot> fis list | 
 | 178 | Name              FLASH addr  Mem addr    Length      Entry point | 
 | 179 | RedBoot           0x50000000  0x50000000  0x00020000  0x00000000 | 
 | 180 | RedBoot config    0x503C0000  0x503C0000  0x00020000  0x00000000 | 
 | 181 | FIS directory     0x503E0000  0x503E0000  0x00020000  0x00000000 | 
 | 182 | Linux kernel      0x50020000  0x00100000  0x000C0000  0x00000000 | 
 | 183 | JFFS2             0x500E0000  0x500E0000  0x002E0000  0x00000000 | 
 | 184 |  | 
 | 185 | However Linux should display something like: | 
 | 186 |  | 
 | 187 | SA1100 flash: probing 32-bit flash bus | 
 | 188 | SA1100 flash: Found 2 x16 devices at 0x0 in 32-bit mode | 
 | 189 | Using RedBoot partition definition | 
 | 190 | Creating 5 MTD partitions on "SA1100 flash": | 
 | 191 | 0x00000000-0x00020000 : "RedBoot" | 
 | 192 | 0x00020000-0x000e0000 : "Linux kernel" | 
 | 193 | 0x000e0000-0x003c0000 : "JFFS2" | 
 | 194 | 0x003c0000-0x003e0000 : "RedBoot config" | 
 | 195 | 0x003e0000-0x00400000 : "FIS directory" | 
 | 196 |  | 
 | 197 | What's important here is the position of the partition we are interested in, | 
 | 198 | which is the third one.  Within Linux, this correspond to /dev/mtdblock2. | 
 | 199 | Therefore to boot Linux with the kernel and its root filesystem in flash, we | 
 | 200 | need this RedBoot command: | 
 | 201 |  | 
 | 202 | 	fis load "Linux kernel" | 
 | 203 | 	exec -b 0x100000 -l 0xc0000 -c "root=/dev/mtdblock2" | 
 | 204 |  | 
 | 205 | Of course other filesystems than JFFS might be used, like cramfs for example. | 
 | 206 | You might want to boot with a root filesystem over NFS, etc.  It is also | 
 | 207 | possible, and sometimes more convenient, to flash a filesystem directly from | 
 | 208 | within Linux while booted from a ramdisk or NFS.  The Linux MTD repository has | 
 | 209 | many tools to deal with flash memory as well, to erase it for example.  JFFS2 | 
 | 210 | can then be mounted directly on a freshly erased partition and files can be | 
 | 211 | copied over directly.  Etc... | 
 | 212 |  | 
 | 213 |  | 
 | 214 | RedBoot scripting | 
 | 215 | ----------------- | 
 | 216 |  | 
 | 217 | All the commands above aren't so useful if they have to be typed in every | 
 | 218 | time the Assabet is rebooted.  Therefore it's possible to automatize the boot | 
 | 219 | process using RedBoot's scripting capability. | 
 | 220 |  | 
 | 221 | For example, I use this to boot Linux with both the kernel and the ramdisk | 
 | 222 | images retrieved from a TFTP server on the network: | 
 | 223 |  | 
 | 224 | RedBoot> fconfig | 
 | 225 | Run script at boot: false true | 
 | 226 | Boot script: | 
 | 227 | Enter script, terminate with empty line | 
 | 228 | >> load zImage -r -b 0x100000 | 
 | 229 | >> load ramdisk_ks.gz -r -b 0x800000 | 
 | 230 | >> exec -b 0x100000 -l 0xc0000 | 
 | 231 | >> | 
 | 232 | Boot script timeout (1000ms resolution): 3 | 
 | 233 | Use BOOTP for network configuration: true | 
 | 234 | GDB connection port: 9000 | 
 | 235 | Network debug at boot time: false | 
 | 236 | Update RedBoot non-volatile configuration - are you sure (y/n)? y | 
 | 237 |  | 
 | 238 | Then, rebooting the Assabet is just a matter of waiting for the login prompt. | 
 | 239 |  | 
 | 240 |  | 
 | 241 |  | 
 | 242 | Nicolas Pitre | 
 | 243 | nico@cam.org | 
 | 244 | June 12, 2001 | 
 | 245 |  | 
 | 246 |  | 
 | 247 | Status of peripherals in -rmk tree (updated 14/10/2001) | 
 | 248 | ------------------------------------------------------- | 
 | 249 |  | 
 | 250 | Assabet: | 
 | 251 |  Serial ports: | 
 | 252 |   Radio:		TX, RX, CTS, DSR, DCD, RI | 
 | 253 |    PM:			Not tested. | 
 | 254 |   COM:			TX, RX, CTS, DSR, DCD, RTS, DTR, PM | 
 | 255 |    PM:			Not tested. | 
 | 256 |   I2C:			Implemented, not fully tested. | 
 | 257 |   L3:			Fully tested, pass. | 
 | 258 |    PM:			Not tested. | 
 | 259 |  | 
 | 260 |  Video: | 
 | 261 |   LCD:			Fully tested.  PM | 
 | 262 | 			(LCD doesn't like being blanked with | 
 | 263 | 			 neponset connected) | 
 | 264 |   Video out:		Not fully | 
 | 265 |  | 
 | 266 |  Audio: | 
 | 267 |   UDA1341: | 
 | 268 |    Playback:		Fully tested, pass. | 
 | 269 |    Record:		Implemented, not tested. | 
 | 270 |    PM:			Not tested. | 
 | 271 |  | 
 | 272 |   UCB1200: | 
 | 273 |    Audio play:		Implemented, not heavily tested. | 
 | 274 |    Audio rec:		Implemented, not heavily tested. | 
 | 275 |    Telco audio play:	Implemented, not heavily tested. | 
 | 276 |    Telco audio rec:	Implemented, not heavily tested. | 
 | 277 |    POTS control:	No | 
 | 278 |    Touchscreen:		Yes | 
 | 279 |    PM:			Not tested. | 
 | 280 |  | 
 | 281 |  Other: | 
 | 282 |   PCMCIA: | 
 | 283 |    LPE:			Fully tested, pass. | 
 | 284 |   USB:			No | 
 | 285 |   IRDA: | 
 | 286 |    SIR:			Fully tested, pass. | 
 | 287 |    FIR:			Fully tested, pass. | 
 | 288 |    PM:			Not tested. | 
 | 289 |  | 
 | 290 | Neponset: | 
 | 291 |  Serial ports: | 
 | 292 |   COM1,2:	TX, RX, CTS, DSR, DCD, RTS, DTR | 
 | 293 |    PM:			Not tested. | 
 | 294 |   USB:			Implemented, not heavily tested. | 
 | 295 |   PCMCIA:		Implemented, not heavily tested. | 
 | 296 |    PM:			Not tested. | 
 | 297 |   CF:			Implemented, not heavily tested. | 
 | 298 |    PM:			Not tested. | 
 | 299 |  | 
 | 300 | More stuff can be found in the -np (Nicolas Pitre's) tree. | 
 | 301 |  |