return true;
 }
+
+/**
+ * insn_decode_mmio() - Decode a MMIO instruction
+ * @insn:      Structure to store decoded instruction
+ * @bytes:     Returns size of memory operand
+ *
+ * Decodes instruction that used for Memory-mapped I/O.
+ *
+ * Returns:
+ *
+ * Type of the instruction. Size of the memory operand is stored in
+ * @bytes. If decode failed, MMIO_DECODE_FAILED returned.
+ */
+enum mmio_type insn_decode_mmio(struct insn *insn, int *bytes)
+{
+       enum mmio_type type = MMIO_DECODE_FAILED;
+
+       *bytes = 0;
+
+       if (insn_get_opcode(insn))
+               return MMIO_DECODE_FAILED;
+
+       switch (insn->opcode.bytes[0]) {
+       case 0x88: /* MOV m8,r8 */
+               *bytes = 1;
+               fallthrough;
+       case 0x89: /* MOV m16/m32/m64, r16/m32/m64 */
+               if (!*bytes)
+                       *bytes = insn->opnd_bytes;
+               type = MMIO_WRITE;
+               break;
+
+       case 0xc6: /* MOV m8, imm8 */
+               *bytes = 1;
+               fallthrough;
+       case 0xc7: /* MOV m16/m32/m64, imm16/imm32/imm64 */
+               if (!*bytes)
+                       *bytes = insn->opnd_bytes;
+               type = MMIO_WRITE_IMM;
+               break;
+
+       case 0x8a: /* MOV r8, m8 */
+               *bytes = 1;
+               fallthrough;
+       case 0x8b: /* MOV r16/r32/r64, m16/m32/m64 */
+               if (!*bytes)
+                       *bytes = insn->opnd_bytes;
+               type = MMIO_READ;
+               break;
+
+       case 0xa4: /* MOVS m8, m8 */
+               *bytes = 1;
+               fallthrough;
+       case 0xa5: /* MOVS m16/m32/m64, m16/m32/m64 */
+               if (!*bytes)
+                       *bytes = insn->opnd_bytes;
+               type = MMIO_MOVS;
+               break;
+
+       case 0x0f: /* Two-byte instruction */
+               switch (insn->opcode.bytes[1]) {
+               case 0xb6: /* MOVZX r16/r32/r64, m8 */
+                       *bytes = 1;
+                       fallthrough;
+               case 0xb7: /* MOVZX r32/r64, m16 */
+                       if (!*bytes)
+                               *bytes = 2;
+                       type = MMIO_READ_ZERO_EXTEND;
+                       break;
+
+               case 0xbe: /* MOVSX r16/r32/r64, m8 */
+                       *bytes = 1;
+                       fallthrough;
+               case 0xbf: /* MOVSX r32/r64, m16 */
+                       if (!*bytes)
+                               *bytes = 2;
+                       type = MMIO_READ_SIGN_EXTEND;
+                       break;
+               }
+               break;
+       }
+
+       return type;
+}