summaryrefslogtreecommitdiff
path: root/include/linux/backing-dev.h
blob: 55218964e7eff43f295997b9c9ba8e474debaa0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*
 * include/linux/backing-dev.h
 *
 * low-level device information and state which is propagated up through
 * to high-level code.
 */

#ifndef _LINUX_BACKING_DEV_H
#define _LINUX_BACKING_DEV_H

#include <asm/atomic.h>

/*
 * Bits in backing_dev_info.state
 */
enum bdi_state {
	BDI_pdflush,		/* A pdflush thread is working this device */
	BDI_write_congested,	/* The write queue is getting full */
	BDI_read_congested,	/* The read queue is getting full */
	BDI_write_active,	/* There are one or more queued writes */
	BDI_read_active,	/* There are one or more queued reads */
	BDI_unused,		/* Available bits start here */
};

struct backing_dev_info {
	unsigned long ra_pages;	/* max readahead in PAGE_CACHE_SIZE units */
	unsigned long state;	/* Always use atomic bitops on this */
	int memory_backed;	/* Cannot clean pages with writepage */
};

extern struct backing_dev_info default_backing_dev_info;

int writeback_acquire(struct backing_dev_info *bdi);
int writeback_in_progress(struct backing_dev_info *bdi);
void writeback_release(struct backing_dev_info *bdi);

static inline int bdi_read_congested(struct backing_dev_info *bdi)
{
	return test_bit(BDI_read_congested, &bdi->state);
}

static inline int bdi_write_congested(struct backing_dev_info *bdi)
{
	return test_bit(BDI_write_congested, &bdi->state);
}

static inline int bdi_read_active(struct backing_dev_info *bdi)
{
	return test_bit(BDI_read_active, &bdi->state);
}

static inline int bdi_write_active(struct backing_dev_info *bdi)
{
	return test_bit(BDI_write_active, &bdi->state);
}

#endif		/* _LINUX_BACKING_DEV_H */