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"
|
* `gamarjoba_munde` - x86-64 linux binary that prints the text "Gamarjoba, Munde"
|
||||||
* `baremetal_gamarjoba` - bare-metal x86 program run with QEMU
|
* `baremetal_gamarjoba` - bare-metal x86 program run with QEMU
|
||||||
* `keyboard` - reads keycode information from keyboard. Also uses both Rust and C includes.
|
* `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
|
# Useful links
|
||||||
|
|
||||||
|
|||||||
13
justfile
13
justfile
@@ -35,3 +35,16 @@ run_keyboard: build_keyboard
|
|||||||
|
|
||||||
run_terminal_keyboard: build_keyboard
|
run_terminal_keyboard: build_keyboard
|
||||||
qemu-system-i386 -display curses -kernel keyboard/keyboard_kernel
|
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
|
extern rust_entry
|
||||||
|
|
||||||
@@ -12,8 +12,8 @@ section .data
|
|||||||
section .text
|
section .text
|
||||||
global boot
|
global boot
|
||||||
|
|
||||||
%include "multiboot_header.asm"
|
%include "../common/multiboot_header.asm"
|
||||||
%include "x86_vram_functions.asm"
|
%include "../common/x86_vram_functions.asm"
|
||||||
|
|
||||||
boot:
|
boot:
|
||||||
mov esp, stack + 0x100
|
mov esp, stack + 0x100
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
#![feature(lang_items, start, no_core)]
|
#![feature(lang_items, no_core)]
|
||||||
#![no_core]
|
#![no_core]
|
||||||
#![no_main]
|
#![no_main]
|
||||||
|
|
||||||
@@ -10,10 +10,18 @@ extern fn eh_personality() {}
|
|||||||
fn panic_fmt() -> ! { loop {} }
|
fn panic_fmt() -> ! { loop {} }
|
||||||
|
|
||||||
#[lang = "panic"]
|
#[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"]
|
#[lang = "sized"]
|
||||||
trait Sized {}
|
pub trait Sized {}
|
||||||
|
|
||||||
#[lang = "copy"]
|
#[lang = "copy"]
|
||||||
trait Copy {}
|
trait Copy {}
|
||||||
@@ -21,7 +29,7 @@ trait Copy {}
|
|||||||
#[lang = "add"]
|
#[lang = "add"]
|
||||||
pub trait Add<RHS=Self> {
|
pub trait Add<RHS=Self> {
|
||||||
type Output;
|
type Output;
|
||||||
fn add(self, rhs: RHS) -> Self::Output;
|
fn add(self, _rhs: RHS) -> Self::Output;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this can be bogus, apparently? */
|
/* this can be bogus, apparently? */
|
||||||
@@ -33,12 +41,12 @@ impl Add for usize {
|
|||||||
#[lang = "mul"]
|
#[lang = "mul"]
|
||||||
pub trait Mul<RHS = Self> {
|
pub trait Mul<RHS = Self> {
|
||||||
type Output;
|
type Output;
|
||||||
fn mul(self, rhs: RHS) -> Self::Output;
|
fn mul(self, _rhs: RHS) -> Self::Output;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Mul for usize {
|
impl Mul for usize {
|
||||||
type Output = 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;
|
const X86_COLS: usize = 80;
|
||||||
|
#[allow(dead_code)]
|
||||||
const X86_ROWS: usize = 25;
|
const X86_ROWS: usize = 25;
|
||||||
const VRAM_OFFSET: usize = 0xb8000;
|
const VRAM_OFFSET: usize = 0xb8000;
|
||||||
|
|
||||||
Reference in New Issue
Block a user