Here is a guide to step through the basics of installation/usage of Maxmod in a GBA project. This tutorial will assume that you are using the default GBA template (makefile) from devkitPro.
Linking
Firstly, libmm must be added to your library references. Add -lmm to the LIBS in your makefile.
#---------------------------------------------------------------------------------
# any extra libraries we wish to link with the project
#---------------------------------------------------------------------------------
LIBS    := -lmm -lgba
Next, you need to tell the makefile to make a soundbank file for you. What is a soundbank file? It's a file that contains all the samples and modules for your project!
Add a new directory to your project; I'll call it "audio". Add a variable to the directory section of the makefile.
#---------------------------------------------------------------------------------
# TARGET is the name of the output
# BUILD is the directory where object files & intermediate files will be placed
# SOURCES is a list of directories containing source code
# INCLUDES is a list of directories containing extra header files
# AUDIO is a list of directories containing sound and music files
#---------------------------------------------------------------------------------
TARGET   :=  $(shell basename $(CURDIR))
BUILD    :=  build
SOURCES  :=  gfx source data
INCLUDES :=  include build
AUDIO    :=  audio
Next, you need to build a list of the files in the audio directory. Also add the soundbank output file to your binary file list.
CFILES    :=  $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.c)))
CPPFILES  :=  $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.cpp)))
SFILES    :=  $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.s)))
BINFILES  :=  $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.bin))) soundbank.bin
 
# build audio file list, include full path
export AUDIOFILES := $(foreach dir,$(notdir $(wildcard $(AUDIO)/*.*)),$(CURDIR)/$(AUDIO)/$(dir))
Finally, you need a rule to make the soundbank file with the Maxmod Utility. Scroll down to the bottom somewhere and add something like this. You also need a rule to convert the output binary so it can be linked in.
#-------------------------------------------------------------
# rule for converting the output into an object file
#-------------------------------------------------------------
%.bin.o: %.bin
#-------------------------------------------------------------
    @$(bin2o)
 
#-------------------------------------------------------------
# rule for generating soundbank file from audio files
#-------------------------------------------------------------
soundbank.bin: $(AUDIOFILES)
#-------------------------------------------------------------
    @mmutil $^ -osoundbank.bin -hsoundbank.h
Now the soundbank file should be generated and linked into the project automatically. Load the audio folder with a few modules (and maybe some WAV files) to test with!
Setup
Now it's time to initialize Maxmod. maxmod.h has the definitions for a GBA project, include it in your source files. Also, include the generated soundbank header too.
#include "soundbank.h"  
Global include of Maxmod for GBA.
 Maxmod may be initialized now. The GBA library is customizable, so you can configure how many channels or what mixing rate to use, but for this example, we will just use the easy method. mmInitDefault. It's two parameters are the soundbank address, and the number of channels to allocate. It sets up everything for us (including VBlank IRQ [with libgba]) and uses 16KHz mixing rate.
#include "soundbank.h"
#include "soundbank_bin.h" 
 
int main(void)
{
    
    
 
    ...
}
bool mmInitDefault(mm_addr soundbank, mm_word number_of_channels)
Initialize Maxmod with default settings.
 
Playing Music
Let's have a look at the soundbank header generated by the Maxmod Utiltiy.
#define MOD_SONG1        0
#define MOD_SONG2        1
#define MOD_CREDITS      2
#define MOD_ANOTHER      3
#define MOD_SECRET       4
#define SFX_BLASTER      179
#define SFX_PHASER       180
#define MSL_NSONGS       5
#define MSL_NSAMPS       181
#define MSL_BANKSIZE     186
Definitions prefixed by MOD_ are module IDs. Definitions prefixed by SFX_ are sample IDs. MSL_NSONGS is the total number of modules in the soundbank, MSL_NSAMPS is the total number of samples, and MSL_BANKSIZE is the total number of modules plus samples (useful for DS projects).
Use mmStart() to play a song.
void mmStart(mm_word module_ID, mm_pmode mode)
Begins playback of a module.
@ MM_PLAY_LOOP
Loop module forever (until stopped).
Definition mm_types.h:170
 Not just yet! The actual song playback (and software mixing) occurs when you call mmFrame(). This must be called every frame (60hz) (in your main loop).
while (1)
{
    
 
    
 
    
    VBlankIntrWait();
 
    
}
void mmFrame(void) __attribute((long_call))
This is the main routine-function that processes music and updates the sound output.
Sound Effects
The simplest way to play a sound is with mmEffect().
mm_sfxhand mmEffect(mm_word sample_ID)
Plays a sound effect with default settings.
 If you need more control; use mmEffectEx() to specify rate, volume, and panning (and more).
 
mm_sfxhand mmEffectEx(mm_sound_effect *sound)
Plays a sound effect with custom settings.
Information for playing a sound effect.
Definition mm_types.h:236
mm_byte panning
Panning level. Ranges from 0 (far-left) to 255 (far-right).
Definition mm_types.h:259
mm_byte volume
Volume level. Ranges from 0 (silent) to 255 (normal).
Definition mm_types.h:256
mm_word id
ID of sample to be played. Values are defined in the soundbank header.
Definition mm_types.h:241
mm_hword rate
Playback rate. 6.10 fixed point number. (1024 = original sound)
Definition mm_types.h:249
mm_sfxhand handle
Handle of previous sound effect. If a valid handle is given, it will be recycled.
Definition mm_types.h:253
 mmEffect() and mmEffectEx() both return an mm_sfxhand type. This can be used to modify the sound effect while it's playing.
 
 
 
void mmEffectRate(mm_sfxhand handle, mm_word rate)
Changes the playback rate for a sound effect.
void mmEffectVolume(mm_sfxhand handle, mm_word volume)
Changes the volume of a sound effect.
void mmEffectPanning(mm_sfxhand handle, mm_byte panning)
Changes the panning of a sound effect.
 To stop an effect that's playing:
mm_word mmEffectCancel(mm_sfxhand handle)
Stops a sound effect. The handle will be invalidated.
 Sometimes the effect you just played isn't so important. You can mark it as a background effect with mmEffectRelease().
void mmEffectRelease(mm_sfxhand handle)
Marks a sound effect as unimportant.
 
Closing
For a better understanding, please have a look at the source code for the GBA examples.