diff options
| -rw-r--r-- | tests/bugs/bug-869724.t | 61 | ||||
| -rw-r--r-- | xlators/features/locks/src/common.c | 24 | 
2 files changed, 84 insertions, 1 deletions
diff --git a/tests/bugs/bug-869724.t b/tests/bugs/bug-869724.t new file mode 100644 index 00000000000..6dfc4060d45 --- /dev/null +++ b/tests/bugs/bug-869724.t @@ -0,0 +1,61 @@ +#!/bin/bash + +. $(dirname $0)/../include.rc + +cleanup; + + +## Start and create a volume +TEST glusterd +TEST pidof glusterd + +TEST $CLI volume create $V0 $H0:$B0/${V0}1; + +function volinfo_field() +{ +    local vol=$1; +    local field=$2; + +    $CLI volume info $vol | grep "^$field: " | sed 's/.*: //'; +} + + +## Verify volume is is created +EXPECT "$V0" volinfo_field $V0 'Volume Name'; +EXPECT 'Created' volinfo_field $V0 'Status'; + + +## Start volume and verify +TEST $CLI volume start $V0; +EXPECT 'Started' volinfo_field $V0 'Status'; + + +## Make volume tightly consistent for metdata +TEST $CLI volume set $V0 performance.stat-prefetch off; + +## Mount FUSE with caching disabled +TEST glusterfs --entry-timeout=0 --attribute-timeout=0 -s $H0 --volfile-id $V0 $M0; + +function cleanup_tester () +{ +    local exe=$1 +    rm -f $exe +} + +function build_tester () +{ +    local cfile=$1 +    local fname=$(basename "$cfile") +    local ext="${fname##*.}" +    local execname="${fname%.*}" +    gcc -g -o $(dirname $cfile)/$execname $cfile +} + +touch $M0/test; +build_tester $(dirname $0)/getlk_owner.c + +TEST $(dirname $0)/getlk_owner $M0/test; + +rm -f $(dirname $0)/getlk_owner +cleanup; + diff --git a/xlators/features/locks/src/common.c b/xlators/features/locks/src/common.c index af03cdf2a7a..9883859a075 100644 --- a/xlators/features/locks/src/common.c +++ b/xlators/features/locks/src/common.c @@ -725,6 +725,28 @@ done:          return v;  } +static posix_lock_t * +first_conflicting_overlap (pl_inode_t *pl_inode, posix_lock_t *lock) +{ +        posix_lock_t *l = NULL; + +        list_for_each_entry (l, &pl_inode->ext_list, list) { +                if (l->blocked) +                        continue; + +                if (locks_overlap (l, lock)) { +                        if (same_owner (l, lock)) +                                continue; + +                        if ((l->fl_type == F_WRLCK) || +                            (lock->fl_type == F_WRLCK)) +                                return l; +                } +        } + +        return NULL; +} +  /*    Start searching from {begin}, and return the first lock that    conflicts, NULL if no conflict @@ -1066,7 +1088,7 @@ pl_getlk (pl_inode_t *pl_inode, posix_lock_t *lock)  {          posix_lock_t *conf = NULL; -        conf = first_overlap (pl_inode, lock); +        conf = first_conflicting_overlap (pl_inode, lock);          if (conf == NULL) {                  lock->fl_type = F_UNLCK;  | 
