/* $OpenBSD: pxa2x0_intr.h,v 1.13 2009/08/26 20:31:43 deraadt Exp $ */ /* $NetBSD: pxa2x0_intr.h,v 1.4 2003/07/05 06:53:08 dogcow Exp $ */ /* Derived from i80321_intr.h */ /* * Copyright (c) 2001, 2002 Wasabi Systems, Inc. * All rights reserved. * * Written by Jason R. Thorpe for Wasabi Systems, Inc. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed for the NetBSD Project by * Wasabi Systems, Inc. * 4. The name of Wasabi Systems, Inc. may not be used to endorse * or promote products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #ifndef _PXA2X0_INTR_H_ #define _PXA2X0_INTR_H_ #define ARM_IRQ_HANDLER _C_LABEL(pxa2x0_irq_handler) #ifndef _LOCORE #include #include #include extern vaddr_t pxaic_base; /* Shared with pxa2x0_irq.S */ #define read_icu(offset) (*(volatile uint32_t *)(pxaic_base+(offset))) #define write_icu(offset,value) \ (*(volatile uint32_t *)(pxaic_base+(offset))=(value)) extern __volatile int current_spl_level; extern __volatile int softint_pending; extern int pxa2x0_imask[]; void pxa2x0_do_pending(void); void pxa2x0_setipl(int new); void pxa2x0_splx(int new); int pxa2x0_splraise(int ipl); int pxa2x0_spllower(int ipl); void pxa2x0_setsoftintr(int si); /* * An useful function for interrupt handlers. * XXX: This shouldn't be here. */ static __inline int find_first_bit( uint32_t bits ) { int count; /* since CLZ is available only on ARMv5, this isn't portable * to all ARM CPUs. This file is for PXA2[15]0 processor. */ asm( "clz %0, %1" : "=r" (count) : "r" (bits) ); return 31-count; } int _splraise(int); int _spllower(int); void splx(int); void _setsoftintr(int); /* * This function *MUST* be called very early on in a port's * initarm() function, before ANY spl*() functions are called. * * The parameter is the virtual address of the PXA2x0's Interrupt * Controller registers. */ void pxa2x0_intr_bootstrap(vaddr_t); void pxa2x0_irq_handler(void *); void *pxa2x0_intr_establish(int irqno, int level, int (*func)(void *), void *cookie, const char *name); void pxa2x0_intr_disestablish(void *cookie); const char *pxa2x0_intr_string(void *cookie); #ifdef DIAGNOSTIC /* * Although this function is implemented in MI code, it must be in this MD * header because we don't want this header to include MI includes. */ void splassert_fail(int, int, const char *); extern int splassert_ctl; void pxa2x0_splassert_check(int, const char *); #define splassert(__wantipl) do { \ if (splassert_ctl > 0) { \ pxa2x0_splassert_check(__wantipl, __func__); \ } \ } while (0) #define splsoftassert(wantipl) splassert(wantipl) #else #define splassert(wantipl) do { /* nothing */ } while (0) #define splsoftassert(wantipl) do { /* nothing */ } while (0) #endif #endif /* ! _LOCORE */ #endif /* _PXA2X0_INTR_H_ */