Skip to content

Adding Symbols

Mark edited this page Dec 2, 2024 · 16 revisions

Symbols (i.e. labelling a function or variable) are controlled by the symbols_addrs.txt file.

The format for defining symbols is:

symbol = address; // option1:value1 option2:value2

e.g.

osInitialize = 0x801378C0; // type:func

ℹ️ The file used can be overridden via the symbol_addrs_path setting in the global options section of the splat yaml. This option can also accept a list of paths, allowing for symbols to be organized in multiple files.

Warning

⚠️ NOTE: This file is an input to splat, it should NOT be passed to the linker (pass undefined_syms_*.txt files to the linker) ⚠️

symbol

This is the name of the symbol and can be any valid C variable name, e.g. myCoolFunction or gReticulatedSplineCounter

address

This is the VRAM address expressed in hexadecimal, e.g. 0x80001050

options

An optional key:pair list of settings, note that each option should be separated by whitespace, but there should be no whitespace between the key:value pairs themselves.

type

Override splat's automatic type detection, possible values are:

  • func: Functions
  • jtbl: Jumptables
  • jtbl_label: Jumptables labels (inside functions)
  • label: Branch labels (inside functions)
  • s8, u8: To specify data/rodata to be disassembled as .bytes
  • s16, u16: To specify data/rodata to be disassembled as .shorts
  • s32, u32: To specify data/rodata to be disassembled as .words (the default)
  • s64, u64: 🤷‍♂️
  • f32, Vec3f: To specify data/rodata to be disassembled as .floats
  • f64: To specify data/rodata to be disassembled as .doubles
  • asciz, char*, char: C strings (disassembled as .asciz)
  • Any custom type starting with a capital letter (will default to .words)

Any other type will produce an error.

Example:

minFrameSize = 0x80241D08; // type:s32

size

The size of the function or the size of the data depending on the type of the symbol. It specifies a size in bytes. e.g. size:0x10.

Example:

RawHuffmanTable = 0x8022E0E0; // type:symbol size:0x100

rom

The ROM offset for the symbol, useful (potentially mandatory) for symbols in overlays where multiple symbols could share the same VRAM address.

Example:

create_particle_effect = 0x802D5F4C; // type:func rom:0x6E75FC

segment

Allows specifying to which specific segment this symbol belongs to, useful to disambiguate symbols from segments that share the same VRAM address. This name must be the same as the name of a segment listed in the yaml.

Example:

sMenuTexture = 0x06004040; // segment:menu_assets

name_end

Emits a symbol after the end of the data of the current symbol. Useful to reference the end of an assembly symbol, like RSP data.

Example:

rspbootTextStart = 0x80084690; // name_end:rspbootTextEnd

defined

Forces the symbol to be defined - i.e. prevent it from appearing in undefined_syms_auto.txt should splat not encounter the symbol during the symbol detection phase.

Example:

__osDpDeviceBusy = 0x8014B3D0; // defined:true

extract

TBD

ignore

Prevents an address from being symbolized and referenced. Useful to get a finer control over the disassembled output.

Example:

D_A0000000 = 0xA0000000; // ignore:true

It can also be combined with the size attribute to avoid a range of addresses of being symbolized.

Example:

D_80000000 = 0x80000000; // ignore:true size:0x10

force_migration and force_not_migration

Grants a finer control over the automatic rodata migration to functions. This may be required because of the migration heuristic failing to migrate (or to not migrate) a symbol, producing a disordered rodata section. Forcing the migration of a rodata symbol to a function will only work if that function references said rodata symbol. Forcing the not-migration of a rodata symbol always works.

This attribute is ignored if the migrate_rodata_to_functions option is disabled.

Example:

jtbl_800B13D0 = 0x800B13D0; // type:jtbl force_migration:True
STR_800B32A8 = 0x800C9520; // type:asciz force_not_migration:True

function_owner

Tells the disassembler that the given rodata symbol must be moved to the given function during rodata migration.

This allows to override the rodata migration heuristic, which may decide to not migrate this symbol to a function or to migrate it to a different function.

Make sure that the corresponding sections for the rodata symbol and the owner function are properly paired in the yaml, otherwise this symbol will be lost to limbo.

This attribute is ignored if the migrate_rodata_to_functions option is disabled.

Example:

D_800E86B0 = 0x800E86B0; // type:jtbl function_owner:func_8009F034

allow_addend and dont_allow_addend

Allows this symbol to reference (or not reference) other symbols with an addend.

This attribute overrides the global allow_data_addends option.

Example:

aspMainTextStart = 0x80084760; // dont_allow_addend:True

can_reference

Allows this symbol to reference (or to not reference) other symbols.

This can be desirable for textures, microcode, or any other symbol that should be treated as plain data.

Defaults to True.

Example:

aspMainTextStart = 0x80084760; // can_reference:False

can_be_referenced

Allows this symbol to be referenced (or to not be referenced) by other symbols.

This can be desirable for some niche cases like games that include certain metadata that shouldn't be referenced by anything else, like relocation information in Zelda and Rare games.

Defaults to True.

Example:

dummy_symbol = 0x800782B0; // can_be_referenced:True

allow_duplicated

Tells splat that a symbol is allowed to have its vram/name duplicated with another symbol.

This attribute has to be specified on all symbols that share the same vram or name.

Warning: Take in mind that using this feature for assembly symbols may produce errors on the build, like duplicated symbol errors on the linker. Use with caution.

Example

obj_fallCA1_tex_rgb_ia8 = 0x06013118; // allow_duplicated:True
// ...
obj_fallCA1_tex_rgb_ia8 = 0x060140A8; // allow_duplicated:True

filename

Allows specifying a different filename than the default (the symbol's name) when writing the symbol to its own file.

Useful when the symbol name has invalid characters for a filename or it exceeds the OS filename limit.

Example

__opPCc__Q23std34_RefCountedPtr<c,Q23std9_Array<c>>CFv = 0x00202850; // filename:func_00202850

Gets written to func_00202850.s