No Message Supplied
[xfstests-dev.git] / dmapi / src / common / cmd / handle_read_invis.c
1 /*
2  * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
3  * 
4  * This program is free software; you can redistribute it and/or modify it
5  * under the terms of version 2 of the GNU General Public License as
6  * published by the Free Software Foundation.
7  * 
8  * This program is distributed in the hope that it would be useful, but
9  * WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11  * 
12  * Further, this software is distributed without any warranty that it is
13  * free of the rightful claim of any third person regarding infringement
14  * or the like.  Any license provided herein, whether implied or
15  * otherwise, applies only to this software file.  Patent licenses, if
16  * any, provided herein do not apply to combinations of this program with
17  * other software, or any other product whatsoever.
18  * 
19  * You should have received a copy of the GNU General Public License along
20  * with this program; if not, write the Free Software Foundation, Inc., 59
21  * Temple Place - Suite 330, Boston MA 02111-1307, USA.
22  * 
23  * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
24  * Mountain View, CA  94043, or:
25  * 
26  * http://www.sgi.com 
27  * 
28  * For further information regarding this notice, see: 
29  * 
30  * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
31  */
32
33 #include <ctype.h>
34
35 #include <lib/hsm.h>
36
37 #include <string.h>
38 #include <malloc.h>
39 #include <unistd.h>
40
41 /*---------------------------------------------------------------------------
42
43 Test program used to test the DMAPI function dm_read_invis().  The
44 command line is:
45
46         handle_read_invis [-o offset] [-l length] [-s sid] handle
47
48 where:
49 'offset' is the offset of the start of the write (0 is the default),
50 'length' is the length of the write in bytes (1 is the default),
51 'sid' is the session ID whose events you you are interested in.
52 'handle' is the ascii representation of the file's handle.
53         You can use the test tool path_to_handle to get this.
54
55 ----------------------------------------------------------------------------*/
56
57 #ifndef linux
58 extern  char    *sys_errlist[];
59 #endif
60 extern  int     optind;
61 extern  char    *optarg;
62
63
64 char    *Progname;
65
66
67 static void
68 usage(void)
69 {
70         fprintf(stderr, "usage:\t%s [-o offset] [-l length] "
71                 "[-s sid] handle\n", Progname);
72         exit(1);
73 }
74
75
76 int
77 main(
78         int     argc, 
79         char    **argv)
80 {
81         dm_sessid_t     sid = DM_NO_SESSION;
82         char            *han_str = NULL;
83         dm_off_t        offset = 0;
84         dm_size_t       length = 1;
85         char            *bufp = NULL;
86         void            *hanp;
87         size_t          hlen;
88         dm_ssize_t      rc;
89         char            *name;
90         int             opt;
91         int             i;
92         int             error;
93
94         if (Progname = strrchr(argv[0], '/')) {
95                 Progname++;
96         } else {
97                 Progname = argv[0];
98         }
99
100         /* Crack and validate the command line options. */
101
102         while ((opt = getopt(argc, argv, "o:l:s:")) != EOF) {
103                 switch (opt) {
104                 case 'o':
105                         offset = atol(optarg);
106                         break;
107                 case 'l':
108                         length = atol(optarg);
109                         break;
110                 case 's':
111                         sid = atol(optarg);
112                         break;
113                 case '?':
114                         usage();
115                 }
116         }
117         if (optind + 1 != argc)
118                 usage();
119         han_str = argv[optind];
120
121         if (dm_init_service(&name) == -1)  {
122                 fprintf(stderr, "Can't inititalize the DMAPI\n");
123                 exit(1);
124         }
125         if (sid == DM_NO_SESSION)
126                 find_test_session(&sid);
127
128         /* Get the file's handle. */
129
130         if ((error = atohan(han_str, &hanp, &hlen)) != 0) {
131                 fprintf(stderr, "atohan() failed, %s\n", strerror(error));
132                 return(1);
133         }
134
135         if (length > 0) {
136                 /* In case it is a realtime file, align the buffer on a
137                    sufficiently big boundary.
138                 */
139                 if ((bufp = memalign(4096, length)) == NULL) {
140                         fprintf(stderr, "malloc of %llu bytes failed\n", length);
141                         exit(1);
142                 }
143                 memset(bufp, '\0', length);
144         }
145
146         rc = dm_read_invis(sid, hanp, hlen, DM_NO_TOKEN, offset, length, bufp);
147
148         if (rc < 0) {
149                 fprintf(stderr, "dm_read_invis failed, %s\n", strerror(errno));
150                 exit(1);
151         } else if (rc != length) {
152                 fprintf(stderr, "expected to read %lld bytes, actually "
153                         "read %lld\n", length, rc);
154                 exit(1);
155         }
156         for (i = 0; i < rc; i++) {
157                 if (isprint(bufp[i])) {
158                         fprintf(stdout, "%c", bufp[i]);
159                 } else {
160                         fprintf(stdout, "\\%03d", bufp[i]);
161                 }
162         }
163         dm_handle_free(hanp, hlen);
164         exit(0);
165 }