summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorSergei Zhmylev <s.zhmylev@yadro.com>2022-10-21 17:56:22 +0300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2022-11-10 14:39:24 +0000
commit7a31cf96eb47049f4cefe6e7f1eaaad32db8730c (patch)
tree85c21710922f306d823fd8e5602a3b5f8d559604 /scripts
parent03a7c1df50e789b2d632042d29e15b4d76685696 (diff)
downloadpoky-7a31cf96eb47049f4cefe6e7f1eaaad32db8730c.tar.gz
wic: honor the SOURCE_DATE_EPOCH in case of updated fstab
In case user requested to build a binary repeatable package, it's required to honor the SOURCE_DATE_EPOCH environment variable. So forcefully set mtime inside all the routines which modify fstab in case it is updated. (From OE-Core rev: 2671667f33d0eac1425db3fc4dff56d4eed1eb3c) Signed-off-by: Sergei Zhmylev <s.zhmylev@yadro.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> (cherry picked from commit 99719a3712a88dce8450994d995803e126e49115) Signed-off-by: Steve Sakoman <steve@sakoman.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts')
-rw-r--r--scripts/lib/wic/partition.py7
-rw-r--r--scripts/lib/wic/plugins/imager/direct.py3
-rw-r--r--scripts/lib/wic/plugins/source/rootfs.py2
3 files changed, 10 insertions, 2 deletions
diff --git a/scripts/lib/wic/partition.py b/scripts/lib/wic/partition.py
index 09e491dd49..7c288d2958 100644
--- a/scripts/lib/wic/partition.py
+++ b/scripts/lib/wic/partition.py
@@ -293,6 +293,11 @@ class Partition():
293 f.write("cd etc\n") 293 f.write("cd etc\n")
294 f.write("rm fstab\n") 294 f.write("rm fstab\n")
295 f.write("write %s fstab\n" % (self.updated_fstab_path)) 295 f.write("write %s fstab\n" % (self.updated_fstab_path))
296 if os.getenv('SOURCE_DATE_EPOCH'):
297 fstab_time = int(os.getenv('SOURCE_DATE_EPOCH'))
298 for time in ["atime", "mtime", "ctime"]:
299 f.write("set_inode_field fstab %s %s\n" % (time, hex(fstab_time)))
300 f.write("set_inode_field fstab %s_extra 0\n" % (time))
296 debugfs_cmd = "debugfs -w -f %s %s" % (debugfs_script_path, rootfs) 301 debugfs_cmd = "debugfs -w -f %s %s" % (debugfs_script_path, rootfs)
297 exec_native_cmd(debugfs_cmd, native_sysroot) 302 exec_native_cmd(debugfs_cmd, native_sysroot)
298 303
@@ -352,7 +357,7 @@ class Partition():
352 exec_native_cmd(mcopy_cmd, native_sysroot) 357 exec_native_cmd(mcopy_cmd, native_sysroot)
353 358
354 if self.updated_fstab_path and self.has_fstab and not self.no_fstab_update: 359 if self.updated_fstab_path and self.has_fstab and not self.no_fstab_update:
355 mcopy_cmd = "mcopy -i %s %s ::/etc/fstab" % (rootfs, self.updated_fstab_path) 360 mcopy_cmd = "mcopy -m -i %s %s ::/etc/fstab" % (rootfs, self.updated_fstab_path)
356 exec_native_cmd(mcopy_cmd, native_sysroot) 361 exec_native_cmd(mcopy_cmd, native_sysroot)
357 362
358 chmod_cmd = "chmod 644 %s" % rootfs 363 chmod_cmd = "chmod 644 %s" % rootfs
diff --git a/scripts/lib/wic/plugins/imager/direct.py b/scripts/lib/wic/plugins/imager/direct.py
index 4d0b836ef6..685d19b30f 100644
--- a/scripts/lib/wic/plugins/imager/direct.py
+++ b/scripts/lib/wic/plugins/imager/direct.py
@@ -148,6 +148,9 @@ class DirectPlugin(ImagerPlugin):
148 self.updated_fstab_path = os.path.join(self.workdir, "fstab") 148 self.updated_fstab_path = os.path.join(self.workdir, "fstab")
149 with open(self.updated_fstab_path, "w") as f: 149 with open(self.updated_fstab_path, "w") as f:
150 f.writelines(fstab_lines) 150 f.writelines(fstab_lines)
151 if os.getenv('SOURCE_DATE_EPOCH'):
152 fstab_time = int(os.getenv('SOURCE_DATE_EPOCH'))
153 os.utime(self.updated_fstab_path, (fstab_time, fstab_time))
151 154
152 def _full_path(self, path, name, extention): 155 def _full_path(self, path, name, extention):
153 """ Construct full file path to a file we generate. """ 156 """ Construct full file path to a file we generate. """
diff --git a/scripts/lib/wic/plugins/source/rootfs.py b/scripts/lib/wic/plugins/source/rootfs.py
index fc06312ee4..e29f3a4c2f 100644
--- a/scripts/lib/wic/plugins/source/rootfs.py
+++ b/scripts/lib/wic/plugins/source/rootfs.py
@@ -224,7 +224,7 @@ class RootfsPlugin(SourcePlugin):
224 if part.update_fstab_in_rootfs and part.has_fstab and not part.no_fstab_update: 224 if part.update_fstab_in_rootfs and part.has_fstab and not part.no_fstab_update:
225 fstab_path = os.path.join(new_rootfs, "etc/fstab") 225 fstab_path = os.path.join(new_rootfs, "etc/fstab")
226 # Assume that fstab should always be owned by root with fixed permissions 226 # Assume that fstab should always be owned by root with fixed permissions
227 install_cmd = "install -m 0644 %s %s" % (part.updated_fstab_path, fstab_path) 227 install_cmd = "install -m 0644 -p %s %s" % (part.updated_fstab_path, fstab_path)
228 if new_pseudo: 228 if new_pseudo:
229 pseudo = cls.__get_pseudo(native_sysroot, new_rootfs, new_pseudo) 229 pseudo = cls.__get_pseudo(native_sysroot, new_rootfs, new_pseudo)
230 else: 230 else: