The Pedigree Project  0.1
kernel/core/processor/x64/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_X64_INTERRUPTMANAGER_H
21 #define KERNEL_PROCESSOR_X64_INTERRUPTMANAGER_H
22 
23 #include "pedigree/kernel/Spinlock.h"
24 #include "pedigree/kernel/compiler.h"
25 #include "pedigree/kernel/processor/InterruptManager.h"
26 #include "pedigree/kernel/processor/state_forward.h"
27 #include "pedigree/kernel/processor/types.h"
28 
29 class InterruptHandler;
30 
36 {
37  friend class Processor;
38 
39  public:
42  inline static X64InterruptManager &instance()
43  {
44  return m_Instance;
45  }
46 
47  virtual bool registerInterruptHandler(
48  size_t nInterruptNumber, InterruptHandler *pHandler);
49 
50 #ifdef DEBUGGER
52  size_t nInterruptNumber, InterruptHandler *pHandler);
53  virtual size_t getBreakpointInterruptNumber() PURE;
54  virtual size_t getDebugInterruptNumber() PURE;
55 #endif
56 
61 
62  private:
66  static void interrupt(InterruptState &interruptState) USED;
67 
73  void setInterruptGate(size_t nInterruptNumber, uintptr_t interruptHandler)
78  void setIst(size_t nInterruptNumber, size_t ist);
88  virtual ~X64InterruptManager();
89 
92  {
94  uint16_t offset0;
96  uint16_t selector;
98  uint8_t ist;
100  uint8_t flags;
102  uint16_t offset1;
104  uint32_t offset2;
106  uint32_t res;
107  } PACKED;
108 
111 
116 #ifdef DEBUGGER
117 
119 #endif
120 
123 };
124 
127 #endif
X64InterruptManager & operator=(const X64InterruptManager &)
Handles interrupts and interrupt registrations from kernel components.
X64InterruptManager() INITIALISATION_ONLY
virtual size_t getBreakpointInterruptNumber() PURE
static void interrupt(InterruptState &interruptState) USED
virtual size_t getDebugInterruptNumber() PURE
The exception was caused by a hardware task switch.
Definition: Processor.h:80
virtual bool registerInterruptHandlerDebugger(size_t nInterruptNumber, InterruptHandler *pHandler)
void setInterruptGate(size_t nInterruptNumber, uintptr_t interruptHandler) INITIALISATION_ONLY
static void initialiseProcessor() INITIALISATION_ONLY
Abstract base class for interrupt-handlers.
virtual bool registerInterruptHandler(size_t nInterruptNumber, InterruptHandler *pHandler)
void setIst(size_t nInterruptNumber, size_t ist)
static X64InterruptManager & instance()