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_locker
*locker
,
20 struct policy_result
*result
)
22 return p
->map(p
, oblock
, can_block
, can_migrate
, discarded_oblock
, bio
, locker
, result
);
25 static inline int policy_lookup(struct dm_cache_policy
*p
, dm_oblock_t oblock
, dm_cblock_t
*cblock
)
28 return p
->lookup(p
, oblock
, cblock
);
31 static inline void policy_set_dirty(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
34 p
->set_dirty(p
, oblock
);
37 static inline void policy_clear_dirty(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
40 p
->clear_dirty(p
, oblock
);
43 static inline int policy_load_mapping(struct dm_cache_policy
*p
,
44 dm_oblock_t oblock
, dm_cblock_t cblock
,
45 uint32_t hint
, bool hint_valid
)
47 return p
->load_mapping(p
, oblock
, cblock
, hint
, hint_valid
);
50 static inline int policy_walk_mappings(struct dm_cache_policy
*p
,
51 policy_walk_fn fn
, void *context
)
53 return p
->walk_mappings
? p
->walk_mappings(p
, fn
, context
) : 0;
56 static inline int policy_writeback_work(struct dm_cache_policy
*p
,
60 return p
->writeback_work
? p
->writeback_work(p
, oblock
, cblock
) : -ENOENT
;
63 static inline void policy_remove_mapping(struct dm_cache_policy
*p
, dm_oblock_t oblock
)
65 p
->remove_mapping(p
, oblock
);
68 static inline int policy_remove_cblock(struct dm_cache_policy
*p
, dm_cblock_t cblock
)
70 return p
->remove_cblock(p
, cblock
);
73 static inline void policy_force_mapping(struct dm_cache_policy
*p
,
74 dm_oblock_t current_oblock
, dm_oblock_t new_oblock
)
76 return p
->force_mapping(p
, current_oblock
, new_oblock
);
79 static inline dm_cblock_t
policy_residency(struct dm_cache_policy
*p
)
81 return p
->residency(p
);
84 static inline void policy_tick(struct dm_cache_policy
*p
)
90 static inline int policy_emit_config_values(struct dm_cache_policy
*p
, char *result
, unsigned maxlen
)
93 if (p
->emit_config_values
)
94 return p
->emit_config_values(p
, result
, maxlen
);
100 static inline int policy_set_config_value(struct dm_cache_policy
*p
,
101 const char *key
, const char *value
)
103 return p
->set_config_value
? p
->set_config_value(p
, key
, value
) : -EINVAL
;
106 /*----------------------------------------------------------------*/
109 * Creates a new cache policy given a policy name, a cache size, an origin size and the block size.
111 struct dm_cache_policy
*dm_cache_policy_create(const char *name
, dm_cblock_t cache_size
,
112 sector_t origin_size
, sector_t block_size
);
115 * Destroys the policy. This drops references to the policy module as well
116 * as calling it's destroy method. So always use this rather than calling
117 * the policy->destroy method directly.
119 void dm_cache_policy_destroy(struct dm_cache_policy
*p
);
122 * In case we've forgotten.
124 const char *dm_cache_policy_get_name(struct dm_cache_policy
*p
);
126 const unsigned *dm_cache_policy_get_version(struct dm_cache_policy
*p
);
128 size_t dm_cache_policy_get_hint_size(struct dm_cache_policy
*p
);
130 /*----------------------------------------------------------------*/
132 #endif /* DM_CACHE_POLICY_INTERNAL_H */