Browse Source

Implement DefAdd

Isaac Woods 4 years ago
parent
commit
2fec65aacf
2 changed files with 28 additions and 0 deletions
  1. 1 0
      aml/src/opcode.rs
  2. 27 0
      aml/src/type2.rs

+ 1 - 0
aml/src/opcode.rs

@@ -45,6 +45,7 @@ pub const DEF_BREAKPOINT_OP: u8 = 0xcc;
  * Type 2 opcodes
  */
 pub const DEF_STORE_OP: u8 = 0x70;
+pub const DEF_ADD_OP: u8 = 0x72;
 pub const DEF_SHIFT_LEFT: u8 = 0x79;
 pub const DEF_SHIFT_RIGHT: u8 = 0x7a;
 pub const DEF_AND_OP: u8 = 0x7b;

+ 27 - 0
aml/src/type2.rs

@@ -40,6 +40,7 @@ where
         DebugVerbosity::AllScopes,
         "Type2Opcode",
         choice!(
+            def_add(),
             def_and(),
             def_buffer(),
             def_l_equal(),
@@ -58,6 +59,32 @@ where
     ))
 }
 
+pub fn def_add<'a, 'c>() -> impl Parser<'a, 'c, AmlValue>
+where
+    'c: 'a,
+{
+    /*
+     * DefAdd := 0x72 Operand Operand Target
+     * Operand := TermArg => Integer
+     */
+    opcode(opcode::DEF_ADD_OP)
+        .then(comment_scope(
+            DebugVerbosity::AllScopes,
+            "DefAdd",
+            term_arg().then(term_arg()).then(target()).map_with_context(
+                |((left_arg, right_arg), target), context| {
+                    let left = try_with_context!(context, left_arg.as_integer(context));
+                    let right = try_with_context!(context, right_arg.as_integer(context));
+                    let result = AmlValue::Integer(left.wrapping_add(right));
+
+                    try_with_context!(context, context.store(target, result.clone()));
+                    (Ok(result), context)
+                },
+            ),
+        ))
+        .map(|((), result)| Ok(result))
+}
+
 pub fn def_and<'a, 'c>() -> impl Parser<'a, 'c, AmlValue>
 where
     'c: 'a,