2 * Copyright (C) 2012 Red Hat. All rights reserved.
4 * This file is released under the GPL.
7 #ifndef DM_CACHE_POLICY_INTERNAL_H
8 #define DM_CACHE_POLICY_INTERNAL_H
10 #include "dm-cache-policy.h"
12 /*----------------------------------------------------------------*/
15 * Little inline functions that simplify calling the policy methods.
17 static inline int policy_map(struct dm_cache_policy
*p
, dm_oblock_t oblock
,
18 bool can_block
, bool can_migrate
, bool discarded_oblock
,
19 struct bio
*bio
, struct policy_result
*result
)
21 return p
->map(p
, oblock
, can_block
, can_migrate
, discarded_oblock
, bio
, result
);
24 static inline int policy_lookup(struct dm_cache_policy
*p
, dm_oblock_t oblock
, dm_cblock_t
*cblock
)
27 return p
->lookup(p
, oblock
, cblock
);
30 static inline void policy_set_dirty(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
33 p
->set_dirty(p
, oblock
);
36 static inline void policy_clear_dirty(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
39 p
->clear_dirty(p
, oblock
);
42 static inline int policy_load_mapping(struct dm_cache_policy
*p
,
43 dm_oblock_t oblock
, dm_cblock_t cblock
,
44 uint32_t hint
, bool hint_valid
)
46 return p
->load_mapping(p
, oblock
, cblock
, hint
, hint_valid
);
49 static inline int policy_walk_mappings(struct dm_cache_policy
*p
,
50 policy_walk_fn fn
, void *context
)
52 return p
->walk_mappings
? p
->walk_mappings(p
, fn
, context
) : 0;
55 static inline int policy_writeback_work(struct dm_cache_policy
*p
,
59 return p
->writeback_work
? p
->writeback_work(p
, oblock
, cblock
) : -ENOENT
;
62 static inline void policy_remove_mapping(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
64 p
->remove_mapping(p
, oblock
);
67 static inline int policy_remove_cblock(struct dm_cache_policy
*p
, dm_cblock_t cblock
)
69 return p
->remove_cblock(p
, cblock
);
72 static inline void policy_force_mapping(struct dm_cache_policy
*p
,
73 dm_oblock_t current_oblock
, dm_oblock_t new_oblock
)
75 return p
->force_mapping(p
, current_oblock
, new_oblock
);
78 static inline dm_cblock_t
policy_residency(struct dm_cache_policy
*p
)
80 return p
->residency(p
);
83 static inline void policy_tick(struct dm_cache_policy
*p
)
89 static inline int policy_emit_config_values(struct dm_cache_policy
*p
, char *result
, unsigned maxlen
)
92 if (p
->emit_config_values
)
93 return p
->emit_config_values(p
, result
, maxlen
);
99 static inline int policy_set_config_value(struct dm_cache_policy
*p
,
100 const char *key
, const char *value
)
102 return p
->set_config_value
? p
->set_config_value(p
, key
, value
) : -EINVAL
;
105 /*----------------------------------------------------------------*/
108 * Creates a new cache policy given a policy name, a cache size, an origin size and the block size.
110 struct dm_cache_policy
*dm_cache_policy_create(const char *name
, dm_cblock_t cache_size
,
111 sector_t origin_size
, sector_t block_size
);
114 * Destroys the policy. This drops references to the policy module as well
115 * as calling it's destroy method. So always use this rather than calling
116 * the policy->destroy method directly.
118 void dm_cache_policy_destroy(struct dm_cache_policy
*p
);
121 * In case we've forgotten.
123 const char *dm_cache_policy_get_name(struct dm_cache_policy
*p
);
125 const unsigned *dm_cache_policy_get_version(struct dm_cache_policy
*p
);
127 size_t dm_cache_policy_get_hint_size(struct dm_cache_policy
*p
);
129 /*----------------------------------------------------------------*/
131 #endif /* DM_CACHE_POLICY_INTERNAL_H */