Difference between revisions of "Boot Sequence"

From SpecNext official Wiki
Jump to: navigation, search
m (2 revisions imported)
Line 5: Line 5:
 
* If this is not the case, the main core is reloaded into the FPGA from flash memory, which includes the IPL (Initial Program Loader) in RAM. The IPL displays the message "Loading..." (which appears only very briefly) and loads the file '''TBBLUE.FW''' from the root of the SD card. If this fails, an error message is displayed ("Error initializing SD card!"), the border turns red, and the code loops.
 
* If this is not the case, the main core is reloaded into the FPGA from flash memory, which includes the IPL (Initial Program Loader) in RAM. The IPL displays the message "Loading..." (which appears only very briefly) and loads the file '''TBBLUE.FW''' from the root of the SD card. If this fails, an error message is displayed ("Error initializing SD card!"), the border turns red, and the code loops.
  
* TBBLUE.FW contains 3 modules; by default the boot module is loaded. It reads the file '''TBBLUE\CONFIG.INI''' from the SD card and uses it to configure the default machine settings. It then loads 3 ROM images from the SD card: one for the DivMMC interface, one for the Multiface, and one for the Spectrum ROM itself. The DivMMC ROM seems to always be loaded from '''TBBLUE\ESXMMC.ROM'''; the Multiface ROM is loaded from one of four potential files in the '''TBBLUE''' directory and it is not clear how they are selected; and the Spectrum ROM is loaded from the file named for the given configuration in the CONFIG.INI file.
+
* TBBLUE.FW contains 3 modules; by default the boot module is loaded. It reads the file '''TBBLUE\CONFIG.INI''' from the SD card and uses it to configure the default machine settings. It then loads 3 ROM images from the SD card: one for the DivMMC interface, one for the Multiface, and one for the Spectrum ROM itself. The DivMMC ROM seems to always be loaded from '''TBBLUE\ESXMMC.ROM'''; the Multiface ROM is loaded from one of four potential files in the '''TBBLUE''' directory and it is not clear how they are selected; and the Spectrum ROM is loaded from the file named for the given configuration in the CONFIG.INI file.
  
 
* The TBBLUE loader then write-protects the areas of ROM, maps the addressable memory to the standard Spectrum layout, and resets the CPU.
 
* The TBBLUE loader then write-protects the areas of ROM, maps the addressable memory to the standard Spectrum layout, and resets the CPU.

Revision as of 17:09, 4 April 2020

The following is the assembled information about the startup sequence of the Spectrum Next.

  • When the machine is first switched on, the Anti-brick system loads a fixed Spectrum 48k and checks to see if a particular combination of physical buttons is being held down. If it does, the updater module (see below) is loaded from the SD card and run on the anti-brick core.
  • If this is not the case, the main core is reloaded into the FPGA from flash memory, which includes the IPL (Initial Program Loader) in RAM. The IPL displays the message "Loading..." (which appears only very briefly) and loads the file TBBLUE.FW from the root of the SD card. If this fails, an error message is displayed ("Error initializing SD card!"), the border turns red, and the code loops.
  • TBBLUE.FW contains 3 modules; by default the boot module is loaded. It reads the file TBBLUE\CONFIG.INI from the SD card and uses it to configure the default machine settings. It then loads 3 ROM images from the SD card: one for the DivMMC interface, one for the Multiface, and one for the Spectrum ROM itself. The DivMMC ROM seems to always be loaded from TBBLUE\ESXMMC.ROM; the Multiface ROM is loaded from one of four potential files in the TBBLUE directory and it is not clear how they are selected; and the Spectrum ROM is loaded from the file named for the given configuration in the CONFIG.INI file.
  • The TBBLUE loader then write-protects the areas of ROM, maps the addressable memory to the standard Spectrum layout, and resets the CPU.
  • The standard ROM setup is interrupted by DivMMC (how?) which runs the ESXDOS setup. This loads four files: SYS\ESXDOS.SYS, SYS\NMI.SYS, SYS\RTC.SYS and SYS\BETADISK.SYS. These are the user-layer software for ESXDOS, the NMI (non-maskable interrupt) driver for the DivMMC button, a real-time clock driver (?) and a TRDos Emulator layer for ESXDos.
  • The remaining Spectrum ROM setup runs, clearing the ULA screen and producing the Sinclair copyright message.