Path: blob/master/arch/blackfin/mach-bf537/ints-priority.c
10817 views
/*1* Copyright 2005-2009 Analog Devices Inc.2*3* Licensed under the GPL-2 or later.4*5* Set up the interrupt priorities6*/78#include <linux/module.h>9#include <linux/irq.h>10#include <asm/blackfin.h>1112#include <asm/irq_handler.h>13#include <asm/bfin5xx_spi.h>14#include <asm/bfin_sport.h>15#include <asm/bfin_can.h>16#include <asm/bfin_dma.h>17#include <asm/dpmc.h>1819void __init program_IAR(void)20{21/* Program the IAR0 Register with the configured priority */22bfin_write_SIC_IAR0(((CONFIG_IRQ_PLL_WAKEUP - 7) << IRQ_PLL_WAKEUP_POS) |23((CONFIG_IRQ_DMA_ERROR - 7) << IRQ_DMA_ERROR_POS) |24((CONFIG_IRQ_ERROR - 7) << IRQ_ERROR_POS) |25((CONFIG_IRQ_RTC - 7) << IRQ_RTC_POS) |26((CONFIG_IRQ_PPI - 7) << IRQ_PPI_POS) |27((CONFIG_IRQ_SPORT0_RX - 7) << IRQ_SPORT0_RX_POS) |28((CONFIG_IRQ_SPORT0_TX - 7) << IRQ_SPORT0_TX_POS) |29((CONFIG_IRQ_SPORT1_RX - 7) << IRQ_SPORT1_RX_POS));3031bfin_write_SIC_IAR1(((CONFIG_IRQ_SPORT1_TX - 7) << IRQ_SPORT1_TX_POS) |32((CONFIG_IRQ_TWI - 7) << IRQ_TWI_POS) |33((CONFIG_IRQ_SPI - 7) << IRQ_SPI_POS) |34((CONFIG_IRQ_UART0_RX - 7) << IRQ_UART0_RX_POS) |35((CONFIG_IRQ_UART0_TX - 7) << IRQ_UART0_TX_POS) |36((CONFIG_IRQ_UART1_RX - 7) << IRQ_UART1_RX_POS) |37((CONFIG_IRQ_UART1_TX - 7) << IRQ_UART1_TX_POS) |38((CONFIG_IRQ_CAN_RX - 7) << IRQ_CAN_RX_POS));3940bfin_write_SIC_IAR2(((CONFIG_IRQ_CAN_TX - 7) << IRQ_CAN_TX_POS) |41((CONFIG_IRQ_MAC_RX - 7) << IRQ_MAC_RX_POS) |42((CONFIG_IRQ_MAC_TX - 7) << IRQ_MAC_TX_POS) |43((CONFIG_IRQ_TIMER0 - 7) << IRQ_TIMER0_POS) |44((CONFIG_IRQ_TIMER1 - 7) << IRQ_TIMER1_POS) |45((CONFIG_IRQ_TIMER2 - 7) << IRQ_TIMER2_POS) |46((CONFIG_IRQ_TIMER3 - 7) << IRQ_TIMER3_POS) |47((CONFIG_IRQ_TIMER4 - 7) << IRQ_TIMER4_POS));4849bfin_write_SIC_IAR3(((CONFIG_IRQ_TIMER5 - 7) << IRQ_TIMER5_POS) |50((CONFIG_IRQ_TIMER6 - 7) << IRQ_TIMER6_POS) |51((CONFIG_IRQ_TIMER7 - 7) << IRQ_TIMER7_POS) |52((CONFIG_IRQ_PROG_INTA - 7) << IRQ_PROG_INTA_POS) |53((CONFIG_IRQ_PORTG_INTB - 7) << IRQ_PORTG_INTB_POS) |54((CONFIG_IRQ_MEM_DMA0 - 7) << IRQ_MEM_DMA0_POS) |55((CONFIG_IRQ_MEM_DMA1 - 7) << IRQ_MEM_DMA1_POS) |56((CONFIG_IRQ_WATCH - 7) << IRQ_WATCH_POS));5758SSYNC();59}6061#define SPI_ERR_MASK (BIT_STAT_TXCOL | BIT_STAT_RBSY | BIT_STAT_MODF | BIT_STAT_TXE) /* SPI_STAT */62#define SPORT_ERR_MASK (ROVF | RUVF | TOVF | TUVF) /* SPORT_STAT */63#define PPI_ERR_MASK (0xFFFF & ~FLD) /* PPI_STATUS */64#define EMAC_ERR_MASK (PHYINT | MMCINT | RXFSINT | TXFSINT | WAKEDET | RXDMAERR | TXDMAERR | STMDONE) /* EMAC_SYSTAT */65#define UART_ERR_MASK (0x6) /* UART_IIR */66#define CAN_ERR_MASK (EWTIF | EWRIF | EPIF | BOIF | WUIF | UIAIF | AAIF | RMLIF | UCEIF | EXTIF | ADIF) /* CAN_GIF */6768static int error_int_mask;6970static void bf537_generic_error_mask_irq(struct irq_data *d)71{72error_int_mask &= ~(1L << (d->irq - IRQ_PPI_ERROR));73if (!error_int_mask)74bfin_internal_mask_irq(IRQ_GENERIC_ERROR);75}7677static void bf537_generic_error_unmask_irq(struct irq_data *d)78{79bfin_internal_unmask_irq(IRQ_GENERIC_ERROR);80error_int_mask |= 1L << (d->irq - IRQ_PPI_ERROR);81}8283static struct irq_chip bf537_generic_error_irqchip = {84.name = "ERROR",85.irq_ack = bfin_ack_noop,86.irq_mask_ack = bf537_generic_error_mask_irq,87.irq_mask = bf537_generic_error_mask_irq,88.irq_unmask = bf537_generic_error_unmask_irq,89};9091static void bf537_demux_error_irq(unsigned int int_err_irq,92struct irq_desc *inta_desc)93{94int irq = 0;9596#if (defined(CONFIG_BF537) || defined(CONFIG_BF536))97if (bfin_read_EMAC_SYSTAT() & EMAC_ERR_MASK)98irq = IRQ_MAC_ERROR;99else100#endif101if (bfin_read_SPORT0_STAT() & SPORT_ERR_MASK)102irq = IRQ_SPORT0_ERROR;103else if (bfin_read_SPORT1_STAT() & SPORT_ERR_MASK)104irq = IRQ_SPORT1_ERROR;105else if (bfin_read_PPI_STATUS() & PPI_ERR_MASK)106irq = IRQ_PPI_ERROR;107else if (bfin_read_CAN_GIF() & CAN_ERR_MASK)108irq = IRQ_CAN_ERROR;109else if (bfin_read_SPI_STAT() & SPI_ERR_MASK)110irq = IRQ_SPI_ERROR;111else if ((bfin_read_UART0_IIR() & UART_ERR_MASK) == UART_ERR_MASK)112irq = IRQ_UART0_ERROR;113else if ((bfin_read_UART1_IIR() & UART_ERR_MASK) == UART_ERR_MASK)114irq = IRQ_UART1_ERROR;115116if (irq) {117if (error_int_mask & (1L << (irq - IRQ_PPI_ERROR)))118bfin_handle_irq(irq);119else {120121switch (irq) {122case IRQ_PPI_ERROR:123bfin_write_PPI_STATUS(PPI_ERR_MASK);124break;125#if (defined(CONFIG_BF537) || defined(CONFIG_BF536))126case IRQ_MAC_ERROR:127bfin_write_EMAC_SYSTAT(EMAC_ERR_MASK);128break;129#endif130case IRQ_SPORT0_ERROR:131bfin_write_SPORT0_STAT(SPORT_ERR_MASK);132break;133134case IRQ_SPORT1_ERROR:135bfin_write_SPORT1_STAT(SPORT_ERR_MASK);136break;137138case IRQ_CAN_ERROR:139bfin_write_CAN_GIS(CAN_ERR_MASK);140break;141142case IRQ_SPI_ERROR:143bfin_write_SPI_STAT(SPI_ERR_MASK);144break;145146default:147break;148}149150pr_debug("IRQ %d:"151" MASKED PERIPHERAL ERROR INTERRUPT ASSERTED\n",152irq);153}154} else155pr_err("%s: IRQ ?: PERIPHERAL ERROR INTERRUPT ASSERTED BUT NO SOURCE FOUND\n",156__func__);157158}159160#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)161static int mac_rx_int_mask;162163static void bf537_mac_rx_mask_irq(struct irq_data *d)164{165mac_rx_int_mask &= ~(1L << (d->irq - IRQ_MAC_RX));166if (!mac_rx_int_mask)167bfin_internal_mask_irq(IRQ_PH_INTA_MAC_RX);168}169170static void bf537_mac_rx_unmask_irq(struct irq_data *d)171{172bfin_internal_unmask_irq(IRQ_PH_INTA_MAC_RX);173mac_rx_int_mask |= 1L << (d->irq - IRQ_MAC_RX);174}175176static struct irq_chip bf537_mac_rx_irqchip = {177.name = "ERROR",178.irq_ack = bfin_ack_noop,179.irq_mask_ack = bf537_mac_rx_mask_irq,180.irq_mask = bf537_mac_rx_mask_irq,181.irq_unmask = bf537_mac_rx_unmask_irq,182};183184static void bf537_demux_mac_rx_irq(unsigned int int_irq,185struct irq_desc *desc)186{187if (bfin_read_DMA1_IRQ_STATUS() & (DMA_DONE | DMA_ERR))188bfin_handle_irq(IRQ_MAC_RX);189else190bfin_demux_gpio_irq(int_irq, desc);191}192#endif193194void __init init_mach_irq(void)195{196int irq;197198#if defined(CONFIG_BF537) || defined(CONFIG_BF536)199/* Clear EMAC Interrupt Status bits so we can demux it later */200bfin_write_EMAC_SYSTAT(-1);201#endif202203irq_set_chained_handler(IRQ_GENERIC_ERROR, bf537_demux_error_irq);204for (irq = IRQ_PPI_ERROR; irq <= IRQ_UART1_ERROR; irq++)205irq_set_chip_and_handler(irq, &bf537_generic_error_irqchip,206handle_level_irq);207208#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)209irq_set_chained_handler(IRQ_PH_INTA_MAC_RX, bf537_demux_mac_rx_irq);210irq_set_chip_and_handler(IRQ_MAC_RX, &bf537_mac_rx_irqchip, handle_level_irq);211irq_set_chip_and_handler(IRQ_PORTH_INTA, &bf537_mac_rx_irqchip, handle_level_irq);212213irq_set_chained_handler(IRQ_MAC_ERROR, bfin_demux_mac_status_irq);214#endif215}216217218