]> git.proxmox.com Git - mirror_edk2.git/blame - ArmPkg/Library/ArmLib/Common/ArmLibPrivate.h
ArmPkg/ArmBaseLib: remove MemoryAllocationLib.h includes
[mirror_edk2.git] / ArmPkg / Library / ArmLib / Common / ArmLibPrivate.h
CommitLineData
2ef2b01e
A
1/** @file\r
2\r
d6ebcab7 3 Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>\r
2ef2b01e 4\r
d6ebcab7 5 This program and the accompanying materials\r
2ef2b01e
A
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
15#ifndef __ARM_LIB_PRIVATE_H__\r
16#define __ARM_LIB_PRIVATE_H__\r
17\r
18#define CACHE_SIZE_4_KB (3UL)\r
19#define CACHE_SIZE_8_KB (4UL)\r
20#define CACHE_SIZE_16_KB (5UL)\r
21#define CACHE_SIZE_32_KB (6UL)\r
22#define CACHE_SIZE_64_KB (7UL)\r
23#define CACHE_SIZE_128_KB (8UL)\r
24\r
25#define CACHE_ASSOCIATIVITY_DIRECT (0UL)\r
26#define CACHE_ASSOCIATIVITY_4_WAY (2UL)\r
27#define CACHE_ASSOCIATIVITY_8_WAY (3UL)\r
28\r
29#define CACHE_PRESENT (0UL)\r
30#define CACHE_NOT_PRESENT (1UL)\r
31\r
32#define CACHE_LINE_LENGTH_32_BYTES (2UL)\r
33\r
34#define SIZE_FIELD_TO_CACHE_SIZE(x) (((x) >> 6) & 0x0F)\r
35#define SIZE_FIELD_TO_CACHE_ASSOCIATIVITY(x) (((x) >> 3) & 0x07)\r
36#define SIZE_FIELD_TO_CACHE_PRESENCE(x) (((x) >> 2) & 0x01)\r
37#define SIZE_FIELD_TO_CACHE_LINE_LENGTH(x) (((x) >> 0) & 0x03)\r
38\r
39#define DATA_CACHE_SIZE_FIELD(x) (((x) >> 12) & 0x0FFF)\r
40#define INSTRUCTION_CACHE_SIZE_FIELD(x) (((x) >> 0) & 0x0FFF)\r
41\r
42#define DATA_CACHE_SIZE(x) (SIZE_FIELD_TO_CACHE_SIZE(DATA_CACHE_SIZE_FIELD(x)))\r
43#define DATA_CACHE_ASSOCIATIVITY(x) (SIZE_FIELD_TO_CACHE_ASSOCIATIVITY(DATA_CACHE_SIZE_FIELD(x)))\r
44#define DATA_CACHE_PRESENT(x) (SIZE_FIELD_TO_CACHE_PRESENCE(DATA_CACHE_SIZE_FIELD(x)))\r
45#define DATA_CACHE_LINE_LENGTH(x) (SIZE_FIELD_TO_CACHE_LINE_LENGTH(DATA_CACHE_SIZE_FIELD(x)))\r
46\r
47#define INSTRUCTION_CACHE_SIZE(x) (SIZE_FIELD_TO_CACHE_SIZE(INSTRUCTION_CACHE_SIZE_FIELD(x)))\r
48#define INSTRUCTION_CACHE_ASSOCIATIVITY(x) (SIZE_FIELD_TO_CACHE_ASSOCIATIVITY(INSTRUCTION_CACHE_SIZE_FIELD(x)))\r
49#define INSTRUCTION_CACHE_PRESENT(x) (SIZE_FIELD_TO_CACHE_PRESENCE(INSTRUCTION_CACHE_SIZE_FIELD(x)))\r
50#define INSTRUCTION_CACHE_LINE_LENGTH(x) (SIZE_FIELD_TO_CACHE_LINE_LENGTH(INSTRUCTION_CACHE_SIZE_FIELD(x)))\r
51\r
52#define CACHE_TYPE(x) (((x) >> 25) & 0x0F)\r
53#define CACHE_TYPE_WRITE_BACK (0x0EUL)\r
54\r
55#define CACHE_ARCHITECTURE(x) (((x) >> 24) & 0x01)\r
56#define CACHE_ARCHITECTURE_UNIFIED (0UL)\r
57#define CACHE_ARCHITECTURE_SEPARATE (1UL)\r
58\r
59VOID\r
60CPSRMaskInsert (\r
61 IN UINT32 Mask,\r
62 IN UINT32 Value\r
63 );\r
64\r
65UINT32\r
66CPSRRead (\r
67 VOID\r
68 );\r
69\r
3402aac7 70UINT32\r
98bc0c8c 71ReadCCSIDR (\r
72 IN UINT32 CSSELR\r
3402aac7
RC
73 );\r
74\r
98bc0c8c 75UINT32\r
76ReadCLIDR (\r
77 VOID\r
78 );\r
98bc0c8c 79\r
2ef2b01e 80#endif // __ARM_LIB_PRIVATE_H__\r