FreeNOS
IntelCoreServer.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2020 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 __SERVER_CORE_INTELCORESERVER_H
19 #define __SERVER_CORE_INTELCORESERVER_H
20 
21 #include "CoreServer.h"
22 #include <intel/IntelAPIC.h>
23 #include <intel/IntelMP.h>
24 #include <intel/IntelACPI.h>
25 
43 {
44  private:
45 
47  static const uint IPIVector = 50;
48 
49  public:
50 
55 
61  virtual Result initialize();
62 
71  virtual Core::Result bootCore(uint coreId, CoreInfo *info);
72 
78  virtual Core::Result discoverCores();
79 
83  virtual void waitIPI() const;
84 
93 
94  private:
95 
99 };
100 
106 #endif /* __SERVER_CORE_INTELCORESERVER_H */
IntelAPIC.h
IntelCoreServer
Represents a single Core in a Central Processing Unit (CPU).
Definition: IntelCoreServer.h:42
IntelCoreServer::waitIPI
virtual void waitIPI() const
Wait for Inter-Processor-Interrupt.
Definition: IntelCoreServer.cpp:86
IntelCoreServer::m_mp
IntelMP m_mp
Definition: IntelCoreServer.h:97
IntelCoreServer::m_apic
IntelAPIC m_apic
Definition: IntelCoreServer.h:96
IntelCoreServer::m_acpi
IntelACPI m_acpi
Definition: IntelCoreServer.h:98
uint
unsigned int uint
Unsigned integer number.
Definition: Types.h:44
CoreServer
Represents a single Core in a Central Processing Unit (CPU).
Definition: CoreServer.h:49
IntelACPI.h
CoreServer.h
ChannelServer< CoreServer, CoreMessage >::Result
Result
Result codes.
Definition: ChannelServer.h:99
IntelACPI
Intel Advanced Configuration and Power Interface (ACPI).
Definition: IntelACPI.h:39
IntelCoreServer::discoverCores
virtual Core::Result discoverCores()
Discover processor cores.
Definition: IntelCoreServer.cpp:62
IntelMP
Intel Multi-Processor Specification.
Definition: IntelMP.h:70
IntelCoreServer::sendIPI
virtual Core::Result sendIPI(uint coreId)
Send Inter-Processor-Interrupt.
Definition: IntelCoreServer.cpp:93
CoreInfo
Per-Core information structure.
Definition: CoreInfo.h:60
Core::Result
Result
Result code for Actions.
Definition: Core.h:47
IntelMP.h
IntelCoreServer::initialize
virtual Result initialize()
Initialize the server.
Definition: IntelCoreServer.cpp:35
IntelCoreServer::IPIVector
static const uint IPIVector
Inter-Processor-Interrupt vector number.
Definition: IntelCoreServer.h:47
IntelCoreServer::IntelCoreServer
IntelCoreServer()
Class constructor function.
Definition: IntelCoreServer.cpp:29
IntelAPIC
Intel Advanced Programmable Interrupt Controller (APIC)
Definition: IntelAPIC.h:45
coreId
u8 coreId
Definition: IntelACPI.h:64
IntelCoreServer::bootCore
virtual Core::Result bootCore(uint coreId, CoreInfo *info)
Boot a processor core.
Definition: IntelCoreServer.cpp:49