Lines Matching refs:server

30 change_conf(struct TCP_Server_Info *server)  in change_conf()  argument
32 server->credits += server->echo_credits + server->oplock_credits; in change_conf()
33 server->oplock_credits = server->echo_credits = 0; in change_conf()
34 switch (server->credits) { in change_conf()
38 server->echoes = false; in change_conf()
39 server->oplocks = false; in change_conf()
42 server->echoes = true; in change_conf()
43 server->oplocks = false; in change_conf()
44 server->echo_credits = 1; in change_conf()
47 server->echoes = true; in change_conf()
49 server->oplocks = true; in change_conf()
50 server->oplock_credits = 1; in change_conf()
52 server->oplocks = false; in change_conf()
54 server->echo_credits = 1; in change_conf()
56 server->credits -= server->echo_credits + server->oplock_credits; in change_conf()
57 return server->credits + server->echo_credits + server->oplock_credits; in change_conf()
61 smb2_add_credits(struct TCP_Server_Info *server, in smb2_add_credits() argument
69 spin_lock(&server->req_lock); in smb2_add_credits()
70 val = server->ops->get_credits_field(server, optype); in smb2_add_credits()
74 trace_smb3_reconnect_with_invalid_credits(server->CurrentMid, in smb2_add_credits()
75 server->hostname, *val, add); in smb2_add_credits()
76 if ((instance == 0) || (instance == server->reconnect_instance)) in smb2_add_credits()
85 server->in_flight--; in smb2_add_credits()
86 if (server->in_flight == 0 && (optype & CIFS_OP_MASK) != CIFS_NEG_OP) in smb2_add_credits()
87 rc = change_conf(server); in smb2_add_credits()
92 else if (server->in_flight > 0 && server->oplock_credits == 0 && in smb2_add_credits()
93 server->oplocks) { in smb2_add_credits()
94 if (server->credits > 1) { in smb2_add_credits()
95 server->credits--; in smb2_add_credits()
96 server->oplock_credits++; in smb2_add_credits()
99 spin_unlock(&server->req_lock); in smb2_add_credits()
100 wake_up(&server->request_q); in smb2_add_credits()
106 if (server->tcpStatus == CifsNeedReconnect in smb2_add_credits()
107 || server->tcpStatus == CifsExiting) in smb2_add_credits()
124 trace_smb3_add_credits(server->CurrentMid, in smb2_add_credits()
125 server->hostname, rc, add); in smb2_add_credits()
131 smb2_set_credits(struct TCP_Server_Info *server, const int val) in smb2_set_credits() argument
133 spin_lock(&server->req_lock); in smb2_set_credits()
134 server->credits = val; in smb2_set_credits()
136 server->reconnect_instance++; in smb2_set_credits()
137 spin_unlock(&server->req_lock); in smb2_set_credits()
144 smb2_get_credits_field(struct TCP_Server_Info *server, const int optype) in smb2_get_credits_field() argument
148 return &server->echo_credits; in smb2_get_credits_field()
150 return &server->oplock_credits; in smb2_get_credits_field()
152 return &server->credits; in smb2_get_credits_field()
163 smb2_wait_mtu_credits(struct TCP_Server_Info *server, unsigned int size, in smb2_wait_mtu_credits() argument
169 spin_lock(&server->req_lock); in smb2_wait_mtu_credits()
171 if (server->credits <= 0) { in smb2_wait_mtu_credits()
172 spin_unlock(&server->req_lock); in smb2_wait_mtu_credits()
173 cifs_num_waiters_inc(server); in smb2_wait_mtu_credits()
174 rc = wait_event_killable(server->request_q, in smb2_wait_mtu_credits()
175 has_credits(server, &server->credits, 1)); in smb2_wait_mtu_credits()
176 cifs_num_waiters_dec(server); in smb2_wait_mtu_credits()
179 spin_lock(&server->req_lock); in smb2_wait_mtu_credits()
181 if (server->tcpStatus == CifsExiting) { in smb2_wait_mtu_credits()
182 spin_unlock(&server->req_lock); in smb2_wait_mtu_credits()
186 scredits = server->credits; in smb2_wait_mtu_credits()
202 credits->instance = server->reconnect_instance; in smb2_wait_mtu_credits()
203 server->credits -= credits->value; in smb2_wait_mtu_credits()
204 server->in_flight++; in smb2_wait_mtu_credits()
205 if (server->in_flight > server->max_in_flight) in smb2_wait_mtu_credits()
206 server->max_in_flight = server->in_flight; in smb2_wait_mtu_credits()
210 spin_unlock(&server->req_lock); in smb2_wait_mtu_credits()
215 smb2_adjust_credits(struct TCP_Server_Info *server, in smb2_adjust_credits() argument
230 spin_lock(&server->req_lock); in smb2_adjust_credits()
232 if (server->reconnect_instance != credits->instance) { in smb2_adjust_credits()
233 spin_unlock(&server->req_lock); in smb2_adjust_credits()
239 server->credits += credits->value - new_val; in smb2_adjust_credits()
240 spin_unlock(&server->req_lock); in smb2_adjust_credits()
241 wake_up(&server->request_q); in smb2_adjust_credits()
247 smb2_get_next_mid(struct TCP_Server_Info *server) in smb2_get_next_mid() argument
252 mid = server->CurrentMid++; in smb2_get_next_mid()
258 smb2_revert_current_mid(struct TCP_Server_Info *server, const unsigned int val) in smb2_revert_current_mid() argument
261 if (server->CurrentMid >= val) in smb2_revert_current_mid()
262 server->CurrentMid -= val; in smb2_revert_current_mid()
267 __smb2_find_mid(struct TCP_Server_Info *server, char *buf, bool dequeue) in __smb2_find_mid() argument
279 list_for_each_entry(mid, &server->pending_mid_q, qhead) { in __smb2_find_mid()
297 smb2_find_mid(struct TCP_Server_Info *server, char *buf) in smb2_find_mid() argument
299 return __smb2_find_mid(server, buf, false); in smb2_find_mid()
303 smb2_find_dequeue_mid(struct TCP_Server_Info *server, char *buf) in smb2_find_dequeue_mid() argument
305 return __smb2_find_mid(server, buf, true); in smb2_find_dequeue_mid()
309 smb2_dump_detail(void *buf, struct TCP_Server_Info *server) in smb2_dump_detail() argument
318 server->ops->calc_smb_size(buf, server)); in smb2_dump_detail()
323 smb2_need_neg(struct TCP_Server_Info *server) in smb2_need_neg() argument
325 return server->max_read == 0; in smb2_need_neg()
344 struct TCP_Server_Info *server = tcon->ses->server; in smb2_negotiate_wsize() local
349 wsize = min_t(unsigned int, wsize, server->max_write); in smb2_negotiate_wsize()
350 if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU)) in smb2_negotiate_wsize()
359 struct TCP_Server_Info *server = tcon->ses->server; in smb3_negotiate_wsize() local
364 wsize = min_t(unsigned int, wsize, server->max_write); in smb3_negotiate_wsize()
366 if (server->rdma) { in smb3_negotiate_wsize()
367 if (server->sign) in smb3_negotiate_wsize()
374 server->smbd_conn->max_fragmented_send_size - in smb3_negotiate_wsize()
379 wsize, server->smbd_conn->max_readwrite_size); in smb3_negotiate_wsize()
382 if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU)) in smb3_negotiate_wsize()
391 struct TCP_Server_Info *server = tcon->ses->server; in smb2_negotiate_rsize() local
396 rsize = min_t(unsigned int, rsize, server->max_read); in smb2_negotiate_rsize()
398 if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU)) in smb2_negotiate_rsize()
407 struct TCP_Server_Info *server = tcon->ses->server; in smb3_negotiate_rsize() local
412 rsize = min_t(unsigned int, rsize, server->max_read); in smb3_negotiate_rsize()
414 if (server->rdma) { in smb3_negotiate_rsize()
415 if (server->sign) in smb3_negotiate_rsize()
422 server->smbd_conn->max_fragmented_recv_size - in smb3_negotiate_rsize()
427 rsize, server->smbd_conn->max_readwrite_size); in smb3_negotiate_rsize()
431 if (!(server->capabilities & SMB2_GLOBAL_CAP_LARGE_MTU)) in smb3_negotiate_rsize()
677 struct TCP_Server_Info *server = ses->server; in open_shroot() local
712 if (!server->ops->new_lease_key) in open_shroot()
716 server->ops->new_lease_key(pfid); in open_shroot()
734 rc = SMB2_open_init(tcon, server, in open_shroot()
744 rc = SMB2_query_info_init(tcon, server, in open_shroot()
755 rc = compound_send_recv(xid, ses, server, in open_shroot()
821 smb2_parse_contexts(server, o_rsp, in open_shroot()
1138 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_set_ea() local
1172 if (ses->server->ops->query_all_EAs) { in smb2_set_ea()
1174 rc = ses->server->ops->query_all_EAs(xid, tcon, path, in smb2_set_ea()
1227 rc = SMB2_open_init(tcon, server, in smb2_set_ea()
1254 rc = SMB2_set_info_init(tcon, server, in smb2_set_ea()
1269 rc = SMB2_close_init(tcon, server, in smb2_set_ea()
1275 rc = compound_send_recv(xid, ses, server, in smb2_set_ea()
1294 smb2_can_echo(struct TCP_Server_Info *server) in smb2_can_echo() argument
1296 return server->echoes; in smb2_can_echo()
1407 struct TCP_Server_Info *server = tlink_tcon(cfile->tlink)->ses->server; in smb2_set_fid() local
1415 server->ops->set_oplock_level(cinode, oplock, fid->epoch, in smb2_set_fid()
1517 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_ioctl_query_info() local
1552 if (!ses || !server) { in smb2_ioctl_query_info()
1600 rc = SMB2_open_init(tcon, server, in smb2_ioctl_query_info()
1616 rc = SMB2_ioctl_init(tcon, server, &rqst[1], COMPOUND_FID, COMPOUND_FID, in smb2_ioctl_query_info()
1638 rc = SMB2_set_info_init(tcon, server, &rqst[1], COMPOUND_FID, COMPOUND_FID, in smb2_ioctl_query_info()
1646 rc = SMB2_query_info_init(tcon, server, in smb2_ioctl_query_info()
1668 rc = SMB2_close_init(tcon, server, in smb2_ioctl_query_info()
1674 rc = compound_send_recv(xid, ses, server, in smb2_ioctl_query_info()
2246 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_dir_first() local
2271 rc = SMB2_open_init(tcon, server, in smb2_query_dir_first()
2285 rc = SMB2_query_directory_init(xid, tcon, server, in smb2_query_dir_first()
2294 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_dir_first()
2369 smb2_is_status_pending(char *buf, struct TCP_Server_Info *server) in smb2_is_status_pending() argument
2377 spin_lock(&server->req_lock); in smb2_is_status_pending()
2378 server->credits += le16_to_cpu(shdr->CreditRequest); in smb2_is_status_pending()
2379 spin_unlock(&server->req_lock); in smb2_is_status_pending()
2380 wake_up(&server->request_q); in smb2_is_status_pending()
2418 if (tcon->ses->server->capabilities & SMB2_GLOBAL_CAP_LEASING) in smb2_oplock_response()
2447 struct TCP_Server_Info *server = ses->server; in smb2_set_next_command() local
2448 unsigned long len = smb_rqst_len(server, rqst); in smb2_set_next_command()
2511 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_query_info_compound() local
2542 rc = SMB2_open_init(tcon, server, in smb2_query_info_compound()
2552 rc = SMB2_query_info_init(tcon, server, in smb2_query_info_compound()
2566 rc = SMB2_close_init(tcon, server, in smb2_query_info_compound()
2572 rc = compound_send_recv(xid, ses, server, in smb2_query_info_compound()
2904 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_symlink() local
2950 rc = SMB2_open_init(tcon, server, in smb2_query_symlink()
2962 rc = SMB2_ioctl_init(tcon, server, in smb2_query_symlink()
2980 rc = SMB2_close_init(tcon, server, in smb2_query_symlink()
2987 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_symlink()
3089 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_reparse_tag() local
3130 rc = SMB2_open_init(tcon, server, in smb2_query_reparse_tag()
3142 rc = SMB2_ioctl_init(tcon, server, in smb2_query_reparse_tag()
3160 rc = SMB2_close_init(tcon, server, in smb2_query_reparse_tag()
3167 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_reparse_tag()
3902 smb2_downgrade_oplock(struct TCP_Server_Info *server, in smb2_downgrade_oplock() argument
3906 server->ops->set_oplock_level(cinode, oplock, 0, NULL); in smb2_downgrade_oplock()
3914 smb3_downgrade_oplock(struct TCP_Server_Info *server, in smb3_downgrade_oplock() argument
4233 smb2_get_enc_key(struct TCP_Server_Info *server, __u64 ses_id, int enc, u8 *key) in smb2_get_enc_key() argument
4239 list_for_each_entry(server, &cifs_tcp_ses_list, tcp_ses_list) { in smb2_get_enc_key()
4240 list_for_each_entry(ses, &server->smb_ses_list, smb_ses_list) { in smb2_get_enc_key()
4262 crypt_message(struct TCP_Server_Info *server, int num_rqst, in crypt_message() argument
4279 rc = smb2_get_enc_key(server, tr_hdr->SessionId, enc, key); in crypt_message()
4286 rc = smb3_crypto_aead_allocate(server); in crypt_message()
4292 tfm = enc ? server->secmech.ccmaesencrypt : in crypt_message()
4293 server->secmech.ccmaesdecrypt; in crypt_message()
4295 if ((server->cipher_type == SMB2_ENCRYPTION_AES256_CCM) || in crypt_message()
4296 (server->cipher_type == SMB2_ENCRYPTION_AES256_GCM)) in crypt_message()
4338 if ((server->cipher_type == SMB2_ENCRYPTION_AES128_GCM) || in crypt_message()
4339 (server->cipher_type == SMB2_ENCRYPTION_AES256_GCM)) in crypt_message()
4394 smb3_init_transform_rq(struct TCP_Server_Info *server, int num_rqst, in smb3_init_transform_rq() argument
4419 orig_len += smb_rqst_len(server, &old_rq[i - 1]); in smb3_init_transform_rq()
4444 fill_transform_hdr(tr_hdr, orig_len, old_rq, server->cipher_type); in smb3_init_transform_rq()
4446 rc = crypt_message(server, num_rqst, new_rq, 1); in smb3_init_transform_rq()
4467 decrypt_raw_data(struct TCP_Server_Info *server, char *buf, in decrypt_raw_data() argument
4488 rc = crypt_message(server, 1, &rqst, 0); in decrypt_raw_data()
4497 server->total_read = buf_data_size + page_data_size; in decrypt_raw_data()
4503 read_data_into_pages(struct TCP_Server_Info *server, struct page **pages, in read_data_into_pages() argument
4522 length = cifs_read_page_from_socket(server, page, 0, n); in read_data_into_pages()
4525 server->total_read += length; in read_data_into_pages()
4560 handle_read_data(struct TCP_Server_Info *server, struct mid_q_entry *mid, in handle_read_data() argument
4583 if (server->ops->is_session_expired && in handle_read_data()
4584 server->ops->is_session_expired(buf)) { in handle_read_data()
4586 cifs_reconnect(server); in handle_read_data()
4590 if (server->ops->is_status_pending && in handle_read_data()
4591 server->ops->is_status_pending(buf, server)) in handle_read_data()
4599 min_t(unsigned int, buf_len, server->vals->read_rsp_size); in handle_read_data()
4605 rdata->result = server->ops->map_error(buf, true); in handle_read_data()
4617 data_offset = server->ops->read_data_offset(buf); in handle_read_data()
4621 data_len = server->ops->read_data_length(buf, use_rdma_mr); in handle_read_data()
4623 if (data_offset < server->vals->read_rsp_size) { in handle_read_data()
4631 data_offset = server->vals->read_rsp_size; in handle_read_data()
4644 pad_len = data_offset - server->vals->read_rsp_size; in handle_read_data()
4701 length = rdata->copy_into_pages(server, rdata, &iter); in handle_read_data()
4717 struct TCP_Server_Info *server; member
4732 rc = decrypt_raw_data(dw->server, dw->buf, dw->server->vals->read_rsp_size, in smb2_decrypt_offload()
4739 dw->server->lstrp = jiffies; in smb2_decrypt_offload()
4740 mid = smb2_find_dequeue_mid(dw->server, dw->buf); in smb2_decrypt_offload()
4745 rc = handle_read_data(dw->server, mid, dw->buf, in smb2_decrypt_offload()
4746 dw->server->vals->read_rsp_size, in smb2_decrypt_offload()
4756 if (dw->server->tcpStatus == CifsNeedReconnect) { in smb2_decrypt_offload()
4764 &dw->server->pending_mid_q); in smb2_decrypt_offload()
4782 receive_encrypted_read(struct TCP_Server_Info *server, struct mid_q_entry **mid, in receive_encrypted_read() argument
4785 char *buf = server->smallbuf; in receive_encrypted_read()
4790 unsigned int buflen = server->pdu_size; in receive_encrypted_read()
4796 len = min_t(unsigned int, buflen, server->vals->read_rsp_size + in receive_encrypted_read()
4797 sizeof(struct smb2_transform_hdr)) - HEADER_SIZE(server) + 1; in receive_encrypted_read()
4799 rc = cifs_read_from_socket(server, buf + HEADER_SIZE(server) - 1, len); in receive_encrypted_read()
4802 server->total_read += rc; in receive_encrypted_read()
4805 server->vals->read_rsp_size; in receive_encrypted_read()
4823 rc = read_data_into_pages(server, pages, npages, len); in receive_encrypted_read()
4827 rc = cifs_discard_remaining_data(server); in receive_encrypted_read()
4836 if ((server->min_offload) && (server->in_flight > 1) && in receive_encrypted_read()
4837 (server->pdu_size >= server->min_offload)) { in receive_encrypted_read()
4842 dw->buf = server->smallbuf; in receive_encrypted_read()
4843 server->smallbuf = (char *)cifs_small_buf_get(); in receive_encrypted_read()
4848 dw->server = server; in receive_encrypted_read()
4857 rc = decrypt_raw_data(server, buf, server->vals->read_rsp_size, in receive_encrypted_read()
4862 *mid = smb2_find_mid(server, buf); in receive_encrypted_read()
4868 rc = handle_read_data(server, *mid, buf, in receive_encrypted_read()
4869 server->vals->read_rsp_size, in receive_encrypted_read()
4879 cifs_discard_remaining_data(server); in receive_encrypted_read()
4884 receive_encrypted_standard(struct TCP_Server_Info *server, in receive_encrypted_standard() argument
4889 char *buf = server->smallbuf; in receive_encrypted_standard()
4891 unsigned int pdu_length = server->pdu_size; in receive_encrypted_standard()
4901 server->large_buf = true; in receive_encrypted_standard()
4902 memcpy(server->bigbuf, buf, server->total_read); in receive_encrypted_standard()
4903 buf = server->bigbuf; in receive_encrypted_standard()
4907 length = cifs_read_from_socket(server, buf + HEADER_SIZE(server) - 1, in receive_encrypted_standard()
4908 pdu_length - HEADER_SIZE(server) + 1); in receive_encrypted_standard()
4911 server->total_read += length; in receive_encrypted_standard()
4914 length = decrypt_raw_data(server, buf, buf_size, NULL, 0, 0, false); in receive_encrypted_standard()
4918 next_is_large = server->large_buf; in receive_encrypted_standard()
4931 mid_entry = smb2_find_mid(server, buf); in receive_encrypted_standard()
4937 mid_entry->resp_buf_size = server->pdu_size; in receive_encrypted_standard()
4948 ret = mid_entry->handle(server, mid_entry); in receive_encrypted_standard()
4950 ret = cifs_handle_standard(server, mid_entry); in receive_encrypted_standard()
4954 server->large_buf = next_is_large; in receive_encrypted_standard()
4956 server->bigbuf = buf = next_buffer; in receive_encrypted_standard()
4958 server->smallbuf = buf = next_buffer; in receive_encrypted_standard()
4977 smb3_receive_transform(struct TCP_Server_Info *server, in smb3_receive_transform() argument
4980 char *buf = server->smallbuf; in smb3_receive_transform()
4981 unsigned int pdu_length = server->pdu_size; in smb3_receive_transform()
4989 cifs_reconnect(server); in smb3_receive_transform()
4995 cifs_reconnect(server); in smb3_receive_transform()
5000 if (pdu_length > CIFSMaxBufSize + MAX_HEADER_SIZE(server)) { in smb3_receive_transform()
5001 return receive_encrypted_read(server, &mids[0], num_mids); in smb3_receive_transform()
5004 return receive_encrypted_standard(server, mids, bufs, num_mids); in smb3_receive_transform()
5008 smb3_handle_read_data(struct TCP_Server_Info *server, struct mid_q_entry *mid) in smb3_handle_read_data() argument
5010 char *buf = server->large_buf ? server->bigbuf : server->smallbuf; in smb3_handle_read_data()
5012 return handle_read_data(server, mid, buf, server->pdu_size, in smb3_handle_read_data()
5081 if (tcon->ses->server->oplocks) in smb2_make_node()
5085 rc = tcon->ses->server->ops->open(xid, &oparms, &oplock, buf); in smb2_make_node()
5105 rc = tcon->ses->server->ops->sync_write(xid, &fid, &io_parms, in smb2_make_node()
5111 rc = tcon->ses->server->ops->sync_write(xid, &fid, &io_parms, in smb2_make_node()
5114 tcon->ses->server->ops->close(xid, tcon, &fid); in smb2_make_node()