Motr  M0
log_discard.h
Go to the documentation of this file.
1 /* -*- C -*- */
2 /*
3  * Copyright (c) 2015-2020 Seagate Technology LLC and/or its Affiliates
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * For any questions about this software or licensing,
18  * please email opensource@seagate.com or cortx-questions@seagate.com.
19  *
20  */
21 
22 
23 #pragma once
24 
25 #ifndef __MOTR_BE_LOG_DISCARD_H__
26 #define __MOTR_BE_LOG_DISCARD_H__
27 
28 #include "lib/mutex.h" /* m0_mutex */
29 #include "lib/tlist.h" /* m0_tl */
30 #include "lib/time.h" /* m0_time_t */
31 #include "lib/semaphore.h" /* m0_semaphore */
32 
33 #include "be/op.h" /* m0_be_op */
34 #include "be/pool.h" /* m0_be_pool */
35 
74 struct m0_locality;
75 struct m0_ext;
76 struct m0_be_op;
77 struct m0_be_log_discard;
79 
81  void (*ldsc_sync)(struct m0_be_log_discard *ld,
82  struct m0_be_op *op,
83  struct m0_be_log_discard_item *ldi);
84  void (*ldsc_discard)(struct m0_be_log_discard *ld,
85  struct m0_be_log_discard_item *ldi);
86  uint32_t ldsc_items_max;
96 };
97 
124 };
125 
126 M0_INTERNAL int m0_be_log_discard_init(struct m0_be_log_discard *ld,
127  struct m0_be_log_discard_cfg *ld_cfg);
128 M0_INTERNAL void m0_be_log_discard_fini(struct m0_be_log_discard *ld);
129 
130 M0_INTERNAL void m0_be_log_discard_sync(struct m0_be_log_discard *ld);
131 M0_INTERNAL void m0_be_log_discard_flush(struct m0_be_log_discard *ld,
132  struct m0_be_op *op);
133 
134 M0_INTERNAL void
136  struct m0_be_log_discard_item *ldi);
137 M0_INTERNAL void
139  struct m0_be_log_discard_item *ldi);
140 
141 M0_INTERNAL void
143  struct m0_be_op *op,
144  struct m0_be_log_discard_item **ldi);
145 M0_INTERNAL void m0_be_log_discard_item_put(struct m0_be_log_discard *ld,
146  struct m0_be_log_discard_item *ldi);
147 
148 M0_INTERNAL void
150  void *data);
151 M0_INTERNAL void *
153 
154 M0_INTERNAL void
156  struct m0_ext *ext);
157 M0_INTERNAL struct m0_ext *
159 
160 
162 #endif /* __MOTR_BE_LOG_DISCARD_H__ */
163 
164 /*
165  * Local variables:
166  * c-indentation-style: "K&R"
167  * c-basic-offset: 8
168  * tab-width: 8
169  * fill-column: 80
170  * scroll-step: 1
171  * End:
172  */
173 /*
174  * vim: tabstop=8 shiftwidth=8 noexpandtab textwidth=80 nowrap
175  */
M0_INTERNAL void m0_be_log_discard_item_finished(struct m0_be_log_discard *ld, struct m0_be_log_discard_item *ldi)
Definition: log_discard.c:417
struct m0_tl lds_start_q
Definition: log_discard.h:103
struct m0_be_op * lds_flush_op
Definition: log_discard.h:109
struct m0_be_log_discard_item * lds_sync_item
Definition: log_discard.h:106
m0_time_t lds_sync_deadline
Definition: log_discard.h:107
uint64_t m0_time_t
Definition: time.h:37
struct m0_locality * ldsc_loc
Definition: log_discard.h:94
M0_INTERNAL void m0_be_log_discard_flush(struct m0_be_log_discard *ld, struct m0_be_op *op)
Definition: log_discard.c:374
void(* ldsc_sync)(struct m0_be_log_discard *ld, struct m0_be_op *op, struct m0_be_log_discard_item *ldi)
Definition: log_discard.h:81
M0_INTERNAL void m0_be_log_discard_item_starting(struct m0_be_log_discard *ld, struct m0_be_log_discard_item *ldi)
Definition: log_discard.c:400
struct m0_bufvec data
Definition: di.c:40
struct m0_semaphore lds_discard_wait_sem
Definition: log_discard.h:117
Definition: sm.h:504
uint32_t ldsc_items_pending_max
Definition: log_discard.h:93
struct m0_sm_ast lds_discard_ast
Definition: log_discard.h:122
M0_INTERNAL int m0_be_log_discard_init(struct m0_be_log_discard *ld, struct m0_be_log_discard_cfg *ld_cfg)
Definition: log_discard.c:85
op
Definition: libdemo.c:64
struct m0_be_log_discard_cfg lds_cfg
Definition: log_discard.h:99
struct m0_be_log_discard_item * lds_item
Definition: log_discard.h:100
M0_INTERNAL void m0_be_log_discard_item_get(struct m0_be_log_discard *ld, struct m0_be_op *op, struct m0_be_log_discard_item **ldi)
Definition: log_discard.c:444
M0_INTERNAL void m0_be_log_discard_item_put(struct m0_be_log_discard *ld, struct m0_be_log_discard_item *ldi)
Definition: log_discard.c:451
Definition: tlist.h:251
uint32_t ldsc_items_threshold
Definition: log_discard.h:92
bool lds_discard_ast_posted
Definition: log_discard.h:123
M0_INTERNAL void m0_be_log_discard_item_ext_set(struct m0_be_log_discard_item *ldi, struct m0_ext *ext)
Definition: log_discard.c:474
struct m0_be_op lds_sync_op
Definition: log_discard.h:108
struct m0_be_pool lds_item_pool
Definition: log_discard.h:102
M0_INTERNAL void m0_be_log_discard_fini(struct m0_be_log_discard *ld)
Definition: log_discard.c:135
void(* ldsc_discard)(struct m0_be_log_discard *ld, struct m0_be_log_discard_item *ldi)
Definition: log_discard.h:84
struct m0_sm_timer lds_sync_timer
Definition: log_discard.h:110
Definition: ext.h:37
M0_INTERNAL void m0_be_log_discard_sync(struct m0_be_log_discard *ld)
Definition: log_discard.c:367
M0_INTERNAL void * m0_be_log_discard_item_user_data(struct m0_be_log_discard_item *ldi)
Definition: log_discard.c:468
M0_INTERNAL struct m0_ext * m0_be_log_discard_item_ext(struct m0_be_log_discard_item *ldi)
Definition: log_discard.c:481
M0_INTERNAL void m0_be_log_discard_item_user_data_set(struct m0_be_log_discard_item *ldi, void *data)
Definition: log_discard.c:461
Definition: op.h:74
m0_time_t ldsc_sync_timeout
Definition: log_discard.h:95
Definition: mutex.h:47
struct m0_mutex lds_lock
Definition: log_discard.h:101