amigaone.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438
  1. /*
  2. * QEMU Eyetech AmigaOne/Mai Logic Teron emulation
  3. *
  4. * Copyright (c) 2023 BALATON Zoltan
  5. *
  6. * This work is licensed under the GNU GPL license version 2 or later.
  7. *
  8. */
  9. #include "qemu/osdep.h"
  10. #include "qemu/units.h"
  11. #include "qemu/datadir.h"
  12. #include "qemu/log.h"
  13. #include "qemu/error-report.h"
  14. #include "qapi/error.h"
  15. #include "hw/ppc/ppc.h"
  16. #include "hw/boards.h"
  17. #include "hw/loader.h"
  18. #include "hw/pci-host/articia.h"
  19. #include "hw/isa/vt82c686.h"
  20. #include "hw/ide/pci.h"
  21. #include "hw/i2c/smbus_eeprom.h"
  22. #include "hw/ppc/ppc.h"
  23. #include "system/block-backend.h"
  24. #include "system/qtest.h"
  25. #include "system/reset.h"
  26. #include "kvm_ppc.h"
  27. #include "elf.h"
  28. #include <zlib.h> /* for crc32 */
  29. #define BUS_FREQ_HZ 100000000
  30. #define INITRD_MIN_ADDR 0x600000
  31. #define INIT_RAM_ADDR 0x40000000
  32. #define PCI_HIGH_ADDR 0x80000000
  33. #define PCI_HIGH_SIZE 0x7d000000
  34. #define PCI_LOW_ADDR 0xfd000000
  35. #define PCI_LOW_SIZE 0xe0000
  36. #define ARTICIA_ADDR 0xfe000000
  37. /*
  38. * Firmware binary available at
  39. * https://www.hyperion-entertainment.com/index.php/downloads?view=files&parent=28
  40. * then "tail -c 524288 updater.image >u-boot-amigaone.bin"
  41. *
  42. * BIOS emulator in firmware cannot run QEMU vgabios and hangs on it, use
  43. * -device VGA,romfile=VGABIOS-lgpl-latest.bin
  44. * from http://www.nongnu.org/vgabios/ instead.
  45. */
  46. #define PROM_ADDR 0xfff00000
  47. #define PROM_SIZE (512 * KiB)
  48. /* AmigaOS calls this routine from ROM, use this if no firmware loaded */
  49. static const char dummy_fw[] = {
  50. 0x54, 0x63, 0xc2, 0x3e, /* srwi r3,r3,8 */
  51. 0x7c, 0x63, 0x18, 0xf8, /* not r3,r3 */
  52. 0x4e, 0x80, 0x00, 0x20, /* blr */
  53. };
  54. #define NVRAM_ADDR 0xfd0e0000
  55. #define NVRAM_SIZE (4 * KiB)
  56. static const char default_env[] =
  57. "baudrate=115200\0"
  58. "stdout=vga\0"
  59. "stdin=ps2kbd\0"
  60. "bootcmd=boota; menu; run menuboot_cmd\0"
  61. "boot1=ide\0"
  62. "boot2=cdrom\0"
  63. "boota_timeout=3\0"
  64. "ide_doreset=on\0"
  65. "pci_irqa=9\0"
  66. "pci_irqa_select=level\0"
  67. "pci_irqb=10\0"
  68. "pci_irqb_select=level\0"
  69. "pci_irqc=11\0"
  70. "pci_irqc_select=level\0"
  71. "pci_irqd=7\0"
  72. "pci_irqd_select=level\0"
  73. "a1ide_irq=1111\0"
  74. "a1ide_xfer=FFFF\0";
  75. #define CRC32_DEFAULT_ENV 0xb5548481
  76. #define CRC32_ALL_ZEROS 0x603b0489
  77. #define TYPE_A1_NVRAM "a1-nvram"
  78. OBJECT_DECLARE_SIMPLE_TYPE(A1NVRAMState, A1_NVRAM)
  79. struct A1NVRAMState {
  80. SysBusDevice parent_obj;
  81. MemoryRegion mr;
  82. BlockBackend *blk;
  83. };
  84. static uint64_t nvram_read(void *opaque, hwaddr addr, unsigned int size)
  85. {
  86. /* read callback not used because of romd mode */
  87. g_assert_not_reached();
  88. }
  89. static void nvram_write(void *opaque, hwaddr addr, uint64_t val,
  90. unsigned int size)
  91. {
  92. A1NVRAMState *s = opaque;
  93. uint8_t *p = memory_region_get_ram_ptr(&s->mr);
  94. p[addr] = val;
  95. if (s->blk && blk_pwrite(s->blk, addr, 1, &val, 0) < 0) {
  96. error_report("%s: could not write %s", __func__, blk_name(s->blk));
  97. }
  98. }
  99. static const MemoryRegionOps nvram_ops = {
  100. .read = nvram_read,
  101. .write = nvram_write,
  102. .endianness = DEVICE_BIG_ENDIAN,
  103. .impl = {
  104. .min_access_size = 1,
  105. .max_access_size = 1,
  106. },
  107. };
  108. static void nvram_realize(DeviceState *dev, Error **errp)
  109. {
  110. A1NVRAMState *s = A1_NVRAM(dev);
  111. void *p;
  112. uint32_t crc, *c;
  113. memory_region_init_rom_device(&s->mr, NULL, &nvram_ops, s, "nvram",
  114. NVRAM_SIZE, &error_fatal);
  115. sysbus_init_mmio(SYS_BUS_DEVICE(dev), &s->mr);
  116. c = p = memory_region_get_ram_ptr(&s->mr);
  117. if (s->blk) {
  118. if (blk_getlength(s->blk) != NVRAM_SIZE) {
  119. error_setg(errp, "NVRAM backing file size must be %" PRId64 "bytes",
  120. NVRAM_SIZE);
  121. return;
  122. }
  123. blk_set_perm(s->blk, BLK_PERM_CONSISTENT_READ | BLK_PERM_WRITE,
  124. BLK_PERM_ALL, &error_fatal);
  125. if (blk_pread(s->blk, 0, NVRAM_SIZE, p, 0) < 0) {
  126. error_setg(errp, "Cannot read NVRAM contents from backing file");
  127. return;
  128. }
  129. }
  130. crc = crc32(0, p + 4, NVRAM_SIZE - 4);
  131. if (crc == CRC32_ALL_ZEROS) { /* If env is uninitialized set default */
  132. *c = cpu_to_be32(CRC32_DEFAULT_ENV);
  133. /* Also copies terminating \0 as env is terminated by \0\0 */
  134. memcpy(p + 4, default_env, sizeof(default_env));
  135. if (s->blk &&
  136. blk_pwrite(s->blk, 0, sizeof(crc) + sizeof(default_env), p, 0) < 0
  137. ) {
  138. error_report("%s: could not write %s", __func__, blk_name(s->blk));
  139. }
  140. return;
  141. }
  142. if (*c == 0) {
  143. *c = cpu_to_be32(crc32(0, p + 4, NVRAM_SIZE - 4));
  144. if (s->blk && blk_pwrite(s->blk, 0, 4, p, 0) < 0) {
  145. error_report("%s: could not write %s", __func__, blk_name(s->blk));
  146. }
  147. }
  148. if (be32_to_cpu(*c) != crc) {
  149. warn_report("NVRAM checksum mismatch");
  150. }
  151. }
  152. static const Property nvram_properties[] = {
  153. DEFINE_PROP_DRIVE("drive", A1NVRAMState, blk),
  154. };
  155. static void nvram_class_init(ObjectClass *oc, void *data)
  156. {
  157. DeviceClass *dc = DEVICE_CLASS(oc);
  158. dc->realize = nvram_realize;
  159. device_class_set_props(dc, nvram_properties);
  160. }
  161. static const TypeInfo nvram_types[] = {
  162. {
  163. .name = TYPE_A1_NVRAM,
  164. .parent = TYPE_SYS_BUS_DEVICE,
  165. .instance_size = sizeof(A1NVRAMState),
  166. .class_init = nvram_class_init,
  167. },
  168. };
  169. DEFINE_TYPES(nvram_types)
  170. struct boot_info {
  171. hwaddr entry;
  172. hwaddr stack;
  173. hwaddr bd_info;
  174. hwaddr initrd_start;
  175. hwaddr initrd_end;
  176. hwaddr cmdline_start;
  177. hwaddr cmdline_end;
  178. };
  179. /* Board info struct from U-Boot */
  180. struct bd_info {
  181. uint32_t bi_memstart;
  182. uint32_t bi_memsize;
  183. uint32_t bi_flashstart;
  184. uint32_t bi_flashsize;
  185. uint32_t bi_flashoffset;
  186. uint32_t bi_sramstart;
  187. uint32_t bi_sramsize;
  188. uint32_t bi_bootflags;
  189. uint32_t bi_ip_addr;
  190. uint8_t bi_enetaddr[6];
  191. uint16_t bi_ethspeed;
  192. uint32_t bi_intfreq;
  193. uint32_t bi_busfreq;
  194. uint32_t bi_baudrate;
  195. } QEMU_PACKED;
  196. static void create_bd_info(hwaddr addr, ram_addr_t ram_size)
  197. {
  198. struct bd_info *bd = g_new0(struct bd_info, 1);
  199. bd->bi_memsize = cpu_to_be32(ram_size);
  200. bd->bi_flashstart = cpu_to_be32(PROM_ADDR);
  201. bd->bi_flashsize = cpu_to_be32(1); /* match what U-Boot detects */
  202. bd->bi_bootflags = cpu_to_be32(1);
  203. bd->bi_intfreq = cpu_to_be32(11.5 * BUS_FREQ_HZ);
  204. bd->bi_busfreq = cpu_to_be32(BUS_FREQ_HZ);
  205. bd->bi_baudrate = cpu_to_be32(115200);
  206. cpu_physical_memory_write(addr, bd, sizeof(*bd));
  207. }
  208. static void amigaone_cpu_reset(void *opaque)
  209. {
  210. PowerPCCPU *cpu = opaque;
  211. CPUPPCState *env = &cpu->env;
  212. cpu_reset(CPU(cpu));
  213. if (env->load_info) {
  214. struct boot_info *bi = env->load_info;
  215. env->gpr[1] = bi->stack;
  216. env->gpr[2] = 1024;
  217. env->gpr[3] = bi->bd_info;
  218. env->gpr[4] = bi->initrd_start;
  219. env->gpr[5] = bi->initrd_end;
  220. env->gpr[6] = bi->cmdline_start;
  221. env->gpr[7] = bi->cmdline_end;
  222. env->nip = bi->entry;
  223. }
  224. cpu_ppc_tb_reset(env);
  225. }
  226. static void fix_spd_data(uint8_t *spd)
  227. {
  228. uint32_t bank_size = 4 * MiB * spd[31];
  229. uint32_t rows = bank_size / spd[13] / spd[17];
  230. spd[3] = ctz32(rows) - spd[4];
  231. }
  232. static void amigaone_init(MachineState *machine)
  233. {
  234. PowerPCCPU *cpu;
  235. CPUPPCState *env;
  236. MemoryRegion *rom, *pci_mem, *mr;
  237. ssize_t sz;
  238. PCIBus *pci_bus;
  239. Object *via;
  240. DeviceState *dev;
  241. I2CBus *i2c_bus;
  242. uint8_t *spd_data;
  243. DriveInfo *di;
  244. hwaddr loadaddr;
  245. struct boot_info *bi = NULL;
  246. /* init CPU */
  247. cpu = POWERPC_CPU(cpu_create(machine->cpu_type));
  248. env = &cpu->env;
  249. if (PPC_INPUT(env) != PPC_FLAGS_INPUT_6xx) {
  250. error_report("Incompatible CPU, only 6xx bus supported");
  251. exit(1);
  252. }
  253. cpu_ppc_tb_init(env, BUS_FREQ_HZ / 4);
  254. qemu_register_reset(amigaone_cpu_reset, cpu);
  255. /* RAM */
  256. if (machine->ram_size > 2 * GiB) {
  257. error_report("RAM size more than 2 GiB is not supported");
  258. exit(1);
  259. }
  260. memory_region_add_subregion(get_system_memory(), 0, machine->ram);
  261. if (machine->ram_size < 1 * GiB + 32 * KiB) {
  262. /* Firmware uses this area for startup */
  263. mr = g_new(MemoryRegion, 1);
  264. memory_region_init_ram(mr, NULL, "init-cache", 32 * KiB, &error_fatal);
  265. memory_region_add_subregion(get_system_memory(), INIT_RAM_ADDR, mr);
  266. }
  267. /* nvram */
  268. dev = qdev_new(TYPE_A1_NVRAM);
  269. di = drive_get(IF_MTD, 0, 0);
  270. if (di) {
  271. qdev_prop_set_drive(dev, "drive", blk_by_legacy_dinfo(di));
  272. }
  273. sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal);
  274. memory_region_add_subregion(get_system_memory(), NVRAM_ADDR,
  275. sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0));
  276. /* allocate and load firmware */
  277. rom = g_new(MemoryRegion, 1);
  278. memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, &error_fatal);
  279. memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
  280. if (!machine->firmware) {
  281. rom_add_blob_fixed("dummy-fw", dummy_fw, sizeof(dummy_fw),
  282. PROM_ADDR + PROM_SIZE - 0x80);
  283. } else {
  284. g_autofree char *filename = qemu_find_file(QEMU_FILE_TYPE_BIOS,
  285. machine->firmware);
  286. if (!filename) {
  287. error_report("Could not find firmware '%s'", machine->firmware);
  288. exit(1);
  289. }
  290. sz = load_image_targphys(filename, PROM_ADDR, PROM_SIZE);
  291. if (sz <= 0 || sz > PROM_SIZE) {
  292. error_report("Could not load firmware '%s'", filename);
  293. exit(1);
  294. }
  295. }
  296. /* Articia S */
  297. dev = sysbus_create_simple(TYPE_ARTICIA, ARTICIA_ADDR, NULL);
  298. i2c_bus = I2C_BUS(qdev_get_child_bus(dev, "smbus"));
  299. if (machine->ram_size > 512 * MiB) {
  300. spd_data = spd_data_generate(SDR, machine->ram_size / 2);
  301. } else {
  302. spd_data = spd_data_generate(SDR, machine->ram_size);
  303. }
  304. fix_spd_data(spd_data);
  305. smbus_eeprom_init_one(i2c_bus, 0x51, spd_data);
  306. if (machine->ram_size > 512 * MiB) {
  307. smbus_eeprom_init_one(i2c_bus, 0x52, spd_data);
  308. }
  309. pci_mem = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 1);
  310. mr = g_new(MemoryRegion, 1);
  311. memory_region_init_alias(mr, OBJECT(dev), "pci-mem-low", pci_mem,
  312. 0, PCI_LOW_SIZE);
  313. memory_region_add_subregion(get_system_memory(), PCI_LOW_ADDR, mr);
  314. mr = g_new(MemoryRegion, 1);
  315. memory_region_init_alias(mr, OBJECT(dev), "pci-mem-high", pci_mem,
  316. PCI_HIGH_ADDR, PCI_HIGH_SIZE);
  317. memory_region_add_subregion(get_system_memory(), PCI_HIGH_ADDR, mr);
  318. pci_bus = PCI_BUS(qdev_get_child_bus(dev, "pci.0"));
  319. /* VIA VT82c686B South Bridge (multifunction PCI device) */
  320. via = OBJECT(pci_create_simple_multifunction(pci_bus, PCI_DEVFN(7, 0),
  321. TYPE_VT82C686B_ISA));
  322. object_property_add_alias(OBJECT(machine), "rtc-time",
  323. object_resolve_path_component(via, "rtc"),
  324. "date");
  325. qdev_connect_gpio_out_named(DEVICE(via), "intr", 0,
  326. qdev_get_gpio_in(DEVICE(cpu),
  327. PPC6xx_INPUT_INT));
  328. for (int i = 0; i < PCI_NUM_PINS; i++) {
  329. qdev_connect_gpio_out(dev, i, qdev_get_gpio_in_named(DEVICE(via),
  330. "pirq", i));
  331. }
  332. pci_ide_create_devs(PCI_DEVICE(object_resolve_path_component(via, "ide")));
  333. pci_vga_init(pci_bus);
  334. if (!machine->kernel_filename) {
  335. return;
  336. }
  337. /* handle -kernel, -initrd, -append options and emulate U-Boot */
  338. bi = g_new0(struct boot_info, 1);
  339. cpu->env.load_info = bi;
  340. loadaddr = MIN(machine->ram_size, 256 * MiB);
  341. bi->bd_info = loadaddr - 8 * MiB;
  342. create_bd_info(bi->bd_info, machine->ram_size);
  343. bi->stack = bi->bd_info - 64 * KiB - 8;
  344. if (machine->kernel_cmdline && machine->kernel_cmdline[0]) {
  345. size_t len = strlen(machine->kernel_cmdline);
  346. loadaddr = bi->bd_info + 1 * MiB;
  347. cpu_physical_memory_write(loadaddr, machine->kernel_cmdline, len + 1);
  348. bi->cmdline_start = loadaddr;
  349. bi->cmdline_end = loadaddr + len + 1; /* including terminating '\0' */
  350. }
  351. sz = load_elf(machine->kernel_filename, NULL, NULL, NULL,
  352. &bi->entry, &loadaddr, NULL, NULL,
  353. ELFDATA2MSB, PPC_ELF_MACHINE, 0, 0);
  354. if (sz <= 0) {
  355. sz = load_uimage(machine->kernel_filename, &bi->entry, &loadaddr,
  356. NULL, NULL, NULL);
  357. }
  358. if (sz <= 0) {
  359. error_report("Could not load kernel '%s'",
  360. machine->kernel_filename);
  361. exit(1);
  362. }
  363. loadaddr += sz;
  364. if (machine->initrd_filename) {
  365. loadaddr = ROUND_UP(loadaddr + 4 * MiB, 4 * KiB);
  366. loadaddr = MAX(loadaddr, INITRD_MIN_ADDR);
  367. sz = load_image_targphys(machine->initrd_filename, loadaddr,
  368. bi->bd_info - loadaddr);
  369. if (sz <= 0) {
  370. error_report("Could not load initrd '%s'",
  371. machine->initrd_filename);
  372. exit(1);
  373. }
  374. bi->initrd_start = loadaddr;
  375. bi->initrd_end = loadaddr + sz;
  376. }
  377. }
  378. static void amigaone_machine_init(MachineClass *mc)
  379. {
  380. mc->desc = "Eyetech AmigaOne/Mai Logic Teron";
  381. mc->init = amigaone_init;
  382. mc->block_default_type = IF_IDE;
  383. mc->default_cpu_type = POWERPC_CPU_TYPE_NAME("7457_v1.2");
  384. mc->default_display = "std";
  385. mc->default_ram_id = "ram";
  386. mc->default_ram_size = 512 * MiB;
  387. }
  388. DEFINE_MACHINE("amigaone", amigaone_machine_init)