opcode.rs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. use crate::{parser::*, AmlContext, AmlError};
  2. pub const NULL_NAME: u8 = 0x00;
  3. pub const DUAL_NAME_PREFIX: u8 = 0x2E;
  4. pub const MULTI_NAME_PREFIX: u8 = 0x2F;
  5. pub const ROOT_CHAR: u8 = b'\\';
  6. pub const PREFIX_CHAR: u8 = b'^';
  7. pub const RESERVED_FIELD: u8 = 0x00;
  8. pub const ACCESS_FIELD: u8 = 0x01;
  9. pub const CONNECT_FIELD: u8 = 0x02;
  10. pub const EXTENDED_ACCESS_FIELD: u8 = 0x03;
  11. pub const ZERO_OP: u8 = 0x00;
  12. pub const ONE_OP: u8 = 0x01;
  13. pub const ONES_OP: u8 = 0xff;
  14. pub const BYTE_CONST: u8 = 0x0a;
  15. pub const WORD_CONST: u8 = 0x0b;
  16. pub const DWORD_CONST: u8 = 0x0c;
  17. pub const STRING_PREFIX: u8 = 0x0d;
  18. pub const QWORD_CONST: u8 = 0x0e;
  19. pub const DEF_NAME_OP: u8 = 0x08;
  20. pub const DEF_SCOPE_OP: u8 = 0x10;
  21. pub const DEF_BUFFER_OP: u8 = 0x11;
  22. pub const DEF_PACKAGE_OP: u8 = 0x12;
  23. pub const DEF_METHOD_OP: u8 = 0x14;
  24. pub const EXT_DEF_MUTEX_OP: u8 = 0x01;
  25. pub const EXT_REVISION_OP: u8 = 0x30;
  26. pub const EXT_DEF_OP_REGION_OP: u8 = 0x80;
  27. pub const EXT_DEF_FIELD_OP: u8 = 0x81;
  28. pub const EXT_DEF_DEVICE_OP: u8 = 0x82;
  29. pub const EXT_DEF_PROCESSOR_OP: u8 = 0x83;
  30. /*
  31. * Type 1 opcodes
  32. */
  33. pub const DEF_IF_ELSE_OP: u8 = 0xa0;
  34. pub const DEF_ELSE_OP: u8 = 0xa1;
  35. pub const DEF_NOOP_OP: u8 = 0xa3;
  36. pub const DEF_RETURN_OP: u8 = 0xa4;
  37. pub const DEF_BREAKPOINT_OP: u8 = 0xcc;
  38. /*
  39. * Type 2 opcodes
  40. */
  41. pub const DEF_STORE_OP: u8 = 0x70;
  42. pub const DEF_ADD_OP: u8 = 0x72;
  43. pub const DEF_SHIFT_LEFT: u8 = 0x79;
  44. pub const DEF_SHIFT_RIGHT: u8 = 0x7a;
  45. pub const DEF_AND_OP: u8 = 0x7b;
  46. pub const DEF_L_OR_OP: u8 = 0x91;
  47. pub const DEF_L_NOT_OP: u8 = 0x92;
  48. pub const DEF_L_EQUAL_OP: u8 = 0x93;
  49. pub const DEF_L_GREATER_OP: u8 = 0x94;
  50. pub const DEF_L_LESS_OP: u8 = 0x95;
  51. /*
  52. * Miscellaneous objects
  53. */
  54. pub const EXT_DEBUG_OP: u8 = 0x31;
  55. pub const LOCAL0_OP: u8 = 0x60;
  56. pub const LOCAL1_OP: u8 = 0x61;
  57. pub const LOCAL2_OP: u8 = 0x62;
  58. pub const LOCAL3_OP: u8 = 0x63;
  59. pub const LOCAL4_OP: u8 = 0x64;
  60. pub const LOCAL5_OP: u8 = 0x65;
  61. pub const LOCAL6_OP: u8 = 0x66;
  62. pub const LOCAL7_OP: u8 = 0x67;
  63. pub const ARG0_OP: u8 = 0x68;
  64. pub const ARG1_OP: u8 = 0x69;
  65. pub const ARG2_OP: u8 = 0x6a;
  66. pub const ARG3_OP: u8 = 0x6b;
  67. pub const ARG4_OP: u8 = 0x6c;
  68. pub const ARG5_OP: u8 = 0x6d;
  69. pub const ARG6_OP: u8 = 0x6e;
  70. pub const EXT_OPCODE_PREFIX: u8 = 0x5b;
  71. pub(crate) fn opcode<'a, 'c>(opcode: u8) -> impl Parser<'a, 'c, ()>
  72. where
  73. 'c: 'a,
  74. {
  75. move |input: &'a [u8], context: &'c mut AmlContext| match input.first() {
  76. None => Err((input, context, Propagate::Err(AmlError::UnexpectedEndOfStream))),
  77. Some(&byte) if byte == opcode => Ok((&input[1..], context, ())),
  78. Some(_) => Err((input, context, Propagate::Err(AmlError::WrongParser))),
  79. }
  80. }
  81. pub(crate) fn ext_opcode<'a, 'c>(ext_opcode: u8) -> impl Parser<'a, 'c, ()>
  82. where
  83. 'c: 'a,
  84. {
  85. opcode(EXT_OPCODE_PREFIX).then(opcode(ext_opcode)).discard_result()
  86. }
  87. #[cfg(test)]
  88. mod tests {
  89. use super::*;
  90. use crate::{test_utils::*, AmlError};
  91. #[test]
  92. fn empty() {
  93. let mut context = crate::test_utils::make_test_context();
  94. check_err!(opcode(NULL_NAME).parse(&[], &mut context), AmlError::UnexpectedEndOfStream, &[]);
  95. check_err!(ext_opcode(EXT_DEF_FIELD_OP).parse(&[], &mut context), AmlError::UnexpectedEndOfStream, &[]);
  96. }
  97. #[test]
  98. fn simple_opcodes() {
  99. let mut context = crate::test_utils::make_test_context();
  100. check_ok!(opcode(DEF_SCOPE_OP).parse(&[DEF_SCOPE_OP], &mut context), (), &[]);
  101. check_ok!(
  102. opcode(DEF_NAME_OP).parse(&[DEF_NAME_OP, 0x31, 0x55, 0xf3], &mut context),
  103. (),
  104. &[0x31, 0x55, 0xf3]
  105. );
  106. }
  107. #[test]
  108. fn extended_opcodes() {
  109. let mut context = crate::test_utils::make_test_context();
  110. check_err!(
  111. ext_opcode(EXT_DEF_FIELD_OP).parse(&[EXT_DEF_FIELD_OP, EXT_DEF_FIELD_OP], &mut context),
  112. AmlError::WrongParser,
  113. &[EXT_DEF_FIELD_OP, EXT_DEF_FIELD_OP]
  114. );
  115. check_ok!(
  116. ext_opcode(EXT_DEF_FIELD_OP).parse(&[EXT_OPCODE_PREFIX, EXT_DEF_FIELD_OP], &mut context),
  117. (),
  118. &[]
  119. );
  120. }
  121. }