afe->dev = &pdev->dev;
 
-       irq_id = platform_get_irq(pdev, 0);
-       if (irq_id <= 0)
-               return irq_id < 0 ? irq_id : -ENXIO;
-       ret = devm_request_irq(afe->dev, irq_id, mt8173_afe_irq_handler,
-                              0, "Afe_ISR_Handle", (void *)afe);
-       if (ret) {
-               dev_err(afe->dev, "could not request_irq\n");
-               return ret;
-       }
-
        afe->base_addr = devm_platform_ioremap_resource(pdev, 0);
        if (IS_ERR(afe->base_addr))
                return PTR_ERR(afe->base_addr);
        if (ret)
                goto err_cleanup_components;
 
+       irq_id = platform_get_irq(pdev, 0);
+       if (irq_id <= 0)
+               return irq_id < 0 ? irq_id : -ENXIO;
+       ret = devm_request_irq(afe->dev, irq_id, mt8173_afe_irq_handler,
+                              0, "Afe_ISR_Handle", (void *)afe);
+       if (ret) {
+               dev_err(afe->dev, "could not request_irq\n");
+               goto err_pm_disable;
+       }
+
        dev_info(&pdev->dev, "MT8173 AFE driver initialized.\n");
        return 0;