From 5a80be213ce08dbd20e42b1dc88fbe10e24b5f03 Mon Sep 17 00:00:00 2001 From: water111 <48171810+water111@users.noreply.github.com> Date: Sat, 2 Sep 2023 09:39:19 -0400 Subject: [PATCH] [sprite] Adjust allocation randomization (#2953) This tries to match the original behavior of the sprite allocation "randomness", which should reduce the number of very empty sprite blocks sent to C++. --- .../engine/gfx/sprite/sparticle/sparticle.gc | 25 ++++++++++--------- .../engine/gfx/sprite/particles/sparticle.gc | 2 +- .../jak2/engine/gfx/texture/texture-anim.gc | 4 +-- 3 files changed, 16 insertions(+), 15 deletions(-) diff --git a/goal_src/jak1/engine/gfx/sprite/sparticle/sparticle.gc b/goal_src/jak1/engine/gfx/sprite/sparticle/sparticle.gc index 9d2254997cd..cbdb0e277a0 100644 --- a/goal_src/jak1/engine/gfx/sprite/sparticle/sparticle.gc +++ b/goal_src/jak1/engine/gfx/sprite/sparticle/sparticle.gc @@ -81,7 +81,7 @@ (set! (-> gp-0 length 1) a2-2) (set! (-> gp-0 num-alloc 1) 0) (set! (-> gp-0 is-3d) arg2) - ;; per block + ;; per block uint64 (bit per-sprite) (set! (-> gp-0 alloc-table) (the-as (pointer uint64) (malloc 'global (* s2-1 8)))) ;; per particle (set! (-> gp-0 cpuinfo-table) (the-as (inline-array sparticle-cpuinfo) (malloc 'global (* 144 s5-1)))) @@ -90,6 +90,7 @@ ;; adgifs (set! (-> gp-0 adgifdata-table) arg4) (dotimes (v1-5 s2-1) + ;; fill alloc-table with 1's (set! (-> gp-0 alloc-table v1-5) (the-as uint -1)) ) (dotimes (s4-1 s5-1) @@ -182,21 +183,21 @@ (defun sp-free-particle ((arg0 sparticle-system) (arg1 int) (arg2 sparticle-cpuinfo) (arg3 sprite-vec-data-2d)) "free a particle" - + ;; clear flags on our launch state. (if (and (-> arg2 binding) (nonzero? (-> arg2 binding))) (logclear! (-> arg2 binding flags) (sp-launch-state-flags launcher-active particles-active) ) ) - + ;; clear the bit indicating that we're alive. (let ((v1-6 (/ arg1 64)) (t0-4 (logand arg1 63)) ) (logior! (-> arg0 alloc-table v1-6) (ash 1 t0-4)) ) - + ;; decrease alloc count for the appropriate group (if (< arg1 (-> arg0 length 0)) (+! (-> arg0 num-alloc 0) -1) @@ -232,17 +233,17 @@ (set! v1-0 t0-0) (set! t0-0 (-> arg0 blocks 1)) ) - + ;; this adds a moving offset to the allocation system. I'm not sure why. (when arg2 (set! a3-0 (the-as int (-> arg2 randomize))) (+! (-> arg2 randomize) 1) - (when (= (-> arg2 randomize) t0-0) + (when (= (-> arg2 randomize) (/ t0-0 SPRITE_MAX_AMOUNT_MULT)) (set! (-> arg2 randomize) (the-as uint 0)) 0 ) ) - + ;; find the earliest free. (dotimes (a2-1 t0-0) (when (nonzero? (-> arg0 alloc-table (+ v1-0 a3-0))) @@ -310,7 +311,7 @@ ) ) ) - + (the-as sparticle-cpuinfo #f) ) @@ -446,7 +447,7 @@ ) (t9-2 sv-16 (the-as pointer a1-7) sv-32) ) - + ;; alternate to run without doing scratchpad (will change behavior of kill, but at least works for hud) ; (set! sv-80 (the-as int (-> arg0 cpuinfo-table arg1))) ; (set! sv-96 (the-as int (&+ (-> arg0 vecdata-table) (* 48 arg1)))) @@ -702,7 +703,7 @@ (new 'static 'rgba :r #x40 :b #x40 :a #x80) ) ) - + ;; update timer (let ((v1-14 (logand (the-as int (-> *sp-frame-time* x)) 255))) (set! *particle-300hz-timer* (+ *particle-300hz-timer* v1-14)) @@ -723,7 +724,7 @@ ) ) ) - + ;; process the particles ;; pc port note : made this not run when paused, since aux sprites wont get added. (unless (paused?) @@ -739,7 +740,7 @@ ) ) (set! *sp-launcher-lock* #f) - + ;; launch queued particles (sp-clear-queue) ;;(.mfc0 v1-29 Count) diff --git a/goal_src/jak2/engine/gfx/sprite/particles/sparticle.gc b/goal_src/jak2/engine/gfx/sprite/particles/sparticle.gc index 260b497bfe5..2a81265ef0e 100644 --- a/goal_src/jak2/engine/gfx/sprite/particles/sparticle.gc +++ b/goal_src/jak2/engine/gfx/sprite/particles/sparticle.gc @@ -205,7 +205,7 @@ (when arg2 (set! a3-0 (the-as int (-> arg2 randomize))) (+! (-> arg2 randomize) 1) - (when (= (-> arg2 randomize) t0-0) + (when (= (-> arg2 randomize) (/ t0-0 SPRITE_MAX_AMOUNT_MULT)) (set! (-> arg2 randomize) (the-as uint 0)) 0 ) diff --git a/goal_src/jak2/engine/gfx/texture/texture-anim.gc b/goal_src/jak2/engine/gfx/texture/texture-anim.gc index 9454bc178a3..c24ec2887ec 100644 --- a/goal_src/jak2/engine/gfx/texture/texture-anim.gc +++ b/goal_src/jak2/engine/gfx/texture/texture-anim.gc @@ -803,7 +803,7 @@ struct SlimeInput { (make-sky-input (the sky-input (-> dma-buf base))) (&+! (-> dma-buf base) (psize-of sky-input)) (pc-texture-anim-flag finish-anim-array dma-buf) - (dotimes (i 9) ;; intentially skipping fog here!! + (dotimes (i 8) ;; intentially skipping fog here!! (pc-update-anim-frame-time (-> *sky-texture-anim-array* array-data i)) ) ) @@ -826,7 +826,7 @@ struct SlimeInput { (make-sky-hires-input (the sky-input (-> dma-buf base))) (&+! (-> dma-buf base) (psize-of sky-input)) (pc-texture-anim-flag finish-anim-array dma-buf) - (dotimes (i 11) ;; intentially skipping fog here!! + (dotimes (i 10) ;; intentially skipping fog here!! (pc-update-anim-frame-time (-> *sky-hires-texture-anim-array* array-data i)) ) )