2013-07-18 21:06:52 +02:00
|
|
|
//
|
2014-02-24 20:20:16 +01:00
|
|
|
// Copyright (c) 2012-2014, ARM Limited. All rights reserved.
|
2013-07-18 21:06:52 +02:00
|
|
|
//
|
2019-04-04 01:03:21 +02:00
|
|
|
// SPDX-License-Identifier: BSD-2-Clause-Patent
|
2013-07-18 21:06:52 +02:00
|
|
|
//
|
|
|
|
//
|
|
|
|
|
2014-02-24 20:20:16 +01:00
|
|
|
#include <AsmMacroIoLibV8.h>
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
//VOID
|
|
|
|
//ArmPlatformStackSet (
|
|
|
|
// IN UINTN StackBase,
|
|
|
|
// IN UINTN MpId,
|
|
|
|
// IN UINTN PrimaryStackSize,
|
|
|
|
// IN UINTN SecondaryStackSize
|
|
|
|
// );
|
2016-08-10 16:55:23 +02:00
|
|
|
ASM_FUNC(ArmPlatformStackSet)
|
2013-07-18 21:06:52 +02:00
|
|
|
// Save parameters
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x26, x3
|
|
|
|
mov x25, x2
|
|
|
|
mov x24, x1
|
|
|
|
mov x23, x0
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Save the Link register
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x27, x30
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Identify Stack
|
|
|
|
mov x0, x1
|
|
|
|
bl ASM_PFX(ArmPlatformIsPrimaryCore)
|
|
|
|
cmp x0, #1
|
|
|
|
|
|
|
|
// Restore parameters
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x0, x23
|
|
|
|
mov x1, x24
|
|
|
|
mov x2, x25
|
|
|
|
mov x3, x26
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Restore the Link register
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x30, x27
|
2013-07-18 21:06:52 +02:00
|
|
|
|
2016-08-10 16:55:23 +02:00
|
|
|
b.ne 0f
|
|
|
|
|
|
|
|
b ASM_PFX(ArmPlatformStackSetPrimary)
|
|
|
|
0:b ASM_PFX(ArmPlatformStackSetSecondary)
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
//VOID
|
|
|
|
//ArmPlatformStackSetPrimary (
|
|
|
|
// IN UINTN StackBase,
|
|
|
|
// IN UINTN MpId,
|
|
|
|
// IN UINTN PrimaryStackSize,
|
|
|
|
// IN UINTN SecondaryStackSize
|
|
|
|
// );
|
2016-08-10 16:55:23 +02:00
|
|
|
ASM_FUNC(ArmPlatformStackSetPrimary)
|
2017-02-22 10:38:18 +01:00
|
|
|
// Add size of primary stack to StackBase
|
2013-07-18 21:06:52 +02:00
|
|
|
add x0, x0, x2
|
|
|
|
|
|
|
|
// Compute SecondaryCoresCount * SecondaryCoreStackSize
|
2016-08-10 16:55:23 +02:00
|
|
|
MOV32 (w1, FixedPcdGet32(PcdCoreCount) - 1)
|
2013-07-18 21:06:52 +02:00
|
|
|
mul x3, x3, x1
|
|
|
|
|
|
|
|
// Set Primary Stack ((StackBase + PrimaryStackSize) + (SecondaryCoresCount * SecondaryCoreStackSize))
|
|
|
|
add sp, x0, x3
|
|
|
|
|
2017-02-22 10:38:18 +01:00
|
|
|
ret
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
//VOID
|
|
|
|
//ArmPlatformStackSetSecondary (
|
|
|
|
// IN UINTN StackBase,
|
|
|
|
// IN UINTN MpId,
|
|
|
|
// IN UINTN PrimaryStackSize,
|
|
|
|
// IN UINTN SecondaryStackSize
|
|
|
|
// );
|
2016-08-10 16:55:23 +02:00
|
|
|
ASM_FUNC(ArmPlatformStackSetSecondary)
|
2013-07-18 21:06:52 +02:00
|
|
|
// Save the Link register
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x24, x30
|
2013-07-18 21:06:52 +02:00
|
|
|
mov sp, x0
|
|
|
|
|
|
|
|
// Get Core Position
|
|
|
|
mov x0, x1
|
|
|
|
bl ASM_PFX(ArmPlatformGetCorePosition)
|
2017-02-22 10:38:18 +01:00
|
|
|
mov x25, x0
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Get Primary Core Position
|
|
|
|
bl ASM_PFX(ArmPlatformGetPrimaryCoreMpId)
|
|
|
|
bl ASM_PFX(ArmPlatformGetCorePosition)
|
|
|
|
|
|
|
|
// Get Secondary Core Position. We should get consecutive secondary stack number from 1...(CoreCount-1)
|
2017-02-22 10:38:18 +01:00
|
|
|
cmp x25, x0
|
|
|
|
|
2013-07-18 21:06:52 +02:00
|
|
|
// Decrement the position if after the primary core
|
2017-02-22 10:38:18 +01:00
|
|
|
cinc x25, x25, ls
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Compute top of the secondary stack
|
2017-02-22 10:38:18 +01:00
|
|
|
mul x3, x3, x25
|
2013-07-18 21:06:52 +02:00
|
|
|
|
|
|
|
// Set stack
|
|
|
|
add sp, sp, x3
|
|
|
|
|
2017-02-22 10:38:18 +01:00
|
|
|
ret x24
|