grlib.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * QEMU GRLIB Components
  3. *
  4. * Copyright (c) 2010-2011 AdaCore
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining a copy
  7. * of this software and associated documentation files (the "Software"), to deal
  8. * in the Software without restriction, including without limitation the rights
  9. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  10. * copies of the Software, and to permit persons to whom the Software is
  11. * furnished to do so, subject to the following conditions:
  12. *
  13. * The above copyright notice and this permission notice shall be included in
  14. * all copies or substantial portions of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  19. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  21. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  22. * THE SOFTWARE.
  23. */
  24. #ifndef GRLIB_H
  25. #define GRLIB_H
  26. #include "hw/qdev.h"
  27. #include "hw/sysbus.h"
  28. /* Emulation of GrLib device is base on the GRLIB IP Core User's Manual:
  29. * http://www.gaisler.com/products/grlib/grip.pdf
  30. */
  31. /* IRQMP */
  32. typedef void (*set_pil_in_fn) (void *opaque, uint32_t pil_in);
  33. void grlib_irqmp_set_irq(void *opaque, int irq, int level);
  34. void grlib_irqmp_ack(DeviceState *dev, int intno);
  35. static inline
  36. DeviceState *grlib_irqmp_create(hwaddr base,
  37. CPUSPARCState *env,
  38. qemu_irq **cpu_irqs,
  39. uint32_t nr_irqs,
  40. set_pil_in_fn set_pil_in)
  41. {
  42. DeviceState *dev;
  43. assert(cpu_irqs != NULL);
  44. dev = qdev_create(NULL, "grlib,irqmp");
  45. qdev_prop_set_ptr(dev, "set_pil_in", set_pil_in);
  46. qdev_prop_set_ptr(dev, "set_pil_in_opaque", env);
  47. qdev_init_nofail(dev);
  48. env->irq_manager = dev;
  49. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  50. *cpu_irqs = qemu_allocate_irqs(grlib_irqmp_set_irq,
  51. dev,
  52. nr_irqs);
  53. return dev;
  54. }
  55. /* GPTimer */
  56. static inline
  57. DeviceState *grlib_gptimer_create(hwaddr base,
  58. uint32_t nr_timers,
  59. uint32_t freq,
  60. qemu_irq *cpu_irqs,
  61. int base_irq)
  62. {
  63. DeviceState *dev;
  64. int i;
  65. dev = qdev_create(NULL, "grlib,gptimer");
  66. qdev_prop_set_uint32(dev, "nr-timers", nr_timers);
  67. qdev_prop_set_uint32(dev, "frequency", freq);
  68. qdev_prop_set_uint32(dev, "irq-line", base_irq);
  69. qdev_init_nofail(dev);
  70. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  71. for (i = 0; i < nr_timers; i++) {
  72. sysbus_connect_irq(SYS_BUS_DEVICE(dev), i, cpu_irqs[base_irq + i]);
  73. }
  74. return dev;
  75. }
  76. /* APB UART */
  77. static inline
  78. DeviceState *grlib_apbuart_create(hwaddr base,
  79. CharDriverState *serial,
  80. qemu_irq irq)
  81. {
  82. DeviceState *dev;
  83. dev = qdev_create(NULL, "grlib,apbuart");
  84. qdev_prop_set_chr(dev, "chrdev", serial);
  85. qdev_init_nofail(dev);
  86. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  87. sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, irq);
  88. return dev;
  89. }
  90. #endif /* GRLIB_H */