2eff5a6c63
Kconfig files. Repartition some functionality. Bootloader support will need to be provided in logic under arch/z80/src/ez80 so the critical configuration selections were moved the Kconfig file there. arch/z80/src/ez80/ez80_i2c.h: Rename arch/z80/src/ez80/ez80f91_i2c.h. It is sharable by both ez80f91 and ez80f92. arch/z80/src/ez80/: Add logic to perform an additional level of interrupt redirection. This is necessary because the the interrupt handling is part of the loader FLASH-based logic. In order to share interrupts with the program loaded into RAM by the loader, another layer or redirection is required to get control to the interrupt handlers in the loaded program. See ez809f2_loader.asm and ez80f92_program.asm boards/z80/ez80/z20x/scripts: Reduce size of the interrupt re-direction buffer from 1Kb to 512b. |
||
---|---|---|
.. | ||
configs | ||
include | ||
scripts | ||
src | ||
Kconfig | ||
README.txt |
README.txt ========== Z20X is a simple expandable DIY computing system, built around the eZ80 microprocessor. The eZ80 was chosen due to its native simplicity and full backward code compatibility with the great and very popular Z80 and Z180. The design goal of Z20X is to offer a good DIY/LIY (Do-It-Yourself/Learn- It-Yourself) kit for system built with through-hole components, simple enough for assembly and learning in deep details, but without the constraints of using only old technology ICs. In order to maintain full exposure to technical details, the system also avoids using secondary MCUs or programmable logic, and sticks only with true hardware solutions. System Summary eZ80 running at 20 MHz (default on board) 128 KB flash ROM (internal for eZ80) 520 KB total RAM on board (512K external plus 8K internal) 4 MB non-volatile storage (optional, can be upgraded by changing the IC) Real-time clock SSD1963-powered 7.0 inch TFT display with resolution 800 x 480 pixels and touch panel SD card slot YM2413 programmable sound generator with amplifier PS/2 connectors for industry standard keyboard and mouse Additionally installable processor modules 72-pin expansion header with Z20X bus Optional expander board with Z20X bus sockets and bonus support for RC2014 bus Contents ======== o ZDS-II Compiler Versions o Environments o Memory Constaints o Serial Console o LEDs and Buttons - LEDs - Buttons o Configurations - Common Configuration Notes - Configuration Subdirectories ZDS-II Compiler Versions ======================== Version 5.3.3 As of this writing, this is the latest version available. This is the default configured for all ez80 boards. Compilation using version 5.3.3 was verified on February 20, 2020. Version 5.3.0 Compilation using version 5.3.0 was verified on February 19, 2020. Other Versions If you use any version of ZDS-II other than 5.3.0/3 or if you install ZDS-II at any location other than the default location, you will have to modify three files: (1) arch/arm/z80/src/ez80/Kconfig, (2) boards/z80/ez80/z20x/scripts/Make.defs and, perhaps, (3) arch/z80/src/ez80/Toolchain.defs. Environments ============ Cygwin: All testing was done using the Cygwin environment under Windows. MinGW/MSYS One attempt was made using the MSYS2 environment under Windws. That build correctly until the very end, then it failed to include "chip.h". this was traced to arch/z80/src/Makefile.zdsiil: The usrinc paths created by Makefile.zdsiil contained POSIX-style paths that were not usable to the ZDS-II compiler. Native The Windows native build has not been attempt. I would expect that it would have numerous problems. Memory Constaints ================= The eZ80F92 has a smaller FLASH memory of 128Kb. That combined with the fact that the size of NuttX is increasing means that it is very easy to exceed the ROM address space. The sdboot configuration will fit into the ROM address space, but NOT if you enable assertions, debug outputs, or even debug symbols. Serial Console ============== The eZ80 has two UART peripherals: UART 0: All of Port D pins can support UART0 functions when configured for the alternate function 7. For typical configurations only RXD and TXD need be configured. eZ80 PIN =============== PD0/TXD0/IR_IXD PD1/RXD0/IR_RXD PD2/RTS0 PD3/CTS0 PD4/DTR0 PD5/DSR0 PD6/DCD0 PD7/RIO0 PD0 and PD1 connect to the PS/2 keyboard connector. UART 1: All of Port C pins can support UART1 functions when configured for the alternate function 7. For typical configurations only RXD and TXD need be configured. eZ80 PIN ======== PC0/TXD1 PC1/RXD1 PC2/RTS1 PC3/CTS1 PC4/DTR1 PC5/DSR1 PC6/DCD1 PC7/RIO1 PC0 and PC1 connect both to the MCP2221 UART-to-USB converter and also to the PS/2 mouse connector. UART1 is the default serial console in all configurations unless otherwise noted in the description of the configuration. LEDs and Buttons ================ There are no on-board user LEDs or buttons. Configurations ============== Common Configuration Notes -------------------------- 1. src/ and include/ These directories contain common logic for all z20x configurations. 2. Variations on the basic z20x configuration are maintained in subdirectories. To configure any specific configuration, do the following steps: tools/configure.sh [OPTIONS] z20x:<sub-directory> make Where <sub-directory> is the specific board configuration that you wish to build. Use 'tools/configure.sh -h' to see the possible options. Typical options are: -l Configure for a Linux host -c Configure for a Windows Cygwin host -g Configure for a Windows MYS2 host Use configure.bat instead of configure.sh if you are building in a native Windows environment. The available board-specific configurations are summarized in the following paragraphs. When the build completes successfully, you will find this files in the top level nuttx directory: a. nuttx.hex - A loadable file in Intel HEX format b. nuttx.lod - A loadable file in ZDS-II binary format c. nuttx.map - A linker map file 3. ZDS-II make be used to write the nuttx.lod file to FLASH. General instructions: a. Start ZDS-II b. Open the project, for example, nsh/nsh.zdsproj c. Select Debug->Connect To Target d. Select Debug->Download code There are projects for the ZiLOG Smart Flash Programmer as well but these are not functional as of this writing. 4. This configuration uses the mconf-based configuration tool. To change this configurations using that tool, you should: a. Build and install the kconfig-mconf tool. See nuttx/README.txt see additional README.txt files in the NuttX tools repository. b. Execute 'make menuconfig' in nuttx/ in order to start the reconfiguration process. Configuration Subdirectories ---------------------------- nsh_ram: This configuration builds the NuttShell (NSH). That code can be found in apps/system/nsh and apps/system/nshlib.. For more information see: apps/system/nsh/README.txt and Documentation/NuttShell.html. NOTES: 1. This configuration builds for execution entirely from RAM. A bootloader of some kind is required to support such execution from RAM! This is reflected in a single configuration setting: CONFIG_BOOT_RUNFROMEXTSRAM=y # Execute from external SRAM Why execute from SRAM? Because you will get MUCH better performance because of the zero wait state SRAM implementation and you will not be constrained by the eZ80F92's small FLASH size. 2. The eZ80 RTC, the procFS file system, and SD card support in included. The procFS file system will be auto-mounted at /proc when the board boots. The RTC can be read and set from the NSH date command. nsh> date Thu, Dec 19 20:53:29 2086 nsh> help date date usage: date [-s "MMM DD HH:MM:SS YYYY"] nsh> date -s "Jun 16 15:09:00 2019" nsh> date Sun, Jun 16 15:09:01 2019 When the system boots, it will probe the SD card and create a block driver called mmcsd0: nsh> ls /dev /dev: console mmcsd0 null ttyS0 nsh> mount /proc type procfs The SD card can be mounted with the following NSH mount command: nsh> mount -t vfat /dev/mmcsd0 /mnt/sdcard nsh> ls /mnt /mnt: sdcard/ nsh> mount /mnt/sdcard type vfat /proc type procfs nsh> ls -lR /mnt/sdcard /mnt/sdcard: drw-rw-rw- 0 System Volume Information/ /mnt/sdcard/System Volume Information: -rw-rw-rw- 76 IndexerVolumeGuid -rw-rw-rw- 12 WPSettings.dat You can they use the SD card as any other file system. nsh> ls /mnt/sdcard /mnt/sdcard: System Volume Information/ nsh> echo "This is a test" >/mnt/sdcard/atest.txt nsh> ls /mnt/sdcard /mnt/sdcard: System Volume Information/ atest.txt nsh> cat /mnt/sdcard/atest.txt This is a test Don't forget to un-mount the volume before power cycling: nsh> mount /mnt/sdcard type vfat /proc type procfs nsh> umount /mnt/sdcard nsh> mount /proc type procfs NOTE: The is no card detect signal so the microSD card must be placed in the card slot before the system is started. 3. Debugging the RAM version You can debug the all RAM version using ZDS-II as follows: a. Connect to the debugger, b. Reset, Go, and Break. This will initialize the external RAM c. Break and Load the nuttx.lod file c. Set the PC to 0x040000 d. Single step a few times to make sure things look good, then e. Go 4. Optimizations: - The stack sizes have not been tuned and, hence, are probably too large. sdboot This configuration implements a very simple boot loader. In runs from FLASH and simply initializes the external SRAM, mounts the FAT file system on the SD card, and checks to see if there is a file called nuttx.hex on the SD card. If so, it will load the Intel HEX file into memory and jump to address 0x040000. This, of course, assumes that the application's reset vector resides at address 0x040000 in external SRAM. The boot loader source is located at boards/z20x/src/sd_main.c. NOTES: 1. This version of the eZ80 bootloader is not usable in its current state. That is because the the eZ80F92 Interrupt Controller is not as robust as the eZ80F91 Interrupt Controller. A consequence is that the interrupt vectors must always reside within the first 64Kb of FLASH memory. It will not be possible to run programs in SRAM *unless* some mechanism is developed to redirect interrupts from ROM and into loaded SRAM logic. For example, it might be possible to implement this kind of vectoring to get to a RAM based interrupt handler: a. The initial 16-bit address in the interrupt vector table can transfer the interrupt to a larger jump table also in lower flash memory. b. That jump table could vector to another jump table at a known location RAM. c. The RAM jump table could then jump to the final RAM-based interrupt handler. This would effect the logic in arch/z80/src/ez80/ez80f92_handlers.am and possible the z20x *.linkcmd files. 2. Another thing that would have to be done before this configuration would be usable is to partition the external in some way so that there is no collision between the bootloader's use of SRAM and the SRAM required by the newly loaded program.