blob: 39f21dbedc38b43ec7bf4818cfca319d27d27433 [file] [log] [blame]
Kent Overstreetcafe5632013-03-23 16:11:31 -07001#ifndef _BCACHE_REQUEST_H_
2#define _BCACHE_REQUEST_H_
3
4#include <linux/cgroup.h>
5
Kent Overstreet220bb382013-09-10 19:02:45 -07006struct data_insert_op {
Kent Overstreetcafe5632013-03-23 16:11:31 -07007 struct closure cl;
Kent Overstreetc18536a2013-07-24 17:44:17 -07008 struct cache_set *c;
Kent Overstreet220bb382013-09-10 19:02:45 -07009 struct bio *bio;
Kent Overstreetcafe5632013-03-23 16:11:31 -070010
Kent Overstreetc18536a2013-07-24 17:44:17 -070011 unsigned inode;
Kent Overstreet2599b532013-07-24 18:11:11 -070012 uint16_t write_point;
Kent Overstreet220bb382013-09-10 19:02:45 -070013 uint16_t write_prio;
14 short error;
Kent Overstreetc18536a2013-07-24 17:44:17 -070015
Kent Overstreeta5ae4302013-09-10 19:16:31 -070016 union {
17 uint16_t flags;
Kent Overstreet220bb382013-09-10 19:02:45 -070018
Kent Overstreeta5ae4302013-09-10 19:16:31 -070019 struct {
20 unsigned bypass:1;
21 unsigned writeback:1;
22 unsigned flush_journal:1;
23 unsigned csum:1;
Kent Overstreetc18536a2013-07-24 17:44:17 -070024
Kent Overstreeta5ae4302013-09-10 19:16:31 -070025 unsigned replace:1;
26 unsigned replace_collision:1;
Kent Overstreet0b932072013-07-24 17:26:51 -070027
Kent Overstreeta5ae4302013-09-10 19:16:31 -070028 unsigned insert_data_done:1;
29 };
30 };
31
Kent Overstreet0b932072013-07-24 17:26:51 -070032 struct keylist insert_keys;
Kent Overstreet1b207d82013-09-10 18:52:54 -070033 BKEY_PADDED(replace_key);
Kent Overstreetcafe5632013-03-23 16:11:31 -070034};
35
Kent Overstreetc37511b2013-04-26 15:39:55 -070036unsigned bch_get_congested(struct cache_set *);
Kent Overstreeta34a8bf2013-10-24 17:07:04 -070037void bch_data_insert(struct closure *cl);
Kent Overstreetcafe5632013-03-23 16:11:31 -070038
Kent Overstreetcafe5632013-03-23 16:11:31 -070039void bch_cached_dev_request_init(struct cached_dev *dc);
40void bch_flash_dev_request_init(struct bcache_device *d);
41
42extern struct kmem_cache *bch_search_cache, *bch_passthrough_cache;
43
44struct bch_cgroup {
45#ifdef CONFIG_CGROUP_BCACHE
46 struct cgroup_subsys_state css;
47#endif
48 /*
49 * We subtract one from the index into bch_cache_modes[], so that
50 * default == -1; this makes it so the rest match up with d->cache_mode,
51 * and we use d->cache_mode if cgrp->cache_mode < 0
52 */
53 short cache_mode;
54 bool verify;
55 struct cache_stat_collector stats;
56};
57
58struct bch_cgroup *bch_bio_to_cgroup(struct bio *bio);
59
60#endif /* _BCACHE_REQUEST_H_ */