In-place boot a Linux kernel from inside the Nspire operating system.
This version of the bootloader has been rewritten to be more stable, portable and flexible than the previous version.
Some big improvements include:
- Being able to load ramdisks and kernels larger than 4MB (up to ~40MB on the CX)
- This version does not need to relocate anything by default which means much higher stability
- Has a shell-like interface to set options for loading
- Scripting support
- Cleaner and more portable code
- Easy to port to other models
linuxloader.tns to your calculator and run it.
Valid commands are:
kernel <filename>: Loads a kernel image into memory
initrd <filename>: Loads a ramdisk into memory
dtb <filename>: Loads a DTB image into memory
script <filename>: Loads a script file
dump: Prints out the current internal state of the bootloader. Useful for debugging.
free: Prints out the total amount of memory provided to the bootloader by the Nspire OS and amounts used by the kernel and ramdisks.
cmdline [str]: Get/set the kernel command line parameters.
mach [id]: Get/set the machine ID that will be provided to Linux upon booting. Useful for overriding the builtin default value without having to recompile.
phys [<start> <size>]: Get/set the address and size of physical memory. Useful for overriding the builtin default value without having to recompile.
rdsize [size]: Get/set the size of the ramdisk that Linux should create on boot. Leave at
0x0for the kernel default.
probemem: If this is run on an calculator model that isn't directly supported by the bootloader, you can use this to try and guess how much memory the system has.
poke <addr> <value>: Write a word to an arbitrary location in the memory address space.
peek <addr>: Read a word from an arbitrary location in the memory address space.
boot: Boot kernel.
The bootloader is also scriptable. Create a text file containing a list of commands to be executed and change the extension to
.ll2.tns, and add the following line to your
/documents/ndless/ndless.cfg.tns file. Any line starting with
# will be considered a comment and ignored by the bootloader.
Then simply open your script file and the loader will execute all the commands in it. A sample one could look like this:
This should save a lot of typing everytime you need to boot Linux.
I've done my best to write nice, clean code but it is always open to improvements. Here are some notes for extending the bootloader to support more commands and models.
If you're having trouble compiling, try removing
-Werror from the CFLAGS.
Commands are defined in
cmd.c. Scroll down until you see a list of
DEFINE_COMMANDs. Just follow the example to add your own.
The bootloader's internal state is stored in a struct called
settings. It is defined in
common.h. Feel free to add your own bootloader variables but if you do, make sure you also update the
dump_settings() function in
common.c so it is dumped correctly.
Most of the code is already portable to other calculators. The only parameters that need adjusting are the ones passed to Linux such as the amount of physical memory and machine ID.
At the moment, they are hardcoded values for the CX. Code to detect and automatically set the correct values for different models needs to be written. They can be manually overrided using
phys commands until proper detection is implemented.
If you're interested in writing an implementation for it, look in
mach.c and implement the