2 * Copyright (c) 2005 Zmanda, Inc. All Rights Reserved.
4 * This library is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU Lesser General Public License version 2.1 as
6 * published by the Free Software Foundation.
8 * This library is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
10 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
11 * License for more details.
13 * You should have received a copy of the GNU Lesser General Public License
14 * along with this library; if not, write to the Free Software Foundation,
15 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
17 * Contact information: Zmanda Inc., 505 N Mathlida Ave, Suite 120
18 * Sunnyvale, CA 94085, USA, or: http://www.zmanda.com
21 /* Tape operations for XENIX systems. Most of this stuff is based on
23 http://www.ifthenfi.nl:8080/cgi-bin/ssl_getmanpage?tape+HW+XNX234+tape
29 /* Uncomment to test compilation on non-XENIX systems. */
39 gboolean tape_rewind(int fd) {
40 return 0 == ioctl(fd, MT_REWIND);
43 gboolean tape_fsf(int fd, guint count) {
44 while (--count >= 0) {
45 if (0 != ioctl(fd, T_RFM))
51 gboolean tape_bsf(int fd, guint count) {
52 g_assert_not_reached();
56 gboolean tape_fsr(int fd, guint count) {
57 g_assert_not_reached();
61 gboolean tape_bsr(int fd, guint count) {
62 g_assert_not_reached();
66 gint tape_eod(int fd) {
67 g_assert_not_reached();
71 gboolean tape_weof(int fd, guint8 count) {
72 while (count -- > 0) {
73 if (0 != ioctl(fd, T_WFM))
80 gboolean tape_setcompression(int fd, gboolean on) {
84 TapeCheckResult tape_is_tape_device(int fd) {
85 struct tape_info result;
86 if (0 == ioctl(fd, MT_STATUS, &result)) {
87 return TAPE_CHECK_SUCCESS;
89 return TAPE_CHECK_FAILURE;
93 TapeCheckResult tape_is_ready(int fd) {
94 /* We can probably do better. */
95 return TAPE_CHECK_UNKNOWN;
98 void tape_device_discover_capabilities(TapeDevice * t_self) {
102 self = DEVICE(t_self);
103 g_return_if_fail(self != NULL);
105 bzero(&val, sizeof(val));
106 g_value_init(&val, FEATURE_SUPPORT_FLAGS_TYPE);
108 g_value_set_flags(&val,
109 FEATURE_STATUS_ENABLED | FEATURE_SURETY_BAD |
110 FEATURE_SOURCE_DEFAULT);
111 device_property_set(self, PROPERTY_FSF, &val);
113 g_value_set_flags(&val,
114 FEATURE_STATUS_DISABLED | FEATURE_SURETY_GOOD |
115 FEATURE_SOURCE_DEFAULT);
116 device_property_set(self, PROPERTY_BSF, &val);
118 g_value_set_flags(&val,
119 FEATURE_STATUS_DISABLED | FEATURE_SURETY_GOOD |
120 FEATURE_SOURCE_DEFAULT);
121 device_property_set(self, PROPERTY_FSR, &val);
123 g_value_set_flags(&val,
124 FEATURE_STATUS_DISABLED | FEATURE_SURETY_GOOD |
125 FEATURE_SOURCE_DEFAULT);
126 device_property_set(self, PROPERTY_BSR, &val);
128 g_value_set_flags(&val,
129 FEATURE_STATUS_DISABLED | FEATURE_SURETY_GOOD |
130 FEATURE_SOURCE_DEFAULT);
131 device_property_set(self, PROPERTY_EOM, &val);
133 g_value_unset_init(&val, G_TYPE_UINT);
134 g_value_set_uint(&val, 2);
135 device_property_set(self, PROPERTY_FINAL_FILEMARKS, &val);