This file contains file splits for a module.
Example:
Sections:
.text type:code align:32
.ctors type:rodata align:32
.data type:data align:32
.bss type:bss align:32
path/to/file.cpp:
.text start:0x80047E5C end:0x8004875C
.ctors start:0x803A54C4 end:0x803A54C8
.data start:0x803B1B40 end:0x803B1B60
.bss start:0x803DF828 end:0x803DFA8C
.bss start:0x8040D4AC end:0x8040D4D8 commonSections:
section [section attributes]type:The section type.code,data,rodataorbss.align:The section alignment in bytes.vaddr:(REL only) The fixed virtual address of the section. When set, split and symbol addresses are written as absolute addresses.
path/to/file.cpp: [file attributes]
section [section attributes]
...path/to/file.cppThe name of the source file, usually relative tosrc. The file does not need to exist to start.
This corresponds to an entry inconfigure.pyfor specifying compiler flags and other options.
-
comment:Overrides themw_comment_versionsetting inconfig.ymlfor this file. See Comment section.comment:0is used to disable.commentsection generation for a file that wasn't compiled withmwcc.
Example:TRK_MINNOW_DOLPHIN/ppc/Export/targsupp.s: comment:0
This file was assembled and only contains label symbols. Generating a.commentsection for it will crashmwld.
-
order:Allows influencing the resolved link order of objects. This is not required, as decomp-toolkit will generate the link order automatically. This can be used to fine-tune the link order for ambiguous cases.
Example:file1.cpp: order:0 ... file2.cpp: order:1 ... file3.cpp: order:2 ...This ensures that
file2.cppis always anchored in between 1 and 3 when resolving the final link order.
start:The start address of the section within the file. For DOLs, this is the absolute address (e.g.0x80001234). For RELs, this is the section-relative address (e.g.0x1234).end:The end address of the section within the file.align:Specifies the alignment of the section. If not specified, the default alignment for the section is used.rename:Writes this section under a different name when generating the split object. Used for.ctors$10, etc.commonOnly valid for.bss. See Common BSS.skipSkips this data when writing the object file. Used for ignoring data that's linker-generated.