opcode.rs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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. /*
  36. * Type 2 opcodes
  37. */
  38. pub const DEF_L_EQUAL_OP: u8 = 0x93;
  39. pub const EXT_OPCODE_PREFIX: u8 = 0x5b;
  40. pub(crate) fn opcode<'a, 'c>(opcode: u8) -> impl Parser<'a, 'c, ()>
  41. where
  42. 'c: 'a,
  43. {
  44. move |input: &'a [u8], context: &'c mut AmlContext| match input.first() {
  45. None => Err((input, context, AmlError::UnexpectedEndOfStream)),
  46. Some(&byte) if byte == opcode => Ok((&input[1..], context, ())),
  47. Some(&byte) => Err((input, context, AmlError::UnexpectedByte(byte))),
  48. }
  49. }
  50. pub(crate) fn ext_opcode<'a, 'c>(ext_opcode: u8) -> impl Parser<'a, 'c, ()>
  51. where
  52. 'c: 'a,
  53. {
  54. opcode(EXT_OPCODE_PREFIX).then(opcode(ext_opcode)).discard_result()
  55. }
  56. #[cfg(test)]
  57. mod tests {
  58. use super::*;
  59. use crate::{test_utils::*, AmlError};
  60. #[test]
  61. fn empty() {
  62. let mut context = AmlContext::new();
  63. check_err!(opcode(NULL_NAME).parse(&[], &mut context), AmlError::UnexpectedEndOfStream, &[]);
  64. check_err!(
  65. ext_opcode(EXT_DEF_FIELD_OP).parse(&[], &mut context),
  66. AmlError::UnexpectedEndOfStream,
  67. &[]
  68. );
  69. }
  70. #[test]
  71. fn simple_opcodes() {
  72. let mut context = AmlContext::new();
  73. check_ok!(opcode(DEF_SCOPE_OP).parse(&[DEF_SCOPE_OP], &mut context), (), &[]);
  74. check_ok!(
  75. opcode(DEF_NAME_OP).parse(&[DEF_NAME_OP, 0x31, 0x55, 0xf3], &mut context),
  76. (),
  77. &[0x31, 0x55, 0xf3]
  78. );
  79. }
  80. #[test]
  81. fn extended_opcodes() {
  82. let mut context = AmlContext::new();
  83. check_err!(
  84. ext_opcode(EXT_DEF_FIELD_OP).parse(&[EXT_DEF_FIELD_OP, EXT_DEF_FIELD_OP], &mut context),
  85. AmlError::UnexpectedByte(EXT_DEF_FIELD_OP),
  86. &[EXT_DEF_FIELD_OP, EXT_DEF_FIELD_OP]
  87. );
  88. check_ok!(
  89. ext_opcode(EXT_DEF_FIELD_OP).parse(&[EXT_OPCODE_PREFIX, EXT_DEF_FIELD_OP], &mut context),
  90. (),
  91. &[]
  92. );
  93. }
  94. }