1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 /* 22 * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23 * Use is subject to license terms. 24 */ 25 26 #ifndef _SMBSRV_SMB_FSOPS_H 27 #define _SMBSRV_SMB_FSOPS_H 28 29 #pragma ident "%Z%%M% %I% %E% SMI" 30 31 /* 32 * This header file contains all the functions for the interface between 33 * the smb layer and the fs layer. 34 */ 35 #include <smbsrv/smb_i18n.h> 36 #include <smbsrv/smbinfo.h> 37 #include <smbsrv/smb_ktypes.h> 38 #include <smbsrv/smb_vops.h> 39 #include <sys/callb.h> 40 #include <sys/flock.h> 41 42 #ifdef __cplusplus 43 extern "C" { 44 #endif 45 46 int smb_fsop_open(smb_ofile_t *of); 47 48 int smb_fsop_close(smb_ofile_t *of); 49 50 int smb_fsop_create(smb_request_t *, cred_t *, smb_node_t *, 51 char *name, smb_attr_t *attr, smb_node_t **ret_snode, smb_attr_t *ret_attr); 52 53 int smb_fsop_mkdir(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 54 char *name, smb_attr_t *attr, smb_node_t **ret_snode, smb_attr_t *ret_attr); 55 56 int smb_fsop_remove(struct smb_request *sr, cred_t *cr, smb_node_t *dir_snode, 57 char *name, int od); 58 59 int smb_fsop_rmdir(struct smb_request *sr, cred_t *cr, smb_node_t *dir_snode, 60 char *name, int od); 61 62 int smb_fsop_getattr(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 63 smb_attr_t *attr); 64 65 int smb_fsop_readdir(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 66 uint32_t *cookie, char *name, int *namelen, ino64_t *fileid, 67 struct fs_stream_info *stream_info, smb_node_t **ret_snode, 68 smb_attr_t *ret_attr); 69 70 int smb_fsop_getdents(struct smb_request *sr, cred_t *cr, 71 struct smb_node *dir_snode, uint32_t *cookie, uint64_t *verifierp, 72 int32_t *maxcnt, char *args, char *pattern); 73 74 int smb_maybe_mangled_name(char *name); 75 76 int smb_fsop_rename(struct smb_request *sr, cred_t *cr, 77 smb_node_t *from_snode, char *from_name, smb_node_t *to_snode, 78 char *to_name); 79 80 int smb_fsop_setattr(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 81 smb_attr_t *set_attr, smb_attr_t *ret_attr); 82 83 int smb_fsop_read(struct smb_request *sr, cred_t *cr, 84 smb_node_t *snode, uio_t *uio, smb_attr_t *ret_attr); 85 86 int smb_fsop_write(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 87 uio_t *uio, uint32_t *lcount, smb_attr_t *ret_attr, 88 uint32_t *stability); 89 90 int smb_fsop_statfs(cred_t *cr, struct smb_node *snode, 91 struct statvfs64 *statp); 92 93 int smb_fsop_remove_streams(struct smb_request *sr, cred_t *cr, 94 smb_node_t *fnode); 95 96 int smb_fsop_access(smb_request_t *sr, cred_t *cr, smb_node_t *snode, 97 uint32_t faccess); 98 99 void smb_fsop_eaccess(smb_request_t *sr, cred_t *cr, smb_node_t *snode, 100 uint32_t *faccess); 101 102 int smb_fsop_lookup_name(struct smb_request *sr, cred_t *cr, int flags, 103 smb_node_t *root_node, smb_node_t *dir_snode, char *name, 104 smb_node_t **ret_snode, smb_attr_t *ret_attr); 105 106 int smb_fsop_lookup(struct smb_request *sr, cred_t *cr, int flags, 107 smb_node_t *root_node, smb_node_t *dir_snode, char *name, 108 smb_node_t **ret_snode, smb_attr_t *ret_attr, char *ret_shortname, 109 char *ret_name83); 110 111 int smb_fsop_commit(smb_request_t *sr, cred_t *cr, struct smb_node *snode); 112 113 int smb_fsop_stream_readdir(struct smb_request *sr, cred_t *cr, 114 smb_node_t *fnode, uint32_t *cookiep, struct fs_stream_info *stream_info, 115 smb_node_t **ret_snode, smb_attr_t *ret_attr); 116 117 int smb_fsop_aclread(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 118 int smb_fsop_aclwrite(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 119 acl_type_t smb_fsop_acltype(smb_node_t *); 120 int smb_fsop_sdread(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 121 int smb_fsop_sdwrite(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *, 122 int); 123 124 uint32_t smb_fsop_shrlock(cred_t *, smb_node_t *, uint32_t, uint32_t, uint32_t); 125 void smb_fsop_unshrlock(cred_t *cr, smb_node_t *node, uint32_t uniq_fid); 126 127 /* 128 * Lookup-related flags 129 * 130 * SMB_FOLLOW_LINKS Follow symbolic links. 131 * SMB_IGNORE_CASE Perform case-insensitive lookup. 132 * 133 * Misc flags 134 * 135 * SMB_STREAM_RDDIR use eflags=0 for streams readdirs this 136 * is currently a workaround because the 137 * vfs isn't filling in this flag 138 */ 139 140 #define SMB_FOLLOW_LINKS 0x00000001 141 #define SMB_IGNORE_CASE 0x00000002 142 #define SMB_STREAM_RDDIR 0x00000004 143 144 #ifdef __cplusplus 145 } 146 #endif 147 148 #endif /* _SMBSRV_SMB_FSOPS_H */ 149