Commit 1bf7ba4c authored by Eric Biggers's avatar Eric Biggers Committed by Mikulas Patocka
Browse files

dm-bufio: merge cache_put() into cache_put_and_wake()



Merge cache_put() into its only caller, cache_put_and_wake().

Signed-off-by: default avatarEric Biggers <ebiggers@kernel.org>
Signed-off-by: default avatarMikulas Patocka <mpatocka@redhat.com>
parent f93bc869
Loading
Loading
Loading
Loading
+10 −22
Original line number Diff line number Diff line
@@ -369,8 +369,8 @@ struct dm_buffer {
 *  - IO
 *  - Eviction or cache sizing.
 *
 * cache_get() and cache_put() are threadsafe, you do not need to
 * protect these calls with a surrounding mutex.  All the other
 * cache_get() and cache_put_and_wake() are threadsafe, you do not need
 * to protect these calls with a surrounding mutex.  All the other
 * methods are not threadsafe; they do use locking primitives, but
 * only enough to ensure get/put are threadsafe.
 */
@@ -619,24 +619,6 @@ static struct dm_buffer *cache_get(struct dm_buffer_cache *bc, sector_t block)

/*--------------*/

/*
 * Returns true if the hold count hits zero.
 * threadsafe
 */
static bool cache_put(struct dm_buffer_cache *bc, struct dm_buffer *b)
{
	bool r;

	cache_read_lock(bc, b->block);
	BUG_ON(!atomic_read(&b->hold_count));
	r = atomic_dec_and_test(&b->hold_count);
	cache_read_unlock(bc, b->block);

	return r;
}

/*--------------*/

typedef enum evict_result (*b_predicate)(struct dm_buffer *, void *);

/*
@@ -1745,12 +1727,18 @@ static void __check_watermark(struct dm_bufio_client *c,

static void cache_put_and_wake(struct dm_bufio_client *c, struct dm_buffer *b)
{
	bool wake;

	cache_read_lock(&c->cache, b->block);
	BUG_ON(!atomic_read(&b->hold_count));
	wake = atomic_dec_and_test(&b->hold_count);
	cache_read_unlock(&c->cache, b->block);

	/*
	 * Relying on waitqueue_active() is racey, but we sleep
	 * with schedule_timeout anyway.
	 */
	if (cache_put(&c->cache, b) &&
	    unlikely(waitqueue_active(&c->free_buffer_wait)))
	if (wake && unlikely(waitqueue_active(&c->free_buffer_wait)))
		wake_up(&c->free_buffer_wait);
}