summaryrefslogtreecommitdiffstats
path: root/scripts/lib
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/lib')
-rw-r--r--scripts/lib/wic/ksparser.py1
-rw-r--r--scripts/lib/wic/plugins/imager/direct.py8
2 files changed, 6 insertions, 3 deletions
diff --git a/scripts/lib/wic/ksparser.py b/scripts/lib/wic/ksparser.py
index a762d3b6cf..48b5b09ddd 100644
--- a/scripts/lib/wic/ksparser.py
+++ b/scripts/lib/wic/ksparser.py
@@ -196,6 +196,7 @@ class KickStart():
196 bootloader.add_argument('--configfile') 196 bootloader.add_argument('--configfile')
197 bootloader.add_argument('--ptable', choices=('msdos', 'gpt', 'gpt-hybrid'), 197 bootloader.add_argument('--ptable', choices=('msdos', 'gpt', 'gpt-hybrid'),
198 default='msdos') 198 default='msdos')
199 bootloader.add_argument('--diskid', type=lambda x: int(x, 0))
199 bootloader.add_argument('--timeout', type=int) 200 bootloader.add_argument('--timeout', type=int)
200 bootloader.add_argument('--source') 201 bootloader.add_argument('--source')
201 202
diff --git a/scripts/lib/wic/plugins/imager/direct.py b/scripts/lib/wic/plugins/imager/direct.py
index 6e1f1c8cba..f40f033a3d 100644
--- a/scripts/lib/wic/plugins/imager/direct.py
+++ b/scripts/lib/wic/plugins/imager/direct.py
@@ -76,7 +76,7 @@ class DirectPlugin(ImagerPlugin):
76 break 76 break
77 77
78 image_path = self._full_path(self.workdir, self.parts[0].disk, "direct") 78 image_path = self._full_path(self.workdir, self.parts[0].disk, "direct")
79 self._image = PartitionedImage(image_path, self.ptable_format, 79 self._image = PartitionedImage(image_path, self.ptable_format, self.ks.bootloader.diskid,
80 self.parts, self.native_sysroot, 80 self.parts, self.native_sysroot,
81 options.extra_space) 81 options.extra_space)
82 82
@@ -302,7 +302,7 @@ class PartitionedImage():
302 Partitioned image in a file. 302 Partitioned image in a file.
303 """ 303 """
304 304
305 def __init__(self, path, ptable_format, partitions, native_sysroot=None, extra_space=0): 305 def __init__(self, path, ptable_format, disk_id, partitions, native_sysroot=None, extra_space=0):
306 self.path = path # Path to the image file 306 self.path = path # Path to the image file
307 self.numpart = 0 # Number of allocated partitions 307 self.numpart = 0 # Number of allocated partitions
308 self.realpart = 0 # Number of partitions in the partition table 308 self.realpart = 0 # Number of partitions in the partition table
@@ -315,7 +315,9 @@ class PartitionedImage():
315 # all partitions (in bytes) 315 # all partitions (in bytes)
316 self.ptable_format = ptable_format # Partition table format 316 self.ptable_format = ptable_format # Partition table format
317 # Disk system identifier 317 # Disk system identifier
318 if os.getenv('SOURCE_DATE_EPOCH'): 318 if disk_id:
319 self.identifier = disk_id
320 elif os.getenv('SOURCE_DATE_EPOCH'):
319 self.identifier = random.Random(int(os.getenv('SOURCE_DATE_EPOCH'))).randint(1, 0xffffffff) 321 self.identifier = random.Random(int(os.getenv('SOURCE_DATE_EPOCH'))).randint(1, 0xffffffff)
320 else: 322 else:
321 self.identifier = random.SystemRandom().randint(1, 0xffffffff) 323 self.identifier = random.SystemRandom().randint(1, 0xffffffff)