com_isapnp.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. /* $OpenBSD: com_isapnp.c,v 1.4 2008/04/27 09:29:40 kettenis Exp $ */
  2. /*
  3. * Copyright (c) 1997 - 1999, Jason Downs. All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name(s) of the author(s) nor the name OpenBSD
  14. * may be used to endorse or promote products derived from this software
  15. * without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS
  18. * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  19. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  20. * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT,
  21. * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  22. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  23. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  24. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  25. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  26. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  27. * SUCH DAMAGE.
  28. */
  29. /*-
  30. * Copyright (c) 1993, 1994, 1995, 1996
  31. * Charles M. Hannum. All rights reserved.
  32. * Copyright (c) 1991 The Regents of the University of California.
  33. * All rights reserved.
  34. *
  35. * Redistribution and use in source and binary forms, with or without
  36. * modification, are permitted provided that the following conditions
  37. * are met:
  38. * 1. Redistributions of source code must retain the above copyright
  39. * notice, this list of conditions and the following disclaimer.
  40. * 2. Redistributions in binary form must reproduce the above copyright
  41. * notice, this list of conditions and the following disclaimer in the
  42. * documentation and/or other materials provided with the distribution.
  43. * 3. Neither the name of the University nor the names of its contributors
  44. * may be used to endorse or promote products derived from this software
  45. * without specific prior written permission.
  46. *
  47. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  48. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  49. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  50. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  51. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  52. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  53. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  54. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  55. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  56. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  57. * SUCH DAMAGE.
  58. *
  59. * @(#)com.c 7.5 (Berkeley) 5/16/91
  60. */
  61. #include <sys/param.h>
  62. #include <sys/systm.h>
  63. #include <sys/tty.h>
  64. #include <sys/device.h>
  65. #include <machine/intr.h>
  66. #include <machine/bus.h>
  67. #include <dev/ic/comreg.h>
  68. #include <dev/ic/comvar.h>
  69. #include <dev/isa/isavar.h>
  70. int com_isapnp_probe(struct device *, void *, void *);
  71. void com_isapnp_attach(struct device *, struct device *, void *);
  72. struct cfattach com_isapnp_ca = {
  73. sizeof(struct com_softc), com_isapnp_probe, com_isapnp_attach
  74. };
  75. int
  76. com_isapnp_probe(struct device *parent, void *match, void *aux)
  77. {
  78. struct isa_attach_args *ia = aux;
  79. bus_space_tag_t iot;
  80. bus_space_handle_t ioh;
  81. int iobase;
  82. iot = ia->ia_iot;
  83. iobase = ia->ia_iobase;
  84. ioh = ia->ia_ioh;
  85. #ifdef KGDB
  86. if (iobase == com_kgdb_addr)
  87. return (1);
  88. #endif
  89. /* if it's in use as console, it's there. */
  90. if (iobase == comconsaddr && !comconsattached)
  91. return (1);
  92. return comprobe1(iot, ioh);
  93. }
  94. void
  95. com_isapnp_attach(struct device *parent, struct device *self, void *aux)
  96. {
  97. struct com_softc *sc = (void *)self;
  98. int iobase;
  99. int irq;
  100. bus_space_tag_t iot;
  101. bus_space_handle_t ioh;
  102. struct isa_attach_args *ia = aux;
  103. /*
  104. * XXX should be broken out into functions for isa attach and
  105. * XXX for commulti attach, with a helper function that contains
  106. * XXX most of the interesting stuff.
  107. */
  108. sc->sc_hwflags = 0;
  109. sc->sc_swflags = 0;
  110. /*
  111. * We're living on an isa.
  112. */
  113. iobase = ia->ia_iobase;
  114. iot = ia->ia_iot;
  115. /* No console support! */
  116. ioh = ia->ia_ioh;
  117. sc->sc_iot = iot;
  118. sc->sc_ioh = ioh;
  119. sc->sc_iobase = iobase;
  120. sc->sc_frequency = COM_FREQ;
  121. com_attach_subr(sc);
  122. irq = ia->ia_irq;
  123. if (irq != IRQUNK) {
  124. #ifdef KGDB
  125. if (iobase == com_kgdb_addr) {
  126. sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
  127. IST_EDGE, IPL_HIGH, kgdbintr, sc,
  128. sc->sc_dev.dv_xname);
  129. } else {
  130. sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
  131. IST_EDGE, IPL_TTY, comintr, sc,
  132. sc->sc_dev.dv_xname);
  133. }
  134. #else
  135. sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
  136. IST_EDGE, IPL_TTY, comintr, sc,
  137. sc->sc_dev.dv_xname);
  138. #endif /* KGDB */
  139. }
  140. }