acpica/source/compiler
aystarik 1488e49d0f Source gen instructions
date	2004.10.06.20.17.00;	author rmoore1;	state Exp;
2005-06-29 16:15:45 +00:00
..
aslanalyze.c Fix for random error when compiling _OSI method 2005-06-29 15:41:32 +00:00
aslcodegen.c Added option to override the table header Revision field 2005-06-29 15:42:30 +00:00
aslcompile.c Fixes to correctly support variable-length packages and packages > 255 2005-06-29 15:44:08 +00:00
aslcompiler.h Automated cleanup 2005-06-29 15:46:33 +00:00
aslcompiler.l use AcpiUtStrupr 2005-06-29 15:47:54 +00:00
aslcompiler.y Support for Terms (executable code) at module level 2005-06-29 15:54:03 +00:00
asldefine.h cleanup 2005-06-29 15:54:05 +00:00
aslerror.c Lint update 2005-06-29 15:55:40 +00:00
aslfiles.c Exit with non-zero on error 2005-06-29 15:56:35 +00:00
aslfold.c auto-cleanup 2005-06-29 15:56:58 +00:00
aslglobal.h source ASCII check is now optional (-a) 2005-06-29 15:57:56 +00:00
asllength.c change all functions of type ASL_WALK_CALLBACK to return ACPI_STATUS 2005-06-29 15:58:18 +00:00
asllisting.c More ASM include file changes 2005-06-29 15:59:35 +00:00
aslload.c update warning message 2005-06-29 16:00:52 +00:00
asllookup.c Method reference in RefOf, DeRefOf, ObjectType are NOT method 2005-06-29 16:02:31 +00:00
aslmain.c Automated cleanup 2005-06-29 16:04:10 +00:00
aslmap.c Add ProcessorObj keyword 2005-06-29 16:05:50 +00:00
aslopcodes.c Revision override now affects the compiler internally (for constant 2005-06-29 16:07:04 +00:00
asloperands.c Range checking for the SyncLevel parameter 2005-06-29 16:08:05 +00:00
aslopt.c Make room for null terminator 2005-06-29 16:08:28 +00:00
aslresource.c New ACPI 3.0 resource template macros 2005-06-29 16:09:12 +00:00
aslrestype1.c Check for > 7 Vendor bytes 2005-06-29 16:09:51 +00:00
aslrestype2.c Error checking for ResourceSourceIndex and ResourceSource dependencies 2005-06-29 16:10:57 +00:00
aslstubs.c New stub 2005-06-29 16:11:18 +00:00
asltransform.c Add VAR_PACKAGE to case 2005-06-29 16:12:00 +00:00
asltree.c Deployed ACPI_FORMAT_UINT64 to simplify output statements 2005-06-29 16:12:59 +00:00
asltypes.h New error message 2005-06-29 16:14:26 +00:00
aslutils.c Fix for segfault on FreeBSD 2005-06-29 16:15:27 +00:00
readme.txt Source gen instructions 2005-06-29 16:15:45 +00:00

Instructions for integrating iASL compiler into MS VC++ 6.0 environment.

Part 1.  Integration as a custom tool

This procedure adds the iASL compiler as a custom tool that can be used
to compile ASL source files.  The output is sent to the VC output 
window.

a) Select Tools->Customize.

b) Select the "Tools" tab.

c) Scroll down to the bottom of the "Menu Contents" window.  There you
   will see an empty rectangle.  Click in the rectangle to enter a 
   name for this tool.

d) Type "iASL Compiler" in the box and hit enter.  You can now edit
   the other fields for this new custom tool.

e) Enter the following into the fields:

   Command:             C:\Acpi\iasl.exe
   Arguments:           -e "$(FilePath)"
   Initial Directory    "$(FileDir)"
   Use Output Window    <Check this option>

   "Command" must be the path to wherever you copied the compiler.
   "-e" instructs the compiler to produce messages appropriate for VC.
   Quotes around FilePath and FileDir enable spaces in filenames.

f) Select "Close".

These steps will add the compiler to the tools menu as a custom tool.
By enabling "Use Output Window", you can click on error messages in
the output window and the source file and source line will be
automatically displayed by VC.  Also, you can use F4 to step through
the messages and the corresponding source line(s).


Part 2.  Integration into a project build

This procedure creates a project that compiles ASL files to AML.

a) Create a new, empty project and add your .ASL files to the project

b) For all ASL files in the project, specify a custom build (under
Project/Settings/CustomBuild with the following settings (or similar):

Commands:
c:\acpi\libraries\iasl.exe -vs -vi "$(InputPath)"

Output:
$(InputDir)\$(InputPath).aml



Compiler Generation From Source

Generation of the ASL compiler from source code requires these items:


Required Tools
1) The Flex (or Lex) lexical analyzer generator.
2) The Bison (or Yacc) parser generator.
3) An ANSI C compiler.


Required Source Code.

There are three major source code components that are required to 
generate the compiler:

1) The ASL compiler source.
2) The ACPI CA Core Subsystem source.  In particular, the Namespace Manager
     component is used to create an internal ACPI namespace and symbol table,
     and the AML Interpreter is used to evaluate constant expressions.
3) The Common source for all ACPI components.