/*
- * Copyright (c) 2005 Zmanda, Inc. All Rights Reserved.
+ * Copyright (c) 2005-2008 Zmanda Inc. All Rights Reserved.
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License version 2.1 as
* along with this library; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*
- * Contact information: Zmanda Inc., 505 N Mathlida Ave, Suite 120
- * Sunnyvale, CA 94085, USA, or: http://www.zmanda.com
+ * Contact information: Zmanda Inc., 465 S Mathlida Ave, Suite 300
+ * Sunnyvale, CA 94086, USA, or: http://www.zmanda.com
*/
/* Tape operations for SVR4 systems. Most of this stuff is based on
#include <amanda.h>
#include <tape-ops.h>
+#include "glib-util.h"
/* Uncomment to test on non-SYSV4 systems. */
/* ---
return 0 == ioctl(fd, T_SBB, count);
}
-int tape_eod(int fd) {
+gint tape_eod(int fd G_GNUC_UNUSED) {
g_assert_not_reached();
return TAPE_OP_ERROR;
}
return 0 == ioctl(fd, T_SETCOMP, cmd);
}
-ReadLabelStatusFlags tape_is_tape_device(int fd) {
+DeviceStatusFlags tape_is_tape_device(int fd) {
/* If we can read block information, it's probably a tape device. */
struct blklen result;
if (0 == ioctl(fd, T_RDBLKLEN, &result)) {
- return READ_LABEL_STATUS_SUCCESS;
+ return DEVICE_STATUS_SUCCESS;
} else {
- dbprintf("tape_is_tape_device: ioctl(MTIOCTOP/MTNOP) failed: %s",
- strerror(errno));
- return READ_LABEL_STATUS_DEVICE_ERROR;
+ return DEVICE_STATUS_DEVICE_ERROR;
}
}
-TapeCheckResult tape_is_tape_ready(int fd) {
- return TAPE_CHECK_UNKNOWN;
+DeviceStatusFlags tape_is_ready(int fd G_GNUC_UNUSED, TapeDevice *t_self G_GNUC_UNUSED) {
+ /* No good way to determine this, so assume it's ready */
+ return DEVICE_STATUS_SUCCESS;
}
-void tape_device_discover_capabilities(TapeDevice * t_self) {
- Device * self;
- GValue val;
-
- self = DEVICE(t_self);
- g_return_if_fail(self != NULL);
-
- bzero(&val, sizeof(val));
- g_value_init(&val, FEATURE_SUPPORT_FLAGS_TYPE);
-
- g_value_set_flags(&val,
- FEATURE_STATUS_ENABLED | FEATURE_SURETY_BAD |
- FEATURE_SOURCE_DEFAULT);
- device_property_set(self, PROPERTY_FSF, &val);
-
- g_value_set_flags(&val,
- FEATURE_STATUS_ENABLED | FEATURE_SURETY_BAD |
- FEATURE_SOURCE_DEFAULT);
- device_property_set(self, PROPERTY_BSF, &val);
-
- g_value_set_flags(&val,
- FEATURE_STATUS_ENABLED | FEATURE_SURETY_BAD |
- FEATURE_SOURCE_DEFAULT);
- device_property_set(self, PROPERTY_FSR, &val);
-
- g_value_set_flags(&val,
- FEATURE_STATUS_ENABLED | FEATURE_SURETY_BAD |
- FEATURE_SOURCE_DEFAULT);
- device_property_set(self, PROPERTY_BSR, &val);
-
- g_value_set_flags(&val,
- FEATURE_STATUS_DISABLED | FEATURE_SURETY_GOOD |
- FEATURE_SOURCE_DEFAULT);
- device_property_set(self, PROPERTY_EOM, &val);
-
- g_value_unset_init(&val, G_TYPE_UINT);
- g_value_set_uint(&val, 2);
- device_property_set(self, PROPERTY_FINAL_FILEMARKS, &val);
+void tape_device_detect_capabilities(TapeDevice * t_self) {
+ tape_device_set_capabilities(t_self,
+ TRUE, PROPERTY_SURETY_BAD, PROPERTY_SOURCE_DEFAULT, /* fsf*/
+ TRUE, PROPERTY_SURETY_BAD, PROPERTY_SOURCE_DEFAULT, /* bsf*/
+ TRUE, PROPERTY_SURETY_BAD, PROPERTY_SOURCE_DEFAULT, /* fsr*/
+ TRUE, PROPERTY_SURETY_BAD, PROPERTY_SOURCE_DEFAULT, /* bsr*/
+ FALSE, PROPERTY_SURETY_GOOD, PROPERTY_SOURCE_DEFAULT, /* eom*/
+ FALSE, PROPERTY_SURETY_GOOD, PROPERTY_SOURCE_DEFAULT, /* bsf_after_eom*/
+ 2, PROPERTY_SURETY_BAD, PROPERTY_SOURCE_DEFAULT /* final_filemarks*/
+ );
}