aboutsummaryrefslogtreecommitdiff
path: root/src/kernel/system.h
blob: c7ed2fdb57d85ca79abd10e4c13d9651d574a14b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#ifndef MELVIX_SYSTEM_H
#define MELVIX_SYSTEM_H

/**
 * Initialize the basic features of the OS
 */
void init();

/**
 * The ASM registers as packed structure
 */
typedef struct __attribute__ ((packed)) {
    unsigned short di, si, bp, sp, bx, dx, cx, ax;
    unsigned short gs, fs, es, ds, eflags;
} regs16_t;

/**
 * Execute BIOS interrupts by switching to real mode
 * @param intnum The interrupt number (e.g. 0x10)
 * @param regs The ASM registers
 */
extern void int32(unsigned char intnum, regs16_t *regs);

/**
 * ASM segment:offset pointer
 */
struct far_ptr {
    union {
        uint32_t ptr;
        struct {
            uint16_t offset, segment;
        };
    };
} __attribute__ ((packed));

/**
 * Get offset from ASM segment:offset pointer
 */
static inline uint16_t get_offset(const volatile void *p) {
    return (uint16_t) (uintptr_t) p & 0x000F;
}

/**
 * Get segment from ASM segment:offset pointer
 */
static inline uint16_t get_segment(const volatile void *p) {
    return (uint16_t) (((uintptr_t) p) >> 4);
}

/**
 * Convert pointer to far_ptr
 * @param __ptr The ASM segment:offset pointer
 * @return The new far pointer
 */
static inline struct far_ptr FAR_PTR(void *__ptr) {
    struct far_ptr __fptr;
    __fptr.offset = get_offset(__ptr);
    __fptr.segment = get_segment(__ptr);
    return __fptr;
}

/**
 * Get pointer from ASM segment:offset far pointer
 * @param fptr The ASM far pointer
 * @return The normalized pointer
 */
static inline void *get_ptr(struct far_ptr fptr) {
    return (void *) (unsigned long) ((fptr.segment << 4) + fptr.offset);
}

#endif