wok rev 6715

linux/bootloader.sh: fix signed 16bits
author Pascal Bellard <pascal.bellard@slitaz.org>
date Thu Oct 14 17:08:12 2010 +0200 (2010-10-14)
parents 3bff7f88b1c8
children 5abda65ec235
files linux/stuff/bootloader.sh
line diff
     1.1 --- a/linux/stuff/bootloader.sh	Thu Oct 14 13:41:19 2010 +0200
     1.2 +++ b/linux/stuff/bootloader.sh	Thu Oct 14 17:08:12 2010 +0200
     1.3 @@ -10,8 +10,10 @@
     1.4  {
     1.5  cat <<EOT
     1.6  Usage: $0 bzImage [--prefix image_prefix] [--cmdline 'args']
     1.7 -       [--rdev device] [--video mode] [--flags rootflags] 
     1.8 -       [--format 1440|1680|1720|2880 ] [--initrd initrdfile]...
     1.9 +       [--rdev device] [--video mode] [--flags rootflags] [--tracks cnt]
    1.10 +       [--format 1440|1680|1920|2880 ] [--initrd initrdfile]...
    1.11 +
    1.12 +Default values: --format 1440 --tracks 80 --prefix floppy.
    1.13  
    1.14  Example:
    1.15  $0 /boot/vmlinuz-2.6.30.6 --rdev /dev/ram0 --video -3 --cmdline 'rw lang=fr_FR kmap=fr-latin1 laptop autologin' --initrd /boot/rootfs.gz --initrd ./myconfig.gz
    1.16 @@ -27,6 +29,7 @@
    1.17  RDEV=""
    1.18  VIDEO=""
    1.19  FLAGS=""
    1.20 +TRACKS=""
    1.21  DEBUG=""
    1.22  while [ -n "$1" ]; do
    1.23  	case "$1" in
    1.24 @@ -37,18 +40,26 @@
    1.25  	--fl*)     FLAGS="$2"; shift;;	# 1 read-only, 0 read-write
    1.26  	--r*|-r*)  RDEV="$2"; shift;;	# /dev/???
    1.27  	--v*|-v*)  VIDEO="$2"; shift;;	# -3 .. n
    1.28 +	--t*|-t*)  TRACKS="$2"; shift;; # likely 81 .. 84
    1.29  	--debug)   DEBUG="1";;
    1.30  	*) KERNEL="$1";;
    1.31  	esac
    1.32  	shift
    1.33  done
    1.34  [ -n "$KERNEL" -a -f "$KERNEL" ] || usage
    1.35 +if [ -n "$TRACKS" ]; then
    1.36 +	if [ $(( $FORMAT % $TRACKS )) -ne 0 ]; then
    1.37 +		echo "Invalid track count for format $FORMAT."
    1.38 +		usage
    1.39 +	fi
    1.40 +fi
    1.41  
    1.42  # write a 16 bits data
    1.43  # usage: store16 offset data16 file
    1.44  store16()
    1.45  {
    1.46 -	echo $2 | awk '{ printf "\\\\x%02X\\\\x%02X",$1%256,($1/256)%256 }' | \
    1.47 +	echo $(( $2 + 0x10000 )) | \
    1.48 +		awk '{ printf "\\\\x%02X\\\\x%02X",$1%256,($1/256)%256 }' | \
    1.49  		xargs echo -en | \
    1.50  	dd bs=2 conv=notrunc of=$3 seek=$(( $1 / 2 )) 2> /dev/null
    1.51  	[ -n "$DEBUG" ] && printf "store16(%04X) = %04X\n" $1 $2 1>&2
    1.52 @@ -76,6 +87,7 @@
    1.53  floppyset()
    1.54  {
    1.55  	# bzImage offsets
    1.56 +	CylinderCount=496
    1.57  	SetupSzOfs=497
    1.58  	FlagsOfs=498
    1.59  	SyssizeOfs=500
    1.60 @@ -118,19 +130,24 @@
    1.61  	setupszb=$(( $setupsz & 255 ))
    1.62  	dd if=$KERNEL bs=512 skip=1 count=$setupszb 2> /dev/null >> $bs
    1.63  
    1.64 +	if [ -n "$TRACKS" ]; then
    1.65 +		[ -n "$DEBUG" ] && echo -n "--tracks " 1>&2
    1.66 +		n=$(getlong $CylinderCount $bs)
    1.67 +		store16 $CylinderCount $(( ($n & -256) + $TRACKS )) $bs
    1.68 +	fi
    1.69  	if [ -n "$FLAGS" ]; then
    1.70  		[ -n "$DEBUG" ] && echo -n "--flags " 1>&2
    1.71 -		store16 $FlagsOfs $(( $FLAGS )) $bs
    1.72 +		store16 $FlagsOfs $FLAGS $bs
    1.73  	fi
    1.74  	if [ -n "$VIDEO" ]; then
    1.75  		[ -n "$DEBUG" ] && echo -n "--video " 1>&2
    1.76 -		store16 $VideoModeOfs $(( $VIDEO )) $bs
    1.77 +		store16 $VideoModeOfs $VIDEO $bs
    1.78  	fi
    1.79  	if [ -n "$RDEV" ]; then
    1.80  		[ -n "$DEBUG" ] && echo -n "--rdev " 1>&2
    1.81  		n=$(stat -c '0x%02t%02T' $RDEV 2> /dev/null)
    1.82  		[ -n "$n" ] || n=$RDEV
    1.83 -		store16 $RootDevOfs $(( $n )) $bs
    1.84 +		store16 $RootDevOfs $n $bs
    1.85  	fi
    1.86  
    1.87  	# Store cmdline after setup
    1.88 @@ -186,6 +203,10 @@
    1.89  	rm -f $bs
    1.90  }
    1.91  
    1.92 +if [ "$FORMAT" == "0" ]; then # unsplitted
    1.93 +	floppyset > $PREFIX
    1.94 +	exit
    1.95 +fi
    1.96  floppyset | split -b ${FORMAT}k /dev/stdin floppy$$
    1.97  i=1
    1.98  ls floppy$$* | while read file ; do