Get it all building
This commit is contained in:
parent
30823ca314
commit
2b41a47bcd
2 changed files with 16 additions and 13 deletions
|
@ -2,6 +2,9 @@
|
|||
# vim: set ft=python:
|
||||
# Eryn Wells <eryn@erynwells.me>
|
||||
|
||||
import os
|
||||
import os.path
|
||||
|
||||
files = [
|
||||
'boot.s',
|
||||
'crti.s',
|
||||
|
@ -9,17 +12,17 @@ files = [
|
|||
'main.cc',
|
||||
]
|
||||
|
||||
Replace(AS='i686-elf-as',
|
||||
CC='clang',
|
||||
CXX='clang++',
|
||||
LINK='i686-elf-ld')
|
||||
Append(CFLAGS='-std=gnu99',
|
||||
CCFLAGS='-target i686-pc-elf -ffreestanding',
|
||||
CXXFLAGS='-std=gnu++11 -fno-exceptions -fno-rtti',
|
||||
LINKFLAGS='-nostdlib')
|
||||
toolchain_bin = Dir(os.environ['POLKA_TOOLCHAIN']).Dir('bin')
|
||||
Replace(AS=toolchain_bin.File('i686-elf-as'),
|
||||
CC=toolchain_bin.File('i686-elf-gcc'),
|
||||
CXX=toolchain_bin.File('i686-elf-g++'),
|
||||
LINK=toolchain_bin.File('i686-elf-ld'))
|
||||
Append(CCFLAGS='-ffreestanding',
|
||||
CPPDEFINES='__polka',
|
||||
CXXFLAGS='-fno-exceptions -fno-rtti',
|
||||
LINKFLAGS='-nostdlib -lgcc')
|
||||
|
||||
linker_script = File('linker.ld')
|
||||
|
||||
kernel = Program('polka.bin', files, LINKFLAGS='-T {}'.format(linker_script.path))
|
||||
Depends(kernel, linker_script)
|
||||
Alias('kernel', kernel)
|
||||
|
@ -28,8 +31,8 @@ img_dir = Dir('img')
|
|||
grub_cfg = File('grub.cfg')
|
||||
image_dir = Command(img_dir, kernel, [
|
||||
Mkdir(img_dir.Dir('boot/grub')),
|
||||
Copy(img_dir.File('boot/${SOURCE.file}'), '$SOURCE'),
|
||||
Copy(img_dir.Dir('boot/grub'), grub_cfg)
|
||||
Copy(os.path.join(img_dir.Dir('boot').path, '${SOURCE.file}'), '$SOURCE'),
|
||||
Copy(img_dir.Dir('boot/grub'), grub_cfg.srcnode())
|
||||
])
|
||||
Clean(image_dir, img_dir)
|
||||
image = Command('polka.img', image_dir, [
|
||||
|
|
|
@ -1,3 +1,3 @@
|
|||
menuentry "paisley" {
|
||||
multiboot /boot/paisley.bin
|
||||
menuentry "polka" {
|
||||
multiboot /boot/polka.bin
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue