Imported Upstream version 3.1.0
[debian/amanda] / ndmp-src / ndmp4_xmt.c
1 /*
2  * Copyright (c) 1998,1999,2000
3  *      Traakan, Inc., Los Altos, CA
4  *      All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice unmodified, this list of conditions, and the following
11  *    disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  */
28
29 /*
30  * Project:  NDMJOB
31  * Ident:    $Id: $
32  *
33  * Description:
34  *
35  */
36
37
38 #include "ndmos.h"
39 #include "ndmprotocol.h"
40
41
42 #ifndef NDMOS_OPTION_NO_NDMP4
43
44
45 #define xdr_ndmp4_connect_close_request         xdr_void
46 #define xdr_ndmp4_connect_close_reply           xdr_void
47 #define xdr_ndmp4_config_get_host_info_request  xdr_void
48 #define xdr_ndmp4_config_get_connection_type_request xdr_void
49 #define xdr_ndmp4_config_get_butype_info_request xdr_void
50 #define xdr_ndmp4_config_get_fs_info_request    xdr_void
51 #define xdr_ndmp4_config_get_tape_info_request  xdr_void
52 #define xdr_ndmp4_config_get_scsi_info_request  xdr_void
53 #define xdr_ndmp4_config_get_server_info_request xdr_void
54 #define xdr_ndmp4_scsi_close_request            xdr_void
55 #define xdr_ndmp4_scsi_get_state_request        xdr_void
56 #define xdr_ndmp4_scsi_reset_device_request     xdr_void
57 #define xdr_ndmp4_scsi_reset_bus_request        xdr_void
58 #define xdr_ndmp4_tape_close_request            xdr_void
59 #define xdr_ndmp4_tape_get_state_request        xdr_void
60 #define xdr_ndmp4_data_get_state_request        xdr_void
61
62 #define xdr_ndmp4_data_abort_request            xdr_void
63 #define xdr_ndmp4_data_get_env_request          xdr_void
64 #define xdr_ndmp4_data_stop_request             xdr_void
65
66 #define xdr_ndmp4_mover_get_state_request       xdr_void
67 #define xdr_ndmp4_mover_continue_request        xdr_void
68 #define xdr_ndmp4_mover_abort_request           xdr_void
69 #define xdr_ndmp4_mover_stop_request            xdr_void
70 #define xdr_ndmp4_mover_close_request           xdr_void
71
72
73
74
75 struct ndmp_xdr_message_table   ndmp4_xdr_message_table[] = {
76    { NDMP4_CONNECT_OPEN,
77      xdr_ndmp4_connect_open_request,
78      xdr_ndmp4_connect_open_reply,
79    },
80    { NDMP4_CONNECT_CLIENT_AUTH,
81      xdr_ndmp4_connect_client_auth_request,
82      xdr_ndmp4_connect_client_auth_reply,
83    },
84    { NDMP4_CONNECT_CLOSE,
85      xdr_ndmp4_connect_close_request,
86      xdr_ndmp4_connect_close_reply,
87    },
88    { NDMP4_CONNECT_SERVER_AUTH,
89      xdr_ndmp4_connect_server_auth_request,
90      xdr_ndmp4_connect_server_auth_reply,
91    },
92    { NDMP4_CONFIG_GET_HOST_INFO,
93      xdr_ndmp4_config_get_host_info_request,
94      xdr_ndmp4_config_get_host_info_reply,
95    },
96    { NDMP4_CONFIG_GET_CONNECTION_TYPE,
97      xdr_ndmp4_config_get_connection_type_request,
98      xdr_ndmp4_config_get_connection_type_reply,
99    },
100    { NDMP4_CONFIG_GET_AUTH_ATTR,
101      xdr_ndmp4_config_get_auth_attr_request,
102      xdr_ndmp4_config_get_auth_attr_reply,
103    },
104    { NDMP4_CONFIG_GET_BUTYPE_INFO,
105      xdr_ndmp4_config_get_butype_info_request,
106      xdr_ndmp4_config_get_butype_info_reply,
107    },
108    { NDMP4_CONFIG_GET_FS_INFO,
109      xdr_ndmp4_config_get_fs_info_request,
110      xdr_ndmp4_config_get_fs_info_reply,
111    },
112    { NDMP4_CONFIG_GET_TAPE_INFO,
113      xdr_ndmp4_config_get_tape_info_request,
114      xdr_ndmp4_config_get_tape_info_reply,
115    },
116    { NDMP4_CONFIG_GET_SCSI_INFO,
117      xdr_ndmp4_config_get_scsi_info_request,
118      xdr_ndmp4_config_get_scsi_info_reply,
119    },
120    { NDMP4_CONFIG_GET_SERVER_INFO,
121      xdr_ndmp4_config_get_server_info_request,
122      xdr_ndmp4_config_get_server_info_reply,
123    },
124    { NDMP4_SCSI_OPEN,
125      xdr_ndmp4_scsi_open_request,
126      xdr_ndmp4_scsi_open_reply,
127    },
128    { NDMP4_SCSI_CLOSE,
129      xdr_ndmp4_scsi_close_request,
130      xdr_ndmp4_scsi_close_reply,
131    },
132    { NDMP4_SCSI_GET_STATE,
133      xdr_ndmp4_scsi_get_state_request,
134      xdr_ndmp4_scsi_get_state_reply,
135    },
136    { NDMP4_SCSI_RESET_DEVICE,
137      xdr_ndmp4_scsi_reset_device_request,
138      xdr_ndmp4_scsi_reset_device_reply,
139    },
140    { NDMP4_SCSI_EXECUTE_CDB,
141      xdr_ndmp4_scsi_execute_cdb_request,
142      xdr_ndmp4_scsi_execute_cdb_reply,
143    },
144    { NDMP4_TAPE_OPEN,
145      xdr_ndmp4_tape_open_request,
146      xdr_ndmp4_tape_open_reply,
147    },
148    { NDMP4_TAPE_CLOSE,
149      xdr_ndmp4_tape_close_request,
150      xdr_ndmp4_tape_close_reply,
151    },
152    { NDMP4_TAPE_GET_STATE,
153      xdr_ndmp4_tape_get_state_request,
154      xdr_ndmp4_tape_get_state_reply,
155    },
156    { NDMP4_TAPE_MTIO,
157      xdr_ndmp4_tape_mtio_request,
158      xdr_ndmp4_tape_mtio_reply,
159    },
160    { NDMP4_TAPE_WRITE,
161      xdr_ndmp4_tape_write_request,
162      xdr_ndmp4_tape_write_reply,
163    },
164    { NDMP4_TAPE_READ,
165      xdr_ndmp4_tape_read_request,
166      xdr_ndmp4_tape_read_reply,
167    },
168    { NDMP4_TAPE_EXECUTE_CDB,
169      xdr_ndmp4_tape_execute_cdb_request,
170      xdr_ndmp4_tape_execute_cdb_reply,
171    },
172    { NDMP4_DATA_GET_STATE,
173      xdr_ndmp4_data_get_state_request,
174      xdr_ndmp4_data_get_state_reply,
175    },
176    { NDMP4_DATA_START_BACKUP,
177      xdr_ndmp4_data_start_backup_request,
178      xdr_ndmp4_data_start_backup_reply,
179    },
180    { NDMP4_DATA_START_RECOVER,
181      xdr_ndmp4_data_start_recover_request,
182      xdr_ndmp4_data_start_recover_reply,
183    },
184    { NDMP4_DATA_START_RECOVER_FILEHIST,
185      xdr_ndmp4_data_start_recover_filehist_request,
186      xdr_ndmp4_data_start_recover_filehist_reply,
187    },
188    { NDMP4_DATA_ABORT,
189      xdr_ndmp4_data_abort_request,
190      xdr_ndmp4_data_abort_reply,
191    },
192    { NDMP4_DATA_GET_ENV,
193      xdr_ndmp4_data_get_env_request,
194      xdr_ndmp4_data_get_env_reply,
195    },
196    { NDMP4_DATA_STOP,
197      xdr_ndmp4_data_stop_request,
198      xdr_ndmp4_data_stop_reply,
199    },
200    { NDMP4_DATA_LISTEN,
201      xdr_ndmp4_data_listen_request,
202      xdr_ndmp4_data_listen_reply,
203    },
204    { NDMP4_DATA_CONNECT,
205      xdr_ndmp4_data_connect_request,
206      xdr_ndmp4_data_connect_reply,
207    },
208    { NDMP4_NOTIFY_DATA_HALTED,
209      xdr_ndmp4_notify_data_halted_post,
210      0
211    },
212    { NDMP4_NOTIFY_CONNECTION_STATUS,
213      xdr_ndmp4_notify_connection_status_post,
214      0
215    },
216    { NDMP4_NOTIFY_MOVER_HALTED,
217      xdr_ndmp4_notify_mover_halted_post,
218      0
219    },
220    { NDMP4_NOTIFY_MOVER_PAUSED,
221      xdr_ndmp4_notify_mover_paused_post,
222      0
223    },
224    { NDMP4_NOTIFY_DATA_READ,
225      xdr_ndmp4_notify_data_read_post,
226      0
227    },
228    { NDMP4_LOG_FILE,
229      xdr_ndmp4_log_file_post,
230      0
231    },
232    { NDMP4_LOG_MESSAGE,
233      xdr_ndmp4_log_message_post,
234      0
235    },
236    { NDMP4_FH_ADD_FILE,
237      xdr_ndmp4_fh_add_file_post,
238      0
239    },
240    { NDMP4_FH_ADD_DIR,
241      xdr_ndmp4_fh_add_dir_post,
242      0
243    },
244    { NDMP4_FH_ADD_NODE,
245      xdr_ndmp4_fh_add_node_post,
246      0
247    },
248    { NDMP4_MOVER_GET_STATE,
249      xdr_ndmp4_mover_get_state_request,
250      xdr_ndmp4_mover_get_state_reply,
251    },
252    { NDMP4_MOVER_LISTEN,
253      xdr_ndmp4_mover_listen_request,
254      xdr_ndmp4_mover_listen_reply,
255    },
256    { NDMP4_MOVER_CONTINUE,
257      xdr_ndmp4_mover_continue_request,
258      xdr_ndmp4_mover_continue_reply,
259    },
260    { NDMP4_MOVER_ABORT,
261      xdr_ndmp4_mover_abort_request,
262      xdr_ndmp4_mover_abort_reply,
263    },
264    { NDMP4_MOVER_STOP,
265      xdr_ndmp4_mover_stop_request,
266      xdr_ndmp4_mover_stop_reply,
267    },
268    { NDMP4_MOVER_SET_WINDOW,
269      xdr_ndmp4_mover_set_window_request,
270      xdr_ndmp4_mover_set_window_reply,
271    },
272    { NDMP4_MOVER_READ,
273      xdr_ndmp4_mover_read_request,
274      xdr_ndmp4_mover_read_reply,
275    },
276    { NDMP4_MOVER_CLOSE,
277      xdr_ndmp4_mover_close_request,
278      xdr_ndmp4_mover_close_reply,
279    },
280    { NDMP4_MOVER_SET_RECORD_SIZE,
281      xdr_ndmp4_mover_set_record_size_request,
282      xdr_ndmp4_mover_set_record_size_reply,
283    },
284    { NDMP4_MOVER_CONNECT,
285      xdr_ndmp4_mover_connect_request,
286      xdr_ndmp4_mover_connect_reply,
287    },
288    {0}
289 };
290
291
292
293 /*
294  * XDR unsigned long integers
295  * same as xdr_long - open coded to save a proc call!
296  */
297 bool_t
298 xdr_ndmp4_u_quad(xdrs, objp)
299         register XDR *xdrs;
300         ndmp4_u_quad *objp;
301 {
302         u_long          hi, lo;
303
304         switch (xdrs->x_op) {
305         case XDR_DECODE:
306                 if (XDR_GETLONG(xdrs, (long*)&hi)
307                  && XDR_GETLONG(xdrs, (long*)&lo)) {
308                         *objp = ((unsigned long long)hi << 32) | (lo & 0xffffffff);
309                         return TRUE;
310                 }
311                 break;
312
313         case XDR_ENCODE:
314                 hi = *objp >> 32;
315                 lo = *objp;
316                 return XDR_PUTLONG(xdrs, (long*)&hi)
317                     && XDR_PUTLONG(xdrs, (long*)&lo);
318
319         case XDR_FREE:
320                 return (TRUE);
321         }
322
323         return (FALSE);
324 }
325
326 #endif /* !NDMOS_OPTION_NO_NDMP4 */