hppa_hardware.h 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /* HPPA cores and system support chips. */
  2. /* Be aware: QEMU and seabios-hppa repositories share this file as-is. */
  3. #ifndef HW_HPPA_HPPA_HARDWARE_H
  4. #define HW_HPPA_HPPA_HARDWARE_H
  5. #define FIRMWARE_START 0xf0000000
  6. #define FIRMWARE_END 0xf0800000
  7. #define FIRMWARE_HIGH 0xfffffff0 /* upper 32-bits of 64-bit firmware address */
  8. #define RAM_MAP_HIGH 0x0100000000 /* memory above 3.75 GB is mapped here */
  9. #define MEM_PDC_ENTRY 0x4800 /* PDC entry address */
  10. #define DEVICE_HPA_LEN 0x00100000
  11. #define GSC_HPA 0xffc00000
  12. #define DINO_HPA 0xfff80000
  13. #define DINO_UART_HPA 0xfff83000
  14. #define DINO_UART_BASE 0xfff83800
  15. #define DINO_SCSI_HPA 0xfff8c000
  16. #define LASI_HPA 0xffd00000
  17. #define LASI_UART_HPA 0xffd05000
  18. #define LASI_SCSI_HPA 0xffd06000
  19. #define LASI_LAN_HPA 0xffd07000
  20. #define LASI_RTC_HPA 0xffd09000
  21. #define LASI_LPT_HPA 0xffd02000
  22. #define LASI_AUDIO_HPA 0xffd04000
  23. #define LASI_PS2KBD_HPA 0xffd08000
  24. #define LASI_PS2MOU_HPA 0xffd08100
  25. #define LASI_GFX_HPA 0xf8000000
  26. #define ARTIST_FB_ADDR 0xf9000000
  27. #define CPU_HPA 0xfffb0000
  28. #define MEMORY_HPA 0xfffff000
  29. #define IDE_HPA 0xf9000000 /* Boot disc controller */
  30. #define ASTRO_HPA 0xfed00000
  31. #define ELROY0_HPA 0xfed30000
  32. #define ELROY2_HPA 0xfed32000
  33. #define ELROY8_HPA 0xfed38000
  34. #define ELROYc_HPA 0xfed3c000
  35. #define ASTRO_MEMORY_HPA 0xfed10200
  36. #define SCSI_HPA 0xf1040000 /* emulated SCSI, needs to be in f region */
  37. /* offsets to DINO HPA: */
  38. #define DINO_PCI_ADDR 0x064
  39. #define DINO_CONFIG_DATA 0x068
  40. #define DINO_IO_DATA 0x06c
  41. #define PORT_PCI_CMD hppa_port_pci_cmd
  42. #define PORT_PCI_DATA hppa_port_pci_data
  43. #define FW_CFG_IO_BASE 0xfffa0000
  44. #define PORT_SERIAL1 (LASI_UART_HPA + 0x800)
  45. #define PORT_SERIAL2 (DINO_UART_HPA + 0x800)
  46. #define HPPA_MAX_CPUS 16 /* max. number of SMP CPUs */
  47. #define CPU_CLOCK_MHZ 250 /* emulate a 250 MHz CPU */
  48. #define CR_PSW_DEFAULT 6 /* used by SeaBIOS & QEMU for default PSW */
  49. #define CPU_HPA_CR_REG 7 /* store CPU HPA in cr7 (SeaBIOS internal) */
  50. #define PIM_STORAGE_SIZE 600 /* storage size of pdc_pim_toc_struct (64bit) */
  51. #define ASTRO_BUS_MODULE 0x0a /* C3700: 0x0a, others maybe 0 ? */
  52. /* ASTRO Memory and I/O regions */
  53. #define ASTRO_BASE_HPA 0xfffed00000
  54. #define ELROY0_BASE_HPA 0xfffed30000 /* ELROY0_HPA */
  55. #define ROPES_PER_IOC 8 /* per Ike half or Pluto/Astro */
  56. #define LMMIO_DIRECT0_BASE 0x300
  57. #define LMMIO_DIRECT0_MASK 0x308
  58. #define LMMIO_DIRECT0_ROUTE 0x310
  59. /* space register hashing */
  60. #define HPPA64_DIAG_SPHASH_ENABLE 0x200 /* DIAG_SPHASH_ENAB (bit 54) */
  61. #define HPPA64_PDC_CACHE_RET_SPID_VAL 0xfe0 /* PDC return value on 64-bit CPU */
  62. #endif