* [PATCH] dracut: write initramfs to temp file then move into place
@ 2013-02-21 21:40 lars-3XmpO8hA3EAAvxtiuMwx3w
[not found] ` <1361482823-30898-1-git-send-email-lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org>
0 siblings, 1 reply; 2+ messages in thread
From: lars-3XmpO8hA3EAAvxtiuMwx3w @ 2013-02-21 21:40 UTC (permalink / raw)
To: initramfs-u79uwXL29TY76Z2rM5mHXA; +Cc: Lars R. Damerow
From: "Lars R. Damerow" <lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org>
We've been finding cases where multiple instances of dracut can be launched
simultaneously, resulting in a corrupted initramfs file. This patch makes
dracut write the initramfs to a new file, then move it into place atomically.
---
dracut.sh | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/dracut.sh b/dracut.sh
index 31cf2a5..da96aaa 100755
--- a/dracut.sh
+++ b/dracut.sh
@@ -1103,10 +1103,11 @@ fi
rm -f "$outfile"
dinfo "*** Creating image file ***"
if ! ( umask 077; cd "$initdir"; find . |cpio -R 0:0 -H newc -o --quiet| \
- $compress > "$outfile"; ); then
- dfatal "dracut: creation of $outfile failed"
+ $compress > "$outfile.$$"; ); then
+ dfatal "dracut: creation of $outfile.$$ failed"
exit 1
fi
+mv $outfile.$$ $outfile
dinfo "*** Creating image file done ***"
dinfo "Wrote $outfile:"
--
1.8.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] dracut: write initramfs to temp file then move into place
[not found] ` <1361482823-30898-1-git-send-email-lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org>
@ 2013-02-22 9:57 ` Harald Hoyer
0 siblings, 0 replies; 2+ messages in thread
From: Harald Hoyer @ 2013-02-22 9:57 UTC (permalink / raw)
To: lars-3XmpO8hA3EAAvxtiuMwx3w; +Cc: initramfs-u79uwXL29TY76Z2rM5mHXA
Am 21.02.2013 22:40, schrieb lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org:
> From: "Lars R. Damerow" <lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org>
>
> We've been finding cases where multiple instances of dracut can be launched
> simultaneously, resulting in a corrupted initramfs file. This patch makes
> dracut write the initramfs to a new file, then move it into place atomically.
> ---
> dracut.sh | 5 +++--
> 1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/dracut.sh b/dracut.sh
> index 31cf2a5..da96aaa 100755
> --- a/dracut.sh
> +++ b/dracut.sh
> @@ -1103,10 +1103,11 @@ fi
> rm -f "$outfile"
> dinfo "*** Creating image file ***"
> if ! ( umask 077; cd "$initdir"; find . |cpio -R 0:0 -H newc -o --quiet| \
> - $compress > "$outfile"; ); then
> - dfatal "dracut: creation of $outfile failed"
> + $compress > "$outfile.$$"; ); then
> + dfatal "dracut: creation of $outfile.$$ failed"
> exit 1
> fi
> +mv $outfile.$$ $outfile
> dinfo "*** Creating image file done ***"
>
> dinfo "Wrote $outfile:"
>
Yes, right!
Thanks for the patch!
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2013-02-22 9:57 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-02-21 21:40 [PATCH] dracut: write initramfs to temp file then move into place lars-3XmpO8hA3EAAvxtiuMwx3w
[not found] ` <1361482823-30898-1-git-send-email-lars-3XmpO8hA3EAAvxtiuMwx3w@public.gmane.org>
2013-02-22 9:57 ` Harald Hoyer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox