The Pedigree Project  0.1
arm_926e/Processor.cc
1 /*
2  * Copyright (c) 2008-2014, Pedigree Developers
3  *
4  * Please see the CONTRIB file in the root of the source tree for a full
5  * list of contributors.
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 #include "pedigree/kernel/processor/Processor.h"
21 #include "InterruptManager.h"
22 #include "pedigree/kernel/Log.h"
23 
25 {
26  // Initialise this processor's interrupt handling
27  // MIPS32InterruptManager::initialiseProcessor();
28 
29  // TODO: Initialise the physical memory-management
30 
31  // TODO
32 
33  // m_Initialised = 1;
34 }
35 
37 {
38  // TODO
39 
40  // m_Initialised = 2;
41 }
42 
44 {
45  // TODO: this is kinda boring, i want inline assembly
46  str += "Arm926E";
47 }
48 
50 {
51  return 0;
52 }
53 
55  size_t nBpNumber, DebugFlags::FaultType &nFaultType, size_t &nLength,
56  bool &bEnabled)
57 {
59  return 0;
60 }
61 
63  size_t nBpNumber, uintptr_t nLinearAddress,
64  DebugFlags::FaultType nFaultType, size_t nLength)
65 {
67 }
68 
69 void Processor::disableDebugBreakpoint(size_t nBpNumber)
70 {
72 }
73 
74 void Processor::setInterrupts(bool bEnable)
75 {
77 }
78 
80 {
81  return false;
82 }
83 
84 void Processor::setSingleStep(bool bEnable, InterruptState &state)
85 {
87  ERROR("Single step unavailable on ARM.");
88 }
89 
91 {
92  ERROR("ARM has no address space support yet");
93 }
Bootstrap structure passed to the kernel entry point.
static bool getInterrupts()
static uintptr_t getDebugBreakpoint(size_t nBpNumber, DebugFlags::FaultType &nFaultType, size_t &nLength, bool &bEnabled)
static void initialise2(const BootstrapStruct_t &Info) INITIALISATION_ONLY
second/last stage in the initialisation of the processor-specific interface
static void switchAddressSpace(VirtualAddressSpace &AddressSpace)
static void enableDebugBreakpoint(size_t nBpNumber, uintptr_t nLinearAddress, DebugFlags::FaultType nFaultType, size_t nLength)
static void setSingleStep(bool bEnable, InterruptState &state)
static void initialise1(const BootstrapStruct_t &Info) INITIALISATION_ONLY
first stage in the initialisation of the processor-specific interface
static void disableDebugBreakpoint(size_t nBpNumber)
static void setInterrupts(bool bEnable)
static void identify(HugeStaticString &str)
#define ERROR(text)
Definition: Log.h:82
static size_t getDebugBreakpointCount()