blob: d1f1c98f4b1fb354ce0acee4c86335605a5de4cb [file] [log] [blame]
Soby Mathewfec4eb72015-07-01 16:16:20 +01001/*
Roberto Vargas2b36b152018-02-12 12:36:17 +00002 * Copyright (c) 2015-2018, ARM Limited and Contributors. All rights reserved.
Soby Mathewfec4eb72015-07-01 16:16:20 +01003 *
dp-armfa3cf0b2017-05-03 09:38:09 +01004 * SPDX-License-Identifier: BSD-3-Clause
Soby Mathewfec4eb72015-07-01 16:16:20 +01005 */
6
7#include <plat_arm.h>
Roberto Vargas2b36b152018-02-12 12:36:17 +00008#include <platform.h>
Vishwanatha HG64f0b6f2018-05-08 17:15:37 +05309#include <assert.h>
Soby Mathewfec4eb72015-07-01 16:16:20 +010010
Summer Qin93c812f2017-02-28 16:46:17 +000011#if ARM_PLAT_MT
12#pragma weak plat_arm_get_cpu_pe_count
13#endif
14
Soby Mathewfec4eb72015-07-01 16:16:20 +010015/******************************************************************************
16 * This function implements a part of the critical interface between the psci
17 * generic layer and the platform that allows the former to query the platform
18 * to convert an MPIDR to a unique linear index. An error code (-1) is
19 * returned in case the MPIDR is invalid.
20 *****************************************************************************/
21int plat_core_pos_by_mpidr(u_register_t mpidr)
22{
Vishwanatha HG64f0b6f2018-05-08 17:15:37 +053023 if (arm_check_mpidr(mpidr) == 0) {
24#if ARM_PLAT_MT
25 assert((read_mpidr_el1() & MPIDR_MT_MASK) != 0);
Nariman Poushinf67abbb2018-06-25 17:04:51 +010026
27 /*
28 * The DTB files don't provide the MT bit in the mpidr argument
29 * so set it manually before calculating core position
30 */
31 mpidr |= MPIDR_MT_MASK;
Vishwanatha HG64f0b6f2018-05-08 17:15:37 +053032#endif
Soby Mathewfec4eb72015-07-01 16:16:20 +010033 return plat_arm_calc_core_pos(mpidr);
Vishwanatha HG64f0b6f2018-05-08 17:15:37 +053034 }
Soby Mathewfec4eb72015-07-01 16:16:20 +010035 return -1;
36}
Summer Qin93c812f2017-02-28 16:46:17 +000037
38#if ARM_PLAT_MT
39/******************************************************************************
40 * This function returns the PE count within the physical cpu corresponding to
41 * `mpidr`. Now one cpu only have one thread, so just return 1.
42 *****************************************************************************/
43unsigned int plat_arm_get_cpu_pe_count(u_register_t mpidr)
44{
45 return 1;
46}
47#endif /* ARM_PLAT_MT */