{
        struct rt5677_priv *rt5677 = snd_soc_component_get_drvdata(component);
 
+       if (rt5677->irq) {
+               cancel_delayed_work_sync(&rt5677->resume_irq_check);
+               disable_irq(rt5677->irq);
+       }
+
        if (!rt5677->dsp_vad_en) {
                regcache_cache_only(rt5677->regmap, true);
                regcache_mark_dirty(rt5677->regmap);
                regcache_sync(rt5677->regmap);
        }
 
+       if (rt5677->irq) {
+               enable_irq(rt5677->irq);
+               schedule_delayed_work(&rt5677->resume_irq_check, 0);
+       }
+
        return 0;
 }
 #else
                return IRQ_NONE;
 }
 
+static void rt5677_resume_irq_check(struct work_struct *work)
+{
+       int i, virq;
+       struct rt5677_priv *rt5677 =
+               container_of(work, struct rt5677_priv, resume_irq_check.work);
+
+       /* This is needed to check and clear the interrupt status register
+        * at resume. If the headset is plugged/unplugged when the device is
+        * fully suspended, there won't be a rising edge at resume to trigger
+        * the interrupt. Without this, we miss the next unplug/plug event.
+        */
+       rt5677_irq(0, rt5677);
+
+       /* Call all enabled jack detect irq handlers again. This is needed in
+        * addition to the above check for a corner case caused by jack gpio
+        * debounce. After codec irq is disabled at suspend, the delayed work
+        * scheduled by soc-jack may run and read wrong jack gpio values, since
+        * the regmap is in cache only mode. At resume, there is no irq because
+        * rt5677_irq has already ran and cleared the irq status at suspend.
+        * Without this explicit check, unplug the headset right after suspend
+        * starts, then after resume the headset is still shown as plugged in.
+        */
+       mutex_lock(&rt5677->irq_lock);
+       for (i = 0; i < RT5677_IRQ_NUM; i++) {
+               if (rt5677->irq_en & rt5677_irq_descs[i].enable_mask) {
+                       virq = irq_find_mapping(rt5677->domain, i);
+                       if (virq)
+                               handle_nested_irq(virq);
+               }
+       }
+       mutex_unlock(&rt5677->irq_lock);
+}
+
 static void rt5677_irq_bus_lock(struct irq_data *data)
 {
        struct rt5677_priv *rt5677 = irq_data_get_irq_chip_data(data);
        }
 
        mutex_init(&rt5677->irq_lock);
+       INIT_DELAYED_WORK(&rt5677->resume_irq_check, rt5677_resume_irq_check);
 
        /*
         * Select RC as the debounce clock so that GPIO works even when
        if (ret)
                dev_err(&i2c->dev, "Failed to request IRQ: %d\n", ret);
 
+       rt5677->irq = i2c->irq;
+
        return ret;
 }