opcode.rs 2.9 KB

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