Добавление модуля "Мелодия"
Модуль воспроизводит мелодию при загрузке используя PC Speaker
This commit is contained in:
parent
8e59115c1e
commit
0eef3837f6
2
.gitignore
vendored
2
.gitignore
vendored
@ -11,3 +11,5 @@ modules/helloworld/helloworld.elf
|
||||
modules/com/com.elf
|
||||
modules/helloworld/hello.o
|
||||
modules/helloworld/hello.so
|
||||
*.so
|
||||
*.o
|
||||
|
3
.vscode/settings.json
vendored
3
.vscode/settings.json
vendored
@ -11,6 +11,7 @@
|
||||
"tool.h": "c",
|
||||
"sys.h": "c",
|
||||
"arch.h": "c",
|
||||
"fb.h": "c"
|
||||
"fb.h": "c",
|
||||
"system.h": "c"
|
||||
}
|
||||
}
|
4
build.sh
4
build.sh
@ -1,2 +1,6 @@
|
||||
#!/bin/sh
|
||||
cd modules/
|
||||
cd helloworld/ && ./build.sh && cd ..
|
||||
cd music/ && ./build.sh && cd ..
|
||||
cd ..
|
||||
python3 pbuild.py
|
@ -15,6 +15,9 @@ BACKGROUND_PATH=boot:///boot.tga
|
||||
KASLR=no
|
||||
KERNEL_PATH=boot:///kernel.elf
|
||||
|
||||
MODULE_PATH=boot:///mod/music.so
|
||||
MODULE_CMDLINE=[MOD]music.so
|
||||
|
||||
MODULE_PATH=boot:///mod/hello.so
|
||||
MODULE_CMDLINE=[MOD]hello.so
|
||||
|
||||
|
@ -1,3 +1,3 @@
|
||||
#define VERSION_MAJOR 0
|
||||
#define VERSION_MINOR 1
|
||||
#define VERSION_BUILD 254
|
||||
#define VERSION_BUILD 279
|
||||
|
@ -83,13 +83,14 @@ void mod_init( ) {
|
||||
}
|
||||
if (!tool_starts_with(module_ptr->cmdline, "[MOD]")) { continue; }
|
||||
modules_count++;
|
||||
module_info_t *(*module_init)(env_t *env) =
|
||||
uint64_t (*module_init)(env_t * env) =
|
||||
(module_info_t * (*)(env_t * env)) elf_entry(module_ptr->address, module_ptr->size);
|
||||
|
||||
fb_printf("\t->Точка входа: 0x%x\n", module_init);
|
||||
|
||||
// module_info_t *ret = module_init(&main_env);
|
||||
uint64_t ret = module_init(&main_env);
|
||||
|
||||
fb_printf("Инициализированно с кодом: %u\n", ret);
|
||||
// fb_printf("Инициализированно с кодом: %u\n", ret->err_code);
|
||||
// fb_printf("Сообщение из модуля: %s\n\n", ret->message);
|
||||
}
|
||||
|
@ -6,6 +6,8 @@
|
||||
*
|
||||
*/
|
||||
|
||||
void task_init( ) {}
|
||||
|
||||
void task_new_thread( ) {
|
||||
return;
|
||||
}
|
||||
|
@ -2,5 +2,5 @@
|
||||
echo "Название: Hello world"
|
||||
echo "Лицензия: Публичное достояние"
|
||||
gcc -I../../modlib -O0 -finput-charset=UTF-8 -fexec-charset=cp1251 -c -fPIC -nostdlib main.c -o hello.o
|
||||
gcc -fPIC -shared -nostdlib hello.o -o hello.so -Wl,--entry=_start
|
||||
gcc -Wl,--entry=init -fPIC -shared -nostdlib hello.o -o hello.so
|
||||
echo "Сборка завершена, файл: hello.so"
|
||||
|
@ -5,8 +5,7 @@ const char message[] = "Привет из модуля!";
|
||||
module_info_t info = {
|
||||
.name = (char *)&name, .message = (char *)&message, .err_code = 2023, .func_count = 1
|
||||
};
|
||||
env_t *env;
|
||||
|
||||
module_info_t *_start(env_t *env) {
|
||||
return &info;
|
||||
uint64_t init(env_t *env) {
|
||||
return info.err_code;
|
||||
}
|
6
modules/music/build.sh
Normal file
6
modules/music/build.sh
Normal file
@ -0,0 +1,6 @@
|
||||
#/bin/sh
|
||||
echo "Название: Мелодия из тетриса"
|
||||
echo "Лицензия: Публичное достояние"
|
||||
gcc -I../../modlib -O0 -finput-charset=UTF-8 -fexec-charset=cp1251 -c -fPIC -nostdlib main.c -o music.o
|
||||
gcc -Wl,--entry=init -fPIC -shared -nostdlib music.o -o music.so
|
||||
echo "Сборка завершена, файл: music.so"
|
42
modules/music/main.c
Normal file
42
modules/music/main.c
Normal file
@ -0,0 +1,42 @@
|
||||
#include <system.h>
|
||||
|
||||
static inline void outb(uint16_t port, uint8_t val) {
|
||||
asm volatile("outb %0, %1" : : "a"(val), "Nd"(port));
|
||||
}
|
||||
|
||||
static inline uint8_t inb(uint16_t port) {
|
||||
uint8_t ret;
|
||||
asm volatile("inb %1, %0" : "=a"(ret) : "Nd"(port));
|
||||
return ret;
|
||||
}
|
||||
|
||||
static inline void usleep(uint64_t ticks) {
|
||||
for (uint64_t i = 0; i < ticks * 100; i++) { asm volatile("pause"); }
|
||||
}
|
||||
|
||||
|
||||
static inline void play_sound(unsigned int frequency) {
|
||||
}
|
||||
|
||||
int init(env_t *env) {
|
||||
// Массив с нотами
|
||||
unsigned int tetris_notes[] = {0};
|
||||
|
||||
// Расчет количества нот в мелодии
|
||||
int num_notes = sizeof(tetris_notes) / sizeof(tetris_notes[0]);
|
||||
|
||||
// Начальное значение для подсчета времени
|
||||
int note_duration = 1000000; // 1 секунда
|
||||
|
||||
// Зацикленное воспроизведение мелодии в течение минуты
|
||||
for (int i = 0; i < num_notes; i++) {
|
||||
// Воспроизведение ноты с заданным временем
|
||||
play_sound(tetris_notes[i]);
|
||||
usleep(note_duration);
|
||||
|
||||
// Уменьшение времени для следующей ноты
|
||||
note_duration -= note_duration / 24; // Уменьшение на 1/24 каждый раз
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
@ -135,7 +135,7 @@ def create_hdd(IMAGE_NAME):
|
||||
subprocess.run(["mcopy", "-i", IMAGE_NAME+".hdd@@1M",
|
||||
"kernel.elf", "configs/limine.cfg", "limine/limine-bios.sys", "::/"])
|
||||
subprocess.run(["mcopy", "-i", IMAGE_NAME+".hdd@@1M",
|
||||
"modules/com/com.elf", "modules/helloworld/hello.so", "::/mod"])
|
||||
"modules/music/music.so", "modules/helloworld/hello.so", "::/mod"])
|
||||
subprocess.run(["mcopy", "-i", IMAGE_NAME+".hdd@@1M",
|
||||
"limine/BOOTX64.EFI", "limine/BOOTIA32.EFI", "::/EFI/BOOT"])
|
||||
subprocess.run(["mcopy", "-i", IMAGE_NAME+".hdd@@1M",
|
||||
@ -155,7 +155,7 @@ def create_iso(IMAGE_NAME):
|
||||
subprocess.run(["mkdir", "-p", "iso_root/EFI/BOOT"])
|
||||
subprocess.run(["mkdir", "-p", "iso_root/mod"])
|
||||
subprocess.run(["cp", "-v", "modules/helloworld/hello.so", "iso_root/mod/"])
|
||||
subprocess.run(["cp", "-v", "modules/com/com.elf", "iso_root/mod/"])
|
||||
subprocess.run(["cp", "-v", "modules/music/music.so", "iso_root/mod/"])
|
||||
subprocess.run(["cp", "-v", "limine/BOOTX64.EFI", "iso_root/EFI/BOOT/"])
|
||||
subprocess.run(["cp", "-v", "limine/BOOTIA32.EFI", "iso_root/EFI/BOOT/"])
|
||||
subprocess.run(["xorriso", "-as", "mkisofs", "-b", "limine-bios-cd.bin",
|
||||
@ -179,7 +179,6 @@ if __name__ == "__main__":
|
||||
check_limine()
|
||||
check_tools()
|
||||
major, minor, build = version_build()
|
||||
os.system("cd modules/helloworld/ && ./build.sh")
|
||||
compile_all()
|
||||
create_iso("bmosp")
|
||||
create_hdd("bmosp")
|
||||
|
2
run.sh
2
run.sh
@ -1,5 +1,5 @@
|
||||
#!/bin/sh
|
||||
qemu-system-x86_64 -name "БМПОС" -cpu max -m 1G -smp 1 -bios ovmf/OVMF.fd -hda bmosp.hdd --no-reboot
|
||||
qemu-system-x86_64 -name "БМПОС" -cpu max -m 1G -smp 1 -hda bmosp.hdd --no-reboot
|
||||
#qemu-system-x86_64 -name "БМПОС" -cpu max -m 1G -smp 1 -bios ovmf/OVMF.fd -hda bmosp.hdd -d int --no-reboot
|
||||
#qemu-system-x86_64 -name "БМПОС" -cpu host -m 1G -smp 1 -bios ovmf/OVMF.fd -hda bmosp.hdd
|
||||
#qemu-system-x86_64 -name "БМПОС" -enable-kvm -cpu host -m 6G -smp 1 -bios ovmf/OVMF.fd -hda bmosp.hdd -d int --no-reboot
|
Loading…
Reference in New Issue
Block a user