|
@@ -245,7 +245,7 @@ void dm_table_destroy(struct dm_table *t)
|
|
|
msleep(1);
|
|
|
smp_mb();
|
|
|
|
|
|
- /* free the indexes (see dm_table_complete) */
|
|
|
+ /* free the indexes */
|
|
|
if (t->depth >= 2)
|
|
|
vfree(t->index[t->depth - 2]);
|
|
|
|
|
@@ -778,7 +778,7 @@ int dm_table_add_target(struct dm_table *t, const char *type,
|
|
|
return r;
|
|
|
}
|
|
|
|
|
|
-int dm_table_set_type(struct dm_table *t)
|
|
|
+static int dm_table_set_type(struct dm_table *t)
|
|
|
{
|
|
|
unsigned i;
|
|
|
unsigned bio_based = 0, request_based = 0;
|
|
@@ -900,7 +900,7 @@ static int setup_indexes(struct dm_table *t)
|
|
|
/*
|
|
|
* Builds the btree to index the map.
|
|
|
*/
|
|
|
-int dm_table_complete(struct dm_table *t)
|
|
|
+static int dm_table_build_index(struct dm_table *t)
|
|
|
{
|
|
|
int r = 0;
|
|
|
unsigned int leaf_nodes;
|
|
@@ -919,6 +919,55 @@ int dm_table_complete(struct dm_table *t)
|
|
|
return r;
|
|
|
}
|
|
|
|
|
|
+/*
|
|
|
+ * Register the mapped device for blk_integrity support if
|
|
|
+ * the underlying devices support it.
|
|
|
+ */
|
|
|
+static int dm_table_prealloc_integrity(struct dm_table *t, struct mapped_device *md)
|
|
|
+{
|
|
|
+ struct list_head *devices = dm_table_get_devices(t);
|
|
|
+ struct dm_dev_internal *dd;
|
|
|
+
|
|
|
+ list_for_each_entry(dd, devices, list)
|
|
|
+ if (bdev_get_integrity(dd->dm_dev.bdev))
|
|
|
+ return blk_integrity_register(dm_disk(md), NULL);
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+/*
|
|
|
+ * Prepares the table for use by building the indices,
|
|
|
+ * setting the type, and allocating mempools.
|
|
|
+ */
|
|
|
+int dm_table_complete(struct dm_table *t)
|
|
|
+{
|
|
|
+ int r;
|
|
|
+
|
|
|
+ r = dm_table_set_type(t);
|
|
|
+ if (r) {
|
|
|
+ DMERR("unable to set table type");
|
|
|
+ return r;
|
|
|
+ }
|
|
|
+
|
|
|
+ r = dm_table_build_index(t);
|
|
|
+ if (r) {
|
|
|
+ DMERR("unable to build btrees");
|
|
|
+ return r;
|
|
|
+ }
|
|
|
+
|
|
|
+ r = dm_table_prealloc_integrity(t, t->md);
|
|
|
+ if (r) {
|
|
|
+ DMERR("could not register integrity profile.");
|
|
|
+ return r;
|
|
|
+ }
|
|
|
+
|
|
|
+ r = dm_table_alloc_md_mempools(t);
|
|
|
+ if (r)
|
|
|
+ DMERR("unable to allocate mempools");
|
|
|
+
|
|
|
+ return r;
|
|
|
+}
|
|
|
+
|
|
|
static DEFINE_MUTEX(_event_lock);
|
|
|
void dm_table_event_callback(struct dm_table *t,
|
|
|
void (*fn)(void *), void *context)
|