diff options
| author | Mandeep Singh Baines <msb@chromium.org> | 2013-03-04 16:33:12 -0800 |
|---|---|---|
| committer | Mike Frysinger <vapier@gentoo.org> | 2013-03-12 16:31:25 -0400 |
| commit | 7991d45446216c493b00a2936d0682a2be49b684 (patch) | |
| tree | 906eb0cf919d0aa1d3bcb79b10d36f203861ab2f /util-linux | |
| parent | 1b49c25e0a719ec3051eafa2329e68012c815abb (diff) | |
| download | busybox-w32-7991d45446216c493b00a2936d0682a2be49b684.tar.gz busybox-w32-7991d45446216c493b00a2936d0682a2be49b684.tar.bz2 busybox-w32-7991d45446216c493b00a2936d0682a2be49b684.zip | |
losetup: fix util-linux compatibility
Added -a support. Also made sure -f works as follows:
losetup [-r] [-o offset] {-f|loopdev} file
Removed support for 'losetup -r' with no arguments.
Signed-off-by: Mandeep Singh Baines <msb@chromium.org>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'util-linux')
| -rw-r--r-- | util-linux/losetup.c | 116 |
1 files changed, 65 insertions, 51 deletions
diff --git a/util-linux/losetup.c b/util-linux/losetup.c index 21108d0bf..c69763335 100644 --- a/util-linux/losetup.c +++ b/util-linux/losetup.c | |||
| @@ -8,16 +8,16 @@ | |||
| 8 | */ | 8 | */ |
| 9 | 9 | ||
| 10 | //usage:#define losetup_trivial_usage | 10 | //usage:#define losetup_trivial_usage |
| 11 | //usage: "[-r] [-o OFS] LOOPDEV FILE - associate loop devices\n" | 11 | //usage: "[-r] [-o OFS] {-f|LOOPDEV} FILE - associate loop devices\n" |
| 12 | //usage: " losetup -d LOOPDEV - disassociate\n" | 12 | //usage: " losetup -d LOOPDEV - disassociate\n" |
| 13 | //usage: " losetup [-f] - show" | 13 | //usage: " losetup -a - show status of all\n" |
| 14 | //usage: " losetup -f - show next available" | ||
| 14 | //usage:#define losetup_full_usage "\n\n" | 15 | //usage:#define losetup_full_usage "\n\n" |
| 15 | //usage: " -o OFS Start OFS bytes into FILE" | 16 | //usage: " -o OFS Start OFS bytes into FILE" |
| 16 | //usage: "\n -r Read-only" | 17 | //usage: "\n -r Read-only" |
| 17 | //usage: "\n -f Show first free loop device" | 18 | //usage: "\n -f Show/find first free loop device" |
| 18 | //usage: | 19 | //usage: |
| 19 | //usage:#define losetup_notes_usage | 20 | //usage:#define losetup_notes_usage |
| 20 | //usage: "No arguments will display all current associations.\n" | ||
| 21 | //usage: "One argument (losetup /dev/loop1) will display the current association\n" | 21 | //usage: "One argument (losetup /dev/loop1) will display the current association\n" |
| 22 | //usage: "(if any), or disassociate it (with -d). The display shows the offset\n" | 22 | //usage: "(if any), or disassociate it (with -d). The display shows the offset\n" |
| 23 | //usage: "and filename of the file the loop device is currently bound to.\n\n" | 23 | //usage: "and filename of the file the loop device is currently bound to.\n\n" |
| @@ -31,77 +31,91 @@ int losetup_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | |||
| 31 | int losetup_main(int argc UNUSED_PARAM, char **argv) | 31 | int losetup_main(int argc UNUSED_PARAM, char **argv) |
| 32 | { | 32 | { |
| 33 | unsigned opt; | 33 | unsigned opt; |
| 34 | int n; | ||
| 35 | char *opt_o; | 34 | char *opt_o; |
| 36 | unsigned long long offset = 0; | 35 | char dev[LOOP_NAMESIZE]; |
| 37 | enum { | 36 | enum { |
| 38 | OPT_d = (1 << 0), | 37 | OPT_d = (1 << 0), |
| 39 | OPT_o = (1 << 1), | 38 | OPT_o = (1 << 1), |
| 40 | OPT_f = (1 << 2), | 39 | OPT_f = (1 << 2), |
| 41 | OPT_r = (1 << 3), /* must be last */ | 40 | OPT_a = (1 << 3), |
| 41 | OPT_r = (1 << 4), /* must be last */ | ||
| 42 | }; | 42 | }; |
| 43 | 43 | ||
| 44 | /* max 2 args, -d,-o,-f opts are mutually exclusive */ | 44 | opt_complementary = "?2:d--ofar:a--ofr"; |
| 45 | opt_complementary = "?2:d--of:o--df:f--do"; | 45 | opt = getopt32(argv, "do:far", &opt_o); |
| 46 | opt = getopt32(argv, "do:fr", &opt_o); | ||
| 47 | argv += optind; | 46 | argv += optind; |
| 48 | 47 | ||
| 49 | if (opt == OPT_o) | 48 | /* LOOPDEV */ |
| 50 | offset = xatoull(opt_o); | 49 | if (!opt && argv[0] && !argv[1]) { |
| 50 | char *s; | ||
| 51 | 51 | ||
| 52 | s = query_loop(argv[0]); | ||
| 53 | if (!s) | ||
| 54 | bb_simple_perror_msg_and_die(argv[0]); | ||
| 55 | printf("%s: %s\n", argv[0], s); | ||
| 56 | if (ENABLE_FEATURE_CLEAN_UP) | ||
| 57 | free(s); | ||
| 58 | return EXIT_SUCCESS; | ||
| 59 | } | ||
| 60 | |||
| 61 | /* -d LOOPDEV */ | ||
| 52 | if (opt == OPT_d) { | 62 | if (opt == OPT_d) { |
| 53 | /* -d BLOCKDEV */ | ||
| 54 | if (!argv[0] || argv[1]) | ||
| 55 | bb_show_usage(); | ||
| 56 | if (del_loop(argv[0])) | 63 | if (del_loop(argv[0])) |
| 57 | bb_simple_perror_msg_and_die(argv[0]); | 64 | bb_simple_perror_msg_and_die(argv[0]); |
| 58 | return EXIT_SUCCESS; | 65 | return EXIT_SUCCESS; |
| 59 | } | 66 | } |
| 60 | 67 | ||
| 61 | if (argv[0]) { | 68 | /* -a */ |
| 62 | char *s; | 69 | if (opt == OPT_a) { |
| 63 | 70 | int n; | |
| 64 | if (opt == OPT_f) /* -f should not have arguments */ | 71 | for (n = 0; n < 10; n++) { |
| 65 | bb_show_usage(); | 72 | char *s; |
| 66 | 73 | ||
| 67 | if (argv[1]) { | 74 | sprintf(dev, LOOP_FORMAT, n); |
| 68 | /* [-r] [-o OFS] BLOCKDEV FILE */ | 75 | s = query_loop(dev); |
| 69 | if (set_loop(&argv[0], argv[1], offset, (opt / OPT_r)) < 0) | 76 | if (s) { |
| 70 | bb_simple_perror_msg_and_die(argv[0]); | 77 | printf("%s: %s\n", dev, s); |
| 71 | return EXIT_SUCCESS; | 78 | if (ENABLE_FEATURE_CLEAN_UP) |
| 79 | free(s); | ||
| 80 | } | ||
| 72 | } | 81 | } |
| 73 | /* [-r] [-o OFS] BLOCKDEV */ | ||
| 74 | s = query_loop(argv[0]); | ||
| 75 | if (!s) | ||
| 76 | bb_simple_perror_msg_and_die(argv[0]); | ||
| 77 | printf("%s: %s\n", argv[0], s); | ||
| 78 | if (ENABLE_FEATURE_CLEAN_UP) | ||
| 79 | free(s); | ||
| 80 | return EXIT_SUCCESS; | 82 | return EXIT_SUCCESS; |
| 81 | } | 83 | } |
| 82 | 84 | ||
| 83 | /* [-r] [-o OFS|-f] with no params */ | 85 | /* contains -f */ |
| 84 | n = 0; | 86 | if (opt & OPT_f) { |
| 85 | while (1) { | ||
| 86 | char *s; | 87 | char *s; |
| 87 | char dev[LOOP_NAMESIZE]; | 88 | int n = 0; |
| 88 | 89 | ||
| 89 | sprintf(dev, LOOP_FORMAT, n); | 90 | do { |
| 90 | s = query_loop(dev); | 91 | sprintf(dev, LOOP_FORMAT, n); |
| 91 | n++; | 92 | s = query_loop(dev); |
| 92 | if (!s) { | 93 | if (s && ENABLE_FEATURE_CLEAN_UP) |
| 93 | if (n > 9 && errno && errno != ENXIO) | ||
| 94 | return EXIT_SUCCESS; | ||
| 95 | if (opt == OPT_f) { | ||
| 96 | puts(dev); | ||
| 97 | return EXIT_SUCCESS; | ||
| 98 | } | ||
| 99 | } else { | ||
| 100 | if (opt != OPT_f) | ||
| 101 | printf("%s: %s\n", dev, s); | ||
| 102 | if (ENABLE_FEATURE_CLEAN_UP) | ||
| 103 | free(s); | 94 | free(s); |
| 95 | } while (s); | ||
| 96 | if ((opt == OPT_f) && !argv[0]) { | ||
| 97 | puts(dev); | ||
| 98 | return EXIT_SUCCESS; | ||
| 104 | } | 99 | } |
| 105 | } | 100 | } |
| 106 | return EXIT_SUCCESS; | 101 | |
| 102 | /* [-r] [-o OFS] {-f|LOOPDEV} FILE */ | ||
| 103 | if (argv[0] && ((opt & OPT_f) || argv[1])) { | ||
| 104 | unsigned long long offset = 0; | ||
| 105 | char *d = dev; | ||
| 106 | |||
| 107 | if (opt == OPT_o) | ||
| 108 | offset = xatoull(opt_o); | ||
| 109 | if (opt != OPT_f) | ||
| 110 | d = *(argv++); | ||
| 111 | |||
| 112 | if (argv[0]) { | ||
| 113 | if (set_loop(&d, argv[0], offset, (opt / OPT_r)) < 0) | ||
| 114 | bb_simple_perror_msg_and_die(argv[0]); | ||
| 115 | return EXIT_SUCCESS; | ||
| 116 | } | ||
| 117 | } | ||
| 118 | |||
| 119 | bb_show_usage(); | ||
| 120 | return EXIT_FAILURE; | ||
| 107 | } | 121 | } |
