Exemplo n.º 1
0
        private static AmlParser.ParseSuccess ParseAndLoadRegion(IoMemory region, AcpiObject.IOperationRegionAccessor operationRegionAccessor)
        {
            AmlParser.AMLCode result;
            int       offset = 0;
            AmlParser parser = new AmlParser(new IoMemoryAmlStreamAdapter(region), null, null);

            AmlParser.ParseSuccess parseSuccess =
                parser.ParseAMLCode(out result, ref offset, region.Length);

            if (parseSuccess == AmlParser.ParseSuccess.Success)
            {
                AmlLoader loader = new AmlLoader(acpiNamespace, operationRegionAccessor);
                loader.Load(result);
            }
            return(parseSuccess);
        }
Exemplo n.º 2
0
        public static void Main(string[] args)
        {
            if (args.Length < 1)
            {
                Usage();
                Environment.Exit(1);
            }

            try {
                AcpiNamespace   acpiNamespace   = new AcpiNamespace();
                ReservedObjects reservedObjects = new ReservedObjects(acpiNamespace);
                reservedObjects.CreateReservedObjects();

                AcpiObject.IOperationRegionAccessor operationRegionAccessor =
                    new TestOperationRegionAccessor();
                AmlInterpreter interpreter = new AmlInterpreter(acpiNamespace, operationRegionAccessor);

                foreach (string flag in args)
                {
                    if (flag.StartsWith("/tracefile="))
                    {
                        operationRegionAccessor =
                            new TraceOperationRegionAccessor(new FileStream(flag.Substring("/tracefile=".Length),
                                                                            FileMode.Open, FileAccess.Read));
                    }
                    else if (flag.StartsWith("/"))
                    {
                        Console.WriteLine("Unrecognized flag '" + flag + "'");
                        Environment.Exit(1);
                    }
                }

                AmlParser.ParseSuccess parseSuccess = AmlParser.ParseSuccess.Success;
                foreach (string dumpFilename in args)
                {
                    if (dumpFilename.StartsWith("/"))
                    {
                        continue;
                    }

                    using (FileStream reader = new FileStream(dumpFilename, FileMode.Open, FileAccess.Read)) {
                        AmlParser.AMLCode result;
                        int       offset = 0x24; // Skip header
                        AmlParser parser = new AmlParser(new FileStreamAmlStreamAdapter(reader), null, null);
                        parseSuccess =
                            parser.ParseAMLCode(out result, ref offset, (int)(new FileInfo(dumpFilename).Length));

                        if (parseSuccess == AmlParser.ParseSuccess.Success)
                        {
                            AmlLoader loader = new AmlLoader(acpiNamespace, operationRegionAccessor);
                            loader.Load(result);
                        }
                        else
                        {
                            break;
                        }
                    }
                }

                if (parseSuccess == AmlParser.ParseSuccess.Success)
                {
                    parseSuccess = interpreter.ParseMethodBodies();
                }

                if (parseSuccess == AmlParser.ParseSuccess.Success)
                {
                    LoadDeviceInfo(acpiNamespace, operationRegionAccessor);
                }

                if (parseSuccess == AmlParser.ParseSuccess.Success)
                {
                    Console.WriteLine("Parsed successfully");
                    Environment.Exit(0);
                }
                else
                {
                    Console.WriteLine("Encountered error during parse");
                    Environment.Exit(1);
                }
            }
            catch (Exception e) {
                Console.WriteLine("Encountered exception: " + e.Message);
                Console.WriteLine(e.StackTrace);
                Environment.Exit(1);
            }
        }