setup.c 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * arch/sh/boards/dreamcast/setup.c
  3. *
  4. * Hardware support for the Sega Dreamcast.
  5. *
  6. * Copyright (c) 2001, 2002 M. R. Brown <mrbrown@linuxdc.org>
  7. * Copyright (c) 2002, 2003, 2004 Paul Mundt <lethal@linux-sh.org>
  8. *
  9. * This file is part of the LinuxDC project (www.linuxdc.org)
  10. *
  11. * Released under the terms of the GNU GPL v2.0.
  12. *
  13. * This file originally bore the message (with enclosed-$):
  14. * Id: setup_dc.c,v 1.5 2001/05/24 05:09:16 mrbrown Exp
  15. * SEGA Dreamcast support
  16. */
  17. #include <linux/sched.h>
  18. #include <linux/kernel.h>
  19. #include <linux/param.h>
  20. #include <linux/interrupt.h>
  21. #include <linux/init.h>
  22. #include <linux/irq.h>
  23. #include <linux/device.h>
  24. #include <asm/io.h>
  25. #include <asm/irq.h>
  26. #include <asm/machvec.h>
  27. #include <asm/machvec_init.h>
  28. #include <asm/mach/sysasic.h>
  29. extern struct hw_interrupt_type systemasic_int;
  30. /* XXX: Move this into it's proper header. */
  31. extern void (*board_time_init)(void);
  32. extern void aica_time_init(void);
  33. extern int gapspci_init(void);
  34. extern int systemasic_irq_demux(int);
  35. void *dreamcast_consistent_alloc(struct device *, size_t, dma_addr_t *, int);
  36. int dreamcast_consistent_free(struct device *, size_t, void *, dma_addr_t);
  37. const char *get_system_type(void)
  38. {
  39. return "Sega Dreamcast";
  40. }
  41. struct sh_machine_vector mv_dreamcast __initmv = {
  42. .mv_nr_irqs = NR_IRQS,
  43. .mv_irq_demux = systemasic_irq_demux,
  44. #ifdef CONFIG_PCI
  45. .mv_consistent_alloc = dreamcast_consistent_alloc,
  46. .mv_consistent_free = dreamcast_consistent_free,
  47. #endif
  48. };
  49. ALIAS_MV(dreamcast)
  50. int __init platform_setup(void)
  51. {
  52. int i;
  53. /* Mask all hardware events */
  54. /* XXX */
  55. /* Acknowledge any previous events */
  56. /* XXX */
  57. __set_io_port_base(0xa0000000);
  58. /* Assign all virtual IRQs to the System ASIC int. handler */
  59. for (i = HW_EVENT_IRQ_BASE; i < HW_EVENT_IRQ_MAX; i++)
  60. irq_desc[i].handler = &systemasic_int;
  61. board_time_init = aica_time_init;
  62. #ifdef CONFIG_PCI
  63. if (gapspci_init() < 0)
  64. printk(KERN_WARNING "GAPSPCI was not detected.\n");
  65. #endif
  66. return 0;
  67. }