summaryrefslogtreecommitdiffstats
path: root/plat/mediatek/include/armv8_2/arch_def.h
blob: 61f818fca21443c0e0c454fcffcd7731498d8295 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
 * Copyright (c) 2022, Mediatek Inc. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#ifndef ARCH_DEF_H
#define ARCH_DEF_H

/* Topology constants */
#define PLAT_MAX_PWR_LVL		(2)
#define PLAT_MAX_RET_STATE		(1)
#define PLAT_MAX_OFF_STATE		(2)

#define PLATFORM_SYSTEM_COUNT		(1)
#define PLATFORM_CLUSTER_COUNT		(1)
#define PLATFORM_CLUSTER0_CORE_COUNT	(8)
#define PLATFORM_CORE_COUNT		(PLATFORM_CLUSTER0_CORE_COUNT)
#define PLATFORM_MAX_CPUS_PER_CLUSTER	(8)
#define PLATFORM_NUM_AFFS		(PLATFORM_SYSTEM_COUNT + \
					 PLATFORM_CLUSTER_COUNT + \
					 PLATFORM_CORE_COUNT)

/*******************************************************************************
 * Declarations and constants to access the mailboxes safely. Each mailbox is
 * aligned on the biggest cache line size in the platform. This is known only
 * to the platform as it might have a combination of integrated and external
 * caches. Such alignment ensures that two maiboxes do not sit on the same cache
 * line at any cache level. They could belong to different cpus/clusters &
 * get written while being protected by different locks causing corruption of
 * a valid mailbox address.
 ******************************************************************************/
/* Cachline size */
#define CACHE_WRITEBACK_SHIFT		(6)
#define CACHE_WRITEBACK_GRANULE		(1 << CACHE_WRITEBACK_SHIFT)

#endif /* ARCH_DEF_H */