aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ocfs2/journal.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ocfs2/journal.c')
-rw-r--r--fs/ocfs2/journal.c30
1 files changed, 17 insertions, 13 deletions
diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c
index 0b2c27a9485e..f033760ecbea 100644
--- a/fs/ocfs2/journal.c
+++ b/fs/ocfs2/journal.c
@@ -1883,7 +1883,7 @@ void ocfs2_queue_orphan_scan(struct ocfs2_super *osb)
1883 if (atomic_read(&os->os_state) == ORPHAN_SCAN_INACTIVE) 1883 if (atomic_read(&os->os_state) == ORPHAN_SCAN_INACTIVE)
1884 goto out; 1884 goto out;
1885 1885
1886 status = ocfs2_orphan_scan_lock(osb, &seqno, DLM_LOCK_EX); 1886 status = ocfs2_orphan_scan_lock(osb, &seqno);
1887 if (status < 0) { 1887 if (status < 0) {
1888 if (status != -EAGAIN) 1888 if (status != -EAGAIN)
1889 mlog_errno(status); 1889 mlog_errno(status);
@@ -1910,7 +1910,7 @@ void ocfs2_queue_orphan_scan(struct ocfs2_super *osb)
1910 os->os_count++; 1910 os->os_count++;
1911 os->os_scantime = CURRENT_TIME; 1911 os->os_scantime = CURRENT_TIME;
1912unlock: 1912unlock:
1913 ocfs2_orphan_scan_unlock(osb, seqno, DLM_LOCK_EX); 1913 ocfs2_orphan_scan_unlock(osb, seqno);
1914out: 1914out:
1915 return; 1915 return;
1916} 1916}
@@ -1938,29 +1938,33 @@ void ocfs2_orphan_scan_stop(struct ocfs2_super *osb)
1938 struct ocfs2_orphan_scan *os; 1938 struct ocfs2_orphan_scan *os;
1939 1939
1940 os = &osb->osb_orphan_scan; 1940 os = &osb->osb_orphan_scan;
1941 atomic_set(&os->os_state, ORPHAN_SCAN_INACTIVE); 1941 if (atomic_read(&os->os_state) == ORPHAN_SCAN_ACTIVE) {
1942 mutex_lock(&os->os_lock); 1942 atomic_set(&os->os_state, ORPHAN_SCAN_INACTIVE);
1943 cancel_delayed_work(&os->os_orphan_scan_work); 1943 mutex_lock(&os->os_lock);
1944 mutex_unlock(&os->os_lock); 1944 cancel_delayed_work(&os->os_orphan_scan_work);
1945 mutex_unlock(&os->os_lock);
1946 }
1945} 1947}
1946 1948
1947int ocfs2_orphan_scan_init(struct ocfs2_super *osb) 1949void ocfs2_orphan_scan_init(struct ocfs2_super *osb)
1948{ 1950{
1949 struct ocfs2_orphan_scan *os; 1951 struct ocfs2_orphan_scan *os;
1950 1952
1951 os = &osb->osb_orphan_scan; 1953 os = &osb->osb_orphan_scan;
1952 atomic_set(&os->os_state, ORPHAN_SCAN_ACTIVE);
1953 os->os_osb = osb; 1954 os->os_osb = osb;
1954 os->os_count = 0; 1955 os->os_count = 0;
1955 os->os_seqno = 0; 1956 os->os_seqno = 0;
1956 os->os_scantime = CURRENT_TIME; 1957 os->os_scantime = CURRENT_TIME;
1957 mutex_init(&os->os_lock); 1958 mutex_init(&os->os_lock);
1959 INIT_DELAYED_WORK(&os->os_orphan_scan_work, ocfs2_orphan_scan_work);
1958 1960
1959 INIT_DELAYED_WORK(&os->os_orphan_scan_work, 1961 if (ocfs2_is_hard_readonly(osb) || ocfs2_mount_local(osb))
1960 ocfs2_orphan_scan_work); 1962 atomic_set(&os->os_state, ORPHAN_SCAN_INACTIVE);
1961 schedule_delayed_work(&os->os_orphan_scan_work, 1963 else {
1962 ocfs2_orphan_scan_timeout()); 1964 atomic_set(&os->os_state, ORPHAN_SCAN_ACTIVE);
1963 return 0; 1965 schedule_delayed_work(&os->os_orphan_scan_work,
1966 ocfs2_orphan_scan_timeout());
1967 }
1964} 1968}
1965 1969
1966struct ocfs2_orphan_filldir_priv { 1970struct ocfs2_orphan_filldir_priv {