mirror of
https://github.com/limine-bootloader/limine
synced 2025-01-22 04:22:05 +03:00
misc: Fixes for GCC 12 warnings; add extern prototypes for inline functions
This commit is contained in:
parent
d307056635
commit
80ae303ba8
2
.github/workflows/check.yml
vendored
2
.github/workflows/check.yml
vendored
@ -15,4 +15,4 @@ jobs:
|
|||||||
run: sudo apt-get update && sudo apt-get install git build-essential autoconf automake nasm curl mtools -y
|
run: sudo apt-get update && sudo apt-get install git build-essential autoconf automake nasm curl mtools -y
|
||||||
|
|
||||||
- name: Build the bootloader
|
- name: Build the bootloader
|
||||||
run: ./autogen.sh && make all
|
run: ./autogen.sh --enable-werror && make all
|
||||||
|
@ -37,9 +37,9 @@ test "x$LIMINE_OBJDUMP" = "x" && LIMINE_OBJDUMP='$(TOOLCHAIN)-objdump'
|
|||||||
AC_ARG_VAR(LIMINE_READELF, [Readelf command for Limine [$(TOOLCHAIN)-readelf]])
|
AC_ARG_VAR(LIMINE_READELF, [Readelf command for Limine [$(TOOLCHAIN)-readelf]])
|
||||||
test "x$LIMINE_READELF" = "x" && LIMINE_READELF='$(TOOLCHAIN)-readelf'
|
test "x$LIMINE_READELF" = "x" && LIMINE_READELF='$(TOOLCHAIN)-readelf'
|
||||||
|
|
||||||
werror_state="yes"
|
werror_state="no"
|
||||||
AC_ARG_ENABLE([werror],
|
AC_ARG_ENABLE([werror],
|
||||||
AS_HELP_STRING([--disable-werror], [do not treat warnings as errors]),
|
AS_HELP_STRING([--enable-werror], [treat warnings as errors]),
|
||||||
werror_state="$enableval")
|
werror_state="$enableval")
|
||||||
|
|
||||||
if test "$werror_state" = "yes"; then
|
if test "$werror_state" = "yes"; then
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#define EBDA ((size_t)(*((uint16_t *)0x40e)) * 16)
|
#define EBDA ((size_t)(*((volatile uint16_t *)0x40e)) * 16)
|
||||||
|
|
||||||
struct sdt {
|
struct sdt {
|
||||||
char signature[4];
|
char signature[4];
|
||||||
|
@ -10,6 +10,8 @@
|
|||||||
#include <lib/print.h>
|
#include <lib/print.h>
|
||||||
#include <mm/pmm.h>
|
#include <mm/pmm.h>
|
||||||
|
|
||||||
|
extern void reset_term(void);
|
||||||
|
|
||||||
bool early_term = false;
|
bool early_term = false;
|
||||||
|
|
||||||
void term_deinit(void) {
|
void term_deinit(void) {
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
|
|
||||||
#if bios == 1
|
#if bios == 1
|
||||||
|
|
||||||
__attribute__((noinline))
|
|
||||||
__attribute__((section(".realmode")))
|
__attribute__((section(".realmode")))
|
||||||
static void spinup(uint8_t drive) {
|
static void spinup(uint8_t drive) {
|
||||||
struct idtr real_mode_idt;
|
struct idtr real_mode_idt;
|
||||||
|
22
stage23/sys/cpu.c
Normal file
22
stage23/sys/cpu.c
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
#include <sys/cpu.h>
|
||||||
|
|
||||||
|
extern bool cpuid(uint32_t leaf, uint32_t subleaf,
|
||||||
|
uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx);
|
||||||
|
extern void outb(uint16_t port, uint8_t value);
|
||||||
|
extern void outw(uint16_t port, uint16_t value);
|
||||||
|
extern void outd(uint16_t port, uint32_t value);
|
||||||
|
extern uint8_t inb(uint16_t port);
|
||||||
|
extern uint16_t inw(uint16_t port);
|
||||||
|
extern uint32_t ind(uint16_t port);
|
||||||
|
extern void mmoutb(uintptr_t addr, uint8_t value);
|
||||||
|
extern void mmoutw(uintptr_t addr, uint16_t value);
|
||||||
|
extern void mmoutd(uintptr_t addr, uint32_t value);
|
||||||
|
extern void mmoutq(uintptr_t addr, uint64_t value);
|
||||||
|
extern uint8_t mminb(uintptr_t addr);
|
||||||
|
extern uint16_t mminw(uintptr_t addr);
|
||||||
|
extern uint32_t mmind(uintptr_t addr);
|
||||||
|
extern uint64_t mminq(uintptr_t addr);
|
||||||
|
extern uint64_t rdmsr(uint32_t msr);
|
||||||
|
extern void wrmsr(uint32_t msr, uint64_t value);
|
||||||
|
extern uint64_t rdtsc(void);
|
||||||
|
extern void delay(uint64_t cycles);
|
@ -4,13 +4,6 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
#define FLAT_PTR(PTR) (*((int(*)[])(PTR)))
|
|
||||||
|
|
||||||
#define BYTE_PTR(PTR) (*((uint8_t *)(PTR)))
|
|
||||||
#define WORD_PTR(PTR) (*((uint16_t *)(PTR)))
|
|
||||||
#define DWORD_PTR(PTR) (*((uint32_t *)(PTR)))
|
|
||||||
#define QWORD_PTR(PTR) (*((uint64_t *)(PTR)))
|
|
||||||
|
|
||||||
inline bool cpuid(uint32_t leaf, uint32_t subleaf,
|
inline bool cpuid(uint32_t leaf, uint32_t subleaf,
|
||||||
uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx) {
|
uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx) {
|
||||||
uint32_t cpuid_max;
|
uint32_t cpuid_max;
|
||||||
@ -58,46 +51,48 @@ inline uint32_t ind(uint16_t port) {
|
|||||||
|
|
||||||
inline void mmoutb(uintptr_t addr, uint8_t value) {
|
inline void mmoutb(uintptr_t addr, uint8_t value) {
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movb %1, %0"
|
"movb %1, (%0)"
|
||||||
: "=m" (BYTE_PTR(addr))
|
:
|
||||||
: "ir" (value)
|
: "r" (addr), "ir" (value)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void mmoutw(uintptr_t addr, uint16_t value) {
|
inline void mmoutw(uintptr_t addr, uint16_t value) {
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movw %1, %0"
|
"movw %1, (%0)"
|
||||||
: "=m" (WORD_PTR(addr))
|
:
|
||||||
: "ir" (value)
|
: "r" (addr), "ir" (value)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void mmoutd(uintptr_t addr, uint32_t value) {
|
inline void mmoutd(uintptr_t addr, uint32_t value) {
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movl %1, %0"
|
"movl %1, (%0)"
|
||||||
: "=m" (DWORD_PTR(addr))
|
:
|
||||||
: "ir" (value)
|
: "r" (addr), "ir" (value)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined (__x86_64__)
|
||||||
inline void mmoutq(uintptr_t addr, uint64_t value) {
|
inline void mmoutq(uintptr_t addr, uint64_t value) {
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movq %1, %0"
|
"movq %1, (%0)"
|
||||||
: "=m" (QWORD_PTR(addr))
|
:
|
||||||
: "ir" (value)
|
: "r" (addr), "r" (value)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
inline uint8_t mminb(uintptr_t addr) {
|
inline uint8_t mminb(uintptr_t addr) {
|
||||||
uint8_t ret;
|
uint8_t ret;
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movb %1, %0"
|
"movb (%1), %0"
|
||||||
: "=r" (ret)
|
: "=r" (ret)
|
||||||
: "m" (BYTE_PTR(addr))
|
: "r" (addr)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
return ret;
|
return ret;
|
||||||
@ -106,9 +101,9 @@ inline uint8_t mminb(uintptr_t addr) {
|
|||||||
inline uint16_t mminw(uintptr_t addr) {
|
inline uint16_t mminw(uintptr_t addr) {
|
||||||
uint16_t ret;
|
uint16_t ret;
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movw %1, %0"
|
"movw (%1), %0"
|
||||||
: "=r" (ret)
|
: "=r" (ret)
|
||||||
: "m" (WORD_PTR(addr))
|
: "r" (addr)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
return ret;
|
return ret;
|
||||||
@ -117,24 +112,26 @@ inline uint16_t mminw(uintptr_t addr) {
|
|||||||
inline uint32_t mmind(uintptr_t addr) {
|
inline uint32_t mmind(uintptr_t addr) {
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movl %1, %0"
|
"movl (%1), %0"
|
||||||
: "=r" (ret)
|
: "=r" (ret)
|
||||||
: "m" (DWORD_PTR(addr))
|
: "r" (addr)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined (__x86_64__)
|
||||||
inline uint64_t mminq(uintptr_t addr) {
|
inline uint64_t mminq(uintptr_t addr) {
|
||||||
uint64_t ret;
|
uint64_t ret;
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"movq %1, %0"
|
"movq (%1), %0"
|
||||||
: "=r" (ret)
|
: "=r" (ret)
|
||||||
: "m" (QWORD_PTR(addr))
|
: "r" (addr)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
inline uint64_t rdmsr(uint32_t msr) {
|
inline uint64_t rdmsr(uint32_t msr) {
|
||||||
uint32_t edx, eax;
|
uint32_t edx, eax;
|
||||||
|
Loading…
Reference in New Issue
Block a user