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
42class 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
96
97 private:
98
101};
102
103namespace Arch
104{
106};
107
114#endif /* __LIBARCH_ARM_ARMCACHEV6_H */
u8 type
Definition IntelACPI.h:0
ARMv6 cache management implementation.
Definition ARMCacheV6.h:43
virtual Result cleanInvalidateAddress(Type type, Address addr)
Clean and invalidate one memory page.
virtual Result invalidateAddress(Type type, Address addr)
Invalidate one memory page.
virtual Result invalidate(Type type)
Invalidate the entire cache.
ARMControl m_control
ARM system control processor object.
Definition ARMCacheV6.h:100
virtual Result cleanInvalidate(Type type)
Clean and invalidate entire cache.
virtual Result cleanAddress(Type type, Address addr)
Clean one memory page.
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 long Address
A memory address.
Definition Types.h:131
ARMCacheV6 Cache
Definition ARMCacheV6.h:105