1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2025-01-25 18:17:48 +00:00
oot/tools/audio/README.md
Tharo df5d4cb467
[Audio 10/10] Loose ends (#2337)
* Introduce afile_sizes, generate headers of sizes for soundfonts and sequences

* Initial tools/audio README

* Versioning for samplebank extraction

* Clean up the disassemble_sequence.py runnable interface

* Add static assertions for maximum bank sizes

* Boost optimization for audio tools

* Samplebank XML doc

* Soundfont XML doc

* More docs in sampleconv for vadpcm

* Various tools fixes/cleanup

* VADPCM doc

* Try to fix md formatting

* VADPCM doc can come later

* Fix merge with PR 9

* Fix blobs from MM

* Try to fix bss

* Try fix bss round 2

* Fix sampleconv memset bug

* Suggested documentation tweaks
2024-12-13 19:26:36 -05:00

3.4 KiB

Z64 Audio Tools

The Z64 Audio Tools work together to implement the full audio asset pipeline

Licensing Information

  • The programs atblgen, sampleconv, sbc and sfc are (mostly) distributed under MPL-2.0. The VADPCM encoding and decoding portions of sampleconv are under CC0-1.0.
  • The programs sfpatch and afile_sizes are distributed under CC0-1.0.
  • The extraction tool is distributed under CC0-1.0.

sampleconv

Converts aifc <-> aiff / wav

Used in extraction and build to convert audio sample data between uncompressed mono 16-bit PCM and the compressed formats used by the audio driver.

SampleBank Compiler (sbc)

Converts samplebank xml + aifc -> asm

Samplebanks are converted to assembly files for building as it is easier to define the necessary absolute symbols, and they are pure unstructured data.

SoundFont Compiler (sfc)

Converts soundfont & samplebank xml + aifc -> C

Soundfonts are converted to C rather than assembly as it shares data structures with the audio driver code. Modifying the structures used by the driver without updating sfc to write them should error at compile-time rather than crash at runtime.

sfpatch

Usage: sfpatch in.elf out.elf

This tool patches the symbol table of an ELF file (in.elf) to make every defined symbol in the file an absolute symbol. This is a required step for building soundfonts from C source as all pointers internal to a soundfont are offset from the start of the soundfont file and not the audiobank segment as a whole. Making all defined symbols ABS symbols prevents the linker from updating their values later, ensuring they remain file-relative.

atblgen

Generates various audio code tables.

  • Samplebank table: Specifies where in the Audiotable file each samplebank begins and how large it is.
  • Soundfont table: Specifies where in the Audiobank files each soundfont begins, how large it is, which samplebanks it uses, and how many instruments/drums/sfx it contains.
  • Sequence font table: Contains information on what soundfonts each sequence uses. Generated from the sequence object files that embed a .note.fonts section that holds this information.

The sequence table is not generated as some things in that table are better left manually specified, such as sequence enum names and flags. This also lets us have the sequence table before assembling any sequence files which is nice for some sequence commands like runseq.

afile_sizes

Produces header files containing binary file sizes for a given set of object files. Used to produce headers containing soundfont and sequence files and the number of each for use in code files.

extraction

This collection of python files implements the extraction of audio data from a base ROM.

Files that are designed to be used externally include:

  • audio_extract.py is the main file for audio extraction, it expects an external script to call extract_audio_for_version with the necessary inputs.
  • disassemble_sequence.py is runnable but is not used in this way in either extraction or building. It may be used to manually disassemble a sequence binary.
  • tuning.py is runnable but is not used that way in either extraction or building. It may be used to manually determine alternative matches for the samplerate and basenote of a sample as the extraction procedure cannot always determine these uniquely.

See individual python source files for further details on their purposes.