summaryrefslogtreecommitdiff
path: root/src/engine/rng.c
diff options
context:
space:
mode:
authorMarcus Huderle <huderlem@gmail.com>2017-10-09 10:23:23 -0700
committerMarcus Huderle <huderlem@gmail.com>2017-10-09 10:40:04 -0700
commit72beb410f423cafd35989c0b8dd4c52860cf80f8 (patch)
tree155aa1e2c39ebd504e095bc8c1dc218aad3acdc4 /src/engine/rng.c
parenta871ce87a74421df64a9ad381d37dc32ff9bdc6d (diff)
parent3e03d362fae398fa56c4a6e45d7b999772d0803f (diff)
Merge remote-tracking branch 'upstream/master' into party_menu
Diffstat (limited to 'src/engine/rng.c')
-rw-r--r--src/engine/rng.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/engine/rng.c b/src/engine/rng.c
new file mode 100644
index 000000000..7d4b5600e
--- /dev/null
+++ b/src/engine/rng.c
@@ -0,0 +1,18 @@
+#include "global.h"
+#include "rng.h"
+
+// The number 1103515245 comes from the example implementation of rand and srand
+// in the ISO C standard.
+
+u32 gRngValue;
+
+u16 Random(void)
+{
+ gRngValue = 1103515245 * gRngValue + 24691;
+ return gRngValue >> 16;
+}
+
+void SeedRng(u16 seed)
+{
+ gRngValue = seed;
+}