aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_log.c
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@infradead.org>2012-02-19 21:31:29 -0500
committerBen Myers <bpm@sgi.com>2012-02-22 23:31:45 -0500
commite179840d74606ab1935c83fe5ad9d93c95ddc956 (patch)
tree47899d69dd92e2e804c7cf47f9cc53abdafdf335 /fs/xfs/xfs_log.c
parent23ee3df349b8b8fd153bd02fccf08b31aec5bce3 (diff)
xfs: share code for grant head wakeups
Reviewed-by: Mark Tinguely <tinguely@sgi.com> Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Dave Chinner <dchinner@redhat.com> Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_log.c')
-rw-r--r--fs/xfs/xfs_log.c50
1 files changed, 20 insertions, 30 deletions
diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c
index c2d13827582b..685997548fb8 100644
--- a/fs/xfs/xfs_log.c
+++ b/fs/xfs/xfs_log.c
@@ -171,49 +171,39 @@ xlog_grant_head_wake_all(
171 spin_unlock(&head->lock); 171 spin_unlock(&head->lock);
172} 172}
173 173
174STATIC bool 174static inline int
175xlog_reserveq_wake( 175xlog_ticket_reservation(
176 struct log *log, 176 struct log *log,
177 int *free_bytes) 177 struct xlog_grant_head *head,
178 struct xlog_ticket *tic)
178{ 179{
179 struct xlog_ticket *tic; 180 if (head == &log->l_write_head) {
180 int need_bytes; 181 ASSERT(tic->t_flags & XLOG_TIC_PERM_RESERV);
181 182 return tic->t_unit_res;
182 list_for_each_entry(tic, &log->l_reserve_head.waiters, t_queue) { 183 } else {
183 if (tic->t_flags & XLOG_TIC_PERM_RESERV) 184 if (tic->t_flags & XLOG_TIC_PERM_RESERV)
184 need_bytes = tic->t_unit_res * tic->t_cnt; 185 return tic->t_unit_res * tic->t_cnt;
185 else 186 else
186 need_bytes = tic->t_unit_res; 187 return tic->t_unit_res;
187
188 if (*free_bytes < need_bytes)
189 return false;
190 *free_bytes -= need_bytes;
191
192 trace_xfs_log_grant_wake_up(log, tic);
193 wake_up_process(tic->t_task);
194 } 188 }
195
196 return true;
197} 189}
198 190
199STATIC bool 191STATIC bool
200xlog_writeq_wake( 192xlog_grant_head_wake(
201 struct log *log, 193 struct log *log,
194 struct xlog_grant_head *head,
202 int *free_bytes) 195 int *free_bytes)
203{ 196{
204 struct xlog_ticket *tic; 197 struct xlog_ticket *tic;
205 int need_bytes; 198 int need_bytes;
206 199
207 list_for_each_entry(tic, &log->l_write_head.waiters, t_queue) { 200 list_for_each_entry(tic, &head->waiters, t_queue) {
208 ASSERT(tic->t_flags & XLOG_TIC_PERM_RESERV); 201 need_bytes = xlog_ticket_reservation(log, head, tic);
209
210 need_bytes = tic->t_unit_res;
211
212 if (*free_bytes < need_bytes) 202 if (*free_bytes < need_bytes)
213 return false; 203 return false;
214 *free_bytes -= need_bytes;
215 204
216 trace_xfs_log_regrant_write_wake_up(log, tic); 205 *free_bytes -= need_bytes;
206 trace_xfs_log_grant_wake_up(log, tic);
217 wake_up_process(tic->t_task); 207 wake_up_process(tic->t_task);
218 } 208 }
219 209
@@ -772,7 +762,7 @@ xfs_log_space_wake(
772 762
773 spin_lock(&log->l_write_head.lock); 763 spin_lock(&log->l_write_head.lock);
774 free_bytes = xlog_space_left(log, &log->l_write_head.grant); 764 free_bytes = xlog_space_left(log, &log->l_write_head.grant);
775 xlog_writeq_wake(log, &free_bytes); 765 xlog_grant_head_wake(log, &log->l_write_head, &free_bytes);
776 spin_unlock(&log->l_write_head.lock); 766 spin_unlock(&log->l_write_head.lock);
777 } 767 }
778 768
@@ -781,7 +771,7 @@ xfs_log_space_wake(
781 771
782 spin_lock(&log->l_reserve_head.lock); 772 spin_lock(&log->l_reserve_head.lock);
783 free_bytes = xlog_space_left(log, &log->l_reserve_head.grant); 773 free_bytes = xlog_space_left(log, &log->l_reserve_head.grant);
784 xlog_reserveq_wake(log, &free_bytes); 774 xlog_grant_head_wake(log, &log->l_reserve_head, &free_bytes);
785 spin_unlock(&log->l_reserve_head.lock); 775 spin_unlock(&log->l_reserve_head.lock);
786 } 776 }
787} 777}
@@ -2562,7 +2552,7 @@ xlog_grant_log_space(
2562 free_bytes = xlog_space_left(log, &log->l_reserve_head.grant); 2552 free_bytes = xlog_space_left(log, &log->l_reserve_head.grant);
2563 if (!list_empty_careful(&log->l_reserve_head.waiters)) { 2553 if (!list_empty_careful(&log->l_reserve_head.waiters)) {
2564 spin_lock(&log->l_reserve_head.lock); 2554 spin_lock(&log->l_reserve_head.lock);
2565 if (!xlog_reserveq_wake(log, &free_bytes) || 2555 if (!xlog_grant_head_wake(log, &log->l_reserve_head, &free_bytes) ||
2566 free_bytes < need_bytes) { 2556 free_bytes < need_bytes) {
2567 error = xlog_grant_head_wait(log, &log->l_reserve_head, 2557 error = xlog_grant_head_wait(log, &log->l_reserve_head,
2568 tic, need_bytes); 2558 tic, need_bytes);
@@ -2618,7 +2608,7 @@ xlog_regrant_write_log_space(
2618 free_bytes = xlog_space_left(log, &log->l_write_head.grant); 2608 free_bytes = xlog_space_left(log, &log->l_write_head.grant);
2619 if (!list_empty_careful(&log->l_write_head.waiters)) { 2609 if (!list_empty_careful(&log->l_write_head.waiters)) {
2620 spin_lock(&log->l_write_head.lock); 2610 spin_lock(&log->l_write_head.lock);
2621 if (!xlog_writeq_wake(log, &free_bytes) || 2611 if (!xlog_grant_head_wake(log, &log->l_write_head, &free_bytes) ||
2622 free_bytes < need_bytes) { 2612 free_bytes < need_bytes) {
2623 error = xlog_grant_head_wait(log, &log->l_write_head, 2613 error = xlog_grant_head_wait(log, &log->l_write_head,
2624 tic, need_bytes); 2614 tic, need_bytes);