|  | /* | 
|  | * File:         Documentation/blackfin/Filesystems | 
|  | * Based on: | 
|  | * Author: | 
|  | * | 
|  | * Created: | 
|  | * Description:  This file contains the simple DMA Implementation for Blackfin | 
|  | * | 
|  | * Rev:          $Id: Filesystems 2384 2006-11-01 04:12:43Z magicyang $ | 
|  | * | 
|  | * Modified: | 
|  | *               Copyright 2004-2006 Analog Devices Inc. | 
|  | * | 
|  | * Bugs:         Enter bugs at http://blackfin.uclinux.org/ | 
|  | * | 
|  | */ | 
|  |  | 
|  | How to mount the root file system in uClinux/Blackfin | 
|  | ----------------------------------------------------- | 
|  |  | 
|  | 1	Mounting EXT3 File system. | 
|  | ------------------------ | 
|  |  | 
|  | Creating an EXT3 File system for uClinux/Blackfin: | 
|  |  | 
|  |  | 
|  | Please follow the steps to form the EXT3 File system and mount the same as root | 
|  | file system. | 
|  |  | 
|  | a	Make an ext3 file system as large as you want the final root file | 
|  | system. | 
|  |  | 
|  | mkfs.ext3  /dev/ram0 <your-rootfs-size-in-1k-blocks> | 
|  |  | 
|  | b	Mount this Empty file system on a free directory as: | 
|  |  | 
|  | mount -t ext3 /dev/ram0  ./test | 
|  | where ./test is the empty directory. | 
|  |  | 
|  | c	Copy your root fs directory that you have so carefully made over. | 
|  |  | 
|  | cp -af  /tmp/my_final_rootfs_files/* ./test | 
|  |  | 
|  | (For ex: cp -af uClinux-dist/romfs/* ./test) | 
|  |  | 
|  | d	If you have done everything right till now you should be able to see | 
|  | the required "root" dir's (that's etc, root, bin, lib, sbin...) | 
|  |  | 
|  | e	Now unmount the file system | 
|  |  | 
|  | umount  ./test | 
|  |  | 
|  | f	Create the root file system image. | 
|  |  | 
|  | dd if=/dev/ram0 bs=1k count=<your-rootfs-size-in-1k-blocks> \ | 
|  | > ext3fs.img | 
|  |  | 
|  |  | 
|  | Now you have to tell the kernel that will be mounting this file system as | 
|  | rootfs. | 
|  | So do a make menuconfig under kernel and select the Ext3 journaling file system | 
|  | support under File system --> submenu. | 
|  |  | 
|  |  | 
|  | 2.	Mounting EXT2 File system. | 
|  | ------------------------- | 
|  |  | 
|  | By default the ext2 file system image will be created if you invoke make from | 
|  | the top uClinux-dist directory. | 
|  |  | 
|  |  | 
|  | 3.	Mounting CRAMFS File System | 
|  | ---------------------------- | 
|  |  | 
|  | To create a CRAMFS file system image execute the command | 
|  |  | 
|  | mkfs.cramfs ./test cramfs.img | 
|  |  | 
|  | where ./test is the target directory. | 
|  |  | 
|  |  | 
|  | 4.	Mounting ROMFS File System | 
|  | -------------------------- | 
|  |  | 
|  | To create a ROMFS file system image execute the command | 
|  |  | 
|  | genromfs -v -V "ROMdisk" -f romfs.img -d ./test | 
|  |  | 
|  | where ./test is the target directory | 
|  |  | 
|  |  | 
|  | 5.	Mounting the JFFS2 Filesystem | 
|  | ----------------------------- | 
|  |  | 
|  | To create a compressed JFFS filesystem (JFFS2), please execute the command | 
|  |  | 
|  | mkfs.jffs2 -d ./test -o jffs2.img | 
|  |  | 
|  | where ./test is the target directory. | 
|  |  | 
|  | However, please make sure the following is in your kernel config. | 
|  |  | 
|  | /* | 
|  | * RAM/ROM/Flash chip drivers | 
|  | */ | 
|  | #define CONFIG_MTD_CFI 1 | 
|  | #define CONFIG_MTD_ROM 1 | 
|  | /* | 
|  | * Mapping drivers for chip access | 
|  | */ | 
|  | #define CONFIG_MTD_COMPLEX_MAPPINGS 1 | 
|  | #define CONFIG_MTD_BF533 1 | 
|  | #undef CONFIG_MTD_UCLINUX | 
|  |  | 
|  | Through the u-boot boot loader, use the jffs2.img in the corresponding | 
|  | partition made in linux-2.6.x/drivers/mtd/maps/bf533_flash.c. | 
|  |  | 
|  | NOTE - 	Currently the Flash driver is available only for EZKIT. Watch out for a | 
|  | STAMP driver soon. | 
|  |  | 
|  |  | 
|  | 6. 	Mounting the NFS File system | 
|  | ----------------------------- | 
|  |  | 
|  | For mounting the NFS please do the following in the kernel config. | 
|  |  | 
|  | In Networking Support --> Networking options --> TCP/IP networking --> | 
|  | IP: kernel level autoconfiguration | 
|  |  | 
|  | Enable BOOTP Support. | 
|  |  | 
|  | In Kernel hacking --> Compiled-in kernel boot parameter add the following | 
|  |  | 
|  | root=/dev/nfs rw ip=bootp | 
|  |  | 
|  | In File system --> Network File system, Enable | 
|  |  | 
|  | NFS file system support --> NFSv3 client support | 
|  | Root File system on NFS | 
|  |  | 
|  | in uClibc menuconfig, do the following | 
|  | In Networking Support | 
|  | enable Remote Procedure Call (RPC) support | 
|  | Full RPC Support | 
|  |  | 
|  | On the Host side, ensure that /etc/dhcpd.conf looks something like this | 
|  |  | 
|  | ddns-update-style ad-hoc; | 
|  | allow bootp; | 
|  | subnet 10.100.4.0 netmask 255.255.255.0 { | 
|  | default-lease-time 122209600; | 
|  | max-lease-time 31557600; | 
|  | group { | 
|  | host bf533 { | 
|  | hardware ethernet 00:CF:52:49:C3:01; | 
|  | fixed-address 10.100.4.50; | 
|  | option root-path "/home/nfsmount"; | 
|  | } | 
|  | } | 
|  |  | 
|  | ensure that /etc/exports looks something like this | 
|  | /home/nfsmount *(rw,no_root_squash,no_all_squash) | 
|  |  | 
|  | run the following commands as root (may differ depending on your | 
|  | distribution) : | 
|  | -  service nfs start | 
|  | -  service portmap start | 
|  | -  service dhcpd start | 
|  | -  /usr/sbin/exportfs |