From 9ea8836357d0f2b53319cb54c032d307cf2533be Mon Sep 17 00:00:00 2001 From: Rob Landley Date: Sat, 14 May 2005 00:46:18 +0000 Subject: Add automatic umount support to eject command. Patch from Tito, with tweaks from Mike Frysinger and Rob Landley. Note: this will still fail to umount a path that contains an ' or \ character. Is it worth the extra size to filter for that? --- miscutils/Config.in | 7 ------- miscutils/eject.c | 43 +++++++++++++++++++++++-------------------- 2 files changed, 23 insertions(+), 27 deletions(-) (limited to 'miscutils') diff --git a/miscutils/Config.in b/miscutils/Config.in index 710639a..afa70a5 100644 --- a/miscutils/Config.in +++ b/miscutils/Config.in @@ -89,13 +89,6 @@ config CONFIG_EJECT help Used to eject cdroms. (defaults to /dev/cdrom) -config CONFIG_FEATURE_EJECT_LONG_OPTIONS - bool " Enable support for --trayclose long option (-t)" - default n - depends on CONFIG_EJECT - help - Enable use of long options (like --trayclose for -t). - config CONFIG_LAST bool "last" default n diff --git a/miscutils/eject.c b/miscutils/eject.c index cbfd115..df275d7 100644 --- a/miscutils/eject.c +++ b/miscutils/eject.c @@ -24,41 +24,44 @@ * Most of the dirty work blatantly ripped off from cat.c =) */ -#include -#include -#include -#include #include #include -#include +#include +#include #include "busybox.h" /* various defines swiped from linux/cdrom.h */ #define CDROMCLOSETRAY 0x5319 /* pendant of CDROMEJECT */ #define CDROMEJECT 0x5309 /* Ejects the cdrom media */ #define DEFAULT_CDROM "/dev/cdrom" -/*#define CLOSE_TRAY 1*/ + +#ifdef CONFIG_FEATURE_MTAB_SUPPORT +#define MTAB CONFIG_FEATURE_MTAB_FILENAME +#else +#define MTAB "/proc/mounts" +#endif extern int eject_main(int argc, char **argv) { unsigned long flags; + char * command; + char *device=argv[optind] ? : DEFAULT_CDROM; -#ifdef CONFIG_FEATURE_EJECT_LONG_OPTIONS - static const struct option eject_long_options[] = { - { "trayclose", 0, 0, 't' }, - { 0, 0, 0, 0 } - }; - bb_applet_long_options = eject_long_options; -#endif - flags = bb_getopt_ulflags(argc, argv, "t"); - - if (ioctl(bb_xopen((argv[optind] ? argv[optind] : DEFAULT_CDROM), + bb_xasprintf(&command, "umount '%s'", device); + + /* validate input before calling system */ + if(find_mount_point(device, MTAB)) + system(command); + + if (ioctl(bb_xopen( device, (O_RDONLY | O_NONBLOCK)), - ( flags /*& CLOSE_TRAY*/ ? CDROMCLOSETRAY : CDROMEJECT))) + ( flags ? CDROMCLOSETRAY : CDROMEJECT))) { - bb_perror_msg_and_die(bb_msg_unknown); + bb_perror_msg_and_die(device); } - - return EXIT_SUCCESS; +#ifdef CONFIG_FEATURE_CLEAN_UP + free(command); +#endif + return(EXIT_SUCCESS); } -- cgit v1.1