Friedrich-Alexander-Universität Erlangen-Nürnberg  /   Technische Fakultät  /   Department Informatik

Übungen zu BS - Dokumentation Aufgabe 3 (WS 2015/16)

Abstraktion des in der CPU integrierten local APICs. Mehr ...

#include <lapic.h>

Öffentliche Methoden

 LAPIC ()
 Konstruktor. Mehr ...
 
void init ()
 Initalisiert den local APIC der jeweiligen CPU. Mehr ...
 
void ackIRQ ()
 Signalisiert EOI(End of interrupt) Mehr ...
 
uint8_t getLAPICID ()
 Liefert die ID des in der aktuellen CPU integrieren APICs. Mehr ...
 
uint8_t getCPUID ()
 Liefert eindeutige Identifikation der jeweiligen CPU. Mehr ...
 
uint8_t getVersion ()
 Liefert Versionsnummer des local APICs. Mehr ...
 
void setLogicalLAPICID (uint8_t id)
 Setzt die local APIC ID im LDR Register. Mehr ...
 
void sendIPI (uint8_t destination, struct ICR_L data)
 Verschickt einen IPI an die adressieren CPU(s) Mehr ...
 
bool isIPIDelivered ()
 Kehrt mit true zurück, falls zum Zeitpunkt des Aufrufs kein IPI aktiv ist. Mehr ...
 
bool isExternalAPIC ()
 Ist dieser lAPIC extern? Mehr ...
 
bool isLocalAPIC ()
 Ist dieser lAPIC intern? Mehr ...
 
bool isPentium4 ()
 Ist diese CPU ein PentiumIV? Mehr ...
 
uint32_t timer_ticks ()
 Ermittelt die Frequenz des LAPIC-Timers. Mehr ...
 
uint8_t timer_div (uint8_t div)
 Berechnet die Bitmaske für den Teiler des LAPIC-Timers. Mehr ...
 
void setTimer (uint32_t counter, uint8_t divide, uint8_t vector, bool periodic, bool masked=false)
 Stellt den LAPIC-Timer ein. Mehr ...
 

Statische öffentliche Attribute

static uint32_t LAPIC_BASE = 0xfee00000
 Basisadresse der local APIC-Register. Mehr ...
 

Ausführliche Beschreibung

Abstraktion des in der CPU integrierten local APICs.

In modernen PCs besitzt jede CPU einen sogenannten "local APIC". Dieser vermittelt zwischen dem I/O APIC, an den die externen Interruptquellen angeschlossen sind, und der CPU. Interruptnachrichten, welche den lokalen APIC von aussen erreichen, werden an den zugeordneten Prozessorkern weitergereicht, um dort die Interruptbearbeitung anzustoßen.

In Multiprozessorsystem ist es darüberhinaus noch möglich mit Hilfe des lokalen APICs Nachrichten in Form von Interprozessorinterrupts an andere CPUs zu schicken bzw. zu empfangen.

Beschreibung der Konstruktoren und Destruktoren

LAPIC::LAPIC ( )
inline

Konstruktor.

Dokumentation der Elementfunktionen

void LAPIC::ackIRQ ( )

Signalisiert EOI(End of interrupt)

Teilt dem local APIC mit, dass die aktuelle Interruptbehandlung abgeschlossen ist. Diese Funktion muss gegen Ende der Unterbrechungsbehandlung aufgerufen werden und zwar bevor prozessorseitig die Unterbrechungen wieder zugelassen werden.

uint8_t LAPIC::getCPUID ( )
inline

Liefert eindeutige Identifikation der jeweiligen CPU.

Rückgabe
lAPIC ID als Identifikation der CPU
uint8_t LAPIC::getLAPICID ( )

Liefert die ID des in der aktuellen CPU integrieren APICs.

Rückgabe
lAPIC ID
uint8_t LAPIC::getVersion ( )

Liefert Versionsnummer des local APICs.

Rückgabe
Versionsnummer
void LAPIC::init ( )

Initalisiert den local APIC der jeweiligen CPU.

bool LAPIC::isExternalAPIC ( )

Ist dieser lAPIC extern?

bool LAPIC::isIPIDelivered ( )

Kehrt mit true zurück, falls zum Zeitpunkt des Aufrufs kein IPI aktiv ist.

Rückgabe
false, falls der letzte gesendete IPI noch nicht vom Zielprozessor akzeptiert wurde
bool LAPIC::isLocalAPIC ( )

Ist dieser lAPIC intern?

bool LAPIC::isPentium4 ( )

Ist diese CPU ein PentiumIV?

void LAPIC::sendIPI ( uint8_t  destination,
struct ICR_L  data 
)

Verschickt einen IPI an die adressieren CPU(s)

Zum schicken von "normalen" IPIs sind folgende Einstellung im struct ICR_L notwerndig:

  • destination_shorthand: 0
  • level : 1 (Kein Init-IPI)
  • destination_mode : 1 (Logical Destination Mode)
  • delivery_mode : 0 (Fixed Delivery Mode)
  • vector : Anwendungsspezifisch
Parameter
destinationMaske mit Zielcpu(s)
dataEinstellungen
void LAPIC::setLogicalLAPICID ( uint8_t  id)

Setzt die local APIC ID im LDR Register.

Parameter
idAPIC ID
void LAPIC::setTimer ( uint32_t  counter,
uint8_t  divide,
uint8_t  vector,
bool  periodic,
bool  masked = false 
)

Stellt den LAPIC-Timer ein.

Parameter
counterStartwert des Zählers, der bei jedem Bus-Takt dekrementiert wird.
divideZweipotenz durch den der Bustakt geteilt werden soll (in numerischer Form, siehe LAPIC::timer_div zur Umrechnung)
vectorNummer des auszulösenden Interrupts.
periodicGibt an, ob die Unterbrechung periodisch kommen soll
maskedUnterdrückt Unterbrechungen bei Zählerablauf
uint8_t LAPIC::timer_div ( uint8_t  div)

Berechnet die Bitmaske für den Teiler des LAPIC-Timers.

Parameter
divTeiler, Möglichkeiten: 1, 2, 4, 8, 16, 32, 64, 128
Rückgabe
Bitmaske für LAPIC::setTimer() oder 0xff falls div ungültig ist.
uint32_t LAPIC::timer_ticks ( )

Ermittelt die Frequenz des LAPIC-Timers.

Rückgabe
Anzahl der Timerticks pro Millisekunde

Dokumentation der Datenelemente

uint32_t LAPIC::LAPIC_BASE = 0xfee00000
static

Basisadresse der local APIC-Register.


Die Dokumentation für diese Klasse wurde erzeugt aufgrund der Dateien: