libmeinos: +llist2
[meinos.git] / apps / include / cdi / bios.h
blob460b09883af63961e4b971b87277e2903fa2ca9e
1 /*
2 meinOS - A unix-like x86 microkernel operating system
3 Copyright (C) 2008 Janosch Gräf <janosch.graef@gmx.net>
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #ifndef _CDI_BIOS_H_
20 #define _CDI_BIOS_H_
22 #include <stdint.h>
24 #include "cdi/lists.h"
26 struct cdi_bios_registers {
27 uint16_t ax;
28 uint16_t bx;
29 uint16_t cx;
30 uint16_t dx;
31 uint16_t si;
32 uint16_t di;
33 uint16_t ds;
34 uint16_t es;
37 /**
38 * Struktur zum Zugriff auf Speicherbereiche des 16bit-Prozesses
40 struct cdi_bios_memory {
41 /**
42 * Virtuelle Addresse im Speicher des 16bit-Prozesses. Muss unterhalb von
43 * 0xC0000 liegen.
45 uintptr_t dest;
47 /**
48 * Pointer auf reservierten Speicher für die Daten des Speicherbereichs. Wird
49 * beim Start des Tasks zum Initialisieren des Bereichs benutzt und erhaelt
50 * auch wieder die Daten nach dem BIOS-Aufruf.
52 void *src;
54 /**
55 * Laenge des Speicherbereichs
57 uint16_t size;
60 /**
61 * Ruft einen BIOS-Interrupt auf.
63 * @param interrupt Nummer des BIOS-Interrupts
64 * @param registers Pointer auf eine Register-Struktur. Diese wird beim Aufruf
65 * in die Register des Tasks geladen und bei Beendigung des Tasks wieder mit den
66 * Werten des Tasks gefuellt.
67 * @param memory Speicherbereiche, die in den Bios-Task kopiert und bei Beendigung
68 * des Tasks wieder zurueck kopiert werden sollen. Die Liste ist vom Typ struct
69 * cdi_bios_memory.
70 * @return 0, wenn der Aufruf erfolgreich war, -1 bei Fehlern
72 int cdi_bios_int10(struct cdi_bios_registers *registers,cdi_list_t memory);
74 #endif