2 Unix SMB/CIFS implementation.
4 Copyright (C) Volker Lendecke 2011
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
21 #include "system/network.h"
22 #include "lib/util/tevent_ntstatus.h"
23 #include "smb_common.h"
24 #include "smbXcli_base.h"
26 struct smb2cli_flush_state
{
30 static void smb2cli_flush_done(struct tevent_req
*subreq
);
32 struct tevent_req
*smb2cli_flush_send(TALLOC_CTX
*mem_ctx
,
33 struct tevent_context
*ev
,
34 struct smbXcli_conn
*conn
,
35 uint32_t timeout_msec
,
36 struct smbXcli_session
*session
,
37 struct smbXcli_tcon
*tcon
,
38 uint64_t fid_persistent
,
39 uint64_t fid_volatile
)
41 struct tevent_req
*req
, *subreq
;
42 struct smb2cli_flush_state
*state
;
45 req
= tevent_req_create(mem_ctx
, &state
,
46 struct smb2cli_flush_state
);
52 SBVAL(fixed
, 8, fid_persistent
);
53 SBVAL(fixed
, 16, fid_volatile
);
55 subreq
= smb2cli_req_send(state
, ev
, conn
, SMB2_OP_FLUSH
,
60 state
->fixed
, sizeof(state
->fixed
),
63 if (tevent_req_nomem(subreq
, req
)) {
64 return tevent_req_post(req
, ev
);
66 tevent_req_set_callback(subreq
, smb2cli_flush_done
, req
);
70 static void smb2cli_flush_done(struct tevent_req
*subreq
)
72 struct tevent_req
*req
=
73 tevent_req_callback_data(subreq
,
76 static const struct smb2cli_req_expected_response expected
[] = {
78 .status
= NT_STATUS_OK
,
83 status
= smb2cli_req_recv(subreq
, NULL
, NULL
,
84 expected
, ARRAY_SIZE(expected
));
86 if (tevent_req_nterror(req
, status
)) {
92 NTSTATUS
smb2cli_flush_recv(struct tevent_req
*req
)
94 return tevent_req_simple_recv_ntstatus(req
);
97 NTSTATUS
smb2cli_flush(struct smbXcli_conn
*conn
,
98 uint32_t timeout_msec
,
99 struct smbXcli_session
*session
,
100 struct smbXcli_tcon
*tcon
,
101 uint64_t fid_persistent
,
102 uint64_t fid_volatile
)
104 TALLOC_CTX
*frame
= talloc_stackframe();
105 struct tevent_context
*ev
;
106 struct tevent_req
*req
;
107 NTSTATUS status
= NT_STATUS_NO_MEMORY
;
109 if (smbXcli_conn_has_async_calls(conn
)) {
111 * Can't use sync call while an async call is in flight
113 status
= NT_STATUS_INVALID_PARAMETER
;
116 ev
= samba_tevent_context_init(frame
);
120 req
= smb2cli_flush_send(frame
, ev
, conn
, timeout_msec
,
122 fid_persistent
, fid_volatile
);
126 if (!tevent_req_poll_ntstatus(req
, ev
, &status
)) {
129 status
= smb2cli_flush_recv(req
);