FreeNOS
ARMCacheV6.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_ARMCACHEV6_H
19 #define __LIBARCH_ARM_ARMCACHEV6_H
20 
21 #include <Types.h>
22 #include <Macros.h>
23 #include <Cache.h>
24 #include "ARMControl.h"
25 
42 class ARMCacheV6 : public Cache
43 {
44  public:
45 
53  virtual Result invalidate(Type type);
54 
66 
76 
85  virtual Result cleanAddress(Type type, Address addr);
86 
95  virtual Result invalidateAddress(Type type, Address addr);
96 
97  private:
98 
101 };
102 
103 namespace Arch
104 {
105  typedef ARMCacheV6 Cache;
106 };
107 
114 #endif /* __LIBARCH_ARM_ARMCACHEV6_H */
ARMCacheV6::m_control
ARMControl m_control
ARM system control processor object.
Definition: ARMCacheV6.h:100
Cache::Type
Type
Cache types.
Definition: Cache.h:53
ARMCacheV6::cleanInvalidate
virtual Result cleanInvalidate(Type type)
Clean and invalidate entire cache.
Definition: ARMCacheV6.cpp:41
Macros.h
Types.h
Arch
Definition: ARMCacheV6.h:103
ARMCacheV6::cleanAddress
virtual Result cleanAddress(Type type, Address addr)
Clean one memory page.
Definition: ARMCacheV6.cpp:96
Address
unsigned long Address
A memory address.
Definition: Types.h:131
ARMCacheV6::cleanInvalidateAddress
virtual Result cleanInvalidateAddress(Type type, Address addr)
Clean and invalidate one memory page.
Definition: ARMCacheV6.cpp:78
ARMCacheV6::invalidate
virtual Result invalidate(Type type)
Invalidate the entire cache.
Definition: ARMCacheV6.cpp:21
ARMControl
ARM System Control Coprocessor (CP15).
Definition: ARMControl.h:47
Arch::Cache
ARMCacheV6 Cache
Definition: ARMCacheV6.h:105
ARMCacheV6
ARMv6 cache management implementation.
Definition: ARMCacheV6.h:42
Cache.h
ARMCacheV6::invalidateAddress
virtual Result invalidateAddress(Type type, Address addr)
Invalidate one memory page.
Definition: ARMCacheV6.cpp:113
Cache::Result
Result
Result codes.
Definition: Cache.h:42
ARMControl.h
type
u8 type
Definition: IntelACPI.h:63
Cache
Cache management interface.
Definition: Cache.h:35