blob: 5caeaa99cb7c4d5f1b1116351853738eea26a9a1 [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,
Aurelien Aptelf780bd32019-09-20 06:08:34 +020049 struct TCP_Server_Info *,
50 struct smb_rqst *rqst);
Jeff Laytonfec344e2012-09-18 16:20:35 -070051extern struct mid_q_entry *smb2_setup_async_request(
52 struct TCP_Server_Info *server, struct smb_rqst *rqst);
Sachin Prabhu38bd4902017-03-03 15:41:38 -080053extern struct cifs_ses *smb2_find_smb_ses(struct TCP_Server_Info *server,
54 __u64 ses_id);
55extern struct cifs_tcon *smb2_find_smb_tcon(struct TCP_Server_Info *server,
56 __u64 ses_id, __u32 tid);
Steve French38107d42012-12-08 22:08:06 -060057extern int smb2_calc_signature(struct smb_rqst *rqst,
58 struct TCP_Server_Info *server);
59extern int smb3_calc_signature(struct smb_rqst *rqst,
60 struct TCP_Server_Info *server);
Pavel Shilovskyc95b8ee2012-07-11 14:45:28 +040061extern void smb2_echo_request(struct work_struct *work);
Pavel Shilovsky0822f512012-09-19 06:22:45 -070062extern __le32 smb2_get_lease_state(struct cifsInodeInfo *cinode);
Pavel Shilovsky983c88a2012-09-18 16:20:33 -070063extern bool smb2_is_valid_oplock_break(char *buffer,
64 struct TCP_Server_Info *srv);
Pavel Shilovsky026e93d2016-11-03 16:47:37 -070065extern struct cifs_ses *smb2_find_smb_ses(struct TCP_Server_Info *server,
66 __u64 ses_id);
Pavel Shilovsky4326ed22016-11-17 15:24:46 -080067extern int smb3_handle_read_data(struct TCP_Server_Info *server,
68 struct mid_q_entry *mid);
Pavel Shilovsky2dc7e1c2011-12-26 22:53:34 +040069
Steve French3d4ef9a2018-04-25 22:19:09 -050070extern int open_shroot(unsigned int xid, struct cifs_tcon *tcon,
71 struct cifs_fid *pfid);
Ronnie Sahlberg9da6ec72018-07-31 08:48:22 +100072extern void close_shroot(struct cached_fid *cfid);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -070073extern void move_smb2_info_to_cifs(FILE_ALL_INFO *dst,
74 struct smb2_file_all_info *src);
Pavel Shilovskybe4cb9e2011-12-29 17:06:33 +040075extern int smb2_query_path_info(const unsigned int xid, struct cifs_tcon *tcon,
76 struct cifs_sb_info *cifs_sb,
77 const char *full_path, FILE_ALL_INFO *data,
Pavel Shilovskyeb85d94b2013-10-23 17:49:47 +040078 bool *adjust_tz, bool *symlink);
Pavel Shilovskyc839ff22012-09-18 16:20:32 -070079extern int smb2_set_path_size(const unsigned int xid, struct cifs_tcon *tcon,
80 const char *full_path, __u64 size,
81 struct cifs_sb_info *cifs_sb, bool set_alloc);
Pavel Shilovsky1feeaac2012-09-18 16:20:32 -070082extern int smb2_set_file_info(struct inode *inode, const char *full_path,
83 FILE_BASIC_INFO *buf, const unsigned int xid);
Steve Frenchbea851b2018-06-14 21:56:32 -050084extern int smb311_posix_mkdir(const unsigned int xid, struct inode *inode,
85 umode_t mode, struct cifs_tcon *tcon,
86 const char *full_path,
87 struct cifs_sb_info *cifs_sb);
Steve Frenchc3ca78e2019-09-25 00:32:13 -050088extern int smb2_mkdir(const unsigned int xid, struct inode *inode,
89 umode_t mode, struct cifs_tcon *tcon,
Pavel Shilovskya0e73182011-07-19 12:56:37 +040090 const char *name, struct cifs_sb_info *cifs_sb);
91extern void smb2_mkdir_setinfo(struct inode *inode, const char *full_path,
92 struct cifs_sb_info *cifs_sb,
93 struct cifs_tcon *tcon, const unsigned int xid);
Pavel Shilovsky1a500f02012-07-10 16:14:38 +040094extern int smb2_rmdir(const unsigned int xid, struct cifs_tcon *tcon,
95 const char *name, struct cifs_sb_info *cifs_sb);
Pavel Shilovskycbe6f432012-09-18 16:20:25 -070096extern int smb2_unlink(const unsigned int xid, struct cifs_tcon *tcon,
97 const char *name, struct cifs_sb_info *cifs_sb);
Pavel Shilovsky35143eb2012-09-18 16:20:31 -070098extern int smb2_rename_path(const unsigned int xid, struct cifs_tcon *tcon,
99 const char *from_name, const char *to_name,
100 struct cifs_sb_info *cifs_sb);
Pavel Shilovsky568798c2012-09-18 16:20:31 -0700101extern int smb2_create_hardlink(const unsigned int xid, struct cifs_tcon *tcon,
102 const char *from_name, const char *to_name,
103 struct cifs_sb_info *cifs_sb);
Steve French5ab97572014-09-15 04:49:28 -0500104extern int smb3_create_mf_symlink(unsigned int xid, struct cifs_tcon *tcon,
105 struct cifs_sb_info *cifs_sb, const unsigned char *path,
106 char *pbuf, unsigned int *pbytes_written);
Steve Frenchc22870e2014-09-16 07:18:19 -0500107extern int smb3_query_mf_symlink(unsigned int xid, struct cifs_tcon *tcon,
108 struct cifs_sb_info *cifs_sb,
109 const unsigned char *path, char *pbuf,
110 unsigned int *pbytes_read);
Pavel Shilovsky226730b2013-07-05 12:00:30 +0400111extern int smb2_open_file(const unsigned int xid,
112 struct cifs_open_parms *oparms,
113 __u32 *oplock, FILE_ALL_INFO *buf);
Pavel Shilovskyf7ba7fe2012-09-19 06:22:43 -0700114extern int smb2_unlock_range(struct cifsFileInfo *cfile,
115 struct file_lock *flock, const unsigned int xid);
Pavel Shilovskyb1407992012-09-19 06:22:44 -0700116extern int smb2_push_mandatory_locks(struct cifsFileInfo *cfile);
Pavel Shilovsky53e0e112016-11-04 11:50:31 -0700117extern void smb2_reconnect_server(struct work_struct *work);
Pavel Shilovsky026e93d2016-11-03 16:47:37 -0700118extern int smb3_crypto_aead_allocate(struct TCP_Server_Info *server);
Ronnie Sahlberg81f39f92018-06-28 10:47:14 +1000119extern unsigned long smb_rqst_len(struct TCP_Server_Info *server,
120 struct smb_rqst *rqst);
Ronnie Sahlberge77fe732018-12-31 13:43:40 +1000121extern void smb2_set_next_command(struct cifs_tcon *tcon,
122 struct smb_rqst *rqst);
Ronnie Sahlbergc5a5f382018-09-03 13:33:41 +1000123extern void smb2_set_related(struct smb_rqst *rqst);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -0700124
Pavel Shilovskyec2e4522011-12-27 16:12:43 +0400125/*
126 * SMB2 Worker functions - most of protocol specific implementation details
127 * are contained within these calls.
128 */
129extern int SMB2_negotiate(const unsigned int xid, struct cifs_ses *ses);
Pavel Shilovsky5478f9b2011-12-27 16:22:00 +0400130extern int SMB2_sess_setup(const unsigned int xid, struct cifs_ses *ses,
131 const struct nls_table *nls_cp);
132extern int SMB2_logoff(const unsigned int xid, struct cifs_ses *ses);
Pavel Shilovskyfaaf9462011-12-27 16:04:00 +0400133extern int SMB2_tcon(const unsigned int xid, struct cifs_ses *ses,
134 const char *tree, struct cifs_tcon *tcon,
135 const struct nls_table *);
136extern int SMB2_tdis(const unsigned int xid, struct cifs_tcon *tcon);
Pavel Shilovsky064f6042013-07-09 18:20:30 +0400137extern int SMB2_open(const unsigned int xid, struct cifs_open_parms *oparms,
138 __le16 *path, __u8 *oplock,
Pavel Shilovskyb42bf882013-08-14 19:25:21 +0400139 struct smb2_file_all_info *buf,
Ronnie Sahlberg9d874c32018-06-08 13:21:18 +1000140 struct kvec *err_iov, int *resp_buftype);
Ronnie Sahlberg1eb9fb52018-08-08 15:07:46 +1000141extern int SMB2_open_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
142 __u8 *oplock, struct cifs_open_parms *oparms,
143 __le16 *path);
144extern void SMB2_open_free(struct smb_rqst *rqst);
Steve French4a72daf2013-06-25 00:20:49 -0500145extern int SMB2_ioctl(const unsigned int xid, struct cifs_tcon *tcon,
146 u64 persistent_fid, u64 volatile_fid, u32 opcode,
Steve French153322f2019-03-28 22:32:49 -0500147 bool is_fsctl, char *in_data, u32 indatalen, u32 maxoutlen,
Steve French4a72daf2013-06-25 00:20:49 -0500148 char **out_data, u32 *plen /* returned data len */);
Ronnie Sahlbergccdc77a2019-03-13 14:37:48 +1000149extern int SMB2_ioctl_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
150 u64 persistent_fid, u64 volatile_fid, u32 opcode,
Steve French153322f2019-03-28 22:32:49 -0500151 bool is_fsctl, char *in_data, u32 indatalen,
152 __u32 max_response_size);
Ronnie Sahlbergccdc77a2019-03-13 14:37:48 +1000153extern void SMB2_ioctl_free(struct smb_rqst *rqst);
Steve French52870d52019-10-01 21:25:46 -0500154extern int SMB2_change_notify(const unsigned int xid, struct cifs_tcon *tcon,
155 u64 persistent_fid, u64 volatile_fid, bool watch_tree,
156 u32 completion_filter);
157
Pavel Shilovsky2503a0d2011-12-26 22:58:46 +0400158extern int SMB2_close(const unsigned int xid, struct cifs_tcon *tcon,
159 u64 persistent_file_id, u64 volatile_file_id);
Ronnie Sahlberg8eb4ecf2018-08-01 09:26:16 +1000160extern int SMB2_close_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
161 u64 persistent_file_id, u64 volatile_file_id);
162extern void SMB2_close_free(struct smb_rqst *rqst);
Pavel Shilovsky7a5cfb12012-09-18 16:20:28 -0700163extern int SMB2_flush(const unsigned int xid, struct cifs_tcon *tcon,
164 u64 persistent_file_id, u64 volatile_file_id);
Ronnie Sahlberg86e14e12019-07-16 15:07:08 +1000165extern int SMB2_flush_init(const unsigned int xid, struct smb_rqst *rqst,
166 struct cifs_tcon *tcon,
167 u64 persistent_file_id, u64 volatile_file_id);
168extern void SMB2_flush_free(struct smb_rqst *rqst);
Pavel Shilovskybe4cb9e2011-12-29 17:06:33 +0400169extern int SMB2_query_info(const unsigned int xid, struct cifs_tcon *tcon,
170 u64 persistent_file_id, u64 volatile_file_id,
171 struct smb2_file_all_info *data);
Ronnie Sahlberg296ecba2018-08-01 09:26:17 +1000172extern int SMB2_query_info_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
173 u64 persistent_fid, u64 volatile_fid,
174 u8 info_class, u8 info_type,
Ronnie Sahlbergf5b05d62018-10-07 19:19:58 -0500175 u32 additional_info, size_t output_len,
176 size_t input_len, void *input);
Ronnie Sahlberg296ecba2018-08-01 09:26:17 +1000177extern void SMB2_query_info_free(struct smb_rqst *rqst);
Shirish Pargaonkar42c493c2017-06-22 22:51:31 -0500178extern int SMB2_query_acl(const unsigned int xid, struct cifs_tcon *tcon,
179 u64 persistent_file_id, u64 volatile_file_id,
180 void **data, unsigned int *plen);
Pavel Shilovskyf0df7372012-09-18 16:20:26 -0700181extern int SMB2_get_srv_num(const unsigned int xid, struct cifs_tcon *tcon,
182 u64 persistent_fid, u64 volatile_fid,
183 __le64 *uniqueid);
Pavel Shilovsky09a47072012-09-18 16:20:29 -0700184extern int smb2_async_readv(struct cifs_readdata *rdata);
Pavel Shilovskyd8e05032012-09-18 16:20:30 -0700185extern int SMB2_read(const unsigned int xid, struct cifs_io_parms *io_parms,
186 unsigned int *nbytes, char **buf, int *buf_type);
Steve French4a5c80d2014-02-07 20:45:12 -0600187extern int smb2_async_writev(struct cifs_writedata *wdata,
188 void (*release)(struct kref *kref));
Pavel Shilovsky009d3442012-09-18 16:20:30 -0700189extern int SMB2_write(const unsigned int xid, struct cifs_io_parms *io_parms,
190 unsigned int *nbytes, struct kvec *iov, int n_vec);
Pavel Shilovsky9094fad2012-07-12 18:30:44 +0400191extern int SMB2_echo(struct TCP_Server_Info *server);
Pavel Shilovskyd324f08d2012-09-18 16:20:33 -0700192extern int SMB2_query_directory(const unsigned int xid, struct cifs_tcon *tcon,
193 u64 persistent_fid, u64 volatile_fid, int index,
194 struct cifs_search_info *srch_inf);
Pavel Shilovskyc839ff22012-09-18 16:20:32 -0700195extern int SMB2_set_eof(const unsigned int xid, struct cifs_tcon *tcon,
196 u64 persistent_fid, u64 volatile_fid, u32 pid,
Ronnie Sahlberg3764cbd2018-09-03 13:33:47 +1000197 __le64 *eof);
Ronnie Sahlbergba8ca112018-09-03 13:33:44 +1000198extern int SMB2_set_info_init(struct cifs_tcon *tcon, struct smb_rqst *rqst,
199 u64 persistent_fid, u64 volatile_fid, u32 pid,
200 u8 info_class, u8 info_type, u32 additional_info,
201 void **data, unsigned int *size);
202extern void SMB2_set_info_free(struct smb_rqst *rqst);
Shirish Pargaonkardac95342017-06-28 22:37:00 -0500203extern int SMB2_set_acl(const unsigned int xid, struct cifs_tcon *tcon,
204 u64 persistent_fid, u64 volatile_fid,
205 struct cifs_ntsd *pnntsd, int pacllen, int aclflag);
Ronnie Sahlberg55175542017-08-24 11:24:56 +1000206extern int SMB2_set_ea(const unsigned int xid, struct cifs_tcon *tcon,
207 u64 persistent_fid, u64 volatile_fid,
208 struct smb2_file_full_ea_info *buf, int len);
Steve French64a5cfa2013-10-14 15:31:32 -0500209extern int SMB2_set_compression(const unsigned int xid, struct cifs_tcon *tcon,
210 u64 persistent_fid, u64 volatile_fid);
Pavel Shilovsky983c88a2012-09-18 16:20:33 -0700211extern int SMB2_oplock_break(const unsigned int xid, struct cifs_tcon *tcon,
212 const u64 persistent_fid, const u64 volatile_fid,
213 const __u8 oplock_level);
Pavel Shilovsky9150c3a2019-11-21 11:35:12 -0800214extern int smb2_handle_cancelled_close(struct cifs_tcon *tcon,
215 __u64 persistent_fid,
216 __u64 volatile_fid);
Sachin Prabhu38bd4902017-03-03 15:41:38 -0800217extern int smb2_handle_cancelled_mid(char *buffer,
218 struct TCP_Server_Info *server);
219void smb2_cancelled_close_fid(struct work_struct *work);
Pavel Shilovsky6fc05c22012-09-18 16:20:34 -0700220extern int SMB2_QFS_info(const unsigned int xid, struct cifs_tcon *tcon,
221 u64 persistent_file_id, u64 volatile_file_id,
222 struct kstatfs *FSData);
Steve French2d304212018-06-24 23:28:12 -0500223extern int SMB311_posix_qfs_info(const unsigned int xid, struct cifs_tcon *tcon,
224 u64 persistent_file_id, u64 volatile_file_id,
225 struct kstatfs *FSData);
Steve French34f62642013-10-09 02:07:00 -0500226extern int SMB2_QFS_attr(const unsigned int xid, struct cifs_tcon *tcon,
Steven French21671142013-10-09 13:36:35 -0500227 u64 persistent_file_id, u64 volatile_file_id, int lvl);
Pavel Shilovskyf7ba7fe2012-09-19 06:22:43 -0700228extern int SMB2_lock(const unsigned int xid, struct cifs_tcon *tcon,
229 const __u64 persist_fid, const __u64 volatile_fid,
230 const __u32 pid, const __u64 length, const __u64 offset,
231 const __u32 lockFlags, const bool wait);
232extern int smb2_lockv(const unsigned int xid, struct cifs_tcon *tcon,
233 const __u64 persist_fid, const __u64 volatile_fid,
234 const __u32 pid, const __u32 num_lock,
235 struct smb2_lock_element *buf);
Pavel Shilovsky0822f512012-09-19 06:22:45 -0700236extern int SMB2_lease_break(const unsigned int xid, struct cifs_tcon *tcon,
237 __u8 *lease_key, const __le32 lease_state);
Steve Frenchff1c0382013-11-19 23:44:46 -0600238extern int smb3_validate_negotiate(const unsigned int, struct cifs_tcon *);
Pavel Shilovskyec2e4522011-12-27 16:12:43 +0400239
Sachin Prabhuef65aae2017-01-18 15:35:57 +0530240extern enum securityEnum smb2_select_sectype(struct TCP_Server_Info *,
241 enum securityEnum);
Steve French89a5bfa2019-07-18 17:22:18 -0500242extern void smb2_parse_contexts(struct TCP_Server_Info *server,
243 struct smb2_create_rsp *rsp,
244 unsigned int *epoch, char *lease_key,
245 __u8 *oplock, struct smb2_file_all_info *buf);
Ronnie Sahlberg730928c2018-08-08 15:07:49 +1000246extern int smb3_encryption_required(const struct cifs_tcon *tcon);
247extern int smb2_validate_iov(unsigned int offset, unsigned int buffer_length,
248 struct kvec *iov, unsigned int min_buf_size);
Ronnie Sahlbergc5a5f382018-09-03 13:33:41 +1000249extern int smb2_validate_and_copy_iov(unsigned int offset,
250 unsigned int buffer_length,
251 struct kvec *iov,
252 unsigned int minbufsize, char *data);
Ronnie Sahlberg730928c2018-08-08 15:07:49 +1000253extern void smb2_copy_fs_info_to_kstatfs(
254 struct smb2_fs_full_size_info *pfs_inf,
255 struct kstatfs *kst);
Aurelien Aptel5fcd7f32018-02-16 19:19:28 +0100256extern int smb311_crypto_shash_allocate(struct TCP_Server_Info *server);
Aurelien Aptel8bd68c62018-02-16 19:19:29 +0100257extern int smb311_update_preauth_hash(struct cifs_ses *ses,
258 struct kvec *iov, int nvec);
Ronnie Sahlbergf9793b62018-11-27 09:52:04 +1000259extern int smb2_query_info_compound(const unsigned int xid,
260 struct cifs_tcon *tcon,
261 __le16 *utf16_path, u32 desired_access,
262 u32 class, u32 type, u32 output_len,
263 struct kvec *rsp, int *buftype,
264 struct cifs_sb_info *cifs_sb);
Steve Frenchddfbefb2011-03-15 02:08:48 +0000265#endif /* _SMB2PROTO_H */