arm-misc.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. * Misc ARM declarations
  3. *
  4. * Copyright (c) 2006 CodeSourcery.
  5. * Written by Paul Brook
  6. *
  7. * This code is licenced under the LGPL.
  8. *
  9. */
  10. #ifndef ARM_MISC_H
  11. #define ARM_MISC_H 1
  12. /* The CPU is also modeled as an interrupt controller. */
  13. #define ARM_PIC_CPU_IRQ 0
  14. #define ARM_PIC_CPU_FIQ 1
  15. qemu_irq *arm_pic_init_cpu(CPUState *env);
  16. /* armv7m.c */
  17. qemu_irq *armv7m_init(int flash_size, int sram_size,
  18. const char *kernel_filename, const char *cpu_model);
  19. /* arm_boot.c */
  20. struct arm_boot_info {
  21. int ram_size;
  22. const char *kernel_filename;
  23. const char *kernel_cmdline;
  24. const char *initrd_filename;
  25. target_phys_addr_t loader_start;
  26. int nb_cpus;
  27. int board_id;
  28. int (*atag_board)(struct arm_boot_info *info, void *p);
  29. };
  30. void arm_load_kernel(CPUState *env, struct arm_boot_info *info);
  31. /* armv7m_nvic.c */
  32. /* Multiplication factor to convert from system clock ticks to qemu timer
  33. ticks. */
  34. extern int system_clock_scale;
  35. qemu_irq *armv7m_nvic_init(CPUState *env);
  36. /* stellaris_enent.c */
  37. void stellaris_enet_init(NICInfo *nd, uint32_t base, qemu_irq irq);
  38. #endif /* !ARM_MISC_H */