blob: bccf2c820e7ab5f58909f084a6b6c2fac40ad0e3 [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>
Soby Mathewfec4eb72015-07-01 16:16:20 +01009
Summer Qin93c812f2017-02-28 16:46:17 +000010#if ARM_PLAT_MT
11#pragma weak plat_arm_get_cpu_pe_count
12#endif
13
Soby Mathewfec4eb72015-07-01 16:16:20 +010014/******************************************************************************
15 * This function implements a part of the critical interface between the psci
16 * generic layer and the platform that allows the former to query the platform
17 * to convert an MPIDR to a unique linear index. An error code (-1) is
18 * returned in case the MPIDR is invalid.
19 *****************************************************************************/
20int plat_core_pos_by_mpidr(u_register_t mpidr)
21{
22 if (arm_check_mpidr(mpidr) == 0)
23 return plat_arm_calc_core_pos(mpidr);
24
25 return -1;
26}
Summer Qin93c812f2017-02-28 16:46:17 +000027
28#if ARM_PLAT_MT
29/******************************************************************************
30 * This function returns the PE count within the physical cpu corresponding to
31 * `mpidr`. Now one cpu only have one thread, so just return 1.
32 *****************************************************************************/
33unsigned int plat_arm_get_cpu_pe_count(u_register_t mpidr)
34{
35 return 1;
36}
37#endif /* ARM_PLAT_MT */