2 // Copyright (c) 2012-2013, ARM Limited. All rights reserved.
4 // This program and the accompanying materials
5 // are licensed and made available under the terms and conditions of the BSD License
6 // which accompanies this distribution. The full text of the license may be found at
7 // http://opensource.org/licenses/bsd-license.php
9 // THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
10 // WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
14 #include <AsmMacroIoLib.h>
15 #include <Library/ArmLib.h>
17 #include <ArmPlatform.h>
19 INCLUDE AsmMacroIoLib.inc
21 EXPORT ArmPlatformPeiBootAction
22 EXPORT ArmPlatformGetCorePosition
23 EXPORT ArmPlatformIsPrimaryCore
24 EXPORT ArmPlatformGetPrimaryCoreMpId
27 AREA CTA15A7Helper, CODE, READONLY
29 ArmPlatformPeiBootAction FUNCTION
34 //ArmPlatformGetCorePosition (
37 ArmPlatformGetCorePosition FUNCTION
38 and r1, r0, #ARM_CORE_MASK
39 and r0, r0, #ARM_CLUSTER_MASK
40 add r0, r1, r0, LSR #7
45 //ArmPlatformIsPrimaryCore (
48 ArmPlatformIsPrimaryCore FUNCTION
49 // Extract cpu_id and cluster_id from ARM_SCC_CFGREG48
50 // with cpu_id[0:3] and cluster_id[4:7]
51 LoadConstantToReg (ARM_CTA15A7_SCC_CFGREG48, r1)
55 // Shift the SCC value to get the cluster ID at the offset #8
59 // Keep only the cpu ID from the original SCC
61 // Add the Cluster ID to the Cpu ID
64 // Keep the Cluster ID and Core ID from the MPID
65 LoadConstantToReg (ARM_CLUSTER_MASK :OR: ARM_CORE_MASK, r2)
68 // Compare mpid and boot cpu from ARM_SCC_CFGREG48
76 //ArmPlatformGetPrimaryCoreMpId (
79 ArmPlatformGetPrimaryCoreMpId FUNCTION
80 // Extract cpu_id and cluster_id from ARM_SCC_CFGREG48
81 // with cpu_id[0:3] and cluster_id[4:7]
82 LoadConstantToReg (ARM_CTA15A7_SCC_CFGREG48, r0)
86 // Shift the SCC value to get the cluster ID at the offset #8
90 // Keep only the cpu ID from the original SCC
92 // Add the Cluster ID to the Cpu ID