The following are the steps performed for this purpose.
Download a fresh copy of Kernel 2.4.18 from http://www.kernel.org/pub/linux/kernel/v2.4.
The kernel that is downloaded from the site does not have support for the M-Systems driver so we need to add this functionality. This is done by adding a patch to the kernel.
The steps to conduct patching are as follows:
Untar the kernel source file and the M-systems TrueFFS Linux driver version 5.14. If the source code is in .tar.gz format, use
tar -xvzf linux-2.4.18.tar.gz
If the source code is in .tar.bz2 format, use
bunzip2 linux-2.4.18.tar.bz2
After using bunzip2, you will get a file named linux-2.4.18.tar. Untar it using the command
tar -xvf linux-2.4.18.tar
Unarchiving the driver is done using the command
tar -xvzf linux_binary.5_1_4.tgz
This results in the creation of two directories: linux and linux_binary.5_1_4.
The TrueFFS Linux driver package contains three different folders:
Documentation: this contains a PDF document describing the various functions of TrueFFS.
dformat_5_1_4_37: this contains a utility dformat, which is used to update the firmware on the DiskOnChip (DOC) and to create low level partitions on the DOC.
doc-linux-5_1_4_20: this contains patches, initrd scripts and other utilities.
Now apply the patch to the kernel. We will use the linux-2_4_7-patch file that is present in linux_binary.5_1_4/doc-linux-5_1_4_20/driver. The following commands are used for this purpose:
cd linux_binary.5_1_4/doc-linux-5_1_4_20/driver
patch -p1 -d /usr/src/linux < linux-2_4_7-patch
This will create a directory named doc in the linux/drivers/block directory.
The patch created the doc directory, but did not copy the source files of the M-Systems driver, which are necessary in order to build the driver, into this directory. So execute the following command:
cp linux_binary.5_1_4/doc-linux-5_1_4_20/driver/doc/* /usr/src/linux/drivers/block/doc
|  | Kernel version | 
|---|---|
| The patch will fail for kernels other than 2.4.18 since the source files where the patch is to be applied may be somewhat different in different kernels. The patch has been provided specifically for kernel 2.4.18. | 
Before moving on to Step 2, do the following:
Login as root.
Make sure that gcc version is 2.95.3 else the build will fail. Use gcc --version to check this. If your gcc version is different compile gcc-2.95.3. Refer to http://xlife.zuarvra.net.columns/20020316 for this purpose.
Complete the following tasks for compiling the kernel:
cd linux
make menuconfig
Check for the following options:
In the "Block devices menu", select:
M-Systems driver as module i.e. (M)
Loopback device support as built-in i.e. (*)
RAM disk support as built-in i.e. (*)
Initial RAM disk (initrd) support as built .in i.e. (*)
In the "Processor type and features menu", select "Disable Symmetric Multiprocessor Support".
In the "filesystem menu", select:
Ext3 journaling file system support as built-in
DOS FAT fs support as built-ina
MSDOS fs support as built-inb
VFAT (Windows-95) fs support as built-inc
|  | File System Menu | 
|---|---|
| a,b,c options should be activated if you want to mount your MS Windows partition, else they can be left out. It is, however, generally recommended to use them. | 
An excellent resource on kernel compilation is the Kernel Rebuild Guide.
The configuration file, linux/.config should essentially contain the following lines (only a part of the config file has been given):
| # # Loadable module support # CONFIG_MODULES=y CONFIG_MODVERSIONS=y CONFIG_KMOD=y # # Processor type and features # # CONFIG_SMP is not set # # Memory Technology Devices (MTD) # # CONFIG_MTD is not set # # Block devices # # CONFIG_BLK_DEV_FD is not set # CONFIG_BLK_DEV_XD is not set # CONFIG_PARIDE is not set # CONFIG_BLK_CPQ_DA is not set # CONFIG_BLK_CPQ_CISS_DA is not set # CONFIG_BLK_DEV_DAC960 is not set CONFIG_BLK_DEV_LOOP=y # CONFIG_BLK_DEV_NBD is not set CONFIG_BLK_DEV_RAM=y CONFIG_BLK_DEV_RAM_SIZE=4096 CONFIG_BLK_DEV_INITRD=y CONFIG_BLK_DEV_MSYS_DOC=m # # File systems # # CONFIG_QUOTA is not set # CONFIG_AUTOFS_FS is not set # CONFIG_AUTOFS4_FS is not set CONFIG_EXT3_FS=y CONFIG_FAT_FS=y CONFIG_MSDOS_FS=y # CONFIG_UMSDOS_FS is not set CONFIG_VFAT_FS=y # CONFIG_EFS_FS is not set # CONFIG_JFFS_FS is not set # CONFIG_JFFS2_FS is not set # CONFIG_CRAMFS is not set CONFIG_TMPFS=y # CONFIG_RAMFS is not set CONFIG_ISO9660_FS=y # CONFIG_JOLIET is not set # CONFIG_HPFS_FS is not set CONFIG_PROC_FS=y # CONFIG_DEVFS_FS is not set # CONFIG_DEVFS_MOUNT is not set # CONFIG_DEVFS_DEBUG is not set CONFIG_DEVPTS_FS=y # CONFIG_QNX4FS_FS is not set # CONFIG_QNX4FS_RW is not set # CONFIG_ROMFS_FS is not set CONFIG_EXT2_FS=y | 
make dep
make bzImage
make modules
make modules_install
Copy the newly created bzImage to the /bott directory and name it vmlinuz-2.4.18, using this command:
cp /arch/i386/boot/bzImage /boot/vmlinuz-2.4.18
Check for lib/modules/2.4.18/kernel/drivers/block/doc.o. This is the M-Systems driver that we need to access DiskOnChip.
Now we will create block devices, which are required to access the DOC These block devices will use the M-Systems driver that was built in Section 4.2 to access the DOC. The script mknod_fl in linux_binary.5_1_4/doc-linux-5_1_4_20/driver is used for this purpose.
We need to create the block devices with the major number of 62. For this purpose we will pass the argument 62 while creating the nodes:
./mknod_fl 62
This will create the following devices in /dev/msys with major number 62:
| fla...fla4 flb...flb4 flc...flc4 fld...fld4 | 
In order to have the DiskOnChip recognized by Linux OS, we need to insert the DOC driver module into the kernel. Since the currently running kernel doesn.t have support for the M-Systems Driver, we need to boot into new kernel we just compiled in .
For this purpose we need to add the following entries in the /boot/grub/menu.lst file:
| title Debian GNU/Linux,Kernel 2.4.18 root (hd0,7) kernel /boot/vmlinuz-2.4.18 root=/dev/hda8 safedefault boot | 
Where (hd0,7) is the partition holding the kernel image vmlinuz-2.4.18 and /dev/hda8 is the partition holding the root filesystem. These partitions may vary from one system to another. Now reboot and choose the kernel 2.4.18 option (the kernel that has been compiled in Step 2) in the grub menu to boot into the new kernel.
The M-Systems driver by default gets loaded with major number 100, but our newly created nodes (see Section 4.3) have a major number 62. Therefore we need to insert this module with a major number 62. This can be done in either of two ways:
While inserting the module using insmod also mention the major number for the module which needs to be assigned to it otherwise it will take the default major number of 100:
insmod doc major=62
Add the following line to /etc/modules.conf:
| options doc major=62 | 
Then use modprobe doc to insert the modules.
Check for the correct loading of the module using the lsmod command without options.
Before we can start using DiskOnChip we need to create a filesystem on it. We will create an ext2 filesystem since it is small in size.
This involves a hidden step of making partitions on the DOC using fdisk. The actual steps are as follows:
fdisk /dev/msys/fla
This command will ask to create partitions. Create a primary partition number 1 with start cylinder as 1 and final cylinder as 1002.
Check the partition table, which should look like this:
| Device Boot Start End Blocks ID System /dev/msys/fla1 1 1002 255984 83 Linux | 
Make the filesystem on /dev/msys/fla1 with the command
mke2fs -c /dev/msys/fla1
Where fla1 is the first primary partition on the DOC. (We have created only one partition in order to avoid unnecessary complexity.)
Create a new mount point for the DiskOnChip in the /mnt directory:
mkdir /mnt/doc
Mount the DOC partition on the newly created directory:
mount -t auto /dev/msys/fla1 /mnt/doc
You will now be able to read and write to the DOC as an additional storage drive.
When you reboot your system, make the DOC available by inserting the driver into the kernel (see Section 4.5) and mounting the device.