1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

o dm-table compiles

This commit is contained in:
Joe Thornber 2001-08-21 14:47:42 +00:00
parent 1993c0acc2
commit 8b0affe220
3 changed files with 38 additions and 54 deletions

View File

@ -25,6 +25,10 @@
* 16/08/2001 - First version [Joe Thornber] * 16/08/2001 - First version [Joe Thornber]
*/ */
#include "dm.h"
static int _alloc_targets(struct mapped_device *md, int num);
static inline ulong _round_up(ulong n, ulong size) static inline ulong _round_up(ulong n, ulong size)
{ {
ulong r = n % size; ulong r = n % size;
@ -65,72 +69,50 @@ static int _setup_btree_index(int l, struct mapped_device *md)
return 1; return 1;
} }
void dm_free_btree(struct mapped_device *md) void dm_free_table(struct mapped_device *md)
{ {
int i; int i;
for (i = 0; i < md->depth; i++) for (i = 0; i < md->depth; i++)
__free_aligned(md->index[i]); vfree(md->index[i]);
__free_aligned(md->targets); vfree(md->targets);
__free_aligned(md->contexts); vfree(md->contexts);
md->num_targets = 0; md->num_targets = 0;
md->num_allocated = 0; md->num_allocated = 0;
} }
static int _setup_targets(struct mapped_device *md, struct device_table *t)
{
int i;
offset_t low = 0;
md->num_targets = t->count;
md->targets = vmalloc(sizeof(*md->targets) * md->num_targets,
NODE_SIZE);
for (i = 0; i < md->num_targets; i++) {
struct mapper *m = _find_mapper(t->map[i].type);
if (!m)
return 0;
if (!m->ctr(low, t->map[i].high + 1,
t->map[i].context, md->contexts + i)) {
WARN("contructor for '%s' failed", m->name);
return 0;
}
md->targets[i] = m->map;
}
return 1;
}
int dm_start_table(struct mapped_device *md) int dm_start_table(struct mapped_device *md)
{ {
bit_set(md->state, DM_LOADING); set_bit(DM_LOADING, &md->state);
dm_free_btree(md); dm_free_table(md);
if (!_alloc_targets(2)) /* FIXME: increase once debugged 256 ? */ if (!_alloc_targets(md, 2)) /* FIXME: increase once debugged 256 ? */
return 0; return -ENOMEM;
return 0;
} }
int dm_add_entry(struct mapped_device *md, offset_t high, int dm_add_entry(struct mapped_device *md, offset_t high,
dm_map_fn target, void *context) dm_map_fn target, void *context)
{ {
if (md->num_targets >= md->num_entries && if (md->num_targets >= md->num_targets &&
!_alloc_targets(md->num_allocated * 2)) !_alloc_targets(md, md->num_allocated * 2))
retun -ENOMEM; return -ENOMEM;
md->highs[md->num_targets] = high; md->highs[md->num_targets] = high;
md->targets[md->num_targets] = target; md->targets[md->num_targets] = target;
md->contexts[md->num_targets] = context; md->contexts[md->num_targets] = context;
md->num_targets++; md->num_targets++;
return 0;
} }
int dm_complete_table(struct mapped_device *md) int dm_complete_table(struct mapped_device *md)
{ {
int n, i; int n, i;
offset_t *k;
clear_bit(DM_LOADING, &md->state);
/* how many indexes will the btree have ? */ /* how many indexes will the btree have ? */
for (n = _div_up(md->num_targets, KEYS_PER_NODE), i = 1; n != 1; i++) for (n = _div_up(md->num_targets, KEYS_PER_NODE), i = 1; n != 1; i++)
@ -155,10 +137,11 @@ int dm_complete_table(struct mapped_device *md)
for (i = md->depth - 1; i; i--) for (i = md->depth - 1; i; i--)
_setup_btree_index(i - 1, md); _setup_btree_index(i - 1, md);
set_bit(DM_LOADED, &md->state);
return 1; return 1;
} }
static int _alloc_targets(int num) static int _alloc_targets(struct mapped_device *md, int num)
{ {
offset_t *n_highs; offset_t *n_highs;
dm_map_fn *n_targets; dm_map_fn *n_targets;

View File

@ -32,16 +32,7 @@
* to the smallest of these. * to the smallest of these.
*/ */
#include <linux/version.h> #include "dm.h"
#include <linux/major.h>
#include <linux/iobuf.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/slab.h>
#include <linux/vmalloc.h>
#include <linux/compatmac.h>
#include <linux/cache.h>
#include <linux/device-mapper.h>
/* defines for blk.h */ /* defines for blk.h */
#define MAJOR_NR DM_BLK_MAJOR #define MAJOR_NR DM_BLK_MAJOR
@ -122,8 +113,6 @@
* for the LV. Could also use poll() for this kind of thing. * for the LV. Could also use poll() for this kind of thing.
*/ */
#include "dm.h"
#define MAX_DEVICES 64 #define MAX_DEVICES 64
#define DEFAULT_READ_AHEAD 64 #define DEFAULT_READ_AHEAD 64

View File

@ -30,6 +30,18 @@
#ifndef DM_INTERNAL_H #ifndef DM_INTERNAL_H
#define DM_INTERNAL_H #define DM_INTERNAL_H
#include <linux/version.h>
#include <linux/major.h>
#include <linux/iobuf.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/slab.h>
#include <linux/vmalloc.h>
#include <linux/compatmac.h>
#include <linux/cache.h>
#include <linux/devfs_fs_kernel.h>
#include <linux/device-mapper.h>
#define MAX_DEPTH 16 #define MAX_DEPTH 16
#define NODE_SIZE L1_CACHE_BYTES #define NODE_SIZE L1_CACHE_BYTES
#define KEYS_PER_NODE (NODE_SIZE / sizeof(offset_t)) #define KEYS_PER_NODE (NODE_SIZE / sizeof(offset_t))
@ -99,19 +111,19 @@ int dm_start_table(struct mapped_device *md);
int dm_add_entry(struct mapped_device *md, offset_t high, int dm_add_entry(struct mapped_device *md, offset_t high,
dm_map_fn target, void *context); dm_map_fn target, void *context);
int dm_complete_table(struct mapped_device *md); int dm_complete_table(struct mapped_device *md);
int dm_clear_table(struct mapped_device *md); void dm_free_table(struct mapped_device *md);
/* dm-fs.c */ /* dm-fs.c */
int dm_init_fs(void); int dm_init_fs(void);
int dm_fin_fs(void); int dm_fin_fs(void);
static int is_active(struct mapped_device *md) static inline int is_active(struct mapped_device *md)
{ {
return test_bit(DM_ACTIVE, &md->state); return test_bit(DM_ACTIVE, &md->state);
} }
static void set_active(struct mapped_device *md, int set) static inline void set_active(struct mapped_device *md, int set)
{ {
if (set) if (set)
set_bit(DM_ACTIVE, &md->state); set_bit(DM_ACTIVE, &md->state);