return 0;
 }
 
+static void meson_ir_shutdown(struct platform_device *pdev)
+{
+       struct device *dev = &pdev->dev;
+       struct device_node *node = dev->of_node;
+       struct meson_ir *ir = platform_get_drvdata(pdev);
+       unsigned long flags;
+
+       spin_lock_irqsave(&ir->lock, flags);
+
+       /*
+        * Set operation mode to NEC/hardware decoding to give
+        * bootloader a chance to power the system back on
+        */
+       if (of_device_is_compatible(node, "amlogic,meson6-ir"))
+               meson_ir_set_mask(ir, IR_DEC_REG1, REG1_MODE_MASK,
+                                 DECODE_MODE_NEC << REG1_MODE_SHIFT);
+       else
+               meson_ir_set_mask(ir, IR_DEC_REG2, REG2_MODE_MASK,
+                                 DECODE_MODE_NEC << REG2_MODE_SHIFT);
+
+       /* Set rate to default value */
+       meson_ir_set_mask(ir, IR_DEC_REG0, REG0_RATE_MASK, 0x13);
+
+       spin_unlock_irqrestore(&ir->lock, flags);
+}
+
 static const struct of_device_id meson_ir_match[] = {
        { .compatible = "amlogic,meson6-ir" },
        { .compatible = "amlogic,meson8b-ir" },
 static struct platform_driver meson_ir_driver = {
        .probe          = meson_ir_probe,
        .remove         = meson_ir_remove,
+       .shutdown       = meson_ir_shutdown,
        .driver = {
                .name           = DRIVER_NAME,
                .of_match_table = meson_ir_match,