1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
/*
Copyright (c) 2008-2012 Red Hat, Inc. <http://www.redhat.com>
This file is part of GlusterFS.
This file is licensed to you under your choice of the GNU Lesser
General Public License, version 3 or any later version (LGPLv3 or
later), or the GNU General Public License, version 2 (GPLv2), in all
cases as published by the Free Software Foundation.
*/
#ifndef __TRANSACTION_H__
#define __TRANSACTION_H__
#include "afr.h"
void
afr_transaction_fop_failed (call_frame_t *frame, xlator_t *this,
int child_index);
void
afr_txn_arbitrate_fop_cbk (call_frame_t *frame, xlator_t *this);
int
afr_lock_server_count (afr_private_t *priv, afr_transaction_type type);
afr_inodelk_t*
afr_get_inodelk (afr_internal_lock_t *int_lock, char *dom);
int32_t
afr_transaction (call_frame_t *frame, xlator_t *this, afr_transaction_type type);
int
afr_set_pending_dict (afr_private_t *priv, dict_t *xattr, int32_t **pending);
void
afr_set_delayed_post_op (call_frame_t *frame, xlator_t *this);
void
afr_delayed_changelog_wake_up (xlator_t *this, fd_t *fd);
void
__mark_all_success (call_frame_t *frame, xlator_t *this);
gf_boolean_t
afr_txn_nothing_failed (call_frame_t *frame, xlator_t *this);
int afr_read_txn (call_frame_t *frame, xlator_t *this, inode_t *inode,
afr_read_txn_wind_t readfn, afr_transaction_type type);
int afr_read_txn_continue (call_frame_t *frame, xlator_t *this, int subvol);
int __afr_txn_write_fop (call_frame_t *frame, xlator_t *this);
int __afr_txn_write_done (call_frame_t *frame, xlator_t *this);
call_frame_t *afr_transaction_detach_fop_frame (call_frame_t *frame);
gf_boolean_t afr_has_quorum (unsigned char *subvols, xlator_t *this);
gf_boolean_t afr_needs_changelog_update (afr_local_t *local);
void afr_zero_fill_stat (afr_local_t *local);
#endif /* __TRANSACTION_H__ */
|