about summary refs log tree commit diff
path: root/src/rt/rust_builtin.cpp
diff options
context:
space:
mode:
authorBrian Anderson <banderson@mozilla.com>2013-05-06 17:07:38 -0700
committerBrian Anderson <banderson@mozilla.com>2013-05-07 12:08:03 -0700
commit21aaa7fb13793e7a4cf0c62653035f6f09a20d9e (patch)
tree861055133ad848641c4027fc0f53d3ee07057845 /src/rt/rust_builtin.cpp
parent4cd51c416b8cf1a9d89089c99b8a1e2ac2f7255a (diff)
downloadrust-21aaa7fb13793e7a4cf0c62653035f6f09a20d9e.tar.gz
rust-21aaa7fb13793e7a4cf0c62653035f6f09a20d9e.zip
rt: Eliminate the dependency on rust_kernel from rust_rng
Diffstat (limited to 'src/rt/rust_builtin.cpp')
-rw-r--r--src/rt/rust_builtin.cpp9
1 files changed, 4 insertions, 5 deletions
diff --git a/src/rt/rust_builtin.cpp b/src/rt/rust_builtin.cpp
index a491379153e..885b40c0a50 100644
--- a/src/rt/rust_builtin.cpp
+++ b/src/rt/rust_builtin.cpp
@@ -88,8 +88,7 @@ rand_seed_size() {
 
 extern "C" CDECL void
 rand_gen_seed(uint8_t* dest, size_t size) {
-    rust_task *task = rust_get_current_task();
-    rng_gen_seed(task->kernel, dest, size);
+    rng_gen_seed(dest, size);
 }
 
 extern "C" CDECL void *
@@ -101,14 +100,14 @@ rand_new_seeded(uint8_t* seed, size_t seed_size) {
         task->fail();
         return NULL;
     }
-    rng_init(task->kernel, rng, seed, seed_size);
+    char *env_seed = task->kernel->env->rust_seed;
+    rng_init(rng, env_seed, seed, seed_size);
     return rng;
 }
 
 extern "C" CDECL uint32_t
 rand_next(rust_rng *rng) {
-    rust_task *task = rust_get_current_task();
-    return rng_gen_u32(task->kernel, rng);
+    return rng_gen_u32(rng);
 }
 
 extern "C" CDECL void