Tobias Diedrich wrote:

> Stefan Reinauer wrote:
> > The specified IO port is most likely wrong. As the comment mentions, the
> > SSDT is a good place for that. A preprocessor define used both in the
> > CPU init code and in the asl would solve the problem without an SSDT.
> > For some info on CPU SSDT creation on intel check out
> > src/cpu/intel/speedstep/acpi.c
> 
> The IO port is ok (and I wrote the comment myself ;)):
> DEFAULT_PMBASE is 0xe400
> PCNTRL reg offset is 0x10
> 
> Using the preprocessor will probably work too if iasl can do simple
> arithmetic (likely yes), I'll look into that.

BTW, my first idea was to use an acpi method that looks up pmbase in
the pci cfg space, but when I define a method like this:

        Method(TEST, 2)
        {
                Return (Add(Arg0, Arg1))
        }

I get:
|build/mainboard/asus/p2b/dsdt.ramstage.asl     9:   Processor (CPU0,
|0x01, TEST(0xe400, 0x10), 0x06) {}
|Error    4096 -       syntax error, unexpected PARSEOP_NAMESEG,
|expecting ')' ^ 

While using the builtin Add() directly works.

Signed-off-by: Tobias Diedrich <ranma+coreboot@tdiedrich.de>
Acked-by: Uwe Hermann <uwe@hermann-uwe.de>



git-svn-id: svn://svn.coreboot.org/coreboot/trunk@6132 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
Tobias Diedrich 2010-11-29 20:40:33 +00:00 committed by Tobias Diedrich
parent b97030d706
commit ca6d8084dd
2 changed files with 8 additions and 3 deletions

View File

@ -17,14 +17,17 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "southbridge/intel/i82371eb/i82371eb.h"
DefinitionBlock ("DSDT.aml", "DSDT", 2, "CORE ", "COREBOOT", 1) DefinitionBlock ("DSDT.aml", "DSDT", 2, "CORE ", "COREBOOT", 1)
{ {
/* Define the main processor.*/ /* Define the main processor.*/
Scope (\_PR) Scope (\_PR)
{ {
/* Looks like the P_CNT field can't be a method or name /* Looks like the P_CNT field can't be a name or method (except
* and has to be hardcoded to 0xe410 or generated in SSDT */ * builtins like Add()) and has to be hardcoded or generated
Processor (CPU0, 0x01, 0xe410, 0x06) {} * into SSDT */
Processor (CPU0, 0x01, Add(DEFAULT_PMBASE, PCNTRL), 0x06) {}
} }
/* For now only define 2 power states: /* For now only define 2 power states:

View File

@ -23,6 +23,7 @@
#if !defined(ASSEMBLY) #if !defined(ASSEMBLY)
#if !defined(__PRE_RAM__) #if !defined(__PRE_RAM__)
#if !defined(__ACPI__) /* dsdt include */
#include <arch/io.h> #include <arch/io.h>
#include <device/device.h> #include <device/device.h>
@ -31,6 +32,7 @@
void i82371eb_enable(device_t dev); void i82371eb_enable(device_t dev);
void i82371eb_hard_reset(void); void i82371eb_hard_reset(void);
#endif
#endif #endif
#endif #endif