aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorAlasdair G Kergon <agk@redhat.com>2008-04-24 16:43:52 -0400
committerAlasdair G Kergon <agk@redhat.com>2008-04-25 08:26:53 -0400
commit0da336e5fab75c712ba8c67f3135d5a20528465f (patch)
tree8907bfc6db07ba73979df23d99424984aa02d3d7 /include/linux
parent945fa4d283a3a472186c11028f6fea1e77a91d14 (diff)
dm: expose macros
Make dm.h macros and inlines available in include/linux/device-mapper.h Signed-off-by: Alasdair G Kergon <agk@redhat.com>
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/device-mapper.h94
1 files changed, 93 insertions, 1 deletions
diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h
index 4db23378cfb1..a68829e274fe 100644
--- a/include/linux/device-mapper.h
+++ b/include/linux/device-mapper.h
@@ -1,6 +1,6 @@
1/* 1/*
2 * Copyright (C) 2001 Sistina Software (UK) Limited. 2 * Copyright (C) 2001 Sistina Software (UK) Limited.
3 * Copyright (C) 2004 Red Hat, Inc. All rights reserved. 3 * Copyright (C) 2004-2008 Red Hat, Inc. All rights reserved.
4 * 4 *
5 * This file is released under the LGPL. 5 * This file is released under the LGPL.
6 */ 6 */
@@ -258,5 +258,97 @@ int dm_swap_table(struct mapped_device *md, struct dm_table *t);
258 */ 258 */
259int dm_create_error_table(struct dm_table **result, struct mapped_device *md); 259int dm_create_error_table(struct dm_table **result, struct mapped_device *md);
260 260
261/*-----------------------------------------------------------------
262 * Macros.
263 *---------------------------------------------------------------*/
264#define DM_NAME "device-mapper"
265
266#define DMERR(f, arg...) \
267 printk(KERN_ERR DM_NAME ": " DM_MSG_PREFIX ": " f "\n", ## arg)
268#define DMERR_LIMIT(f, arg...) \
269 do { \
270 if (printk_ratelimit()) \
271 printk(KERN_ERR DM_NAME ": " DM_MSG_PREFIX ": " \
272 f "\n", ## arg); \
273 } while (0)
274
275#define DMWARN(f, arg...) \
276 printk(KERN_WARNING DM_NAME ": " DM_MSG_PREFIX ": " f "\n", ## arg)
277#define DMWARN_LIMIT(f, arg...) \
278 do { \
279 if (printk_ratelimit()) \
280 printk(KERN_WARNING DM_NAME ": " DM_MSG_PREFIX ": " \
281 f "\n", ## arg); \
282 } while (0)
283
284#define DMINFO(f, arg...) \
285 printk(KERN_INFO DM_NAME ": " DM_MSG_PREFIX ": " f "\n", ## arg)
286#define DMINFO_LIMIT(f, arg...) \
287 do { \
288 if (printk_ratelimit()) \
289 printk(KERN_INFO DM_NAME ": " DM_MSG_PREFIX ": " f \
290 "\n", ## arg); \
291 } while (0)
292
293#ifdef CONFIG_DM_DEBUG
294# define DMDEBUG(f, arg...) \
295 printk(KERN_DEBUG DM_NAME ": " DM_MSG_PREFIX " DEBUG: " f "\n", ## arg)
296# define DMDEBUG_LIMIT(f, arg...) \
297 do { \
298 if (printk_ratelimit()) \
299 printk(KERN_DEBUG DM_NAME ": " DM_MSG_PREFIX ": " f \
300 "\n", ## arg); \
301 } while (0)
302#else
303# define DMDEBUG(f, arg...) do {} while (0)
304# define DMDEBUG_LIMIT(f, arg...) do {} while (0)
305#endif
306
307#define DMEMIT(x...) sz += ((sz >= maxlen) ? \
308 0 : scnprintf(result + sz, maxlen - sz, x))
309
310#define SECTOR_SHIFT 9
311
312/*
313 * Definitions of return values from target end_io function.
314 */
315#define DM_ENDIO_INCOMPLETE 1
316#define DM_ENDIO_REQUEUE 2
317
318/*
319 * Definitions of return values from target map function.
320 */
321#define DM_MAPIO_SUBMITTED 0
322#define DM_MAPIO_REMAPPED 1
323#define DM_MAPIO_REQUEUE DM_ENDIO_REQUEUE
324
325/*
326 * Ceiling(n / sz)
327 */
328#define dm_div_up(n, sz) (((n) + (sz) - 1) / (sz))
329
330#define dm_sector_div_up(n, sz) ( \
331{ \
332 sector_t _r = ((n) + (sz) - 1); \
333 sector_div(_r, (sz)); \
334 _r; \
335} \
336)
337
338/*
339 * ceiling(n / size) * size
340 */
341#define dm_round_up(n, sz) (dm_div_up((n), (sz)) * (sz))
342
343static inline sector_t to_sector(unsigned long n)
344{
345 return (n >> SECTOR_SHIFT);
346}
347
348static inline unsigned long to_bytes(sector_t n)
349{
350 return (n << SECTOR_SHIFT);
351}
352
261#endif /* __KERNEL__ */ 353#endif /* __KERNEL__ */
262#endif /* _LINUX_DEVICE_MAPPER_H */ 354#endif /* _LINUX_DEVICE_MAPPER_H */