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
42class ARMCacheV7 : public Cache
43{
44 private:
45
56
57 public:
58
66 virtual Result invalidate(Type type);
67
79
89
98 virtual Result cleanAddress(Type type, Address addr);
99
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
161namespace Arch
162{
163 typedef ARMCacheV7 Cache;
164};
165
172#endif /* __LIBARCH_ARM_ARMCACHEV7_H */
u8 type
Definition IntelACPI.h:0
ARMv7 cache management implementation.
Definition ARMCacheV7.h:43
Result flushLevel(u32 level, bool clean)
Clean and Invalidate by cache level.
virtual Result invalidateAddress(Type type, Address addr)
Invalidate one memory page.
Result dataFlush(bool clean)
Flush the entire data cache.
virtual Result cleanAddress(Type type, Address addr)
Clean one memory page.
CacheLevelType
Defines the cache level type bits.
Definition ARMCacheV7.h:50
@ CacheLevelInstructionData
Definition ARMCacheV7.h:53
@ CacheLevelInstruction
Definition ARMCacheV7.h:51
@ CacheLevelUnified
Definition ARMCacheV7.h:54
u32 getCacheLevelId() const
Get cache level identifier.
virtual Result cleanInvalidateAddress(Type type, Address addr)
Clean and invalidate one memory page.
virtual Result invalidate(Type type)
Invalidate the entire cache.
u32 readCacheSize(u32 level, u32 type) const
Get cache size.
ARMControl m_control
ARM system control processor object.
Definition ARMCacheV7.h:158
virtual Result cleanInvalidate(Type type)
Clean and invalidate entire cache.
u32 getCacheLineSize() const
Get cache line size in bytes.
ARM System Control Coprocessor (CP15).
Definition ARMControl.h:48
Cache management interface.
Definition Cache.h:36
Result
Result codes.
Definition Cache.h:43
Type
Cache types.
Definition Cache.h:54
unsigned int u32
Unsigned 32-bit number.
Definition Types.h:53
unsigned long Address
A memory address.
Definition Types.h:131
ARMCacheV6 Cache
Definition ARMCacheV6.h:105