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:
Greg Shuflin
2022-01-29 23:15:39 -08:00
parent c01cbbc458
commit faaadcf475
4 changed files with 32 additions and 9 deletions

View File

@@ -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

View File

@@ -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

View File

@@ -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

View File

@@ -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;