The Pedigree Project  0.1
kernel/core/processor/armv7/InterruptManager.h
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 #ifndef KERNEL_PROCESSOR_ARMV7_INTERRUPTMANAGER_H
21 #define KERNEL_PROCESSOR_ARMV7_INTERRUPTMANAGER_H
22 
23 #include "pedigree/kernel/compiler.h"
24 #include "pedigree/kernel/processor/InterruptManager.h"
25 #include "pedigree/kernel/processor/MemoryRegion.h"
26 #include "pedigree/kernel/processor/SyscallManager.h"
27 #include "pedigree/kernel/processor/types.h"
28 
34 {
35  public:
39  {
40  return m_Instance;
41  }
42 
43  // InterruptManager Interface
44  virtual bool
45  registerInterruptHandler(size_t interruptNumber, InterruptHandler *handler);
46 
47 #ifdef DEBUGGER
49  size_t interruptNumber, InterruptHandler *handler);
50  virtual size_t getBreakpointInterruptNumber() PURE;
51  virtual size_t getDebugInterruptNumber() PURE;
52 #endif
53 
54  // SyscallManager Interface
55  virtual bool
56  registerSyscallHandler(Service_t Service, SyscallHandler *handler);
57 
58  virtual uintptr_t syscall(
59  Service_t service, uintptr_t function, uintptr_t p1 = 0,
60  uintptr_t p2 = 0, uintptr_t p3 = 0, uintptr_t p4 = 0, uintptr_t p5 = 0);
61 
65  static void initialiseProcessor();
66 
70  static void interrupt(InterruptState &interruptState);
71 
72  private:
82  virtual ~ARMV7InterruptManager();
83 
84  InterruptHandler *m_Handler[256];
85 #ifdef DEBUGGER
86 
88 #endif
89 
90  SyscallHandler *m_SyscallHandler[/*SyscallManager::*/ serviceEnd];
91 
94 
97 
99  enum Registers
100  {
101  INTCPS_REVISION = 0x00, // R
102  INTCPS_SYSCONFIG = 0x10 / 4, // RW
103  INTCPS_SYSSTATUS = 0x14 / 4, // R
104  INTCPS_SIR_IRQ = 0x40 / 4, // R
105  INTCPS_SIR_FIQ = 0x44 / 4, // R
106  INTCPS_CONTROL = 0x48 / 4, // RW
107  INTCPS_PROTECTION = 0x4C / 4, // RW
108  INTCPS_IDLE = 0x50 / 4, // RW
109  INTCPS_IRQ_PRIORITY = 0x60 / 4, // RW
110  INTCPS_FIQ_PRIORITY = 0x64 / 4, // RW
111  INTCPS_THRESHOLD = 0x68 / 4, // RW
112  INTCPS_ITR = 0x80 / 4, // R, multiple entries
113  INTCPS_MIR = 0x84 / 4, // RW, as above
114  INTCPS_MIR_CLEAR = 0x88 / 4, // W, as above
115  INTCPS_MIR_SET = 0x8C / 4, // W, as above
116  INTCPS_ISR_SET = 0x90 / 4, // RW, as above
117  INTCPS_ISR_CLEAR = 0x94 / 4, // W, as above
118  INTCPS_PENDING_IRQ = 0x98 / 4, // R, as above
119  INTCPS_PENDING_FIQ = 0x9C / 4, // R, as above
120  INTCPS_ILR = 0x100 / 4, // RW, multiple entries
121  };
122 };
123 
126 #endif
virtual size_t getBreakpointInterruptNumber() PURE
virtual bool registerInterruptHandlerDebugger(size_t interruptNumber, InterruptHandler *handler)
virtual bool registerInterruptHandler(size_t interruptNumber, InterruptHandler *handler)
Handles interrupts and interrupt registrations from kernel components.
static void interrupt(InterruptState &interruptState)
virtual uintptr_t syscall(Service_t service, uintptr_t function, uintptr_t p1=0, uintptr_t p2=0, uintptr_t p3=0, uintptr_t p4=0, uintptr_t p5=0)
ARMV7InterruptManager & operator=(const ARMV7InterruptManager &)
Special memory entity in the kernel's virtual address space.
Definition: MemoryRegion.h:35
Abstract base class for interrupt-handlers.
virtual bool registerSyscallHandler(Service_t Service, SyscallHandler *handler)
virtual size_t getDebugInterruptNumber() PURE