diff options
| -rw-r--r-- | fs/gfs2/glock.c | 23 |
1 files changed, 9 insertions, 14 deletions
diff --git a/fs/gfs2/glock.c b/fs/gfs2/glock.c index a7f3c462d4fe..80e09c50590a 100644 --- a/fs/gfs2/glock.c +++ b/fs/gfs2/glock.c | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved. | 2 | * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved. |
| 3 | * Copyright (C) 2004-2006 Red Hat, Inc. All rights reserved. | 3 | * Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved. |
| 4 | * | 4 | * |
| 5 | * This copyrighted material is made available to anyone wishing to use, | 5 | * This copyrighted material is made available to anyone wishing to use, |
| 6 | * modify, copy, or redistribute it subject to the terms and conditions | 6 | * modify, copy, or redistribute it subject to the terms and conditions |
| @@ -620,26 +620,21 @@ static void run_queue(struct gfs2_glock *gl) | |||
| 620 | 620 | ||
| 621 | static void gfs2_glmutex_lock(struct gfs2_glock *gl) | 621 | static void gfs2_glmutex_lock(struct gfs2_glock *gl) |
| 622 | { | 622 | { |
| 623 | struct gfs2_holder gh; | ||
| 624 | |||
| 625 | gfs2_holder_init(gl, 0, 0, &gh); | ||
| 626 | if (test_and_set_bit(HIF_WAIT, &gh.gh_iflags)) | ||
| 627 | BUG(); | ||
| 628 | |||
| 629 | spin_lock(&gl->gl_spin); | 623 | spin_lock(&gl->gl_spin); |
| 630 | if (test_and_set_bit(GLF_LOCK, &gl->gl_flags)) { | 624 | if (test_and_set_bit(GLF_LOCK, &gl->gl_flags)) { |
| 625 | struct gfs2_holder gh; | ||
| 626 | |||
| 627 | gfs2_holder_init(gl, 0, 0, &gh); | ||
| 628 | set_bit(HIF_WAIT, &gh.gh_iflags); | ||
| 631 | list_add_tail(&gh.gh_list, &gl->gl_waiters1); | 629 | list_add_tail(&gh.gh_list, &gl->gl_waiters1); |
| 630 | spin_unlock(&gl->gl_spin); | ||
| 631 | wait_on_holder(&gh); | ||
| 632 | gfs2_holder_uninit(&gh); | ||
| 632 | } else { | 633 | } else { |
| 633 | gl->gl_owner_pid = current->pid; | 634 | gl->gl_owner_pid = current->pid; |
| 634 | gl->gl_ip = (unsigned long)__builtin_return_address(0); | 635 | gl->gl_ip = (unsigned long)__builtin_return_address(0); |
| 635 | clear_bit(HIF_WAIT, &gh.gh_iflags); | 636 | spin_unlock(&gl->gl_spin); |
| 636 | smp_mb(); | ||
| 637 | wake_up_bit(&gh.gh_iflags, HIF_WAIT); | ||
| 638 | } | 637 | } |
| 639 | spin_unlock(&gl->gl_spin); | ||
| 640 | |||
| 641 | wait_on_holder(&gh); | ||
| 642 | gfs2_holder_uninit(&gh); | ||
| 643 | } | 638 | } |
| 644 | 639 | ||
| 645 | /** | 640 | /** |
