Start on --assemble support for DDF

This commit is contained in:
Neil Brown 2008-05-15 16:48:18 +10:00
parent 2503d23b5a
commit a19c88b83d
2 changed files with 72 additions and 4 deletions

View File

@ -843,6 +843,24 @@ int Assemble(struct supertype *st, char *mddev, int mdfd,
/* Almost ready to actually *do* something */
if (!old_linux) {
int rv;
#ifndef MDASSEMBLE
struct mdinfo *sra;
if (st->ss->external) {
char ver[100];
strcat(strcpy(ver, "external:"), st->ss->text_version);
sra = sysfs_read(mdfd, 0, 0);
if ((vers % 100) < 2 ||
sra == NULL ||
sysfs_set_str(sra, NULL, "metadata_version",
ver) < 0) {
fprintf(stderr, Name ": This kernel does not "
"support external metadata.\n");
return 1;
}
rv = sysfs_set_array(sra, &info);
} else
#endif
if ((vers % 100) >= 1) { /* can use different versions */
mdu_array_info_t inf;
memset(&inf, 0, sizeof(inf));
@ -893,8 +911,22 @@ int Assemble(struct supertype *st, char *mddev, int mdfd,
j = chosen_drive;
if (j >= 0 /* && devices[j].uptodate */) {
if (ioctl(mdfd, ADD_NEW_DISK,
&devices[j].i.disk)!=0) {
#ifndef MDASSEMBLE
if (st->ss->external) {
int fd = dev_open(devices[j].devname,
O_RDONLY);
if (fd < 0)
rv = 1;
else {
rv = sysfs_add_disk(sra, fd,
&devices[j].i);
close(fd);
}
} else
#endif
rv = ioctl(mdfd, ADD_NEW_DISK,
&devices[j].i.disk);
if (rv) {
fprintf(stderr, Name ": failed to add "
"%s to %s: %s\n",
devices[j].devname,

View File

@ -1149,6 +1149,7 @@ static void uuid_from_super_ddf(struct supertype *st, int uuid[4])
static void getinfo_super_ddf(struct supertype *st, struct mdinfo *info)
{
struct ddf_super *ddf = st->sb;
int i;
info->array.major_version = 1000;
info->array.minor_version = 0; /* FIXME use ddf->revision somehow */
@ -1167,9 +1168,17 @@ static void getinfo_super_ddf(struct supertype *st, struct mdinfo *info)
info->disk.major = 0;
info->disk.minor = 0;
// info->disk.number = __be32_to_cpu(ddf->disk.refnum);
info->disk.number = __be32_to_cpu(ddf->dlist->disk.refnum);
// info->disk.raid_disk = find refnum in the table and use index;
// info->disk.state = ???;
info->disk.raid_disk = -1;
for (i = 0; i < __be16_to_cpu(ddf->phys->max_pdes) ; i++)
if (ddf->phys->entries[i].refnum == ddf->dlist->disk.refnum) {
info->disk.raid_disk = i;
break;
}
info->disk.state = (1 << MD_DISK_SYNC);
info->reshape_active = 0;
// uuid_from_super_ddf(info->uuid, sbv);
@ -2248,6 +2257,31 @@ static int store_zero_ddf(struct supertype *st, int fd)
return 0;
}
static int compare_super_ddf(struct supertype *st, struct supertype *tst)
{
/*
* return:
* 0 same, or first was empty, and second was copied
* 1 second had wrong number
* 2 wrong uuid
* 3 wrong other info
*/
struct ddf_super *first = st->sb;
struct ddf_super *second = tst->sb;
if (!first) {
st->sb = tst->sb;
tst->sb = NULL;
return 0;
}
if (memcmp(first->anchor.guid, second->anchor.guid, DDF_GUID_LEN) != 0)
return 2;
/* FIXME should I look at anything else? */
return 0;
}
struct superswitch super_ddf = {
#ifndef MDASSEMBLE
.examine_super = examine_super_ddf,
@ -2263,6 +2297,8 @@ struct superswitch super_ddf = {
.avail_size = avail_size_ddf,
.compare_super = compare_super_ddf,
.load_super = load_super_ddf,
.init_super = init_zero_ddf,
.store_super = store_zero_ddf,