The built-in Loongson 2E/2F northbridge in is bonito64-compatible but not identical with it. To avoid influencing the original bonito64 support and make the loongson support more maintainable, it's better to separate the Bonito64 code from the Loongson code. This also prepares the kernel for the coming Loongson 2f machines family support. Signed-off-by: Wu Zhangjin <wuzhangjin@gmail.com> Cc: Linux-MIPS <linux-mips@linux-mips.org> Cc: yanh@lemote.com Cc: huhb@lemote.com Cc: Zhang Le <r0bertz@gentoo.org> Cc: zhangfx@lemote.com, Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
52 lines
1.3 KiB
C
52 lines
1.3 KiB
C
/*
|
|
* Copyright 2001 MontaVista Software Inc.
|
|
* Author: Jun Sun, jsun@mvista.com or jsun@junsun.net
|
|
* Copyright (C) 2000, 2001 Ralf Baechle (ralf@gnu.org)
|
|
*
|
|
* Copyright (C) 2007 Lemote Inc. & Insititute of Computing Technology
|
|
* Author: Fuxin Zhang, zhangfx@lemote.com
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2 of the License, or (at your
|
|
* option) any later version.
|
|
*/
|
|
#include <linux/interrupt.h>
|
|
|
|
#include <loongson.h>
|
|
|
|
static inline void bonito_irq_enable(unsigned int irq)
|
|
{
|
|
LOONGSON_INTENSET = (1 << (irq - LOONGSON_IRQ_BASE));
|
|
mmiowb();
|
|
}
|
|
|
|
static inline void bonito_irq_disable(unsigned int irq)
|
|
{
|
|
LOONGSON_INTENCLR = (1 << (irq - LOONGSON_IRQ_BASE));
|
|
mmiowb();
|
|
}
|
|
|
|
static struct irq_chip bonito_irq_type = {
|
|
.name = "bonito_irq",
|
|
.ack = bonito_irq_disable,
|
|
.mask = bonito_irq_disable,
|
|
.mask_ack = bonito_irq_disable,
|
|
.unmask = bonito_irq_enable,
|
|
};
|
|
|
|
static struct irqaction dma_timeout_irqaction = {
|
|
.handler = no_action,
|
|
.name = "dma_timeout",
|
|
};
|
|
|
|
void bonito_irq_init(void)
|
|
{
|
|
u32 i;
|
|
|
|
for (i = LOONGSON_IRQ_BASE; i < LOONGSON_IRQ_BASE + 32; i++)
|
|
set_irq_chip_and_handler(i, &bonito_irq_type, handle_level_irq);
|
|
|
|
setup_irq(LOONGSON_IRQ_BASE + 10, &dma_timeout_irqaction);
|
|
}
|