Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 162635
b: refs/heads/master
c: cd3dd40
h: refs/heads/master
i:
  162633: 8200530
  162631: 3de0a48
v: v3
  • Loading branch information
Greg Ungerer committed Sep 15, 2009
1 parent 525c142 commit 3ff63db
Show file tree
Hide file tree
Showing 5 changed files with 69 additions and 2 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 584320156b7e42e74105ca78bdf895d2b0269251
refs/heads/master: cd3dd4068db5e1258a14b63e0feaf0332640d896
2 changes: 2 additions & 0 deletions trunk/arch/m68k/include/asm/m520xsim.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@
#define MCFINTC_IMRL 0x0c /* Interrupt mask 1-31 */
#define MCFINTC_INTFRCH 0x10 /* Interrupt force 32-63 */
#define MCFINTC_INTFRCL 0x14 /* Interrupt force 1-31 */
#define MCFINTC_SIMR 0x1c /* Set interrupt mask 0-63 */
#define MCFINTC_CIMR 0x1d /* Clear interrupt mask 0-63 */
#define MCFINTC_ICR0 0x40 /* Base ICR register */

#define MCFINT_VECBASE 64
Expand Down
4 changes: 4 additions & 0 deletions trunk/arch/m68knommu/kernel/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ asmlinkage void do_IRQ(int irq, struct pt_regs *regs)
set_irq_regs(oldregs);
}

#if !defined(CONFIG_M520x)

static struct irq_chip m_irq_chip = {
.name = "M68K-INTC",
.enable = enable_vector,
Expand All @@ -50,6 +52,8 @@ void __init init_IRQ(void)
}
}

#endif

int show_interrupts(struct seq_file *p, void *v)
{
struct irqaction *ap;
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/m68knommu/platform/coldfire/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ asflags-$(CONFIG_FULLDEBUG) := -DDEBUGGER_COMPATIBLE_CACHE=1
obj-$(CONFIG_COLDFIRE) += clk.o dma.o entry.o vectors.o
obj-$(CONFIG_M5206) += timers.o
obj-$(CONFIG_M5206e) += timers.o
obj-$(CONFIG_M520x) += pit.o
obj-$(CONFIG_M520x) += pit.o intc-simr.o
obj-$(CONFIG_M523x) += pit.o dma_timer.o
obj-$(CONFIG_M5249) += timers.o
obj-$(CONFIG_M527x) += pit.o
Expand Down
61 changes: 61 additions & 0 deletions trunk/arch/m68knommu/platform/coldfire/intc-simr.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
/*
* intc-simr.c
*
* (C) Copyright 2009, Greg Ungerer <gerg@snapgear.com>
*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file COPYING in the main directory of this archive
* for more details.
*/

#include <linux/types.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/interrupt.h>
#include <linux/irq.h>
#include <linux/io.h>
#include <asm/coldfire.h>
#include <asm/mcfsim.h>
#include <asm/traps.h>

static void intc_irq_mask(unsigned int irq)
{
if ((irq >= MCFINT_VECBASE) && (irq <= MCFINT_VECBASE + 63))
__raw_writeb(irq - MCFINT_VECBASE, MCF_IPSBAR + MCFICM_INTC0 + MCFINTC_SIMR);
}

static void intc_irq_unmask(unsigned int irq)
{
if ((irq >= MCFINT_VECBASE) && (irq <= MCFINT_VECBASE + 63))
__raw_writeb(irq - MCFINT_VECBASE, MCF_IPSBAR + MCFICM_INTC0 + MCFINTC_CIMR);
}

static int intc_irq_set_type(unsigned int irq, unsigned int type)
{
if ((irq >= MCFINT_VECBASE) && (irq <= MCFINT_VECBASE + 63))
__raw_writeb(5, MCF_IPSBAR + MCFICM_INTC0 + MCFINTC_ICR0 + irq - MCFINT_VECBASE);
return 0;
}

static struct irq_chip intc_irq_chip = {
.name = "CF-INTC",
.mask = intc_irq_mask,
.unmask = intc_irq_unmask,
.set_type = intc_irq_set_type,
};

void __init init_IRQ(void)
{
int irq;

init_vectors();

for (irq = 0; (irq < NR_IRQS); irq++) {
irq_desc[irq].status = IRQ_DISABLED;
irq_desc[irq].action = NULL;
irq_desc[irq].depth = 1;
irq_desc[irq].chip = &intc_irq_chip;
intc_irq_set_type(irq, 0);
}
}

0 comments on commit 3ff63db

Please sign in to comment.