rust/src/test/run-pass/extern-stress.rs

50 lines
1.3 KiB
Rust
Raw Normal View History

// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
// This creates a bunch of descheduling tasks that run concurrently
2012-02-15 03:16:53 -06:00
// while holding onto C stacks
2014-02-26 11:58:41 -06:00
extern crate libc;
use std::task;
mod rustrt {
2014-02-26 11:58:41 -06:00
extern crate libc;
#[link(name = "rustrt")]
extern {
pub fn rust_dbg_call(cb: extern "C" fn(libc::uintptr_t) -> libc::uintptr_t,
data: libc::uintptr_t)
2013-05-15 16:10:42 -05:00
-> libc::uintptr_t;
}
2012-02-15 03:16:53 -06:00
}
2012-07-03 18:32:02 -05:00
extern fn cb(data: libc::uintptr_t) -> libc::uintptr_t {
2012-02-15 03:16:53 -06:00
if data == 1u {
data
} else {
task::deschedule();
2012-02-15 03:16:53 -06:00
count(data - 1u) + count(data - 1u)
}
}
fn count(n: uint) -> uint {
2013-01-23 18:29:31 -06:00
unsafe {
rustrt::rust_dbg_call(cb, n)
}
2012-02-15 03:16:53 -06:00
}
pub fn main() {
for _ in range(0, 100u) {
2014-01-27 17:29:50 -06:00
task::spawn(proc() {
assert_eq!(count(5u), 16u);
2014-01-27 17:29:50 -06:00
});
}
}