1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2 * vim:expandtab:shiftwidth=8:tabstop=8:
6 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 only,
10 * as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License version 2 for more details (a copy is included
16 * in the LICENSE file that accompanied this code).
18 * You should have received a copy of the GNU General Public License
19 * version 2 along with this program; If not, see
20 * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
22 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
23 * CA 95054 USA or visit www.sun.com if you need additional information or
29 * Copyright 2009 Sun Microsystems, Inc. All rights reserved
30 * Use is subject to license terms.
33 * This file is part of Lustre, http://www.lustre.org/
34 * Lustre is a trademark of Sun Microsystems, Inc.
36 * Author: Nathan Rutman <nathan.rutman@sun.com>
40 /* HSM copytool example program.
41 * The copytool acts on action requests from Lustre to copy files to and from
42 * an HSM archive system.
44 * Note: under Linux, until llapi_copytool_fini is called (or the program is
45 * killed), the libcfs module will be referenced and unremovable,
46 * even after Lustre services stop.
51 #include <libcfs/libcfs.h>
52 #include <lustre/lustre_user.h>
53 #include <lustre/liblustreapi.h>
55 int main(int argc, char **argv) {
57 struct option long_opts[] = {
58 {"test", no_argument, 0, 't'},
62 int archive_nums[] = {1}; /* which archive numbers we care about */
66 while ((c = getopt_long(argc, argv, "t", long_opts, NULL)) != -1) {
72 fprintf(stderr, "error: %s: option '%s' unrecognized\n",
73 argv[0], argv[optind - 1]);
78 rc = llapi_copytool_start(&ctdata, 0, ARRAY_SIZE(archive_nums),
81 fprintf(stderr, "Can't start copytool interface: %s\n",
87 return -llapi_copytool_fini(&ctdata);
89 printf("Waiting for message from kernel (pid=%d)\n", getpid());
92 struct hsm_action_list *hal;
93 struct hsm_action_item *hai;
96 rc = llapi_copytool_recv(ctdata, &hal, &msgsize);
97 if (rc == -ESHUTDOWN) {
98 fprintf(stderr, "shutting down");
102 fprintf(stderr, "Message receive: %s", strerror(-rc));
106 continue; /* msg not for us */
108 printf("Copytool fs=%s archive#=%d item_count=%d\n",
109 hal->hal_fsname, hal->hal_archive_num, hal->hal_count);
112 while (++i <= hal->hal_count) {
113 printf("Item %d: action %d reclen %d\n", i,
114 hai->hai_action, hai->hai_len);
115 printf(" "DFID" gid="LPU64" cookie="LPU64"\n",
116 PFID(&hai->hai_fid), hai->hai_gid,
121 llapi_copytool_free(&hal);
124 llapi_copytool_fini(&ctdata);