2
0

grlib.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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 "qdev.h"
  27. #include "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. if (qdev_init(dev)) {
  48. return NULL;
  49. }
  50. env->irq_manager = dev;
  51. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  52. *cpu_irqs = qemu_allocate_irqs(grlib_irqmp_set_irq,
  53. dev,
  54. nr_irqs);
  55. return dev;
  56. }
  57. /* GPTimer */
  58. static inline
  59. DeviceState *grlib_gptimer_create(hwaddr base,
  60. uint32_t nr_timers,
  61. uint32_t freq,
  62. qemu_irq *cpu_irqs,
  63. int base_irq)
  64. {
  65. DeviceState *dev;
  66. int i;
  67. dev = qdev_create(NULL, "grlib,gptimer");
  68. qdev_prop_set_uint32(dev, "nr-timers", nr_timers);
  69. qdev_prop_set_uint32(dev, "frequency", freq);
  70. qdev_prop_set_uint32(dev, "irq-line", base_irq);
  71. if (qdev_init(dev)) {
  72. return NULL;
  73. }
  74. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  75. for (i = 0; i < nr_timers; i++) {
  76. sysbus_connect_irq(SYS_BUS_DEVICE(dev), i, cpu_irqs[base_irq + i]);
  77. }
  78. return dev;
  79. }
  80. /* APB UART */
  81. static inline
  82. DeviceState *grlib_apbuart_create(hwaddr base,
  83. CharDriverState *serial,
  84. qemu_irq irq)
  85. {
  86. DeviceState *dev;
  87. dev = qdev_create(NULL, "grlib,apbuart");
  88. qdev_prop_set_chr(dev, "chrdev", serial);
  89. if (qdev_init(dev)) {
  90. return NULL;
  91. }
  92. sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, base);
  93. sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, irq);
  94. return dev;
  95. }
  96. #endif /* ! _GRLIB_H_ */