summaryrefslogblamecommitdiff
path: root/README.txt
blob: d95258dbf5a6b89087c69fa73e5a1804f328d014 (plain) (tree)
1
2
3
4
5
6
7
8
      


                                   
                                                                              


                                                                              


                                                                              

                                                                             
 

                                                                               


       

                                                              
       




                                           
               
 
                                                                              


                                                               
                                                                  

       

                                                                        

      
                                                                                       


                                                                  




                                                                             
                          
                
                               
                     
                              
                     






                                                         


                              



                                                                               
                                                                            
                                                          
 
                                        
- LUMA

Copyright 2021-2023 Gabriel Jensen.

This program is free software: you can redistribute it and/or modify it under 
the terms of the GNU Affero General Public License as published by the Free 
Software Foundation, either version 3 of the License, or (at your option) any 
later version.

This program is distributed in the hope that it will be useful, but WITHOUT 
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS 
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more 
details.

You should have received a copy of the GNU Affero General Public License along 
with this program. If not, see <https://www.gnu.org/licenses/>. 

- ABOUT

luma is an emulator for the AGB - Game Boy Advance - platform.

- USAGE

luma [image] [bootloader]

Invoke the emulator via the 'luma' command.

- CONFIGURATION

The emulator tries to read the configuration file at '${HOME}/.luma.toml'. If 
this file is found, the following fields are read (if present):

luma:
 * version:    (Integer) The version of the configuration file (0)

device:
 * bootloader: (String)  The path to the bootloader file (home-relative)
 * image:      (String)  The path to the image file (home-relative)

video:
 * scale:      (Integer) The scale modifier applied to the screen (min 1; max (2^32-1))

These settings are overwritten by terminal parameters (see USAGE).

- COMPATIBILITY

Currently, the emulator supports the following ARM instructions only. Others 
will be skipped.

 * b{cond}{l} +/-offset_24
 * bx         Rm
 * ldr{cond}  Rn,  +/-offset_12
 * mov{cond}  Rd,  Rn
 * mov{cond}  Rd,  immediate_8
 * mov{cons}s r15, Rn
 * str{cond}  Rn,  +/-offset_12

Moreover, the following Thumb instructions are supported:

 * b          +/-offset_11
 * b{cond}    +/-offset_8
 * bx         Rm
 * mov        Rd,  Rn
 * movs       Rd,  immediate_8
 * movs       Rd,  Rn

When the virtual processor boots, the default mode is the sys mode. As no 
supported instruction can change this mode, this is also the only mode for now.

The entire memory space (0x00000000 to 0x0E010000, exclusive) is available, 
however, no I/O-mapped addresses are currently functional.

Improved support is, of course, planned.