os/kernelhwsrv/kernel/eka/nkernsmp/arm/nccpu.cia
author sl
Tue, 10 Jun 2014 14:32:02 +0200 (2014-06-10)
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// e32\nkernsmp\arm\nccpu.cia
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include <arm.h>
sl@0
    19
#include <arm_gic.h>
sl@0
    20
#include <arm_scu.h>
sl@0
    21
#include <arm_tmr.h>
sl@0
    22
#include <e32cia.h>
sl@0
    23
sl@0
    24
extern "C" {
sl@0
    25
sl@0
    26
__NAKED__ void KickCpu(volatile T_UintPtr* aPtr, T_UintPtr aRegsPhys)
sl@0
    27
	{
sl@0
    28
	asm("orr	r1, r1, #3 ");
sl@0
    29
	asm("str	r1, [r0] ");
sl@0
    30
	__DATA_SYNC_BARRIER__(r0);
sl@0
    31
	ARM_SEV;
sl@0
    32
	__JUMP(,lr);
sl@0
    33
	}
sl@0
    34
sl@0
    35
__NAKED__ void _ApEntry()
sl@0
    36
	{
sl@0
    37
	asm("str	sp, [r6] ");
sl@0
    38
	__DATA_SYNC_BARRIER__(r0);
sl@0
    39
	asm("ldr	r1, [r4, #%a0]" : : "i" _FOFF(SAPBootInfo,iMain));
sl@0
    40
	asm("mov	r0, r4 ");			// pointer to SAPBootInfo
sl@0
    41
	asm("adr	lr, 1f ");
sl@0
    42
	__JUMP(,r1);
sl@0
    43
	asm("1: ");
sl@0
    44
	__ASM_CRASH();
sl@0
    45
	}
sl@0
    46
sl@0
    47
}