Add display
This commit is contained in:
parent
c9d338715d
commit
234fb64999
3
Makefile
3
Makefile
|
@ -11,9 +11,10 @@ ifeq ($(UNAME),Darwin)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
QEMUFLAGS+=-smp 4 -machine q35
|
QEMUFLAGS+=-smp 4 -machine q35
|
||||||
QEMUFLAGS+=-serial mon:stdio -nographic
|
QEMUFLAGS+=-serial mon:stdio
|
||||||
QEMUFLAGS+=-d guest_errors
|
QEMUFLAGS+=-d guest_errors
|
||||||
#,int,pcall
|
#,int,pcall
|
||||||
|
#-nographic
|
||||||
#-device intel-iommu
|
#-device intel-iommu
|
||||||
|
|
||||||
|
|
||||||
|
|
91
arch/x86_64/src/display.rs
Normal file
91
arch/x86_64/src/display.rs
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
use core::slice;
|
||||||
|
use spin::Mutex;
|
||||||
|
|
||||||
|
use externs::memset;
|
||||||
|
use memory::Frame;
|
||||||
|
use paging::{ActivePageTable, PhysicalAddress, entry};
|
||||||
|
|
||||||
|
/// The info of the VBE mode
|
||||||
|
#[derive(Copy, Clone, Default, Debug)]
|
||||||
|
#[repr(packed)]
|
||||||
|
pub struct VBEModeInfo {
|
||||||
|
attributes: u16,
|
||||||
|
win_a: u8,
|
||||||
|
win_b: u8,
|
||||||
|
granularity: u16,
|
||||||
|
winsize: u16,
|
||||||
|
segment_a: u16,
|
||||||
|
segment_b: u16,
|
||||||
|
winfuncptr: u32,
|
||||||
|
bytesperscanline: u16,
|
||||||
|
pub xresolution: u16,
|
||||||
|
pub yresolution: u16,
|
||||||
|
xcharsize: u8,
|
||||||
|
ycharsize: u8,
|
||||||
|
numberofplanes: u8,
|
||||||
|
bitsperpixel: u8,
|
||||||
|
numberofbanks: u8,
|
||||||
|
memorymodel: u8,
|
||||||
|
banksize: u8,
|
||||||
|
numberofimagepages: u8,
|
||||||
|
unused: u8,
|
||||||
|
redmasksize: u8,
|
||||||
|
redfieldposition: u8,
|
||||||
|
greenmasksize: u8,
|
||||||
|
greenfieldposition: u8,
|
||||||
|
bluemasksize: u8,
|
||||||
|
bluefieldposition: u8,
|
||||||
|
rsvdmasksize: u8,
|
||||||
|
rsvdfieldposition: u8,
|
||||||
|
directcolormodeinfo: u8,
|
||||||
|
physbaseptr: u32,
|
||||||
|
offscreenmemoryoffset: u32,
|
||||||
|
offscreenmemsize: u16,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub static DISPLAY: Mutex<Option<Display>> = Mutex::new(None);
|
||||||
|
|
||||||
|
pub unsafe fn init(active_table: &mut ActivePageTable) {
|
||||||
|
active_table.identity_map(Frame::containing_address(PhysicalAddress::new(0x5200)), entry::PRESENT | entry::NO_EXECUTE);
|
||||||
|
|
||||||
|
let mode_info = &*(0x5200 as *const VBEModeInfo);
|
||||||
|
if mode_info.physbaseptr > 0 {
|
||||||
|
let width = mode_info.xresolution as usize;
|
||||||
|
let height = mode_info.yresolution as usize;
|
||||||
|
let start = mode_info.physbaseptr as usize;
|
||||||
|
let size = width * height;
|
||||||
|
|
||||||
|
{
|
||||||
|
let start_frame = Frame::containing_address(PhysicalAddress::new(start));
|
||||||
|
let end_frame = Frame::containing_address(PhysicalAddress::new(start + size * 4 - 1));
|
||||||
|
for frame in Frame::range_inclusive(start_frame, end_frame) {
|
||||||
|
active_table.identity_map(frame, entry::PRESENT | entry::WRITABLE | entry::NO_EXECUTE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for i in 0..size {
|
||||||
|
let c = ((i * 256)/size) as u32 & 0xFF;
|
||||||
|
*(start as *mut u32).offset(i as isize) = (c << 16) | (c << 8) | c;
|
||||||
|
}
|
||||||
|
//memset(start as *mut u8, 0, size * 4);
|
||||||
|
|
||||||
|
*DISPLAY.lock() = Some(Display::new(width, height, slice::from_raw_parts_mut(start as *mut u32, size)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// A display
|
||||||
|
pub struct Display {
|
||||||
|
pub width: usize,
|
||||||
|
pub height: usize,
|
||||||
|
pub data: &'static mut [u32],
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Display {
|
||||||
|
fn new(width: usize, height: usize, data: &'static mut [u32]) -> Self {
|
||||||
|
Display {
|
||||||
|
width: width,
|
||||||
|
height: height,
|
||||||
|
data: data,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -124,6 +124,9 @@ pub mod acpi;
|
||||||
/// Context switching
|
/// Context switching
|
||||||
pub mod context;
|
pub mod context;
|
||||||
|
|
||||||
|
/// Display handling
|
||||||
|
pub mod display;
|
||||||
|
|
||||||
/// Memcpy, memmove, etc.
|
/// Memcpy, memmove, etc.
|
||||||
pub mod externs;
|
pub mod externs;
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ use core::sync::atomic::{AtomicBool, ATOMIC_BOOL_INIT, AtomicUsize, ATOMIC_USIZE
|
||||||
|
|
||||||
use acpi;
|
use acpi;
|
||||||
use allocator::{HEAP_START, HEAP_SIZE};
|
use allocator::{HEAP_START, HEAP_SIZE};
|
||||||
|
use display;
|
||||||
use externs::memset;
|
use externs::memset;
|
||||||
use gdt;
|
use gdt;
|
||||||
use idt;
|
use idt;
|
||||||
|
@ -90,6 +91,9 @@ pub unsafe extern fn kstart() -> ! {
|
||||||
assert_eq!(TDATA_TEST_NONZERO, 0xFFFFFFFFFFFFFFFE);
|
assert_eq!(TDATA_TEST_NONZERO, 0xFFFFFFFFFFFFFFFE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Initialize display
|
||||||
|
display::init(&mut active_table);
|
||||||
|
|
||||||
// Reset AP variables
|
// Reset AP variables
|
||||||
AP_COUNT.store(0, Ordering::SeqCst);
|
AP_COUNT.store(0, Ordering::SeqCst);
|
||||||
BSP_READY.store(false, Ordering::SeqCst);
|
BSP_READY.store(false, Ordering::SeqCst);
|
||||||
|
|
Loading…
Reference in a new issue