irqs.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /*
  2. * Copyright (C) 2007 Google, Inc.
  3. * Copyright (c) 2008-2010, Code Aurora Forum. All rights reserved.
  4. * Author: Brian Swetland <swetland@google.com>
  5. *
  6. * This software is licensed under the terms of the GNU General Public
  7. * License version 2, as published by the Free Software Foundation, and
  8. * may be copied, distributed, and modified under those terms.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. */
  16. #ifndef __ASM_ARCH_MSM_IRQS_H
  17. #define __ASM_ARCH_MSM_IRQS_H
  18. #define MSM_IRQ_BIT(irq) (1 << ((irq) & 31))
  19. #if defined(CONFIG_ARCH_MSM7X30)
  20. #include "irqs-7x30.h"
  21. #elif defined(CONFIG_ARCH_QSD8X50)
  22. #include "irqs-8x50.h"
  23. #include "sirc.h"
  24. #elif defined(CONFIG_ARCH_MSM8X60)
  25. #include "irqs-8x60.h"
  26. #elif defined(CONFIG_ARCH_MSM8960)
  27. /* TODO: Make these not generic. */
  28. #include "irqs-8960.h"
  29. #elif defined(CONFIG_ARCH_MSM_ARM11)
  30. #include "irqs-7x00.h"
  31. #else
  32. #error "Unknown architecture specification"
  33. #endif
  34. #define NR_IRQS (NR_MSM_IRQS + NR_GPIO_IRQS + NR_BOARD_IRQS)
  35. #define MSM_GPIO_TO_INT(n) (NR_MSM_IRQS + (n))
  36. #define MSM_INT_TO_REG(base, irq) (base + irq / 32)
  37. #endif