On Sun, Nov 23, 2008 at 11:02 PM, Feng, Libo <[EMAIL PROTECTED]> wrote:
>
> Hi, All,
>
> I am still trying to implement the S3 state in dbm690t. Now I can jump into 
> the waking vector code running under the real mode. However, the code 
> contains some 32bit instructions, when these instructions are executed, the 
> system always hangs, for the processor thought they were of 16bit. Please see 
> the code in the below link.
>
> http://lxr.linux.no/linux+v2.6.18/arch/x86_64/kernel/acpi/wakeup.S
>
> In 37 and 38 line, there are two 32bit instructions,
>
> 66 6a 00   pushl   $0  # Kill any dangerous flags
> 66 9d        popfl
>
> You can see the machine codes starting with 0x66 indicating these 32bit 
> instructions. However, processor always thought these were of 16bit, so, 
> instructions are changed into:
>
> 66 6a         push byte 00h
> 00 66 9d     add [bp-63h], ah
>

what could explain this is that you are not in 16-bit mode, you are
actually in 32-bit mode for some reason. The 66 will then run these
instructions in 16 bit. That is just a guess.

Are you certain you are in 16 bit mode?

ron

--
coreboot mailing list: [email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to