Blob Blame History Raw
/*
  Copyright (C) 2006, 2008, 2009, 2011, 2017 Rocky Bernstein <rocky@gnu.org>

  This program is free software: you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation, either version 3 of the License, or
  (at your option) any later version.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.

  You should have received a copy of the GNU General Public License
  along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

/* Another simple program to show use of SCSI MMC interface. Is
   basically the the libdio scsi_mmc_get_hwinfo() routine.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#define __CDIO_CONFIG_H__ 1
#endif

#ifdef HAVE_STDIO_H
#include <stdio.h>
#endif
#ifdef HAVE_SYS_TYPES_H
#include <sys/types.h>
#endif
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
#endif
#ifdef HAVE_STRING_H
#include <string.h>
#endif

#include <cdio/cdio.h>
#include <cdio/mmc.h>

/* Set how long to wait for MMC commands to complete */
#define DEFAULT_TIMEOUT_MS 10000

int
main(int argc, const char *argv[])
{
  CdIo_t *p_cdio;
  driver_return_code_t ret;
  driver_id_t driver_id = DRIVER_DEVICE;
  char *psz_drive = NULL;
  bool do_eject = false;
  bool do_close = false;

  if (argc > 1)
    psz_drive = strdup(argv[1]);

  if (!psz_drive) {
    psz_drive = cdio_get_default_device_driver(&driver_id);
    if (!psz_drive) {
      printf("-- Can't find a CD-ROM\n");
     exit(77);
    }
  }

  p_cdio = cdio_open (psz_drive, driver_id);
  if (!p_cdio) {
    printf("-- Can't open %s\n", psz_drive);
    exit(77);
  }

  ret = mmc_get_tray_status(p_cdio);
  switch((int) ret) {
  case 0:
    printf("-- CD-ROM drive %s is closed.\n", psz_drive);
    do_eject = true;
    do_close = true;
    break;
  case 1:
    printf("-- CD-ROM drive %s is open.\n", psz_drive);
    break;
  default:
    printf("-- Error status for drive %s: %s.\n", psz_drive,
	   cdio_driver_errmsg(ret));
    free(psz_drive);
    return 77;
  }

  ret = mmc_get_media_changed(p_cdio);
  switch((int) ret) {
  case 0:
    printf("-- CD-ROM drive %s media not changed since last test.\n",
	   psz_drive);
    break;
  case 1:
    printf("-- CD-ROM drive %s media changed since last test.\n", psz_drive);
    break;
  default:
    printf("-- Error status for drive %s: %s.\n", psz_drive,
	   cdio_driver_errmsg(ret));
    free(psz_drive);
    return 77;
  }

  if (do_eject && argc > 2)
    cdio_eject_media_drive(psz_drive);
  else
    cdio_close_tray(psz_drive, &driver_id);

  ret = mmc_get_tray_status(p_cdio);
  switch((int) ret) {
  case 0:
    printf("-- CD-ROM drive %s is closed.\n", psz_drive);
    break;
  case 1:
    printf("-- CD-ROM drive %s is open.\n", psz_drive);
    break;
  default:
    printf("Error status for drive %s: %s.\n", psz_drive,
	   cdio_driver_errmsg(ret));
    free(psz_drive);
    return 77;
  }

  ret = mmc_get_media_changed(p_cdio);
  switch((int) ret) {
  case 0:
    printf("-- CD-ROM drive %s media not changed since last test.\n",
	   psz_drive);
    break;
  case 1:
    printf("-- CD-ROM drive %s media changed since last test.\n", psz_drive);
    break;
  default:
    printf("-- Error status for drive %s: %s.\n", psz_drive,
	   cdio_driver_errmsg(ret));
    free(psz_drive);
    return 77;
  }

  if (do_close)
    cdio_close_tray(psz_drive, &driver_id);

  free(psz_drive);
  cdio_destroy(p_cdio);

  return 0;
}