{
        u32 addr_reg_val, func_ctrl_reg_val;
 
-       /* Set slave addr. */
-       addr_reg_val = readl(bus->base + ASPEED_I2C_DEV_ADDR_REG);
-       addr_reg_val &= ~ASPEED_I2CD_DEV_ADDR_MASK;
-       addr_reg_val |= slave_addr & ASPEED_I2CD_DEV_ADDR_MASK;
+       /*
+        * Set slave addr.  Reserved bits can all safely be written with zeros
+        * on all of ast2[456]00, so zero everything else to ensure we only
+        * enable a single slave address (ast2500 has two, ast2600 has three,
+        * the enable bits for which are also in this register) so that we don't
+        * end up with additional phantom devices responding on the bus.
+        */
+       addr_reg_val = slave_addr & ASPEED_I2CD_DEV_ADDR_MASK;
        writel(addr_reg_val, bus->base + ASPEED_I2C_DEV_ADDR_REG);
 
        /* Turn on slave mode. */