[Bug 1197766] [NEW] Different partition layout after recovery with keep home partition

Franz Hsieh franz.hsieh at canonical.com
Thu Jul 4 11:08:11 UTC 2013


Public bug reported:

When using ubuntu-recovery to recover the system, 
The partition layout is different when keeping home partition.

consider disk-recipe:

 100 150 200 free
	$iflabel{ gpt }
	$reusemethod{ }
	method{ efi }
	format{ } .

128 512 256 ext2
	$defaultignore{ }
	method{ format }
	format{ }
	use_filesystem{ }
	filesystem{ ext2 }
	mountpoint{ /boot } .

32000 10000 32000 $default_filesystem
	$lvmok{ }
	method{ format }
	format{ }
	use_filesystem{ }
	reserved_for_root{ 1 }
	$default_filesystem{ }
	mountpoint{ / } .

8000 512 8000 linux-swap
	$lvmok{ }
	method{ swap }
	format{ } .

500 10000 -1 $default_filesystem
	$lvmok{ }
	$reusemethod{ }
	method{ format }
	format{ }
	use_filesystem{ }
	$default_filesystem{ }
	label{ User_Data }
	mountpoint{ /home } .

In this case, we want to build this layout in a 320G hard disk and keep the home partition.
If we recover system WITHOUT keeping home partition, the partition layout looks like:

Model: ATA ST320LT012-9WS14 (scsi)
Disk /dev/sda: 320072933376B
Sector size (logical/physical): 512B/4096B
Partition Table: gpt

Number  Start         End            Size           File system     Name                  Flags
        17408B        20479B         3072B          Free Space
 1      20480B        99999743B      99979264B      fat32           EFI System Partition  boot
 2      99999744B     4100001791B    4000002048B    fat32           Recovery Partition
 3      4100001792B   36100001791B   32000000000B   ext4
 4      36100001792B  44100001791B   8000000000B    linux-swap(v1)
 5      44100001792B  320072916479B  275972914688B  ext4            Ubuntu Home Partition


But if we recovery system WITH keeping home partition, the partition layout looks like:

Model: ATA ST320LT012-9WS14 (scsi)
Disk /dev/sda: 320072933376B
Sector size (logical/physical): 512B/4096B
Partition Table: gpt

Number  Start          End            Size           File system     Name                   Flags
        17408B         20479B         3072B          Free Space
 1      20480B         99999743B      99979264B      fat32           EFI System Partition   boot
 2      99999744B      4100001791B    4000002048B    fat32           Recovery Partition
 4      4100001792B    42073001983B   37973000192B   ext4
 6      42073001984B   44100001791B   2026999808B    linux-swap(v1)
 5      44100001792B   320072916479B  275972914688B  ext4            Ubuntu Home Partition

The behavior is abnormal.

According to my test, partman thinks the necessary space is
100+32000+8000 while the home partition is kept. And I discovered that
partman knows EFI partition has $reusemethod option and the partition
exists but it still adds the partition size to total. So the total need
(40100m) is not equal to total free (40000M) and then partman use
alternative recipe instead. This is the root cause of why partition
layout is different.

------------------------------------------------------------------------------------------------------
recipe.sh line: 187~ 209

foreach_partition () {
	local - doing IFS pcount last partition
	doing=$1
	pcount=$(echo "$scheme" | wc -l)
	last=no

	IFS="$NL"
	for partition in $scheme; do
		restore_ifs
		[ $pcount -gt 1 ] || last=yes
		set -- $partition
		eval "$doing"
		pcount=$(($pcount - 1))
	done
}

min_size () {
	local size
	size=0
	foreach_partition '
		size=$(($size + $1))'
	echo $size
}

These codes are used for calculate total recipe size, and I can't find
any expression deals with $reusemethod.

** Affects: oem-priority
     Importance: Critical
         Status: New

** Affects: partman-auto
     Importance: Undecided
         Status: New

** Also affects: partman-auto
   Importance: Undecided
       Status: New

** Package changed: partman-auto (Ubuntu) => oem-priority

** Summary changed:

- Different partition layout after recover with keep home partition
+ Different partition layout after recovery with keep home partition

-- 
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to partman-auto in Ubuntu.
https://bugs.launchpad.net/bugs/1197766

Title:
  Different partition layout after recovery with keep home partition

Status in OEM Priority Project:
  New
Status in partman-auto:
  New

Bug description:
  When using ubuntu-recovery to recover the system, 
  The partition layout is different when keeping home partition.

  consider disk-recipe:

   100 150 200 free
  	$iflabel{ gpt }
  	$reusemethod{ }
  	method{ efi }
  	format{ } .

  128 512 256 ext2
  	$defaultignore{ }
  	method{ format }
  	format{ }
  	use_filesystem{ }
  	filesystem{ ext2 }
  	mountpoint{ /boot } .

  32000 10000 32000 $default_filesystem
  	$lvmok{ }
  	method{ format }
  	format{ }
  	use_filesystem{ }
  	reserved_for_root{ 1 }
  	$default_filesystem{ }
  	mountpoint{ / } .

  8000 512 8000 linux-swap
  	$lvmok{ }
  	method{ swap }
  	format{ } .

  500 10000 -1 $default_filesystem
  	$lvmok{ }
  	$reusemethod{ }
  	method{ format }
  	format{ }
  	use_filesystem{ }
  	$default_filesystem{ }
  	label{ User_Data }
  	mountpoint{ /home } .

  In this case, we want to build this layout in a 320G hard disk and keep the home partition.
  If we recover system WITHOUT keeping home partition, the partition layout looks like:

  Model: ATA ST320LT012-9WS14 (scsi)
  Disk /dev/sda: 320072933376B
  Sector size (logical/physical): 512B/4096B
  Partition Table: gpt

  Number  Start         End            Size           File system     Name                  Flags
          17408B        20479B         3072B          Free Space
   1      20480B        99999743B      99979264B      fat32           EFI System Partition  boot
   2      99999744B     4100001791B    4000002048B    fat32           Recovery Partition
   3      4100001792B   36100001791B   32000000000B   ext4
   4      36100001792B  44100001791B   8000000000B    linux-swap(v1)
   5      44100001792B  320072916479B  275972914688B  ext4            Ubuntu Home Partition

  
  But if we recovery system WITH keeping home partition, the partition layout looks like:

  Model: ATA ST320LT012-9WS14 (scsi)
  Disk /dev/sda: 320072933376B
  Sector size (logical/physical): 512B/4096B
  Partition Table: gpt

  Number  Start          End            Size           File system     Name                   Flags
          17408B         20479B         3072B          Free Space
   1      20480B         99999743B      99979264B      fat32           EFI System Partition   boot
   2      99999744B      4100001791B    4000002048B    fat32           Recovery Partition
   4      4100001792B    42073001983B   37973000192B   ext4
   6      42073001984B   44100001791B   2026999808B    linux-swap(v1)
   5      44100001792B   320072916479B  275972914688B  ext4            Ubuntu Home Partition

  The behavior is abnormal.

  According to my test, partman thinks the necessary space is
  100+32000+8000 while the home partition is kept. And I discovered that
  partman knows EFI partition has $reusemethod option and the partition
  exists but it still adds the partition size to total. So the total
  need (40100m) is not equal to total free (40000M) and then partman use
  alternative recipe instead. This is the root cause of why partition
  layout is different.

  ------------------------------------------------------------------------------------------------------
  recipe.sh line: 187~ 209

  foreach_partition () {
  	local - doing IFS pcount last partition
  	doing=$1
  	pcount=$(echo "$scheme" | wc -l)
  	last=no

  	IFS="$NL"
  	for partition in $scheme; do
  		restore_ifs
  		[ $pcount -gt 1 ] || last=yes
  		set -- $partition
  		eval "$doing"
  		pcount=$(($pcount - 1))
  	done
  }

  min_size () {
  	local size
  	size=0
  	foreach_partition '
  		size=$(($size + $1))'
  	echo $size
  }

  These codes are used for calculate total recipe size, and I can't find
  any expression deals with $reusemethod.

To manage notifications about this bug go to:
https://bugs.launchpad.net/oem-priority/+bug/1197766/+subscriptions




More information about the foundations-bugs mailing list