gpio->parent = config->parent;
        gpio->driver_data = config->drvdata;
        gpio->regmap = config->regmap;
-       gpio->ngpio_per_reg = config->ngpio_per_reg;
-       gpio->reg_stride = config->reg_stride;
-       gpio->reg_mask_xlate = config->reg_mask_xlate;
        gpio->reg_dat_base = config->reg_dat_base;
        gpio->reg_set_base = config->reg_set_base;
        gpio->reg_clr_base = config->reg_clr_base;
        gpio->reg_dir_out_base = config->reg_dir_out_base;
 
        /* if not set, assume there is only one register */
+       gpio->ngpio_per_reg = config->ngpio_per_reg;
        if (!gpio->ngpio_per_reg)
                gpio->ngpio_per_reg = config->ngpio;
 
        /* if not set, assume they are consecutive */
+       gpio->reg_stride = config->reg_stride;
        if (!gpio->reg_stride)
                gpio->reg_stride = 1;
 
+       gpio->reg_mask_xlate = config->reg_mask_xlate;
        if (!gpio->reg_mask_xlate)
                gpio->reg_mask_xlate = gpio_regmap_simple_xlate;
 
 
  * @reg_dir_out_base:  (Optional) out setting register base address
  * @reg_stride:                (Optional) May be set if the registers (of the
  *                     same type, dat, set, etc) are not consecutive.
- * @ngpio_per_reg:     Number of GPIOs per register
+ * @ngpio_per_reg:     (Optional) Number of GPIOs per register
  * @irq_domain:                (Optional) IRQ domain if the controller is
  *                     interrupt-capable
  * @reg_mask_xlate:     (Optional) Translates base address and GPIO