X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=daemon%2Fsfdisk.c;h=8221ffa8561f1d99502ec1010fb0aba3c3a03604;hb=HEAD;hp=b68b9f67c87ad72c433eb49d70b32fcfd5461289;hpb=9b0ab841856ed7168171f6dceaede88dc9fbb9b2;p=libguestfs.git diff --git a/daemon/sfdisk.c b/daemon/sfdisk.c index b68b9f6..8221ffa 100644 --- a/daemon/sfdisk.c +++ b/daemon/sfdisk.c @@ -13,7 +13,7 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #include @@ -38,7 +38,7 @@ sfdisk (const char *device, int n, int cyls, int heads, int sectors, char buf[256]; int i; - strcpy (buf, "/sbin/sfdisk"); + strcpy (buf, "sfdisk"); if (n > 0) sprintf (buf + strlen (buf), " -N %d", n); @@ -89,6 +89,20 @@ sfdisk (const char *device, int n, int cyls, int heads, int sectors, return -1; } + /* sfdisk sometimes fails on fast machines with: + * + * Re-reading the partition table ... + * BLKRRPART: Device or resource busy + * The command to re-read the partition table failed. + * Run partprobe(8), kpartx(8) or reboot your system now, + * before using mkfs + * + * Unclear if this is a bug in sfdisk or the kernel or some + * other component. In any case, reread the partition table + * unconditionally here. + */ + (void) command (NULL, NULL, "blockdev", "--rereadpt", device, NULL); + udev_settle (); return 0; @@ -122,9 +136,9 @@ sfdisk_flag (const char *device, const char *flag) char *out, *err; int r; - r = command (&out, &err, "/sbin/sfdisk", flag, device, NULL); + r = command (&out, &err, "sfdisk", flag, device, NULL); if (r == -1) { - reply_with_error ("sfdisk: %s: %s", device, err); + reply_with_error ("%s: %s", device, err); free (out); free (err); return NULL;