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()
1137 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_set_ea() local
1171 if (ses->server->ops->query_all_EAs) { in smb2_set_ea()
1173 rc = ses->server->ops->query_all_EAs(xid, tcon, path, in smb2_set_ea()
1226 rc = SMB2_open_init(tcon, server, in smb2_set_ea()
1253 rc = SMB2_set_info_init(tcon, server, in smb2_set_ea()
1266 rc = SMB2_close_init(tcon, server, in smb2_set_ea()
1270 rc = compound_send_recv(xid, ses, server, in smb2_set_ea()
1289 smb2_can_echo(struct TCP_Server_Info *server) in smb2_can_echo() argument
1291 return server->echoes; in smb2_can_echo()
1402 struct TCP_Server_Info *server = tlink_tcon(cfile->tlink)->ses->server; in smb2_set_fid() local
1410 server->ops->set_oplock_level(cinode, oplock, fid->epoch, in smb2_set_fid()
1513 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_ioctl_query_info() local
1548 if (!ses || !server) { in smb2_ioctl_query_info()
1596 rc = SMB2_open_init(tcon, server, in smb2_ioctl_query_info()
1612 rc = SMB2_ioctl_init(tcon, server, &rqst[1], COMPOUND_FID, COMPOUND_FID, in smb2_ioctl_query_info()
1634 rc = SMB2_set_info_init(tcon, server, &rqst[1], COMPOUND_FID, COMPOUND_FID, in smb2_ioctl_query_info()
1642 rc = SMB2_query_info_init(tcon, server, in smb2_ioctl_query_info()
1664 rc = SMB2_close_init(tcon, server, in smb2_ioctl_query_info()
1670 rc = compound_send_recv(xid, ses, server, in smb2_ioctl_query_info()
2239 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_dir_first() local
2264 rc = SMB2_open_init(tcon, server, in smb2_query_dir_first()
2278 rc = SMB2_query_directory_init(xid, tcon, server, in smb2_query_dir_first()
2287 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_dir_first()
2362 smb2_is_status_pending(char *buf, struct TCP_Server_Info *server) in smb2_is_status_pending() argument
2370 spin_lock(&server->req_lock); in smb2_is_status_pending()
2371 server->credits += le16_to_cpu(shdr->CreditRequest); in smb2_is_status_pending()
2372 spin_unlock(&server->req_lock); in smb2_is_status_pending()
2373 wake_up(&server->request_q); in smb2_is_status_pending()
2411 if (tcon->ses->server->capabilities & SMB2_GLOBAL_CAP_LEASING) in smb2_oplock_response()
2440 struct TCP_Server_Info *server = ses->server; in smb2_set_next_command() local
2441 unsigned long len = smb_rqst_len(server, rqst); in smb2_set_next_command()
2504 struct TCP_Server_Info *server = cifs_pick_channel(ses); in smb2_query_info_compound() local
2535 rc = SMB2_open_init(tcon, server, in smb2_query_info_compound()
2545 rc = SMB2_query_info_init(tcon, server, in smb2_query_info_compound()
2559 rc = SMB2_close_init(tcon, server, in smb2_query_info_compound()
2565 rc = compound_send_recv(xid, ses, server, in smb2_query_info_compound()
2898 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_symlink() local
2944 rc = SMB2_open_init(tcon, server, in smb2_query_symlink()
2956 rc = SMB2_ioctl_init(tcon, server, in smb2_query_symlink()
2975 rc = SMB2_close_init(tcon, server, in smb2_query_symlink()
2982 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_symlink()
3084 struct TCP_Server_Info *server = cifs_pick_channel(tcon->ses); in smb2_query_reparse_tag() local
3125 rc = SMB2_open_init(tcon, server, in smb2_query_reparse_tag()
3137 rc = SMB2_ioctl_init(tcon, server, in smb2_query_reparse_tag()
3156 rc = SMB2_close_init(tcon, server, in smb2_query_reparse_tag()
3163 rc = compound_send_recv(xid, tcon->ses, server, in smb2_query_reparse_tag()
3898 smb2_downgrade_oplock(struct TCP_Server_Info *server, in smb2_downgrade_oplock() argument
3902 server->ops->set_oplock_level(cinode, oplock, 0, NULL); in smb2_downgrade_oplock()
3910 smb3_downgrade_oplock(struct TCP_Server_Info *server, in smb3_downgrade_oplock() argument
4227 smb2_get_enc_key(struct TCP_Server_Info *server, __u64 ses_id, int enc, u8 *key) in smb2_get_enc_key() argument
4233 list_for_each_entry(server, &cifs_tcp_ses_list, tcp_ses_list) { in smb2_get_enc_key()
4234 list_for_each_entry(ses, &server->smb_ses_list, smb_ses_list) { in smb2_get_enc_key()
4256 crypt_message(struct TCP_Server_Info *server, int num_rqst, in crypt_message() argument
4273 rc = smb2_get_enc_key(server, tr_hdr->SessionId, enc, key); in crypt_message()
4280 rc = smb3_crypto_aead_allocate(server); in crypt_message()
4286 tfm = enc ? server->secmech.ccmaesencrypt : in crypt_message()
4287 server->secmech.ccmaesdecrypt; in crypt_message()
4289 if ((server->cipher_type == SMB2_ENCRYPTION_AES256_CCM) || in crypt_message()
4290 (server->cipher_type == SMB2_ENCRYPTION_AES256_GCM)) in crypt_message()
4332 if ((server->cipher_type == SMB2_ENCRYPTION_AES128_GCM) || in crypt_message()
4333 (server->cipher_type == SMB2_ENCRYPTION_AES256_GCM)) in crypt_message()
4388 smb3_init_transform_rq(struct TCP_Server_Info *server, int num_rqst, in smb3_init_transform_rq() argument
4413 orig_len += smb_rqst_len(server, &old_rq[i - 1]); in smb3_init_transform_rq()
4438 fill_transform_hdr(tr_hdr, orig_len, old_rq, server->cipher_type); in smb3_init_transform_rq()
4440 rc = crypt_message(server, num_rqst, new_rq, 1); in smb3_init_transform_rq()
4461 decrypt_raw_data(struct TCP_Server_Info *server, char *buf, in decrypt_raw_data() argument
4482 rc = crypt_message(server, 1, &rqst, 0); in decrypt_raw_data()
4491 server->total_read = buf_data_size + page_data_size; in decrypt_raw_data()
4497 read_data_into_pages(struct TCP_Server_Info *server, struct page **pages, in read_data_into_pages() argument
4516 length = cifs_read_page_from_socket(server, page, 0, n); in read_data_into_pages()
4519 server->total_read += length; in read_data_into_pages()
4554 handle_read_data(struct TCP_Server_Info *server, struct mid_q_entry *mid, in handle_read_data() argument
4577 if (server->ops->is_session_expired && in handle_read_data()
4578 server->ops->is_session_expired(buf)) { in handle_read_data()
4580 cifs_reconnect(server); in handle_read_data()
4584 if (server->ops->is_status_pending && in handle_read_data()
4585 server->ops->is_status_pending(buf, server)) in handle_read_data()
4593 min_t(unsigned int, buf_len, server->vals->read_rsp_size); in handle_read_data()
4599 rdata->result = server->ops->map_error(buf, true); in handle_read_data()
4611 data_offset = server->ops->read_data_offset(buf); in handle_read_data()
4615 data_len = server->ops->read_data_length(buf, use_rdma_mr); in handle_read_data()
4617 if (data_offset < server->vals->read_rsp_size) { in handle_read_data()
4625 data_offset = server->vals->read_rsp_size; in handle_read_data()
4638 pad_len = data_offset - server->vals->read_rsp_size; in handle_read_data()
4695 length = rdata->copy_into_pages(server, rdata, &iter); in handle_read_data()
4711 struct TCP_Server_Info *server; member
4726 rc = decrypt_raw_data(dw->server, dw->buf, dw->server->vals->read_rsp_size, in smb2_decrypt_offload()
4733 dw->server->lstrp = jiffies; in smb2_decrypt_offload()
4734 mid = smb2_find_dequeue_mid(dw->server, dw->buf); in smb2_decrypt_offload()
4739 rc = handle_read_data(dw->server, mid, dw->buf, in smb2_decrypt_offload()
4740 dw->server->vals->read_rsp_size, in smb2_decrypt_offload()
4750 if (dw->server->tcpStatus == CifsNeedReconnect) { in smb2_decrypt_offload()
4758 &dw->server->pending_mid_q); in smb2_decrypt_offload()
4776 receive_encrypted_read(struct TCP_Server_Info *server, struct mid_q_entry **mid, in receive_encrypted_read() argument
4779 char *buf = server->smallbuf; in receive_encrypted_read()
4784 unsigned int buflen = server->pdu_size; in receive_encrypted_read()
4790 len = min_t(unsigned int, buflen, server->vals->read_rsp_size + in receive_encrypted_read()
4791 sizeof(struct smb2_transform_hdr)) - HEADER_SIZE(server) + 1; in receive_encrypted_read()
4793 rc = cifs_read_from_socket(server, buf + HEADER_SIZE(server) - 1, len); in receive_encrypted_read()
4796 server->total_read += rc; in receive_encrypted_read()
4799 server->vals->read_rsp_size; in receive_encrypted_read()
4817 rc = read_data_into_pages(server, pages, npages, len); in receive_encrypted_read()
4821 rc = cifs_discard_remaining_data(server); in receive_encrypted_read()
4830 if ((server->min_offload) && (server->in_flight > 1) && in receive_encrypted_read()
4831 (server->pdu_size >= server->min_offload)) { in receive_encrypted_read()
4836 dw->buf = server->smallbuf; in receive_encrypted_read()
4837 server->smallbuf = (char *)cifs_small_buf_get(); in receive_encrypted_read()
4842 dw->server = server; in receive_encrypted_read()
4851 rc = decrypt_raw_data(server, buf, server->vals->read_rsp_size, in receive_encrypted_read()
4856 *mid = smb2_find_mid(server, buf); in receive_encrypted_read()
4862 rc = handle_read_data(server, *mid, buf, in receive_encrypted_read()
4863 server->vals->read_rsp_size, in receive_encrypted_read()
4873 cifs_discard_remaining_data(server); in receive_encrypted_read()
4878 receive_encrypted_standard(struct TCP_Server_Info *server, in receive_encrypted_standard() argument
4883 char *buf = server->smallbuf; in receive_encrypted_standard()
4885 unsigned int pdu_length = server->pdu_size; in receive_encrypted_standard()
4895 server->large_buf = true; in receive_encrypted_standard()
4896 memcpy(server->bigbuf, buf, server->total_read); in receive_encrypted_standard()
4897 buf = server->bigbuf; in receive_encrypted_standard()
4901 length = cifs_read_from_socket(server, buf + HEADER_SIZE(server) - 1, in receive_encrypted_standard()
4902 pdu_length - HEADER_SIZE(server) + 1); in receive_encrypted_standard()
4905 server->total_read += length; in receive_encrypted_standard()
4908 length = decrypt_raw_data(server, buf, buf_size, NULL, 0, 0, false); in receive_encrypted_standard()
4912 next_is_large = server->large_buf; in receive_encrypted_standard()
4925 mid_entry = smb2_find_mid(server, buf); in receive_encrypted_standard()
4931 mid_entry->resp_buf_size = server->pdu_size; in receive_encrypted_standard()
4942 ret = mid_entry->handle(server, mid_entry); in receive_encrypted_standard()
4944 ret = cifs_handle_standard(server, mid_entry); in receive_encrypted_standard()
4948 server->large_buf = next_is_large; in receive_encrypted_standard()
4950 server->bigbuf = buf = next_buffer; in receive_encrypted_standard()
4952 server->smallbuf = buf = next_buffer; in receive_encrypted_standard()
4971 smb3_receive_transform(struct TCP_Server_Info *server, in smb3_receive_transform() argument
4974 char *buf = server->smallbuf; in smb3_receive_transform()
4975 unsigned int pdu_length = server->pdu_size; in smb3_receive_transform()
4983 cifs_reconnect(server); in smb3_receive_transform()
4989 cifs_reconnect(server); in smb3_receive_transform()
4994 if (pdu_length > CIFSMaxBufSize + MAX_HEADER_SIZE(server)) { in smb3_receive_transform()
4995 return receive_encrypted_read(server, &mids[0], num_mids); in smb3_receive_transform()
4998 return receive_encrypted_standard(server, mids, bufs, num_mids); in smb3_receive_transform()
5002 smb3_handle_read_data(struct TCP_Server_Info *server, struct mid_q_entry *mid) in smb3_handle_read_data() argument
5004 char *buf = server->large_buf ? server->bigbuf : server->smallbuf; in smb3_handle_read_data()
5006 return handle_read_data(server, mid, buf, server->pdu_size, in smb3_handle_read_data()
5075 if (tcon->ses->server->oplocks) in smb2_make_node()
5079 rc = tcon->ses->server->ops->open(xid, &oparms, &oplock, buf); in smb2_make_node()
5099 rc = tcon->ses->server->ops->sync_write(xid, &fid, &io_parms, in smb2_make_node()
5105 rc = tcon->ses->server->ops->sync_write(xid, &fid, &io_parms, in smb2_make_node()
5108 tcon->ses->server->ops->close(xid, tcon, &fid); in smb2_make_node()