Tomasz Majchrzak <tomasz.majchrzak@xxxxxxxxx> writes: > If metadata handler provides support for bad blocks, tell md by writing > 'external_bbl' to rdev state file (both on create and assemble), > followed by a list of known bad blocks written via sysfs 'bad_blocks' > file. > > Signed-off-by: Tomasz Majchrzak <tomasz.majchrzak@xxxxxxxxx> > Reviewed-by: Artur Paszkiewicz <artur.paszkiewicz@xxxxxxxxx> > --- > mdadm.h | 13 +++++++++++++ > sysfs.c | 29 ++++++++++++++++++++++++++++- > 2 files changed, 41 insertions(+), 1 deletion(-) Hi Tomasz, Most of this one looks fine, just one minor nit. > diff --git a/mdadm.h b/mdadm.h > index 0516c82..5156ea4 100755 > --- a/mdadm.h > +++ b/mdadm.h > @@ -237,6 +237,17 @@ struct dlm_lksb { > > extern const char Name[]; > > +struct md_bb_entry { > + unsigned long long sector; > + int length; > +}; > + > +struct md_bb { > + int supported; > + int count; > + struct md_bb_entry *entries; > +}; > + > /* general information that might be extracted from a superblock */ > struct mdinfo { > mdu_array_info_t array; > @@ -311,6 +322,8 @@ struct mdinfo { > > /* info read from sysfs */ > char sysfs_array_state[20]; > + > + struct md_bb bb; > }; > > struct createinfo { > diff --git a/sysfs.c b/sysfs.c > index d28e21a..c7a8e66 100644 > --- a/sysfs.c > +++ b/sysfs.c > @@ -50,8 +50,12 @@ void sysfs_free(struct mdinfo *sra) > while (sra->devs) { > struct mdinfo *d = sra->devs; > sra->devs = d->next; > + if (d->bb.entries) > + free(d->bb.entries); > free(d); > } > + if (sra->bb.entries) > + free(sra->bb.entries); > free(sra); > sra = sra2; > } free() handles NULL pointers, so no need to check first. Cheers, Jes -- To unsubscribe from this list: send the line "unsubscribe linux-raid" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html