12345678910111213141516171819202122232425262728293031323334353637 |
- # -*- perl -*-
- #
- # I/O device configuration
- #
- # Common constants
- our %consts = (
- '_PC_RESET' => 0x10,
- '_PC_IRQ' => 0x20,
- 'SRAM_ADDR' => 0,
- 'SRAM_BITS' => 15,
- 'SDRAM_ADDR' => 0x40000000,
- 'SDRAM_BITS' => 25
- );
- # I/O address definitions
- our $xdev_addr_bits = 2;
- our $xdev_addr_shift = 28;
- our $iodev_addr_bits = 4;
- our $iodev_addr_shift = 7;
- # Special IRQs (CPU or non-device)
- our @sysirqs = ('timer', 'ebreak', 'buserr');
- # Define -irq to a string of 'e' (edge) or 'l' (level)
- # for a corresponding number of IRQs.
- our @iodevs = (
- { -name => 'sys' },
- { -name => 'sysclock', -irq => 'e' },
- { -name => 'console', -irq => 'l' },
- { -name => 'romcopy', -irq => 'l' },
- { -name => 'sdcard', -irq => 'l' },
- { -name => 'i2c', -irq => 'l' },
- { -name => 'esp', -irq => 'l' },
- { -name => 'abc', -irq => 'l' },
- { -name => 'abcmemmap', -xdev => 1 },
- );
|