Implement 'dd' command.
[libguestfs.git] / daemon / dd.c
1 /* libguestfs - the guestfsd daemon
2  * Copyright (C) 2009 Red Hat Inc.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17  */
18
19 #include <config.h>
20
21 #include <stdio.h>
22 #include <stdlib.h>
23
24 #include "../src/guestfs_protocol.h"
25 #include "daemon.h"
26 #include "actions.h"
27
28 int
29 do_dd (const char *src, const char *dest)
30 {
31   int src_is_dev, dest_is_dev;
32   char *if_arg, *of_arg;
33   char *err;
34   int r;
35
36   src_is_dev = STRPREFIX (src, "/dev/");
37
38   if (src_is_dev)
39     r = asprintf (&if_arg, "if=%s", src);
40   else
41     r = asprintf (&if_arg, "if=%s%s", sysroot, src);
42   if (r == -1) {
43     reply_with_perror ("asprintf");
44     return -1;
45   }
46
47   dest_is_dev = STRPREFIX (dest, "/dev/");
48
49   if (dest_is_dev)
50     r = asprintf (&of_arg, "of=%s", dest);
51   else
52     r = asprintf (&of_arg, "of=%s%s", sysroot, dest);
53   if (r == -1) {
54     reply_with_perror ("asprintf");
55     free (if_arg);
56     return -1;
57   }
58
59   r = command (NULL, &err, "dd", "bs=1024K", if_arg, of_arg, NULL);
60   free (if_arg);
61   free (of_arg);
62
63   if (r == -1) {
64     reply_with_error ("dd: %s: %s: %s", src, dest, err);
65     free (err);
66     return -1;
67   }
68   free (err);
69
70   return 0;
71 }