-
Notifications
You must be signed in to change notification settings - Fork 44
Adding Symbols
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
undefined_syms_*.txt
files to the linker)
This is the name of the symbol and can be any valid C variable name, e.g. myCoolFunction
or gReticulatedSplineCounter
This is the VRAM address expressed in hexadecimal, e.g. 0x80001050
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.
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.byte
s -
s16
,u16
: To specify data/rodata to be disassembled as.short
s -
s32
,u32
: To specify data/rodata to be disassembled as.word
s (the default) -
s64
,u64
: 🤷♂️ -
f32
,Vec3f
: To specify data/rodata to be disassembled as.float
s -
f64
: To specify data/rodata to be disassembled as.double
s -
asciz
,char*
,char
: C strings (disassembled as.asciz
) - Any custom type starting with a capital letter (will default to
.word
s)
Any other type will produce an error.
Example:
minFrameSize = 0x80241D08; // type:s32
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
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
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
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
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
TBD
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
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
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
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
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
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
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
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