1 /* 2 * Copyright (c) 2011-2012 The DragonFly Project. All rights reserved. 3 * 4 * This code is derived from software contributed to The DragonFly Project 5 * by Matthew Dillon <dillon@dragonflybsd.org> 6 * by Venkatesh Srinivas <vsrinivas@dragonflybsd.org> 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in 16 * the documentation and/or other materials provided with the 17 * distribution. 18 * 3. Neither the name of The DragonFly Project nor the names of its 19 * contributors may be used to endorse or promote products derived 20 * from this software without specific, prior written permission. 21 * 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 23 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 25 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 26 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 27 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, 28 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 29 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 30 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 31 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 32 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33 * SUCH DAMAGE. 34 */ 35 36 #ifndef _VFS_HAMMER2_IOCTL_H_ 37 #define _VFS_HAMMER2_IOCTL_H_ 38 39 #ifndef _SYS_IOCCOM_H_ 40 #include <sys/ioccom.h> 41 #endif 42 #ifndef _VFS_HAMMER2_DISK_H_ 43 #include "hammer2_disk.h" 44 #endif 45 #ifndef _VFS_HAMMER2_MOUNT_H_ 46 #include "hammer2_mount.h" 47 #endif 48 49 /* 50 * get_version 51 */ 52 struct hammer2_ioc_version { 53 int version; 54 char reserved[256 - 4]; 55 }; 56 57 typedef struct hammer2_ioc_version hammer2_ioc_version_t; 58 59 struct hammer2_ioc_recluster { 60 int fd; 61 char reserved[256 - 4]; 62 }; 63 64 typedef struct hammer2_ioc_recluster hammer2_ioc_recluster_t; 65 66 /* 67 * Ioctls to manage the volume->copyinfo[] array and to associate or 68 * disassociate sockets 69 */ 70 struct hammer2_ioc_remote { 71 int copyid; 72 int nextid; /* for iteration (get only) */ 73 int fd; /* socket descriptor if applicable */ 74 int reserved03; 75 int reserved04[8]; 76 dmsg_vol_data_t copy1; /* copy spec */ 77 dmsg_vol_data_t copy2; /* copy spec (rename ops only) */ 78 }; 79 80 typedef struct hammer2_ioc_remote hammer2_ioc_remote_t; 81 82 /* 83 * Ioctls to manage PFSs 84 * 85 * PFSs can be clustered by matching their pfs_clid, and the PFSs making up 86 * a cluster can be uniquely identified by combining the vol_id with 87 * the pfs_clid. 88 */ 89 struct hammer2_ioc_pfs { 90 hammer2_key_t name_key; /* super-root directory scan */ 91 hammer2_key_t name_next; /* (GET only) */ 92 uint8_t pfs_type; /* e.g. MASTER, SLAVE, ... */ 93 uint8_t reserved0011; 94 uint8_t reserved0012; 95 uint8_t reserved0013; 96 uint32_t reserved0014; 97 uint64_t reserved0018; 98 uuid_t pfs_fsid; /* identifies PFS instance */ 99 uuid_t pfs_clid; /* identifies PFS cluster */ 100 char name[NAME_MAX+1]; /* device@name mtpt */ 101 }; 102 103 typedef struct hammer2_ioc_pfs hammer2_ioc_pfs_t; 104 105 /* 106 * Ioctls to manage inodes 107 */ 108 struct hammer2_ioc_inode { 109 uint32_t flags; 110 void *kdata; 111 hammer2_inode_data_t ip_data; 112 }; 113 114 typedef struct hammer2_ioc_inode hammer2_ioc_inode_t; 115 116 #define HAMMER2IOC_INODE_FLAG_IQUOTA 0x00000001 117 #define HAMMER2IOC_INODE_FLAG_DQUOTA 0x00000002 118 #define HAMMER2IOC_INODE_FLAG_COPIES 0x00000004 119 120 /* 121 * Ioctl list 122 */ 123 124 #define HAMMER2IOC_VERSION_GET _IOWR('h', 64, struct hammer2_ioc_version) 125 #define HAMMER2IOC_RECLUSTER _IOWR('h', 65, struct hammer2_ioc_recluster) 126 127 #define HAMMER2IOC_REMOTE_SCAN _IOWR('h', 68, struct hammer2_ioc_remote) 128 #define HAMMER2IOC_REMOTE_ADD _IOWR('h', 69, struct hammer2_ioc_remote) 129 #define HAMMER2IOC_REMOTE_DEL _IOWR('h', 70, struct hammer2_ioc_remote) 130 #define HAMMER2IOC_REMOTE_REP _IOWR('h', 71, struct hammer2_ioc_remote) 131 132 #define HAMMER2IOC_SOCKET_GET _IOWR('h', 76, struct hammer2_ioc_remote) 133 #define HAMMER2IOC_SOCKET_SET _IOWR('h', 77, struct hammer2_ioc_remote) 134 135 #define HAMMER2IOC_PFS_GET _IOWR('h', 80, struct hammer2_ioc_pfs) 136 #define HAMMER2IOC_PFS_CREATE _IOWR('h', 81, struct hammer2_ioc_pfs) 137 #define HAMMER2IOC_PFS_DELETE _IOWR('h', 82, struct hammer2_ioc_pfs) 138 #define HAMMER2IOC_PFS_LOOKUP _IOWR('h', 83, struct hammer2_ioc_pfs) 139 #define HAMMER2IOC_PFS_SNAPSHOT _IOWR('h', 84, struct hammer2_ioc_pfs) 140 141 #define HAMMER2IOC_INODE_GET _IOWR('h', 86, struct hammer2_ioc_inode) 142 #define HAMMER2IOC_INODE_SET _IOWR('h', 87, struct hammer2_ioc_inode) 143 144 /*#define HAMMER2IOC_INODE_COMP_SET _IOWR('h', 88, struct hammer2_ioc_inode) //set compression mode on inode 145 #define HAMMER2IOC_INODE_COMP_REC_SET _IOWR('h', 89, struct hammer2_ioc_inode) 146 #define HAMMER2IOC_INODE_COMP_REC_SET2 _IOWR('h', 90, struct hammer2_ioc_inode)*/ 147 148 #endif /* !_VFS_HAMMER2_IOCTL_H_ */ 149