/* vi: set sw=4 ts=4: */ /* * eject implementation for busybox * * Copyright (C) 2004 Peter Willis * Copyright (C) 2005 Tito Ragusa * * Licensed under the GPL v2 or later, see the file LICENSE in this tarball. */ /* * This is a simple hack of eject based on something Erik posted in #uclibc. * Most of the dirty work blatantly ripped off from cat.c =) */ #include "busybox.h" #include /* 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 FLAG_CLOSE 1 #define FLAG_SMART 2 int eject_main(int argc, char **argv) { unsigned long flags; char *device; struct mntent *m; int dev; /*opt_complementary = "t--T:T--t";*/ flags = getopt32(argc, argv, "tT"); device = argv[optind] ? : DEFAULT_CDROM; m = find_mount_point(device, bb_path_mtab_file); if (m) { if (umount(m->mnt_dir)) { bb_error_msg_and_die("can't umount"); } else if (ENABLE_FEATURE_MTAB_SUPPORT) { erase_mtab(m->mnt_fsname); } } dev = xopen(device, O_RDONLY|O_NONBLOCK); if (flags & FLAG_CLOSE) goto close_tray; if (ioctl(dev, CDROMEJECT)) { close_tray: if (ioctl(dev, CDROMCLOSETRAY)) bb_perror_msg_and_die("%s", device); } if (ENABLE_FEATURE_CLEAN_UP) close(dev); return EXIT_SUCCESS; }