AFTER CLONING THE REPO, CHECK OUT THE include/config.h
FILE BEFORE ANYTHING ELSE! IT THERE'S A LOT OF STUFF IN THIS REPO THAT CAN BE TOGGLED THERE.
HackerSM64 now has a discord server! https://discord.gg/brETAakcXr
This repo needs BOTH an US ROM and a JP ROM in order to build. Place baserom.us.z64 in the repo as usual and ALSO place baserom.jp.z64
This repo needs gcc in order to be able to build it. To install it, run sudo apt install gcc-mips-linux-gnu
This is a fork of HackerSM64 by Reonu, with the following additional features, fixes, and optimizations (patches marked with *
are toggleable in config.h
):
Graphics:
- Power stars have a glowing effect (Arceveti) *
- 30 FPS ia8 (64x64) coins (Arceveti) *
- Screen tint effects caused by damage, electric damage, and the camera being underwater or in poison gas. Damage and environment effects can be enabled separately (Arceveti) *
- Mario's silhouette is shown when behind most surfaces (Frame#5375, Axollyon, AloXado320, Wiseguy, Arceveti) *
- Bowser 3's rainbow effect is animated (Arceveti) *
- 64x64 quarter shadow textures (Arceveti) *
- King Bob-omb blinks
- Reflective metal cap texture using the framebuffer (mks#2512, Rovert, Arceveti) *
- Certain objects, like trees, reduce their opacity when close to the camera (Arceveti) *
- FoV slider in Puppycam's menu (Arceveti) *
- Lightweight directional lighting engine, intended for giving proximity and positional pointlights to small objects (Fazana) *
Vanilla level changes:
- Fixed various models which had misaligned vertices/UVs (Arceveti)
- Added a few bonus objects in some levels (mostly just coins, 1-ups, and recovery hearts) (Arceveti) *
- Fixed the "Impossible" coins' locations (Arceveti) *
- Both 1-Ups in the CCM slide shortcut are actually collectible (Arceveti) *
- The Blast Away The Wall star spawns from the wall instead of existing in the world already (AdyaGD) *
- Fix for Lakitu cutscene detection bounds *
- Re-implementation of the unused SSL pillars cutscene (SunlitSpace542, AloXado320/AloYuisabelle, Arceveti) *
- Re-implementation of the unused cracked ice in SL (SunlitSpace542, Arceveti) *
- Seamless Bowser's puzzle in LLL (Arceveti)
- A visual moving water current to the warp behind the Bowser door in DDD (Arceveti) *
- Removed the ambient slow water level increasing and decreasing in WDW due to potential nausea (Arceveti) *
- PSS Painting uses painting data instead of being part of the level model (Arceveti) *
Optimizations:
- Uses -Os compiler flag
- Most doubles are now floats where the extra percision isn't needed (Arceveti)
- Almost all unused code/data from the Goddard folder is removed (Arceveti)
- find_floor only checks static surfaces when checking for rooms (Arceveti)
- Some unecessary find_floor (collision) checks are removed (Arceveti)
- Optimized some models to use the expanded vertex buffer in newer f3d versions (Arceveti)
- Optimized DDD Bowser's Submarine collision model (Arceveti)
- Many stubbed/unused/duplicate functions/variables are removed (Arceveti)
- Many functions replaced by #define versions to reduce function call overhead (Arceveti)
- More particles use OBJ_LIST_UNIMPORTANT so they can be unloaded when needed (Arceveti) *
- Use the floor's normal for alignment instead of a triangle of find_floor if the floor isn't steep (Arceveti) *
- Many smaller optimizations/bugfixes (Arceveti)
Hacker QoL:
- Many unnamed variables have been named/documented (Arceveti, AloXado320, iProgramMC)
- Many unnamed display lists and geolayouts have been named (Arceveti)
- Almost all textures have been named (Arceveti)
- Some actor and behavior files have been moved around for consistency (Arceveti)
- Hardcoded render layers are replaced with their defines (Arceveti)
- Many object constants have been defined (Arceveti)
- Most general use math functions moved to
math_util.c
(Arceveti) - Expanded
math_util.c
with more general use math fuctions (Arceveti) - New render layer (LAYER_ALPHA_DECAL) when Silhouette is enabled (Arceveti) *
- Extended debug info, with more info for movement, input, and info for floors/ceilings/walls (Arceveti) *
- Configurable terminal velocity for gravity (Arceveti) *
- Z Offset for billboards, used for the star glow effect (Arceveti)
- Defines for specific cos() values used through out the game, usually for checking the Y normal of surfaces (Arceveti)
- Include the English characters that were missing from US segment2
J, Q, V, X, Z, ¨, !, !!, ?, &, %, ., and the beta key
[MAKE SURE TO ALSO BUILD FROM JP/SH AND EU TO OBTAIN THE ASSETS] (Arceveti) * - Backup segment2 characters for if the above isn't enabled (Arceveti)
- Extra segment2 characters/glyphs:
Red Coin, Blue Coin, Silver Coin, Minus Symbol
(Arceveti) * - Configurable amount of segments for Chain Chomp, Pokey, and Wiggler (Arceveti) *
- LLL Fire Bars use oBehParams2ndByte to determine their length (Arceveti)
- Extra fields in the MarioState struct, based on Mario's movement and angles: wallYaw, wallYaw, lastSafePos, prevPos, movePitch, moveYaw, lateralSpeed, moveSpeed. Updated once per frame. (Arceveti)
- Disable the demo that plays when idle on the start screen (Arceveti) *
- gbi.h defines (for point/bilerp sampling) to convert texel coordinates to internal s,t values (Arceveti)
HUD:
- Number of Red Coins collected is displayed on the HUD (Arceveti) *
- Number of Secrets collected is displayed on the HUD (Arceveti) *
- A bowser key is shown on the Castle pause menu if Mario has a key but its door isn't unlocked yet (Arceveti) *
- Leading zeroes on HUD counters like in modern Mario games (Arceveti) *
- Air/Breath meter is separate from health meter when underwater (Arceveti) *
Camera:
- Fix air jittering in Puppycam (Arceveti)
- Slightly modified version of Reonu Cam 3 (Reonu) *
- Camera approaches Mario's height much more quickly (Reonu) *
Object Behaviors:
object_step()
allows moving objects to step up and down floors like Mario, with a configurable step height (Arceveti) *- Fixed
cur_obj_resolve_object_collisions()
not working consistently (Arceveti) * - Fixed
bhv_init_room()
checking dynamic surfaces for rooms (Arceveti) * - Fixed DDD water rings by using interaction checking (Arceveti) *
- Fixed bomb clip (Arceveti) *
- Signs and NPCs are easier to talk to (Arceveti) *
- An "A" is shown above an object or NPC when Mario is able to talk to it (Arceveti) *
- Collecting a Power Star or 1-Up Mushroom will fully heal Mario (Arceveti) *
- The speed of a platform on a track can be controlled by standing near the front or back of it (Arceveti) *
- Respawning Koopa shell boxes (Arceveti) *
- Allow for retries on collecting the remaining blue coins from a blue coin switch (Arceveti) *
- Clams don't damage mario unless they are moving (opening/closing) (Arceveti) *
- Moving Coins flicker and disappear when they hit lava instead of being instantly deleted (Arceveti) *
- Tiny Goombas (from THI) always drop their coin (Arceveti) *
- Unagi and Klepto's stars become transparent stars after they are collected (SunlitSpace542) *
- Bowser throws are more lenient (Arceveti) *
- Leaf particles fall from trees which contain Hoot (Arceveti) *
- Reimplemented the unused "sad" eye texture for the mother penguin in CCM *
Collision:
- Mario's collision with lava is detected regardless of his action (Arceveti) *
- Vertical quicksand support (Wiseguy) *
- Platform Displacement 2 is modified to work with static objects, such as TTC Treadmills (Arceveti)
- Improved slope fix and exposed ceilings fix (Arceveti)
- Improved wall collision detection (frameperfection/Frame#5375)
- Better ceiling handling (Arceveti) *
Movement:
- Perform ground steps while standing still (Arceveti) *
- Configurable fall damage height *
- Uses the relative angles of Mario's slope rather than surface normals, allowing Mario to properly walk laterally across floor surfaces (Arceveti) *
- Turn circle fix (Arceveti) *
- Midair turn (Arceveti) *
- Faster transitions between actions (Arceveti) *
- Increasses the subframe step count the faster Mario is moving (Arceveti) *
- Water steps are split into quarter steps just like ground and air steps (Arceveti) *
- The number of air/ground/water steps per frame are individually configurable (Arceveti) *
- Don't fall after a star grab if the floor is too far below Mario (Arceveti) *
- Hold A when bouncing on an enemy to jump higher (Arceveti) *
- Hold Z while twirling to descend faster (Arceveti) *
- Air steps while ground pounding, preventing stuff like clipping through whomps (Arceveti) *
- Ground pound jump similar to SMO (Arceveti) *
- Underwater Ground pound similar to SMO (Arceveti) *
- Ground pound dive similar to SMO, but can also be used to cancel out of a ground pound if the analog stick is held back (Arceveti) *
- Check past null floors for a safe floor on the other side, preventing most cases of invisible walls caused by small gaps in level geometry (Arceveti) *
- General movement improvements, less softlocks, etc. See config for more details (Arceveti) *
- Mario can move sideways on ledges (Arceveti) *
- Fix wall sidle on slopes (Arceveti) *
- Unique wall slide which takes horizontal momentum into account (Arceveti) *
- Configurable wall kick/slide angle (Arceveti) *
- Coyote time, allowing Mario to walk over small gaps or make a jump for a few frames late after walking off a ledge, while also preventing most cases of ledge jittering (Arceveti) *
Misc:
- Goddard easter egg from Shindou *
Experimental:
- Unlock FPS *
- Check Mario's collision from the his center rather than his feet (Arceveti) *
- Platform Displacement 2 for objects other than Mario & Bowser (Arceveti) *
This is a fork of the ultrasm64 repo by CrashOveride which includes the following commonly used patches (patches marked with *
are toggleable in config.h
):
Lighting Engine by Wiseguy
- Lighting Engine is available on a separate branch
(lighting-engine)
. Instructions on how to use it are in the readme of that branch. - Alternatively, the main repo has
Puppylights
available, which is a more lightweight, but limited lighting library intended to be used to modify existing light properties. You can look atpuppylights.c
to find out how to use it.
Puppycam
- Puppycam is available on the master branch now, you can toogle it in config.h. *
Collision:
- Slope fix and exposed ceilings fix
- No false ledgegrabs fix *
- Jump kick fix *
- 46 degree wallkicks *
- Pole fix
- Possibility of disabling BLJs *
- Hanging fix (mario can grab hangable ceilings from any state, instead of only jump or double jump) *
- Increased maximum pole length (The game will read bparam1 and bparam2 together as a single value, so you can have a very long pole) *
- Platform Displacement 2 by Arthurtilly *
- Water Surface Type patch by thecozies
- Better Wall Collision With Rounded Corners by FramePerfection, merged by Cheezepin & Arceveti
- Automatically calculate the optimal collision distance for an object based on its vertices, by Kaze *
Common Hack Changes:
- Better extended boundaries by anonymous_moose
- Mario head skip *
- Peach letter cutscene skip *
- Exit course while moving *
- Toggle to disable fall damage and the fall damage sound *
- Nonstop stars *
- Removed course-specific camera processing *
- You can increase the number of frames that you have to perform a firsty *
- Ability to set Mario's movement speed when hanging from a ceiling *
- Tighter hanging controls (mario will face the direction of the analog stick directly while hanging from a ceiling) *
- reonucam3: custom camera by me. This is included as a .patch file in the enhancements folder, you need to apply it if you want this camera. This video shows a rundown of the features: https://youtu.be/TQNkznX9Z3k
- Ability to disable Mario getting suck in snow or sand
Hacker QOL:
- Global, non-level based, star IDs (off by default) *
- Debug mode: prints mario's coordinates, angle and speed, and a FPS counter.
- Automatic console/emulator detection. If emulator is detected, LODs are disabled. *
- Ability to configure whether there's a 100 coin star at all and how many coins are required to spawn it *
- Ability to easily change the warp that EXIT COURSE takes you to via config.h, or disable it entirely. *
- 16 bit model IDs by someone2639. This means you can have up to 65536 models (lol). You can set the maximum number of model IDs in
config.h
. - Apply_patch.sh improved
- Removed the ifdef hell in
file_select.c
andingame_menu.c
- Added Blake's custom function for object model stuff:
obj_set_model
andobj_has_model
- Added function to get the model ID from an object:
obj_get_model_id
(by Arceveti) - The "far" variable is now u16, allowing you to increase the farclip (the max distance at which geometry is rendered). However, when increasing the farclip, make sure to increase the nearclip by the same ratio, or rendering will break on console and LLE plugins.
- Many general use defines for object struct members, meant for use in custom object behaviors. Check
object_fields.h
for more info on this. (By MrComit) - Included
actors/group0.c
inbehavior_data.c
- The internal ROM name is now set with a define in
config.h
to make it simpler - There is a
gIsConsole
variable that is 1 when running on console and 0 when running on emulator. This way you can wrap your code in a console check. - Expanded audio heap allows for a larger concurrent note count and the importing of more m64 sequences and sound banks (By ArcticJaguar725) *
- You can set a test level in config.h in order to boot straight into it, so you can quickly test the level you're working on. *
- Allows all surfaces in the game to have a
force
parameter. Activating this doesn't REQUIRE you to setforce
for every surface: If you don't set, it will default to 0x0000 rather than crashing. Increases RAM usage of collision. * - The clown font includes the entire English alphabet.
- Colored ia4 text support. Format:
"@XXXXXXXX[YOUR TEXT]@--------"
(By ArcticJaguar725)- Example Text:
"@FF0000FFRED @00FF00FFGREEN @0000FFFFBLUE @FFFFFF00INVISIBLE @--------NORMAL"
- NOTE: It is not mandatory to reset the text color with
"@--------"
, but text will need to be recolored each time it scrolls in a dialog box, or the custom color will reset.
- Example Text:
- Toggle visiblity of collision surfaces and object hitboxes with Visual Surface Debug.
config.h
has VISUAL_DEBUG which can be turned on to enable this feature.
Other Bugfixes:
- Castle music fix (Fixes the castle music sometimes triggering after getting a dialog) *
- bparam4 fix (the game no longer uses bparam4 to check if an object is mario and therefore you can safely use it)
- Instant warp offset fix (makes the instant warp offset work even when warping to a different area) *
- haveyourcake, also known as cake screen fix. Made by Wiseguy and ported/PR'd by Cheezepin
- Tree particle fix (Whether a tree uses snow particles or not is decided via the model IDs instead of the course number) *
- Coordinate overflow fix by falcobuster. Your levels will render correctly on console and LLE emulators even when using 2x or 4x bounds, while not hurting anything on HLE plugins. This is automatic now, you don't have to set WORLD_SCALE manually.
- A couple vanilla texture fixes
- Smoke fix (the smoke texture uses the correct texture format) *
Neat Misc. Changes:
- Instant Input patch by Wiseguy (Removes all input lag caused by plugins supporting framebuffer)
- This means that you'll have to do your framebuffer effects on buffer 0 for emulator, but NOT for console. You can use the
gIsConsole
variable to check for console when doing your framebuffer effects.
- This means that you'll have to do your framebuffer effects on buffer 0 for emulator, but NOT for console. You can use the
- Widescreen (16:9) support toggleable by pressing
L
in the pause menu. * - S2DEX engine by someone2639! To use it, compile with
make TEXT_ENGINE=s2dex_text_engine
or just setTEXT_ENGINE
tos2dex_text_engine
in the makefile. - ia8 coins (64x64), the vanilla coin texture is upgraded to accomodate. *
- Mario's silhouette is shown when behind most surfaces (By Frame#5375, Axollyon, AloXado320, Wiseguy, Arceveti) *
- Skybox size modifier. You can have 2x, 3x and 4x size skyboxes (you can select the skybox size in
config.h
.) Please note that this might affect console performance, especially 4x mode. 2x or 3x mode is recommended if aiming for console. By CowQuack * - You can set the black border size to different values for console and emulator. It's set to 0 by default for both. *
- This repo supports much better implementation of reverb over vanilla's fake echo reverb. Great for caves or eerie levels, as well as just a better audio experience in general. See
audio/synthesis.c
for more configuration info. (By ArcticJaguar725) * - Fazana's "puppyprint" text engine. *
- Use
print_small_text
to print normal text. The two last params are aligment and how many characters to print (-1 means PRINT_ALL). - Use
render_multi_image
to draw large texture rectangles consisting of multiple images on the screen. - More info in
puppyprint.c
- Use
- Wiseguy's Farcall TLB mapping allows to store executable code inside uncompressed segments, that can be loaded and ran as needed, instead of it having to be loaded at all times. See
farcall.h
in the include folder for instructions and details.
- This repo contains a full decompilation of Super Mario 64 (J), (U), (E), and (SH).
- Naming and documentation of the source code and data structures are in progress.
- It has been edited to allow for the usage of the final "N64 OS" library, version
2.0L
- Shindou Rumble Pak code is on for all regions.
- Targeting the iQue Player is supported.
- Saving to 32kbyte/256kbit SRAM is supported.
- Newer compression options are supported.
- UNFLoader (flashcart USB library) is supported, allowing for debugging on EverDrive/64Drive.
- It has been patched with someone2639's shiftable segments patch
- Wiseguy's instant input patch has been added to allow for less input lag on emulation (Does not affect console) This does mean that any framebuffer effects will have to be done on buffer 0 if targeting emulators
- Automatic console and emulator detection: Use the
gIsConsole
variable to wrap your code in an emulator check. - Separate defines for emulator and console black border height.
- Getting HVQM FMV support to work with the game is WIP.
Requirements are the same as regular SM64, however a GCC MIPS cross compiler is also required. If you're on Debian-like Linux, you can use the gcc-mips-linux-gnu
package. The toolchain that comes with my SDK is also supported.
BinPNG (the CI texture converter) requires some python3 dependencies. Use pip to install them.
pip install pypng bitstring
The repository supports UNFLoader for debugging.
To build with UNF, run make with UNF=1
.
Further instructions can be found at the official repository
NOTE: Closing the UNFLoader window will result in your game eventually hanging due to lacking a USB device to send messages to, so beware of that
The repository supports SRAM in addition to EEPROM. The standard save data functions are #ifdef'd to accommedate this.
To build with SRAM support, run make with SAVETYPE=sram
.
I may attempt FlashRAM in the future.
The repository supports targeting the iQue Player in addition to the N64. The iQue libultra is NOT compatible with N64 in many ways, so it is currently NOT possible to have one build for both consoles.
To target iQue, run make with the CONSOLE=bb
argument.
The repo also supports RNC (Rob Northen Compression). RNC has two methods.
Method 1 is designed to compress as small as possible, while method 2 is designed so that decompression is as fast as possible.
Method 1 is the current default, and is the best all-rounder in terms of speed and ratio.
Both methods are fast. Method 1 has better compression than 2, so I suggest using method 1 if using RNC.
To switch to RNC, run make with either COMPRESS=rnc1
or COMPRESS=rnc2
, depending on preferred method.
The repository also supports using DEFLATE compression. This boasts a better compression ratio, but at a slight cost to load times. On average I'd estimate that the bottleneck on decompression is about 1-2 seconds.
To switch to gzip, run make with the COMPRESS=gzip
argument.
The repo also supports gziping with libdeflate-gzip
. This compresses at a slightly better ratio than standard gzip
, with no real downside from a decompression standpoint.
To use libdeflate-gzip
, first clone the repo, then make
and make install
it.
Then run make for sm64 with GZIPVER=libdef
in addition to COMPRESS=gzip
The repo also supports building a ROM with no compression.
This is not recommended as it increases ROM size significantly, with little point other than load times decreased to almost nothing.
To switch to no compression, run make with the COMPRESS=uncomp
argument.
Q: Why in the hell are you bundling your own build of ld
?
A: Newer binutils (Like the one bundled with Ubuntu, 2.34) break linking with libultra builds due to local asm symbols. This puts me at a crossroads of either touching leaked code and requiring GCC, or just using an older linker that works just fine. I went with the latter. Thanks to "someone2639" for this hacky-ass idea
Q: Will this allow me to use FlashRAM/Transfer Pak/microcode swapping/Other Cool N64 Features?
A: Theoretically, all yes.
Go read the original SM64 repo README.md