#define SPIFMC_MAX_READ_SIZE                   0x10000
 
+struct sg204x_spifmc_chip_info {
+       bool has_opt_reg;
+       u32 rd_fifo_int_trigger_level;
+};
+
 struct sg2044_spifmc {
        struct spi_controller *ctrl;
        void __iomem *io_base;
        struct device *dev;
        struct mutex lock;
        struct clk *clk;
+       const struct sg204x_spifmc_chip_info *chip_info;
 };
 
 static int sg2044_spifmc_wait_int(struct sg2044_spifmc *spifmc, u8 int_type)
 
        reg = sg2044_spifmc_init_reg(spifmc);
        reg |= (op->addr.nbytes + op->dummy.nbytes) << SPIFMC_TRAN_CSR_ADDR_BYTES_SHIFT;
-       reg |= SPIFMC_TRAN_CSR_FIFO_TRG_LVL_8_BYTE;
+       reg |= spifmc->chip_info->rd_fifo_int_trigger_level;
        reg |= SPIFMC_TRAN_CSR_WITH_CMD;
        reg |= SPIFMC_TRAN_CSR_TRAN_MODE_RX;
 
                reg |= SPIFMC_TRAN_CSR_TRAN_MODE_RX;
                reg |= SPIFMC_TRAN_CSR_TRAN_MODE_TX;
 
-               writel(SPIFMC_OPT_DISABLE_FIFO_FLUSH, spifmc->io_base + SPIFMC_OPT);
+               if (spifmc->chip_info->has_opt_reg)
+                       writel(SPIFMC_OPT_DISABLE_FIFO_FLUSH, spifmc->io_base + SPIFMC_OPT);
        } else {
                /*
                 * If write values to the Status Register,
        ret = devm_mutex_init(dev, &spifmc->lock);
        if (ret)
                return ret;
+       spifmc->chip_info = device_get_match_data(&pdev->dev);
+       if (!spifmc->chip_info) {
+               dev_err(&pdev->dev, "Failed to get specific chip info\n");
+               return -EINVAL;
+       }
 
        sg2044_spifmc_init(spifmc);
        sg2044_spifmc_init_reg(spifmc);
        return 0;
 }
 
+static const struct sg204x_spifmc_chip_info sg2044_chip_info = {
+       .has_opt_reg = true,
+       .rd_fifo_int_trigger_level = SPIFMC_TRAN_CSR_FIFO_TRG_LVL_8_BYTE,
+};
+
 static const struct of_device_id sg2044_spifmc_match[] = {
-       { .compatible = "sophgo,sg2044-spifmc-nor" },
+       { .compatible = "sophgo,sg2044-spifmc-nor", .data = &sg2044_chip_info },
        { /* sentinel */ }
 };
 MODULE_DEVICE_TABLE(of, sg2044_spifmc_match);