blob: 71b2930b8e0b89d9301251b43dea35fab01a9619 [file] [log] [blame]
Steve Frenchddfbefb2011-03-15 02:08:48 +00001/*
2 * fs/cifs/smb2proto.h
3 *
4 * Copyright (c) International Business Machines Corp., 2002, 2011
5 * Etersoft, 2012
6 * Author(s): Steve French (sfrench@us.ibm.com)
7 * Pavel Shilovsky (pshilovsky@samba.org) 2012
8 *
9 * This library is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU Lesser General Public License as published
11 * by the Free Software Foundation; either version 2.1 of the License, or
12 * (at your option) any later version.
13 *
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
17 * the GNU Lesser General Public License for more details.
18 *
19 * You should have received a copy of the GNU Lesser General Public License
20 * along with this library; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 */
23#ifndef _SMB2PROTO_H
24#define _SMB2PROTO_H
25#include <linux/nls.h>
26#include <linux/key-type.h>
27
28struct statfs;
Jeff Layton0b688cf2012-09-18 16:20:34 -070029struct smb_rqst;
Steve Frenchddfbefb2011-03-15 02:08:48 +000030
31/*
32 *****************************************************************
33 * All Prototypes
34 *****************************************************************
35 */
36extern int map_smb2_to_linux_error(char *buf, bool log_err);
Steve French373512e2015-12-18 13:05:30 -060037extern int smb2_check_message(char *buf, unsigned int length,
38 struct TCP_Server_Info *server);
Ronnie Sahlberg9ec672b2018-04-22 15:30:12 -060039extern unsigned int smb2_calc_size(void *buf, struct TCP_Server_Info *server);
Ronnie Sahlberge4dc31f2018-06-01 10:53:05 +100040extern char *smb2_get_data_area_len(int *off, int *len,
41 struct smb2_sync_hdr *shdr);
Pavel Shilovsky2503a0d2011-12-26 22:58:46 +040042extern __le16 *cifs_convert_path_to_utf16(const char *from,
43 struct cifs_sb_info *cifs_sb);
Steve Frenchddfbefb2011-03-15 02:08:48 +000044
Jeff Layton0b688cf2012-09-18 16:20:34 -070045extern int smb2_verify_signature(struct smb_rqst *, struct TCP_Server_Info *);
Pavel Shilovsky2dc7e1c2011-12-26 22:53:34 +040046extern int smb2_check_receive(struct mid_q_entry *mid,
47 struct TCP_Server_Info *server, bool log_error);
Jeff Laytonfec344e2012-09-18 16:20:35 -070048extern struct mid_q_entry *smb2_setup_request(struct cifs_ses *ses,
49 struct smb_rqst *rqst);
50extern struct mid_q_entry *smb2_setup_async_request(
51 struct TCP_Server_Info *server, struct smb_rqst *rqst);
Sachin Prabhu38bd4902017-03-03 15:41:38 -080052extern struct cifs_ses *smb2_find_smb_ses(struct TCP_Server_Info *server,
53 __u64 ses_id);
54extern struct cifs_tcon *smb2_find_smb_tcon(struct TCP_Server_Info *server,
55 __u64 ses_id, __u32 tid);
Steve French38107d42012-12-08 22:08:06 -060056extern int smb2_calc_signature(struct smb_rqst *rqst,
57 struct TCP_Server_Info *server);
58extern int smb3_calc_signature(struct smb_rqst *rqst,
59 struct TCP_Server_Info *server);
Pavel Shilovskyc95b8ee2012-07-11 14:45:28 +040060extern void smb2_echo_request(struct work_struct *work);
Pavel Shilovsky0822f512012-09-19 06:22:45 -070061extern __le32 smb2_get_lease_state(struct cifsInodeInfo *cinode);
Pavel Shilovsky983c88a2012-09-18 16:20:33 -070062extern bool smb2_is_valid_oplock_break(char *buffer,
63 struct TCP_Server_Info *srv);
Pavel Shilovsky026e93d2016-11-03 16:47:37 -070064extern struct cifs_ses *smb2_find_smb_ses(struct TCP_Server_Info *server,
65 __u64 ses_id);
Pavel Shilovsky4326ed22016-11-17 15:24:46 -080066extern int smb3_handle_read_data(struct TCP_Server_Info *server,
67 struct mid_q_entry *mid);
Pavel Shilovsky2dc7e1c2011-12-26 22:53:34 +040068
Steve French3d4ef9a2018-04-25 22:19:09 -050069extern int open_shroot(unsigned int xid, struct cifs_tcon *tcon,
70 struct cifs_fid *pfid);
Ronnie Sahlberg9da6ec72018-07-31 08:48:22 +100071extern void close_shroot(struct cached_fid *cfid);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -070072extern void move_smb2_info_to_cifs(FILE_ALL_INFO *dst,
73 struct smb2_file_all_info *src);
Pavel Shilovskybe4cb9e2011-12-29 17:06:33 +040074extern int smb2_query_path_info(const unsigned int xid, struct cifs_tcon *tcon,
75 struct cifs_sb_info *cifs_sb,
76 const char *full_path, FILE_ALL_INFO *data,
Pavel Shilovskyeb85d94b2013-10-23 17:49:47 +040077 bool *adjust_tz, bool *symlink);
Pavel Shilovskyc839ff22012-09-18 16:20:32 -070078extern int smb2_set_path_size(const unsigned int xid, struct cifs_tcon *tcon,
79 const char *full_path, __u64 size,
80 struct cifs_sb_info *cifs_sb, bool set_alloc);
Pavel Shilovsky1feeaac2012-09-18 16:20:32 -070081extern int smb2_set_file_info(struct inode *inode, const char *full_path,
82 FILE_BASIC_INFO *buf, const unsigned int xid);
Steve Frenchbea851b2018-06-14 21:56:32 -050083extern int smb311_posix_mkdir(const unsigned int xid, struct inode *inode,
84 umode_t mode, struct cifs_tcon *tcon,
85 const char *full_path,
86 struct cifs_sb_info *cifs_sb);
Steve Frenchc3ca78e2019-09-25 00:32:13 -050087extern int smb2_mkdir(const unsigned int xid, struct inode *inode,
88 umode_t mode, struct cifs_tcon *tcon,
Pavel Shilovskya0e73182011-07-19 12:56:37 +040089 const char *name, struct cifs_sb_info *cifs_sb);
90extern void smb2_mkdir_setinfo(struct inode *inode, const char *full_path,
91 struct cifs_sb_info *cifs_sb,
92 struct cifs_tcon *tcon, const unsigned int xid);
Pavel Shilovsky1a500f02012-07-10 16:14:38 +040093extern int smb2_rmdir(const unsigned int xid, struct cifs_tcon *tcon,
94 const char *name, struct cifs_sb_info *cifs_sb);
Pavel Shilovskycbe6f432012-09-18 16:20:25 -070095extern int smb2_unlink(const unsigned int xid, struct cifs_tcon *tcon,
96 const char *name, struct cifs_sb_info *cifs_sb);
Pavel Shilovsky35143eb2012-09-18 16:20:31 -070097extern int smb2_rename_path(const unsigned int xid, struct cifs_tcon *tcon,
98 const char *from_name, const char *to_name,
99 struct cifs_sb_info *cifs_sb);
Pavel Shilovsky568798c2012-09-18 16:20:31 -0700100extern int smb2_create_hardlink(const unsigned int xid, struct cifs_tcon *tcon,
101 const char *from_name, const char *to_name,
102 struct cifs_sb_info *cifs_sb);
Steve French5ab97572014-09-15 04:49:28 -0500103extern int smb3_create_mf_symlink(unsigned int xid, struct cifs_tcon *tcon,
104 struct cifs_sb_info *cifs_sb, const unsigned char *path,
105 char *pbuf, unsigned int *pbytes_written);
Steve Frenchc22870e2014-09-16 07:18:19 -0500106extern int smb3_query_mf_symlink(unsigned int xid, struct cifs_tcon *tcon,
107 struct cifs_sb_info *cifs_sb,
108 const unsigned char *path, char *pbuf,
109 unsigned int *pbytes_read);
Pavel Shilovsky226730b2013-07-05 12:00:30 +0400110extern int smb2_open_file(const unsigned int xid,
111 struct cifs_open_parms *oparms,
112 __u32 *oplock, FILE_ALL_INFO *buf);
Pavel Shilovskyf7ba7fe2012-09-19 06:22:43 -0700113extern int smb2_unlock_range(struct cifsFileInfo *cfile,
114 struct file_lock *flock, const unsigned int xid);
Pavel Shilovskyb1407992012-09-19 06:22:44 -0700115extern int smb2_push_mandatory_locks(struct cifsFileInfo *cfile);
Pavel Shilovsky53e0e112016-11-04 11:50:31 -0700116extern void smb2_reconnect_server(struct work_struct *work);
Pavel Shilovsky026e93d2016-11-03 16:47:37 -0700117extern int smb3_crypto_aead_allocate(struct TCP_Server_Info *server);
Ronnie Sahlberg81f39f92018-06-28 10:47:14 +1000118extern unsigned long smb_rqst_len(struct TCP_Server_Info *server,
119 struct smb_rqst *rqst);
Ronnie Sahlberge77fe732018-12-31 13:43:40 +1000120extern void smb2_set_next_command(struct cifs_tcon *tcon,
121 struct smb_rqst *rqst);
Ronnie Sahlbergc5a5f382018-09-03 13:33:41 +1000122extern void smb2_set_related(struct smb_rqst *rqst);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -0700123
Pavel Shilovskyec2e4522011-12-27 16:12:43 +0400124/*
125 * SMB2 Worker functions - most of protocol specific implementation details
126 * are contained within these calls.
127 */
128extern int SMB2_negotiate(const unsigned int xid, struct cifs_ses *ses);
Pavel Shilovsky5478f9b2011-12-27 16:22:00 +0400129extern int SMB2_sess_setup(const unsigned int xid, struct cifs_ses *ses,
130 const struct nls_table *nls_cp);
131extern int SMB2_logoff(const unsigned int xid, struct cifs_ses *ses);
Pavel Shilovskyfaaf9462011-12-27 16:04:00 +0400132extern int SMB2_tcon(const unsigned int xid, struct cifs_ses *ses,
133 const char *tree, struct cifs_tcon *tcon,
134 const struct nls_table *);
135extern int SMB2_tdis(const unsigned int xid, struct cifs_tcon *tcon);
Pavel Shilovsky064f6042013-07-09 18:20:30 +0400136extern int SMB2_open(const unsigned int xid, struct cifs_open_parms *oparms,
137 __le16 *path, __u8 *oplock,
Pavel Shilovskyb42bf882013-08-14 19:25:21 +0400138 struct smb2_file_all_info *buf,
Ronnie Sahlberg9d874c32018-06-08 13:21:18 +1000139 struct kvec *err_iov, int *resp_buftype);
Ronnie Sahlberg1eb9fb52018-08-08 15:07:46 +1000140extern int SMB2_open_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
141 __u8 *oplock, struct cifs_open_parms *oparms,
142 __le16 *path);
143extern void SMB2_open_free(struct smb_rqst *rqst);
Steve French4a72daf2013-06-25 00:20:49 -0500144extern int SMB2_ioctl(const unsigned int xid, struct cifs_tcon *tcon,
145 u64 persistent_fid, u64 volatile_fid, u32 opcode,
Steve French153322f2019-03-28 22:32:49 -0500146 bool is_fsctl, char *in_data, u32 indatalen, u32 maxoutlen,
Steve French4a72daf2013-06-25 00:20:49 -0500147 char **out_data, u32 *plen /* returned data len */);
Ronnie Sahlbergccdc77a2019-03-13 14:37:48 +1000148extern int SMB2_ioctl_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
149 u64 persistent_fid, u64 volatile_fid, u32 opcode,
Steve French153322f2019-03-28 22:32:49 -0500150 bool is_fsctl, char *in_data, u32 indatalen,
151 __u32 max_response_size);
Ronnie Sahlbergccdc77a2019-03-13 14:37:48 +1000152extern void SMB2_ioctl_free(struct smb_rqst *rqst);
Steve French52870d52019-10-01 21:25:46 -0500153extern int SMB2_change_notify(const unsigned int xid, struct cifs_tcon *tcon,
154 u64 persistent_fid, u64 volatile_fid, bool watch_tree,
155 u32 completion_filter);
156
Pavel Shilovsky2503a0d2011-12-26 22:58:46 +0400157extern int SMB2_close(const unsigned int xid, struct cifs_tcon *tcon,
158 u64 persistent_file_id, u64 volatile_file_id);
Ronnie Sahlberg97ca1762018-04-26 08:50:49 -0600159extern int SMB2_close_flags(const unsigned int xid, struct cifs_tcon *tcon,
160 u64 persistent_fid, u64 volatile_fid, int flags);
Ronnie Sahlberg8eb4ecf2018-08-01 09:26:16 +1000161extern int SMB2_close_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
162 u64 persistent_file_id, u64 volatile_file_id);
163extern void SMB2_close_free(struct smb_rqst *rqst);
Pavel Shilovsky7a5cfb12012-09-18 16:20:28 -0700164extern int SMB2_flush(const unsigned int xid, struct cifs_tcon *tcon,
165 u64 persistent_file_id, u64 volatile_file_id);
Ronnie Sahlberg86e14e12019-07-16 15:07:08 +1000166extern int SMB2_flush_init(const unsigned int xid, struct smb_rqst *rqst,
167 struct cifs_tcon *tcon,
168 u64 persistent_file_id, u64 volatile_file_id);
169extern void SMB2_flush_free(struct smb_rqst *rqst);
Pavel Shilovskybe4cb9e2011-12-29 17:06:33 +0400170extern int SMB2_query_info(const unsigned int xid, struct cifs_tcon *tcon,
171 u64 persistent_file_id, u64 volatile_file_id,
172 struct smb2_file_all_info *data);
Ronnie Sahlberg296ecba2018-08-01 09:26:17 +1000173extern int SMB2_query_info_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
174 u64 persistent_fid, u64 volatile_fid,
175 u8 info_class, u8 info_type,
Ronnie Sahlbergf5b05d62018-10-07 19:19:58 -0500176 u32 additional_info, size_t output_len,
177 size_t input_len, void *input);
Ronnie Sahlberg296ecba2018-08-01 09:26:17 +1000178extern void SMB2_query_info_free(struct smb_rqst *rqst);
Shirish Pargaonkar42c493c2017-06-22 22:51:31 -0500179extern int SMB2_query_acl(const unsigned int xid, struct cifs_tcon *tcon,
180 u64 persistent_file_id, u64 volatile_file_id,
181 void **data, unsigned int *plen);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -0700182extern int SMB2_get_srv_num(const unsigned int xid, struct cifs_tcon *tcon,
183 u64 persistent_fid, u64 volatile_fid,
184 __le64 *uniqueid);
Pavel Shilovsky09a47072012-09-18 16:20:29 -0700185extern int smb2_async_readv(struct cifs_readdata *rdata);
Pavel Shilovskyd8e05032012-09-18 16:20:30 -0700186extern int SMB2_read(const unsigned int xid, struct cifs_io_parms *io_parms,
187 unsigned int *nbytes, char **buf, int *buf_type);
Steve French4a5c80d2014-02-07 20:45:12 -0600188extern int smb2_async_writev(struct cifs_writedata *wdata,
189 void (*release)(struct kref *kref));
Pavel Shilovsky009d3442012-09-18 16:20:30 -0700190extern int SMB2_write(const unsigned int xid, struct cifs_io_parms *io_parms,
191 unsigned int *nbytes, struct kvec *iov, int n_vec);
Pavel Shilovsky9094fad2012-07-12 18:30:44 +0400192extern int SMB2_echo(struct TCP_Server_Info *server);
Pavel Shilovskyd324f08d2012-09-18 16:20:33 -0700193extern int SMB2_query_directory(const unsigned int xid, struct cifs_tcon *tcon,
194 u64 persistent_fid, u64 volatile_fid, int index,
195 struct cifs_search_info *srch_inf);
Pavel Shilovskyc839ff22012-09-18 16:20:32 -0700196extern int SMB2_set_eof(const unsigned int xid, struct cifs_tcon *tcon,
197 u64 persistent_fid, u64 volatile_fid, u32 pid,
Ronnie Sahlberg3764cbd2018-09-03 13:33:47 +1000198 __le64 *eof);
Ronnie Sahlbergba8ca112018-09-03 13:33:44 +1000199extern int SMB2_set_info_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
200 u64 persistent_fid, u64 volatile_fid, u32 pid,
201 u8 info_class, u8 info_type, u32 additional_info,
202 void **data, unsigned int *size);
203extern void SMB2_set_info_free(struct smb_rqst *rqst);
Shirish Pargaonkardac95342017-06-28 22:37:00 -0500204extern int SMB2_set_acl(const unsigned int xid, struct cifs_tcon *tcon,
205 u64 persistent_fid, u64 volatile_fid,
206 struct cifs_ntsd *pnntsd, int pacllen, int aclflag);
Ronnie Sahlberg55175542017-08-24 11:24:56 +1000207extern int SMB2_set_ea(const unsigned int xid, struct cifs_tcon *tcon,
208 u64 persistent_fid, u64 volatile_fid,
209 struct smb2_file_full_ea_info *buf, int len);
Steve French64a5cfa2013-10-14 15:31:32 -0500210extern int SMB2_set_compression(const unsigned int xid, struct cifs_tcon *tcon,
211 u64 persistent_fid, u64 volatile_fid);
Pavel Shilovsky983c88a2012-09-18 16:20:33 -0700212extern int SMB2_oplock_break(const unsigned int xid, struct cifs_tcon *tcon,
213 const u64 persistent_fid, const u64 volatile_fid,
214 const __u8 oplock_level);
Sachin Prabhu38bd4902017-03-03 15:41:38 -0800215extern int smb2_handle_cancelled_mid(char *buffer,
216 struct TCP_Server_Info *server);
217void smb2_cancelled_close_fid(struct work_struct *work);
Pavel Shilovsky6fc05c22012-09-18 16:20:34 -0700218extern int SMB2_QFS_info(const unsigned int xid, struct cifs_tcon *tcon,
219 u64 persistent_file_id, u64 volatile_file_id,
220 struct kstatfs *FSData);
Steve French2d304212018-06-24 23:28:12 -0500221extern int SMB311_posix_qfs_info(const unsigned int xid, struct cifs_tcon *tcon,
222 u64 persistent_file_id, u64 volatile_file_id,
223 struct kstatfs *FSData);
Steve French34f62642013-10-09 02:07:00 -0500224extern int SMB2_QFS_attr(const unsigned int xid, struct cifs_tcon *tcon,
Steven French21671142013-10-09 13:36:35 -0500225 u64 persistent_file_id, u64 volatile_file_id, int lvl);
Pavel Shilovskyf7ba7fe2012-09-19 06:22:43 -0700226extern int SMB2_lock(const unsigned int xid, struct cifs_tcon *tcon,
227 const __u64 persist_fid, const __u64 volatile_fid,
228 const __u32 pid, const __u64 length, const __u64 offset,
229 const __u32 lockFlags, const bool wait);
230extern int smb2_lockv(const unsigned int xid, struct cifs_tcon *tcon,
231 const __u64 persist_fid, const __u64 volatile_fid,
232 const __u32 pid, const __u32 num_lock,
233 struct smb2_lock_element *buf);
Pavel Shilovsky0822f512012-09-19 06:22:45 -0700234extern int SMB2_lease_break(const unsigned int xid, struct cifs_tcon *tcon,
235 __u8 *lease_key, const __le32 lease_state);
Steve Frenchff1c0382013-11-19 23:44:46 -0600236extern int smb3_validate_negotiate(const unsigned int, struct cifs_tcon *);
Pavel Shilovskyec2e4522011-12-27 16:12:43 +0400237
Sachin Prabhuef65aae2017-01-18 15:35:57 +0530238extern enum securityEnum smb2_select_sectype(struct TCP_Server_Info *,
239 enum securityEnum);
Steve French89a5bfa2019-07-18 17:22:18 -0500240extern void smb2_parse_contexts(struct TCP_Server_Info *server,
241 struct smb2_create_rsp *rsp,
242 unsigned int *epoch, char *lease_key,
243 __u8 *oplock, struct smb2_file_all_info *buf);
Ronnie Sahlberg730928c2018-08-08 15:07:49 +1000244extern int smb3_encryption_required(const struct cifs_tcon *tcon);
245extern int smb2_validate_iov(unsigned int offset, unsigned int buffer_length,
246 struct kvec *iov, unsigned int min_buf_size);
Ronnie Sahlbergc5a5f382018-09-03 13:33:41 +1000247extern int smb2_validate_and_copy_iov(unsigned int offset,
248 unsigned int buffer_length,
249 struct kvec *iov,
250 unsigned int minbufsize, char *data);
Ronnie Sahlberg730928c2018-08-08 15:07:49 +1000251extern void smb2_copy_fs_info_to_kstatfs(
252 struct smb2_fs_full_size_info *pfs_inf,
253 struct kstatfs *kst);
Aurelien Aptel5fcd7f32018-02-16 19:19:28 +0100254extern int smb311_crypto_shash_allocate(struct TCP_Server_Info *server);
Aurelien Aptel8bd68c62018-02-16 19:19:29 +0100255extern int smb311_update_preauth_hash(struct cifs_ses *ses,
256 struct kvec *iov, int nvec);
Ronnie Sahlbergf9793b62018-11-27 09:52:04 +1000257extern int smb2_query_info_compound(const unsigned int xid,
258 struct cifs_tcon *tcon,
259 __le16 *utf16_path, u32 desired_access,
260 u32 class, u32 type, u32 output_len,
261 struct kvec *rsp, int *buftype,
262 struct cifs_sb_info *cifs_sb);
Steve Frenchddfbefb2011-03-15 02:08:48 +0000263#endif /* _SMB2PROTO_H */