113 lines
		
	
	
	
		
			4.5 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
		
		
			
		
	
	
			113 lines
		
	
	
	
		
			4.5 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
| 
								 | 
							
										       initramfs buffer format
							 | 
						||
| 
								 | 
							
										       -----------------------
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										       Al Viro, H. Peter Anvin
							 | 
						||
| 
								 | 
							
										      Last revision: 2002-01-13
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Starting with kernel 2.5.x, the old "initial ramdisk" protocol is
							 | 
						||
| 
								 | 
							
								getting {replaced/complemented} with the new "initial ramfs"
							 | 
						||
| 
								 | 
							
								(initramfs) protocol.  The initramfs contents is passed using the same
							 | 
						||
| 
								 | 
							
								memory buffer protocol used by the initrd protocol, but the contents
							 | 
						||
| 
								 | 
							
								is different.  The initramfs buffer contains an archive which is
							 | 
						||
| 
								 | 
							
								expanded into a ramfs filesystem; this document details the format of
							 | 
						||
| 
								 | 
							
								the initramfs buffer format.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The initramfs buffer format is based around the "newc" or "crc" CPIO
							 | 
						||
| 
								 | 
							
								formats, and can be created with the cpio(1) utility.  The cpio
							 | 
						||
| 
								 | 
							
								archive can be compressed using gzip(1).  One valid version of an
							 | 
						||
| 
								 | 
							
								initramfs buffer is thus a single .cpio.gz file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The full format of the initramfs buffer is defined by the following
							 | 
						||
| 
								 | 
							
								grammar, where:
							 | 
						||
| 
								 | 
							
									*	is used to indicate "0 or more occurrences of"
							 | 
						||
| 
								 | 
							
									(|)	indicates alternatives
							 | 
						||
| 
								 | 
							
									+	indicates concatenation
							 | 
						||
| 
								 | 
							
									GZIP()	indicates the gzip(1) of the operand
							 | 
						||
| 
								 | 
							
									ALGN(n)	means padding with null bytes to an n-byte boundary
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									initramfs  := ("\0" | cpio_archive | cpio_gzip_archive)*
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									cpio_gzip_archive := GZIP(cpio_archive)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									cpio_archive := cpio_file* + (<nothing> | cpio_trailer)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									cpio_file := ALGN(4) + cpio_header + filename + "\0" + ALGN(4) + data
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									cpio_trailer := ALGN(4) + cpio_header + "TRAILER!!!\0" + ALGN(4)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In human terms, the initramfs buffer contains a collection of
							 | 
						||
| 
								 | 
							
								compressed and/or uncompressed cpio archives (in the "newc" or "crc"
							 | 
						||
| 
								 | 
							
								formats); arbitrary amounts zero bytes (for padding) can be added
							 | 
						||
| 
								 | 
							
								between members.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The cpio "TRAILER!!!" entry (cpio end-of-archive) is optional, but is
							 | 
						||
| 
								 | 
							
								not ignored; see "handling of hard links" below.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The structure of the cpio_header is as follows (all fields contain
							 | 
						||
| 
								 | 
							
								hexadecimal ASCII numbers fully padded with '0' on the left to the
							 | 
						||
| 
								 | 
							
								full width of the field, for example, the integer 4780 is represented
							 | 
						||
| 
								 | 
							
								by the ASCII string "000012ac"):
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Field name    Field size	 Meaning
							 | 
						||
| 
								 | 
							
								c_magic	      6 bytes		 The string "070701" or "070702"
							 | 
						||
| 
								 | 
							
								c_ino	      8 bytes		 File inode number
							 | 
						||
| 
								 | 
							
								c_mode	      8 bytes		 File mode and permissions
							 | 
						||
| 
								 | 
							
								c_uid	      8 bytes		 File uid
							 | 
						||
| 
								 | 
							
								c_gid	      8 bytes		 File gid
							 | 
						||
| 
								 | 
							
								c_nlink	      8 bytes		 Number of links
							 | 
						||
| 
								 | 
							
								c_mtime	      8 bytes		 Modification time
							 | 
						||
| 
								 | 
							
								c_filesize    8 bytes		 Size of data field
							 | 
						||
| 
								 | 
							
								c_maj	      8 bytes		 Major part of file device number
							 | 
						||
| 
								 | 
							
								c_min	      8 bytes		 Minor part of file device number
							 | 
						||
| 
								 | 
							
								c_rmaj	      8 bytes		 Major part of device node reference
							 | 
						||
| 
								 | 
							
								c_rmin	      8 bytes		 Minor part of device node reference
							 | 
						||
| 
								 | 
							
								c_namesize    8 bytes		 Length of filename, including final \0
							 | 
						||
| 
								 | 
							
								c_chksum      8 bytes		 Checksum of data field if c_magic is 070702;
							 | 
						||
| 
								 | 
							
												 otherwise zero
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The c_mode field matches the contents of st_mode returned by stat(2)
							 | 
						||
| 
								 | 
							
								on Linux, and encodes the file type and file permissions.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The c_filesize should be zero for any file which is not a regular file
							 | 
						||
| 
								 | 
							
								or symlink.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The c_chksum field contains a simple 32-bit unsigned sum of all the
							 | 
						||
| 
								 | 
							
								bytes in the data field.  cpio(1) refers to this as "crc", which is
							 | 
						||
| 
								 | 
							
								clearly incorrect (a cyclic redundancy check is a different and
							 | 
						||
| 
								 | 
							
								significantly stronger integrity check), however, this is the
							 | 
						||
| 
								 | 
							
								algorithm used.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								If the filename is "TRAILER!!!" this is actually an end-of-archive
							 | 
						||
| 
								 | 
							
								marker; the c_filesize for an end-of-archive marker must be zero.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								*** Handling of hard links
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								When a nondirectory with c_nlink > 1 is seen, the (c_maj,c_min,c_ino)
							 | 
						||
| 
								 | 
							
								tuple is looked up in a tuple buffer.  If not found, it is entered in
							 | 
						||
| 
								 | 
							
								the tuple buffer and the entry is created as usual; if found, a hard
							 | 
						||
| 
								 | 
							
								link rather than a second copy of the file is created.  It is not
							 | 
						||
| 
								 | 
							
								necessary (but permitted) to include a second copy of the file
							 | 
						||
| 
								 | 
							
								contents; if the file contents is not included, the c_filesize field
							 | 
						||
| 
								 | 
							
								should be set to zero to indicate no data section follows.  If data is
							 | 
						||
| 
								 | 
							
								present, the previous instance of the file is overwritten; this allows
							 | 
						||
| 
								 | 
							
								the data-carrying instance of a file to occur anywhere in the sequence
							 | 
						||
| 
								 | 
							
								(GNU cpio is reported to attach the data to the last instance of a
							 | 
						||
| 
								 | 
							
								file only.)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								c_filesize must not be zero for a symlink.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								When a "TRAILER!!!" end-of-archive marker is seen, the tuple buffer is
							 | 
						||
| 
								 | 
							
								reset.  This permits archives which are generated independently to be
							 | 
						||
| 
								 | 
							
								concatenated.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								To combine file data from different sources (without having to
							 | 
						||
| 
								 | 
							
								regenerate the (c_maj,c_min,c_ino) fields), therefore, either one of
							 | 
						||
| 
								 | 
							
								the following techniques can be used:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								a) Separate the different file data sources with a "TRAILER!!!"
							 | 
						||
| 
								 | 
							
								   end-of-archive marker, or
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								b) Make sure c_nlink == 1 for all nondirectory entries.
							 |