mtd->_put_device = spi_nor_put_device;
 }
 
+static int spi_nor_hw_reset(struct spi_nor *nor)
+{
+       struct gpio_desc *reset;
+
+       reset = devm_gpiod_get_optional(nor->dev, "reset", GPIOD_OUT_LOW);
+       if (IS_ERR_OR_NULL(reset))
+               return PTR_ERR_OR_ZERO(reset);
+
+       /*
+        * Experimental delay values by looking at different flash device
+        * vendors datasheets.
+        */
+       usleep_range(1, 5);
+       gpiod_set_value_cansleep(reset, 1);
+       usleep_range(100, 150);
+       gpiod_set_value_cansleep(reset, 0);
+       usleep_range(1000, 1200);
+
+       return 0;
+}
+
 int spi_nor_scan(struct spi_nor *nor, const char *name,
                 const struct spi_nor_hwcaps *hwcaps)
 {
        if (!nor->bouncebuf)
                return -ENOMEM;
 
+       ret = spi_nor_hw_reset(nor);
+       if (ret)
+               return ret;
+
        info = spi_nor_get_flash_info(nor, name);
        if (IS_ERR(info))
                return PTR_ERR(info);