return result;
        }
 
-       if (inv_mpu_bus_setup)
-               inv_mpu_bus_setup(indio_dev);
-
        dev_set_drvdata(dev, indio_dev);
        indio_dev->dev.parent = dev;
        /* name will be NULL when enumerated via ACPI */
        else
                indio_dev->name = dev_name(dev);
 
+       /* requires parent device set in indio_dev */
+       if (inv_mpu_bus_setup)
+               inv_mpu_bus_setup(indio_dev);
+
        if (chip_type == INV_ICM20602) {
                indio_dev->channels = inv_icm20602_channels;
                indio_dev->num_channels = ARRAY_SIZE(inv_icm20602_channels);
 
        return dev_name(dev);
 }
 
+static bool inv_mpu_i2c_aux_bus(struct device *dev)
+{
+       struct inv_mpu6050_state *st = iio_priv(dev_get_drvdata(dev));
+
+       switch (st->chip_type) {
+       case INV_ICM20608:
+       case INV_ICM20602:
+               /* no i2c auxiliary bus on the chip */
+               return false;
+       case INV_MPU9250:
+       case INV_MPU9255:
+               if (st->magn_disabled)
+                       return true;
+               else
+                       return false;
+       default:
+               return true;
+       }
+}
+
+/*
+ * MPU9xxx magnetometer support requires to disable i2c auxiliary bus support.
+ * To ensure backward compatibility with existing setups, do not disable
+ * i2c auxiliary bus if it used.
+ * Check for i2c-gate node in devicetree and set magnetometer disabled.
+ * Only MPU6500 is supported by ACPI, no need to check.
+ */
+static int inv_mpu_magn_disable(struct iio_dev *indio_dev)
+{
+       struct inv_mpu6050_state *st = iio_priv(indio_dev);
+       struct device *dev = indio_dev->dev.parent;
+       struct device_node *mux_node;
+
+       switch (st->chip_type) {
+       case INV_MPU9250:
+       case INV_MPU9255:
+               mux_node = of_get_child_by_name(dev->of_node, "i2c-gate");
+               if (mux_node != NULL) {
+                       st->magn_disabled = true;
+                       dev_warn(dev, "disable internal use of magnetometer\n");
+               }
+               of_node_put(mux_node);
+               break;
+       default:
+               break;
+       }
+
+       return 0;
+}
+
 /**
  *  inv_mpu_probe() - probe function.
  *  @client:          i2c client.
        }
 
        result = inv_mpu_core_probe(regmap, client->irq, name,
-                                   NULL, chip_type);
+                                   inv_mpu_magn_disable, chip_type);
        if (result < 0)
                return result;
 
        st = iio_priv(dev_get_drvdata(&client->dev));
-       switch (st->chip_type) {
-       case INV_ICM20608:
-       case INV_ICM20602:
-               /* no i2c auxiliary bus on the chip */
-               break;
-       default:
+       if (inv_mpu_i2c_aux_bus(&client->dev)) {
                /* declare i2c auxiliary bus */
                st->muxc = i2c_mux_alloc(client->adapter, &client->dev,
                                         1, 0, I2C_MUX_LOCKED | I2C_MUX_GATE,
                result = inv_mpu_acpi_create_mux_client(client);
                if (result)
                        goto out_del_mux;
-               break;
        }
 
        return 0;
 
  *  @it_timestamp:     timestamp from previous interrupt.
  *  @data_timestamp:   timestamp for next data sample.
  *  @vddio_supply      voltage regulator for the chip.
+ *  @magn_disabled:     magnetometer disabled for backward compatibility reason.
  */
 struct inv_mpu6050_state {
        struct mutex lock;
        s64 it_timestamp;
        s64 data_timestamp;
        struct regulator *vddio_supply;
+       bool magn_disabled;
 };
 
 /*register and associated bit definition*/