Use malloc in mini_core::allocate
This commit is contained in:
parent
4fbff29a4a
commit
4bca86c236
@ -51,6 +51,7 @@ unsafe impl Copy for isize {}
|
|||||||
unsafe impl Copy for char {}
|
unsafe impl Copy for char {}
|
||||||
unsafe impl<'a, T: ?Sized> Copy for &'a T {}
|
unsafe impl<'a, T: ?Sized> Copy for &'a T {}
|
||||||
unsafe impl<T: ?Sized> Copy for *const T {}
|
unsafe impl<T: ?Sized> Copy for *const T {}
|
||||||
|
unsafe impl<T: ?Sized> Copy for *mut T {}
|
||||||
|
|
||||||
#[lang = "sync"]
|
#[lang = "sync"]
|
||||||
pub unsafe trait Sync {}
|
pub unsafe trait Sync {}
|
||||||
@ -118,6 +119,14 @@ impl Add for u8 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Add for usize {
|
||||||
|
type Output = Self;
|
||||||
|
|
||||||
|
fn add(self, rhs: Self) -> Self {
|
||||||
|
self + rhs
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[lang = "sub"]
|
#[lang = "sub"]
|
||||||
pub trait Sub<RHS = Self> {
|
pub trait Sub<RHS = Self> {
|
||||||
type Output;
|
type Output;
|
||||||
@ -172,6 +181,33 @@ impl PartialEq for u8 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl PartialEq for u16 {
|
||||||
|
fn eq(&self, other: &u16) -> bool {
|
||||||
|
(*self) == (*other)
|
||||||
|
}
|
||||||
|
fn ne(&self, other: &u16) -> bool {
|
||||||
|
(*self) != (*other)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq for u32 {
|
||||||
|
fn eq(&self, other: &u32) -> bool {
|
||||||
|
(*self) == (*other)
|
||||||
|
}
|
||||||
|
fn ne(&self, other: &u32) -> bool {
|
||||||
|
(*self) != (*other)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq for usize {
|
||||||
|
fn eq(&self, other: &usize) -> bool {
|
||||||
|
(*self) == (*other)
|
||||||
|
}
|
||||||
|
fn ne(&self, other: &usize) -> bool {
|
||||||
|
(*self) != (*other)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl PartialEq for char {
|
impl PartialEq for char {
|
||||||
fn eq(&self, other: &char) -> bool {
|
fn eq(&self, other: &char) -> bool {
|
||||||
(*self) == (*other)
|
(*self) == (*other)
|
||||||
@ -230,7 +266,7 @@ pub trait FnMut<Args>: FnOnce<Args> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[lang = "panic"]
|
#[lang = "panic"]
|
||||||
pub fn panic(_expr_file_line_col: &(&'static str, &'static str, u32, u32)) -> ! {
|
pub fn panic(&(_msg, _file, _line, _col): &(&'static str, &'static str, u32, u32)) -> ! {
|
||||||
unsafe {
|
unsafe {
|
||||||
intrinsics::abort();
|
intrinsics::abort();
|
||||||
}
|
}
|
||||||
@ -254,11 +290,12 @@ pub struct Box<T: ?Sized>(*mut T);
|
|||||||
|
|
||||||
impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<Box<U>> for Box<T> {}
|
impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<Box<U>> for Box<T> {}
|
||||||
|
|
||||||
static mut MY_TINY_HEAP: [u8; 16] = [0xff; 16];
|
|
||||||
|
|
||||||
#[lang = "exchange_malloc"]
|
#[lang = "exchange_malloc"]
|
||||||
|
// Make it available to jited mini_core_hello_world
|
||||||
|
// FIXME remove next line when jit supports linking rlibs
|
||||||
|
#[inline(always)]
|
||||||
unsafe fn allocate(size: usize, _align: usize) -> *mut u8 {
|
unsafe fn allocate(size: usize, _align: usize) -> *mut u8 {
|
||||||
&mut MY_TINY_HEAP as *mut [u8; 16] as *mut u8
|
libc::malloc(size)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[lang = "drop"]
|
#[lang = "drop"]
|
||||||
@ -281,6 +318,17 @@ pub mod intrinsics {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub mod libc {
|
||||||
|
#[link(name = "c")]
|
||||||
|
extern "C" {
|
||||||
|
pub fn puts(s: *const u8);
|
||||||
|
pub fn malloc(size: usize) -> *mut u8;
|
||||||
|
pub fn memcpy(dst: *mut u8, src: *const u8, size: usize);
|
||||||
|
pub fn memmove(dst: *mut u8, src: *const u8, size: usize);
|
||||||
|
pub fn strncpy(dst: *mut u8, src: *const u8, size: usize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[lang = "index"]
|
#[lang = "index"]
|
||||||
pub trait Index<Idx: ?Sized> {
|
pub trait Index<Idx: ?Sized> {
|
||||||
type Output: ?Sized;
|
type Output: ?Sized;
|
||||||
|
@ -7,11 +7,7 @@
|
|||||||
extern crate mini_core;
|
extern crate mini_core;
|
||||||
|
|
||||||
use mini_core::*;
|
use mini_core::*;
|
||||||
|
use mini_core::libc::*;
|
||||||
#[link(name = "c")]
|
|
||||||
extern "C" {
|
|
||||||
fn puts(s: *const u8);
|
|
||||||
}
|
|
||||||
|
|
||||||
unsafe extern "C" fn my_puts(s: *const u8) {
|
unsafe extern "C" fn my_puts(s: *const u8) {
|
||||||
puts(s);
|
puts(s);
|
||||||
@ -132,13 +128,9 @@ fn main() {
|
|||||||
let ptr: *const u8 = hello as *const [u8] as *const u8;
|
let ptr: *const u8 = hello as *const [u8] as *const u8;
|
||||||
puts(ptr);
|
puts(ptr);
|
||||||
|
|
||||||
// TODO remove when jit supports linking rlibs
|
let world: Box<&str> = box "World!\0";
|
||||||
#[cfg(not(jit))]
|
puts(*world as *const str as *const u8);
|
||||||
{
|
world as Box<SomeTrait>;
|
||||||
let world: Box<&str> = box "World!\0";
|
|
||||||
puts(*world as *const str as *const u8);
|
|
||||||
world as Box<SomeTrait>;
|
|
||||||
}
|
|
||||||
|
|
||||||
assert_eq!(intrinsics::size_of_val(hello) as u8, 6);
|
assert_eq!(intrinsics::size_of_val(hello) as u8, 6);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user