FreeNOS
ARMCacheV7.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2015 Niek Linnenbank
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program. If not, see <http://www.gnu.org/licenses/>.
16  */
17 
18 #ifndef __LIBARCH_ARM_ARMCACHEV7_H
19 #define __LIBARCH_ARM_ARMCACHEV7_H
20 
21 #include <Types.h>
22 #include <Macros.h>
23 #include <Cache.h>
24 #include "ARMControl.h"
25 
42 class ARMCacheV7 : public Cache
43 {
44  private:
45 
50  {
55  };
56 
57  public:
58 
66  virtual Result invalidate(Type type);
67 
79 
89 
98  virtual Result cleanAddress(Type type, Address addr);
99 
108  virtual Result invalidateAddress(Type type, Address addr);
109 
110  private:
111 
119  Result dataFlush(bool clean);
120 
126  u32 getCacheLevelId() const;
127 
133  u32 getCacheLineSize() const;
134 
143  u32 readCacheSize(u32 level, u32 type) const;
144 
153  Result flushLevel(u32 level, bool clean);
154 
155  private:
156 
159 };
160 
161 namespace Arch
162 {
163  typedef ARMCacheV7 Cache;
164 };
165 
172 #endif /* __LIBARCH_ARM_ARMCACHEV7_H */
Cache::Type
Type
Cache types.
Definition: Cache.h:53
ARMCacheV7::readCacheSize
u32 readCacheSize(u32 level, u32 type) const
Get cache size.
Definition: ARMCacheV7.cpp:188
Macros.h
Types.h
ARMCacheV7::dataFlush
Result dataFlush(bool clean)
Flush the entire data cache.
Definition: ARMCacheV7.cpp:267
ARMCacheV7::CacheLevelUnified
@ CacheLevelUnified
Definition: ARMCacheV7.h:54
ARMCacheV7::getCacheLevelId
u32 getCacheLevelId() const
Get cache level identifier.
Definition: ARMCacheV7.cpp:163
Arch
Definition: ARMCacheV6.h:103
Address
unsigned long Address
A memory address.
Definition: Types.h:131
ARMCacheV7::invalidate
virtual Result invalidate(Type type)
Invalidate the entire cache.
Definition: ARMCacheV7.cpp:34
ARMCacheV7::CacheLevelType
CacheLevelType
Defines the cache level type bits.
Definition: ARMCacheV7.h:49
ARMCacheV7::cleanAddress
virtual Result cleanAddress(Type type, Address addr)
Clean one memory page.
Definition: ARMCacheV7.cpp:110
ARMCacheV7::flushLevel
Result flushLevel(u32 level, bool clean)
Clean and Invalidate by cache level.
Definition: ARMCacheV7.cpp:218
ARMControl
ARM System Control Coprocessor (CP15).
Definition: ARMControl.h:47
Arch::Cache
ARMCacheV6 Cache
Definition: ARMCacheV6.h:105
u32
unsigned int u32
Unsigned 32-bit number.
Definition: Types.h:53
ARMCacheV7::getCacheLineSize
u32 getCacheLineSize() const
Get cache line size in bytes.
Definition: ARMCacheV7.cpp:170
ARMCacheV7::CacheLevelInstructionData
@ CacheLevelInstructionData
Definition: ARMCacheV7.h:53
Cache.h
ARMCacheV7::CacheLevelInstruction
@ CacheLevelInstruction
Definition: ARMCacheV7.h:51
Cache::Result
Result
Result codes.
Definition: Cache.h:42
ARMControl.h
ARMCacheV7::cleanInvalidateAddress
virtual Result cleanInvalidateAddress(Type type, Address addr)
Clean and invalidate one memory page.
Definition: ARMCacheV7.cpp:82
ARMCacheV7
ARMv7 cache management implementation.
Definition: ARMCacheV7.h:42
type
u8 type
Definition: IntelACPI.h:63
Cache
Cache management interface.
Definition: Cache.h:35
ARMCacheV7::CacheLevelData
@ CacheLevelData
Definition: ARMCacheV7.h:52
ARMCacheV7::m_control
ARMControl m_control
ARM system control processor object.
Definition: ARMCacheV7.h:158
ARMCacheV7::invalidateAddress
virtual Result invalidateAddress(Type type, Address addr)
Invalidate one memory page.
Definition: ARMCacheV7.cpp:138
ARMCacheV7::cleanInvalidate
virtual Result cleanInvalidate(Type type)
Clean and invalidate entire cache.
Definition: ARMCacheV7.cpp:52