blob: e7c03786b4f1356913fda78aeda9b2100c5b43ac [file] [log] [blame]
Soren Brinkmannc8284402016-03-06 20:16:27 -08001/*
Michal Simek619bc132023-04-14 08:43:51 +02002 * Copyright (c) 2015-2018, Arm Limited and Contributors. All rights reserved.
Soren Brinkmannc8284402016-03-06 20:16:27 -08003 *
dp-arm82cb2c12017-05-03 09:38:09 +01004 * SPDX-License-Identifier: BSD-3-Clause
Soren Brinkmannc8284402016-03-06 20:16:27 -08005 */
6
Antonio Nino Diaz09d40e02018-12-14 00:18:21 +00007#include <plat/common/platform.h>
8
Prasad Kummari01a326a2023-06-22 10:50:02 +05309#include <plat_private.h>
10
Venkatesh Yadav Abbarapuffa91032022-05-19 14:49:49 +053011int32_t plat_core_pos_by_mpidr(u_register_t mpidr)
Soren Brinkmannc8284402016-03-06 20:16:27 -080012{
Maheedhar Bollapallia42e6e42024-04-22 15:10:45 +053013 if ((mpidr & MPIDR_CLUSTER_MASK) != 0U) {
Soren Brinkmannc8284402016-03-06 20:16:27 -080014 return -1;
Venkatesh Yadav Abbarapue43258f2021-01-10 20:40:16 -070015 }
Soren Brinkmannc8284402016-03-06 20:16:27 -080016
Venkatesh Yadav Abbarapue43258f2021-01-10 20:40:16 -070017 if ((mpidr & MPIDR_CPU_MASK) >= PLATFORM_CORE_COUNT) {
Soren Brinkmannc8284402016-03-06 20:16:27 -080018 return -1;
Venkatesh Yadav Abbarapue43258f2021-01-10 20:40:16 -070019 }
Soren Brinkmannc8284402016-03-06 20:16:27 -080020
Maheedhar Bollapalli6ae95622024-04-24 16:20:26 +053021 return (int32_t)zynqmp_calc_core_pos(mpidr);
Soren Brinkmannc8284402016-03-06 20:16:27 -080022}