1 #ifndef PARALLEL_CHECKOUT_H
2 #define PARALLEL_CHECKOUT_H
10 /****************************************************************
11 * Users of parallel checkout
12 ****************************************************************/
20 enum pc_status
parallel_checkout_status(void);
21 void get_parallel_checkout_configs(int *num_workers
, int *threshold
);
24 * Put parallel checkout into the PC_ACCEPTING_ENTRIES state. Should be used
25 * only when in the PC_UNINITIALIZED state.
27 void init_parallel_checkout(void);
30 * Return -1 if parallel checkout is currently not accepting entries or if the
31 * entry is not eligible for parallel checkout. Otherwise, enqueue the entry
32 * for later write and return 0.
34 int enqueue_checkout(struct cache_entry
*ce
, struct conv_attrs
*ca
,
35 int *checkout_counter
);
36 size_t pc_queue_size(void);
39 * Write all the queued entries, returning 0 on success. If the number of
40 * entries is smaller than the specified threshold, the operation is performed
43 int run_parallel_checkout(struct checkout
*state
, int num_workers
, int threshold
,
44 struct progress
*progress
, unsigned int *progress_cnt
);
46 /****************************************************************
47 * Interface with checkout--worker
48 ****************************************************************/
54 * The entry could not be written because there was another file
55 * already present in its path or leading directories. Since
56 * checkout_entry_ca() removes such files from the working tree before
57 * enqueueing the entry for parallel checkout, it means that there was
58 * a path collision among the entries being written.
64 struct parallel_checkout_item
{
66 * In main process ce points to a istate->cache[] entry. Thus, it's not
67 * owned by us. In workers they own the memory, which *must be* released.
69 struct cache_entry
*ce
;
71 size_t id
; /* position in parallel_checkout.items[] of main process */
72 int *checkout_counter
;
74 /* Output fields, sent from workers. */
75 enum pc_item_status status
;
80 * The fixed-size portion of `struct parallel_checkout_item` that is sent to the
81 * workers. Following this will be 2 strings: ca.working_tree_encoding and
82 * ce.name; These are NOT null terminated, since we have the size in the fixed
85 * Note that not all fields of conv_attrs and cache_entry are passed, only the
86 * ones that will be required by the workers to smudge and write the entry.
88 struct pc_item_fixed_portion
{
92 enum convert_crlf_action crlf_action
;
94 size_t working_tree_encoding_len
;
99 * The fields of `struct parallel_checkout_item` that are returned by the
100 * workers. Note: `st` must be the last one, as it is omitted on error.
102 struct pc_item_result
{
104 enum pc_item_status status
;
108 #define PC_ITEM_RESULT_BASE_SIZE offsetof(struct pc_item_result, st)
110 void write_pc_item(struct parallel_checkout_item
*pc_item
,
111 struct checkout
*state
);
113 #endif /* PARALLEL_CHECKOUT_H */