legacy.h revision 1.1 1 1.1 pho /* $NetBSD: legacy.h,v 1.1 2022/01/22 07:57:30 pho Exp $ */
2 1.1 pho
3 1.1 pho /*
4 1.1 pho * Copyright (c) 2021 The NetBSD Foundation, Inc.
5 1.1 pho * All rights reserved.
6 1.1 pho *
7 1.1 pho * Redistribution and use in source and binary forms, with or without
8 1.1 pho * modification, are permitted provided that the following conditions
9 1.1 pho * are met:
10 1.1 pho * 1. Redistributions of source code must retain the above copyright
11 1.1 pho * notice, this list of conditions and the following disclaimer.
12 1.1 pho * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 pho * notice, this list of conditions and the following disclaimer in the
14 1.1 pho * documentation and/or other materials provided with the distribution.
15 1.1 pho * 3. The name of the author may not be used to endorse or promote
16 1.1 pho * products derived from this software without specific prior written
17 1.1 pho * permission.
18 1.1 pho *
19 1.1 pho * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
20 1.1 pho * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 1.1 pho * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 1.1 pho * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
23 1.1 pho * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 1.1 pho * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
25 1.1 pho * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 pho * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27 1.1 pho * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 1.1 pho * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29 1.1 pho * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 1.1 pho */
31 1.1 pho #if !defined(_FUSE_LEGACY_H_)
32 1.1 pho #define _FUSE_LEGACY_H_
33 1.1 pho
34 1.1 pho #include <sys/fstypes.h>
35 1.1 pho
36 1.1 pho /* Legacy data types and functions that had once existed but have been
37 1.1 pho * removed from the FUSE API. */
38 1.1 pho
39 1.1 pho #if !defined(FUSE_H_)
40 1.1 pho # error Do not include this header directly. Include <fuse.h> instead.
41 1.1 pho #endif
42 1.1 pho
43 1.1 pho #ifdef __cplusplus
44 1.1 pho extern "C" {
45 1.1 pho #endif
46 1.1 pho
47 1.1 pho /* statfs structure used by FUSE < 1.9. On 2.1 it's been replaced with
48 1.1 pho * "struct statfs" and later replaced again with struct statvfs on
49 1.1 pho * 2.5. */
50 1.1 pho struct fuse_statfs {
51 1.1 pho long block_size;
52 1.1 pho long blocks;
53 1.1 pho long blocks_free;
54 1.1 pho long files;
55 1.1 pho long files_free;
56 1.1 pho long namelen;
57 1.1 pho };
58 1.1 pho
59 1.1 pho /* Linux-specific struct statfs; used by FUSE >= 2.1 && < 2.5. */
60 1.1 pho struct statfs {
61 1.1 pho long f_type;
62 1.1 pho long f_bsize;
63 1.1 pho fsblkcnt_t f_blocks;
64 1.1 pho fsblkcnt_t f_bfree;
65 1.1 pho fsblkcnt_t f_bavail;
66 1.1 pho fsfilcnt_t f_files;
67 1.1 pho fsfilcnt_t f_ffree;
68 1.1 pho fsid_t f_fsid;
69 1.1 pho long f_namelen;
70 1.1 pho long f_frsize;
71 1.1 pho long f_flags;
72 1.1 pho };
73 1.1 pho
74 1.1 pho /* Handle for a getdir() operation. Removed as of FUSE 3.0. */
75 1.1 pho typedef void *fuse_dirh_t;
76 1.1 pho
77 1.1 pho /* Enable debugging output. Removed on FUSE 3.0. */
78 1.1 pho #define FUSE_DEBUG (1 << 1)
79 1.1 pho
80 1.1 pho /* Invalidate cached data of a file. Added on FUSE 1.9 and removed on
81 1.1 pho * FUSE 3.0. Not to be confused with fuse_invalidate_path() appeared
82 1.1 pho * on FUSE 3.2. */
83 1.1 pho int fuse_invalidate(struct fuse *f, const char *path);
84 1.1 pho
85 1.1 pho /* Check whether a mount option should be passed to the kernel or the
86 1.1 pho * library. Added on FUSE 1.9 and removed on FUSE 3.0. */
87 1.1 pho int fuse_is_lib_option(const char *opt);
88 1.1 pho
89 1.1 pho #ifdef __cplusplus
90 1.1 pho }
91 1.1 pho #endif
92 1.1 pho
93 1.1 pho #endif
94