Move lightshow into dir
Note: this currently has a rustc compiler panic trying to use the `#[no_core]` attribute, which seems poorly supported
This commit is contained in:
@@ -8,6 +8,7 @@ This repo contains the following executables:
|
||||
* `gamarjoba_munde` - x86-64 linux binary that prints the text "Gamarjoba, Munde"
|
||||
* `baremetal_gamarjoba` - bare-metal x86 program run with QEMU
|
||||
* `keyboard` - reads keycode information from keyboard. Also uses both Rust and C includes.
|
||||
* `lightshow` - NOTE: Broken - an attempt at a substantial #[no_core] rust object file, currently crashes rustc
|
||||
|
||||
# Useful links
|
||||
|
||||
|
||||
13
justfile
13
justfile
@@ -35,3 +35,16 @@ run_keyboard: build_keyboard
|
||||
|
||||
run_terminal_keyboard: build_keyboard
|
||||
qemu-system-i386 -display curses -kernel keyboard/keyboard_kernel
|
||||
|
||||
build_lightshow:
|
||||
#!/usr/bin/env bash
|
||||
cd lightshow
|
||||
rustc --emit obj -o lightshow_rust.o --target i686-unknown-linux-gnu -g lightshow.rs
|
||||
nasm -f elf32 -i ../common -g lightshow.asm
|
||||
ld -m elf_i386 -nostdlib -T ../common/linker.ld lightshow.o lightshow_rust.o -o lightshow
|
||||
|
||||
run_lightshow: build_lightshow
|
||||
qemu-system-i386 -kernel lightshow
|
||||
|
||||
debug_lightshow: build_lightshow
|
||||
qemu-system-i386 -kernel lightshow -gdb tcp::9999 -S
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
%include "x86_vram.asm"
|
||||
%include "../common/x86_vram.asm"
|
||||
|
||||
extern rust_entry
|
||||
|
||||
@@ -12,8 +12,8 @@ section .data
|
||||
section .text
|
||||
global boot
|
||||
|
||||
%include "multiboot_header.asm"
|
||||
%include "x86_vram_functions.asm"
|
||||
%include "../common/multiboot_header.asm"
|
||||
%include "../common/x86_vram_functions.asm"
|
||||
|
||||
boot:
|
||||
mov esp, stack + 0x100
|
||||
@@ -1,5 +1,5 @@
|
||||
|
||||
#![feature(lang_items, start, no_core)]
|
||||
#![feature(lang_items, no_core)]
|
||||
#![no_core]
|
||||
#![no_main]
|
||||
|
||||
@@ -10,10 +10,18 @@ extern fn eh_personality() {}
|
||||
fn panic_fmt() -> ! { loop {} }
|
||||
|
||||
#[lang = "panic"]
|
||||
pub fn panic(expr_file_line: &(&'static str, &'static str, u32)) -> ! { panic_fmt() }
|
||||
pub fn panic(_expr_file_line: &(&'static str, &'static str, u32)) -> ! { panic_fmt() }
|
||||
|
||||
#[lang = "panic_location"]
|
||||
struct Location<'a> {
|
||||
_file: &'a str,
|
||||
_line: u32,
|
||||
_col: u32,
|
||||
}
|
||||
|
||||
|
||||
#[lang = "sized"]
|
||||
trait Sized {}
|
||||
pub trait Sized {}
|
||||
|
||||
#[lang = "copy"]
|
||||
trait Copy {}
|
||||
@@ -21,7 +29,7 @@ trait Copy {}
|
||||
#[lang = "add"]
|
||||
pub trait Add<RHS=Self> {
|
||||
type Output;
|
||||
fn add(self, rhs: RHS) -> Self::Output;
|
||||
fn add(self, _rhs: RHS) -> Self::Output;
|
||||
}
|
||||
|
||||
/* this can be bogus, apparently? */
|
||||
@@ -33,12 +41,12 @@ impl Add for usize {
|
||||
#[lang = "mul"]
|
||||
pub trait Mul<RHS = Self> {
|
||||
type Output;
|
||||
fn mul(self, rhs: RHS) -> Self::Output;
|
||||
fn mul(self, _rhs: RHS) -> Self::Output;
|
||||
}
|
||||
|
||||
impl Mul for usize {
|
||||
type Output = usize;
|
||||
fn mul(self, rhs: usize) -> usize { 1 }
|
||||
fn mul(self, _rhs: usize) -> usize { 1 }
|
||||
}
|
||||
|
||||
|
||||
@@ -54,6 +62,7 @@ pub extern fn rust_entry() {
|
||||
}
|
||||
|
||||
const X86_COLS: usize = 80;
|
||||
#[allow(dead_code)]
|
||||
const X86_ROWS: usize = 25;
|
||||
const VRAM_OFFSET: usize = 0xb8000;
|
||||
|
||||
Reference in New Issue
Block a user