1 1.1 kiyohara /* $NetBSD: gtintrvar.h,v 1.1 2010/04/28 13:51:56 kiyohara Exp $ */ 2 1.1 kiyohara /* 3 1.1 kiyohara * Copyright (c) 2009 KIYOHARA Takashi 4 1.1 kiyohara * All rights reserved. 5 1.1 kiyohara * 6 1.1 kiyohara * Redistribution and use in source and binary forms, with or without 7 1.1 kiyohara * modification, are permitted provided that the following conditions 8 1.1 kiyohara * are met: 9 1.1 kiyohara * 1. Redistributions of source code must retain the above copyright 10 1.1 kiyohara * notice, this list of conditions and the following disclaimer. 11 1.1 kiyohara * 2. Redistributions in binary form must reproduce the above copyright 12 1.1 kiyohara * notice, this list of conditions and the following disclaimer in the 13 1.1 kiyohara * documentation and/or other materials provided with the distribution. 14 1.1 kiyohara * 15 1.1 kiyohara * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 16 1.1 kiyohara * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 17 1.1 kiyohara * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 18 1.1 kiyohara * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, 19 1.1 kiyohara * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 20 1.1 kiyohara * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 21 1.1 kiyohara * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22 1.1 kiyohara * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 23 1.1 kiyohara * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 24 1.1 kiyohara * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25 1.1 kiyohara * POSSIBILITY OF SUCH DAMAGE. 26 1.1 kiyohara */ 27 1.1 kiyohara #ifndef _MARVELL_GTINTRVAR_H_ 28 1.1 kiyohara #define _MARVELL_GTINTRVAR_H_ 29 1.1 kiyohara 30 1.1 kiyohara #include <dev/marvell/gtreg.h> 31 1.1 kiyohara 32 1.1 kiyohara /* 33 1.1 kiyohara * Main Interrupt related functions 34 1.1 kiyohara */ 35 1.1 kiyohara 36 1.1 kiyohara static __inline uint32_t 37 1.1 kiyohara discovery_enable_intr(struct gt_softc *sc, int irq) 38 1.1 kiyohara { 39 1.1 kiyohara bus_size_t reg; 40 1.1 kiyohara uint32_t cim; 41 1.1 kiyohara 42 1.1 kiyohara reg = (irq < 32) ? ICR_CIM_LO : ICR_CIM_HI; 43 1.1 kiyohara cim = bus_space_read_4(sc->sc_iot, sc->sc_ioh, reg); 44 1.1 kiyohara cim |= 1 << (irq & 31); 45 1.1 kiyohara bus_space_write_4(sc->sc_iot, sc->sc_ioh, reg, cim); 46 1.1 kiyohara return cim; 47 1.1 kiyohara } 48 1.1 kiyohara 49 1.1 kiyohara static __inline uint32_t 50 1.1 kiyohara discovery_disable_intr(struct gt_softc *sc, int irq) 51 1.1 kiyohara { 52 1.1 kiyohara bus_size_t reg; 53 1.1 kiyohara uint32_t cim; 54 1.1 kiyohara 55 1.1 kiyohara reg = (irq < 32) ? ICR_CIM_LO : ICR_CIM_HI; 56 1.1 kiyohara cim = bus_space_read_4(sc->sc_iot, sc->sc_ioh, reg); 57 1.1 kiyohara cim &= ~(1 << (irq & 31)); 58 1.1 kiyohara bus_space_write_4(sc->sc_iot, sc->sc_ioh, reg, cim); 59 1.1 kiyohara return cim; 60 1.1 kiyohara } 61 1.1 kiyohara 62 1.1 kiyohara static __inline int 63 1.1 kiyohara discovery_mic_low(struct gt_softc *sc) 64 1.1 kiyohara { 65 1.1 kiyohara 66 1.1 kiyohara return bus_space_read_4(sc->sc_iot, sc->sc_ioh, ICR_MIC_LO); 67 1.1 kiyohara } 68 1.1 kiyohara 69 1.1 kiyohara static __inline int 70 1.1 kiyohara discovery_mic_high(struct gt_softc *sc) 71 1.1 kiyohara { 72 1.1 kiyohara 73 1.1 kiyohara return bus_space_read_4(sc->sc_iot, sc->sc_ioh, ICR_MIC_HI); 74 1.1 kiyohara } 75 1.1 kiyohara 76 1.1 kiyohara 77 1.1 kiyohara /* 78 1.1 kiyohara * GPP Interrupt related functions 79 1.1 kiyohara */ 80 1.1 kiyohara 81 1.1 kiyohara static __inline uint32_t 82 1.1 kiyohara discovery_gpp_enable_intr(struct gt_softc *sc, int pin) 83 1.1 kiyohara { 84 1.1 kiyohara uint32_t gppim; 85 1.1 kiyohara 86 1.1 kiyohara gppim = bus_space_read_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Mask); 87 1.1 kiyohara gppim |= 1 << pin; 88 1.1 kiyohara bus_space_write_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Mask, gppim); 89 1.1 kiyohara return gppim; 90 1.1 kiyohara } 91 1.1 kiyohara 92 1.1 kiyohara static __inline uint32_t 93 1.1 kiyohara discovery_gpp_disable_intr(struct gt_softc *sc, int pin) 94 1.1 kiyohara { 95 1.1 kiyohara uint32_t gppim; 96 1.1 kiyohara 97 1.1 kiyohara gppim = bus_space_read_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Mask); 98 1.1 kiyohara gppim &= ~(1 << pin); 99 1.1 kiyohara bus_space_write_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Mask, gppim); 100 1.1 kiyohara return gppim; 101 1.1 kiyohara } 102 1.1 kiyohara 103 1.1 kiyohara static __inline void 104 1.1 kiyohara discovery_gpp_clear_cause(struct gt_softc *sc, int pin) 105 1.1 kiyohara { 106 1.1 kiyohara uint32_t gppic; 107 1.1 kiyohara 108 1.1 kiyohara gppic = 109 1.1 kiyohara bus_space_read_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Cause); 110 1.1 kiyohara gppic &= ~(1 << pin); 111 1.1 kiyohara bus_space_write_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Cause, 112 1.1 kiyohara gppic); 113 1.1 kiyohara } 114 1.1 kiyohara 115 1.1 kiyohara static __inline int 116 1.1 kiyohara discovery_gpp_cause(struct gt_softc *sc) 117 1.1 kiyohara { 118 1.1 kiyohara 119 1.1 kiyohara return bus_space_read_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Cause); 120 1.1 kiyohara } 121 1.1 kiyohara 122 1.1 kiyohara static __inline int 123 1.1 kiyohara discovery_gpp_mask(struct gt_softc *sc) 124 1.1 kiyohara { 125 1.1 kiyohara 126 1.1 kiyohara return bus_space_read_4(sc->sc_iot, sc->sc_ioh, GT_GPP_Interrupt_Mask); 127 1.1 kiyohara } 128 1.1 kiyohara #endif /* _MARVELL_GTINTRVAR_H_ */ 129