dummy_m68k.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * Dummy board with just RAM and CPU for use as an ISS.
  3. *
  4. * Copyright (c) 2007 CodeSourcery.
  5. *
  6. * This code is licenced under the GPL
  7. */
  8. #include "hw.h"
  9. #include "sysemu.h"
  10. #include "boards.h"
  11. #define KERNEL_LOAD_ADDR 0x10000
  12. /* Board init. */
  13. static void dummy_m68k_init(ram_addr_t ram_size, int vga_ram_size,
  14. const char *boot_device,
  15. const char *kernel_filename, const char *kernel_cmdline,
  16. const char *initrd_filename, const char *cpu_model)
  17. {
  18. CPUState *env;
  19. int kernel_size;
  20. uint64_t elf_entry;
  21. target_ulong entry;
  22. if (!cpu_model)
  23. cpu_model = "cfv4e";
  24. env = cpu_init(cpu_model);
  25. if (!env) {
  26. fprintf(stderr, "Unable to find m68k CPU definition\n");
  27. exit(1);
  28. }
  29. /* Initialize CPU registers. */
  30. env->vbr = 0;
  31. /* RAM at address zero */
  32. cpu_register_physical_memory(0, ram_size,
  33. qemu_ram_alloc(ram_size) | IO_MEM_RAM);
  34. /* Load kernel. */
  35. if (kernel_filename) {
  36. kernel_size = load_elf(kernel_filename, 0, &elf_entry, NULL, NULL);
  37. entry = elf_entry;
  38. if (kernel_size < 0) {
  39. kernel_size = load_uimage(kernel_filename, &entry, NULL, NULL);
  40. }
  41. if (kernel_size < 0) {
  42. kernel_size = load_image(kernel_filename,
  43. phys_ram_base + KERNEL_LOAD_ADDR);
  44. entry = KERNEL_LOAD_ADDR;
  45. }
  46. if (kernel_size < 0) {
  47. fprintf(stderr, "qemu: could not load kernel '%s'\n",
  48. kernel_filename);
  49. exit(1);
  50. }
  51. } else {
  52. entry = 0;
  53. }
  54. env->pc = entry;
  55. }
  56. QEMUMachine dummy_m68k_machine = {
  57. .name = "dummy",
  58. .desc = "Dummy board",
  59. .init = dummy_m68k_init,
  60. };