kernel/eka/nkernsmp/x86/nccpu.cia
changeset 9 96e5fb8b040d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kernel/eka/nkernsmp/x86/nccpu.cia	Thu Dec 17 09:24:54 2009 +0200
@@ -0,0 +1,79 @@
+// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// e32\nkernsmp\x86\nccpu.cia
+// 
+//
+
+#include <x86.h>
+#include <apic.h>
+
+__NAKED__ void cmos_write(TUint32 val, TUint32 addr)
+	{
+	asm("mov eax, [esp+8]");
+	asm("out 0x70, al");
+	asm("mov eax, [esp+4]");
+	asm("out 0x71, al");
+	asm("ret");
+	}
+
+__NAKED__ void SetupApInitInfo(volatile SApInitInfo&)
+	{
+	asm("mov ecx, [esp+4]");
+	asm("sgdt [ecx+%0]": :"i"_FOFF(SApInitInfo, iGdtr));
+	asm("sidt [ecx+%0]": :"i"_FOFF(SApInitInfo, iIdtr));
+	asm("mov eax, cr0");
+	asm("mov [ecx+%0], eax": :"i"_FOFF(SApInitInfo, iCr0));
+	asm("mov eax, cr3");
+	asm("mov [ecx+%0], eax": :"i"_FOFF(SApInitInfo, iCr3));
+	MOV_EAX_CR4;
+	asm("mov [ecx+%0], eax": :"i"_FOFF(SApInitInfo, iCr4));
+	asm("ret");
+	}
+
+__NAKED__ void _ApMain()
+	{
+	asm("mov eax, %0" : : "i" (RING0_DS));
+	asm("mov ss, ax ");
+	asm("mov ds, ax ");
+	asm("mov es, ax ");
+	asm("mov fs, ax ");
+	asm("mov gs, ax ");
+	asm("lgdt [edi+%0]" : : "i" _FOFF(SApInitInfo, iGdtr));
+	asm("lidt [edi+%0]" : : "i" _FOFF(SApInitInfo, iIdtr));
+	asm("mov esp, [edi+%0]" : : "i" _FOFF(SApInitInfo, iRgs.iEsp));
+	asm("mov eax, [edi+%0]" : : "i" _FOFF(SApInitInfo, iBootFlag));
+	asm("lock dec dword ptr [edi+%0]" : : "i" _FOFF(SApInitInfo, iBootFlag));
+	asm("sub eax, 2 ");
+	asm("wait_for_bp: ");
+	asm("cmp eax, [edi+%0]" : : "i" _FOFF(SApInitInfo, iBootFlag));
+	X86_PAUSE
+	asm("jne wait_for_bp ");
+
+	asm("mov eax, cr0 ");
+	asm("and al, 0xf7 ");	// enable access to FPU
+	asm("mov cr0, eax ");
+	asm("fninit ");			// initialise coprocessor
+	asm("fwait ");
+	asm("or al, 8 ");
+	asm("mov cr0, eax ");	// disable access to coprocessor
+
+	asm("mov ecx, [edi+%0]" : : "i" _FOFF(SApInitInfo, iExtra));
+	asm("mov eax, [ecx+%0]" : : "i" _FOFF(SAPBootInfo, iMain));
+	asm("push ecx ");
+	asm("call eax ");
+	asm("add esp, 4 ");
+	asm("spin: ");
+	asm("hlt ");
+	asm("jmp spin ");
+	}