2012-11-30 00:47:45 -08:00
|
|
|
#[legacy_exports];
|
|
|
|
|
2012-08-14 19:25:42 -04:00
|
|
|
// NB: transitionary, de-mode-ing.
|
|
|
|
#[forbid(deprecated_mode)];
|
|
|
|
#[forbid(deprecated_pattern)];
|
2012-07-10 15:52:05 -07:00
|
|
|
//! Runtime calls emitted by the compiler.
|
|
|
|
|
2012-09-04 11:12:17 -07:00
|
|
|
use libc::c_char;
|
|
|
|
use libc::c_void;
|
|
|
|
use libc::size_t;
|
|
|
|
use libc::uintptr_t;
|
2012-07-10 15:52:05 -07:00
|
|
|
|
2012-09-07 18:08:21 -07:00
|
|
|
use gc::{cleanup_stack_for_failure, gc, Word};
|
2012-07-16 12:28:15 -07:00
|
|
|
|
2012-09-02 15:39:37 -07:00
|
|
|
#[allow(non_camel_case_types)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub type rust_task = c_void;
|
2012-07-10 15:52:05 -07:00
|
|
|
|
|
|
|
extern mod rustrt {
|
|
|
|
#[rust_stack]
|
|
|
|
fn rust_upcall_fail(expr: *c_char, file: *c_char, line: size_t);
|
2012-07-17 10:48:19 -07:00
|
|
|
|
|
|
|
#[rust_stack]
|
|
|
|
fn rust_upcall_exchange_malloc(td: *c_char, size: uintptr_t) -> *c_char;
|
|
|
|
|
|
|
|
#[rust_stack]
|
|
|
|
fn rust_upcall_exchange_free(ptr: *c_char);
|
|
|
|
|
|
|
|
#[rust_stack]
|
|
|
|
fn rust_upcall_malloc(td: *c_char, size: uintptr_t) -> *c_char;
|
|
|
|
|
|
|
|
#[rust_stack]
|
|
|
|
fn rust_upcall_free(ptr: *c_char);
|
2012-07-10 15:52:05 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// FIXME (#2861): This needs both the attribute, and the name prefixed with
|
|
|
|
// 'rt_', otherwise the compiler won't find it. To fix this, see
|
|
|
|
// gather_rust_rtcalls.
|
2012-09-12 11:51:44 -07:00
|
|
|
#[rt(fail_)]
|
2012-11-27 18:05:20 -08:00
|
|
|
pub fn rt_fail_(expr: *c_char, file: *c_char, line: size_t) -> ! {
|
|
|
|
unsafe {
|
|
|
|
cleanup_stack_for_failure();
|
|
|
|
rustrt::rust_upcall_fail(expr, file, line);
|
|
|
|
cast::transmute(())
|
|
|
|
}
|
2012-07-10 15:52:05 -07:00
|
|
|
}
|
|
|
|
|
2012-09-29 12:34:11 +01:00
|
|
|
#[rt(fail_bounds_check)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub fn rt_fail_bounds_check(file: *c_char, line: size_t,
|
2012-09-29 12:34:11 +01:00
|
|
|
index: size_t, len: size_t) {
|
|
|
|
let msg = fmt!("index out of bounds: the len is %d but the index is %d",
|
|
|
|
len as int, index as int);
|
|
|
|
do str::as_buf(msg) |p, _len| {
|
|
|
|
rt_fail_(p as *c_char, file, line);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-07-17 10:48:19 -07:00
|
|
|
#[rt(exchange_malloc)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub fn rt_exchange_malloc(td: *c_char, size: uintptr_t) -> *c_char {
|
2012-08-01 17:30:05 -07:00
|
|
|
return rustrt::rust_upcall_exchange_malloc(td, size);
|
2012-07-17 10:48:19 -07:00
|
|
|
}
|
|
|
|
|
2012-07-23 16:00:19 -07:00
|
|
|
// NB: Calls to free CANNOT be allowed to fail, as throwing an exception from
|
|
|
|
// inside a landing pad may corrupt the state of the exception handler. If a
|
|
|
|
// problem occurs, call exit instead.
|
2012-07-17 10:48:19 -07:00
|
|
|
#[rt(exchange_free)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub fn rt_exchange_free(ptr: *c_char) {
|
2012-07-17 10:48:19 -07:00
|
|
|
rustrt::rust_upcall_exchange_free(ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[rt(malloc)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub fn rt_malloc(td: *c_char, size: uintptr_t) -> *c_char {
|
2012-08-01 17:30:05 -07:00
|
|
|
return rustrt::rust_upcall_malloc(td, size);
|
2012-07-17 10:48:19 -07:00
|
|
|
}
|
|
|
|
|
2012-07-23 16:00:19 -07:00
|
|
|
// NB: Calls to free CANNOT be allowed to fail, as throwing an exception from
|
|
|
|
// inside a landing pad may corrupt the state of the exception handler. If a
|
|
|
|
// problem occurs, call exit instead.
|
2012-07-17 10:48:19 -07:00
|
|
|
#[rt(free)]
|
2012-10-02 16:31:52 -07:00
|
|
|
pub fn rt_free(ptr: *c_char) {
|
2012-07-17 10:48:19 -07:00
|
|
|
rustrt::rust_upcall_free(ptr);
|
|
|
|
}
|
|
|
|
|
2012-07-10 15:52:05 -07:00
|
|
|
// Local Variables:
|
|
|
|
// mode: rust;
|
|
|
|
// fill-column: 78;
|
|
|
|
// indent-tabs-mode: nil
|
|
|
|
// c-basic-offset: 4
|
|
|
|
// buffer-file-coding-system: utf-8-unix
|
|
|
|
// End:
|