Hi, On Wed, Jun 07, 2017 at 11:37:58AM -0700, Liam Breck wrote: > From: Liam Breck > > We tie multiple chips to unique register maps. When supporting a new chip, > it's easy to add a duplicate map by mistake. > > In debug mode we now scan the register maps for duplicates. > > Signed-off-by: Liam Breck This does not belong into the kernel, but into some static analyzer tool. -- Sebastian > drivers/power/supply/bq27xxx_battery.c | 21 +++++++++++++++++++++ > 1 file changed, 21 insertions(+) > > diff --git a/drivers/power/supply/bq27xxx_battery.c b/drivers/power/supply/bq27xxx_battery.c > index a7014525..f4449aba 100644 > --- a/drivers/power/supply/bq27xxx_battery.c > +++ b/drivers/power/supply/bq27xxx_battery.c > @@ -1931,6 +1931,25 @@ static void bq27xxx_external_power_changed(struct power_supply *psy) > schedule_delayed_work(&di->work, 0); > } > > +#ifdef DEBUG > +static void bq27xxx_battery_dbg_regs_dupes(struct bq27xxx_device_info *di) > +{ > + const size_t max = ARRAY_SIZE(bq27xxx_regs); > + int a, b; > + > + for (a = 1; a < max-1; a++) { > + for (b = a+1; b < max; b++) { > + if (!memcmp(bq27xxx_regs[a], bq27xxx_regs[b], > + sizeof(bq27xxx_regs[0]))) > + dev_warn(di->dev, > + "bq27xxx_regs[%d] & [%d] are identical\n", a, b); > + } > + } > +} > +#else > +static inline void bq27xxx_battery_dbg_regs_dupes(struct bq27xxx_device_info *di) {} > +#endif > + > int bq27xxx_battery_setup(struct bq27xxx_device_info *di) > { > struct power_supply_desc *psy_desc; > @@ -1939,6 +1958,8 @@ int bq27xxx_battery_setup(struct bq27xxx_device_info *di) > .drv_data = di, > }; > > + bq27xxx_battery_dbg_regs_dupes(di); > + > di->ram_chip = di->real_chip == BQ27421 || > di->real_chip == BQ27441 || > di->real_chip == BQ27621; > -- > 2.13.0 >