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_vops.h> 38 #include <smbsrv/smbvar.h> 39 #include <sys/callb.h> 40 #include <sys/flock.h> 41 42 #ifdef __cplusplus 43 extern "C" { 44 #endif 45 46 extern caller_context_t smb_ct; 47 48 int smb_fsop_open(smb_ofile_t *of); 49 50 int smb_fsop_close(smb_ofile_t *of); 51 52 int smb_fsop_create(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 53 char *name, smb_attr_t *attr, smb_node_t **ret_snode, smb_attr_t *ret_attr); 54 55 int smb_fsop_mkdir(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 56 char *name, smb_attr_t *attr, smb_node_t **ret_snode, smb_attr_t *ret_attr); 57 58 int smb_fsop_remove(struct smb_request *sr, cred_t *cr, smb_node_t *dir_snode, 59 char *name, int od); 60 61 int smb_fsop_rmdir(struct smb_request *sr, cred_t *cr, smb_node_t *dir_snode, 62 char *name, int od); 63 64 int smb_fsop_getattr(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 65 smb_attr_t *attr); 66 67 int smb_fsop_readdir(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 68 uint32_t *cookie, char *name, int *namelen, ino64_t *fileid, 69 struct fs_stream_info *stream_info, smb_node_t **ret_snode, 70 smb_attr_t *ret_attr); 71 72 int smb_fsop_getdents(struct smb_request *sr, cred_t *cr, 73 struct smb_node *dir_snode, uint32_t *cookie, uint64_t *verifierp, 74 int32_t *maxcnt, char *args, char *pattern); 75 76 int smb_maybe_mangled_name(char *name); 77 78 int smb_fsop_rename(struct smb_request *sr, cred_t *cr, 79 smb_node_t *from_snode, char *from_name, smb_node_t *to_snode, 80 char *to_name); 81 82 int smb_fsop_setattr(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 83 smb_attr_t *set_attr, smb_attr_t *ret_attr); 84 85 int smb_fsop_read(struct smb_request *sr, cred_t *cr, 86 smb_node_t *snode, uio_t *uio, smb_attr_t *ret_attr); 87 88 int smb_fsop_write(struct smb_request *sr, cred_t *cr, smb_node_t *snode, 89 uio_t *uio, uint32_t *lcount, smb_attr_t *ret_attr, 90 uint32_t *stability); 91 92 int smb_fsop_statfs(cred_t *cr, struct smb_node *snode, 93 struct statvfs64 *statp); 94 95 int smb_fsop_remove_streams(struct smb_request *sr, cred_t *cr, 96 smb_node_t *fnode); 97 98 int smb_fsop_access(smb_request_t *sr, cred_t *cr, smb_node_t *snode, 99 uint32_t faccess); 100 101 void smb_fsop_eaccess(smb_request_t *sr, cred_t *cr, smb_node_t *snode, 102 uint32_t *faccess); 103 104 int smb_fsop_lookup_name(struct smb_request *sr, cred_t *cr, int flags, 105 smb_node_t *root_node, smb_node_t *dir_snode, char *name, 106 smb_node_t **ret_snode, smb_attr_t *ret_attr); 107 108 int smb_fsop_lookup(struct smb_request *sr, cred_t *cr, int flags, 109 smb_node_t *root_node, smb_node_t *dir_snode, char *name, 110 smb_node_t **ret_snode, smb_attr_t *ret_attr, char *ret_shortname, 111 char *ret_name83); 112 113 int smb_fsop_commit(smb_request_t *sr, cred_t *cr, struct smb_node *snode); 114 115 int smb_fsop_stream_readdir(struct smb_request *sr, cred_t *cr, 116 smb_node_t *fnode, uint32_t *cookiep, struct fs_stream_info *stream_info, 117 smb_node_t **ret_snode, smb_attr_t *ret_attr); 118 119 int smb_fsop_aclread(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 120 int smb_fsop_aclwrite(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 121 acl_type_t smb_fsop_acltype(smb_node_t *); 122 int smb_fsop_sdread(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *); 123 int smb_fsop_sdwrite(smb_request_t *, cred_t *, smb_node_t *, smb_fssd_t *, 124 int); 125 126 uint32_t smb_fsop_shrlock(cred_t *cr, smb_node_t *node, uint32_t uniq_fid, 127 uint32_t desired_access, uint32_t share_access); 128 129 void smb_fsop_unshrlock(cred_t *cr, smb_node_t *node, uint32_t uniq_fid); 130 131 int smb_fsop_frlock(smb_request_t *sr, smb_node_t *node, smb_lock_t *lock, 132 boolean_t unlock); 133 134 /* 135 * Lookup-related flags 136 * 137 * SMB_FOLLOW_LINKS Follow symbolic links. 138 * SMB_IGNORE_CASE Perform case-insensitive lookup. 139 * 140 * Misc flags 141 * 142 * SMB_STREAM_RDDIR use eflags=0 for streams readdirs this 143 * is currently a workaround because the 144 * vfs isn't filling in this flag 145 */ 146 147 #define SMB_FOLLOW_LINKS 0x00000001 148 #define SMB_IGNORE_CASE 0x00000002 149 #define SMB_STREAM_RDDIR 0x00000004 150 151 #ifdef __cplusplus 152 } 153 #endif 154 155 #endif /* _SMBSRV_SMB_FSOPS_H */ 156