blob: bc4adfaf815c1c2276c2f0f18bd84924b10c12d7 [file] [log] [blame]
David Howellsb920de12008-02-08 04:19:31 -08001/* ASB2305 Initialisation
2 *
3 * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
4 * Written by David Howells (dhowells@redhat.com)
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public Licence
8 * as published by the Free Software Foundation; either version
9 * 2 of the Licence, or (at your option) any later version.
10 */
11#include <linux/kernel.h>
12#include <linux/param.h>
13#include <linux/init.h>
14#include <linux/pci.h>
15#include <asm/io.h>
Geert Uytterhoeven325c1172012-07-11 14:01:56 -070016#include <asm/irq.h>
David Howellsb920de12008-02-08 04:19:31 -080017#include <asm/setup.h>
18#include <asm/processor.h>
Al Viro07c706a2010-01-08 14:43:17 -080019#include <asm/intctl-regs.h>
20#include <asm/serial-regs.h>
David Howells2f2a2132009-04-10 14:33:48 +010021#include <unit/serial.h>
David Howellsb920de12008-02-08 04:19:31 -080022
23/*
24 * initialise some of the unit hardware before gdbstub is set up
25 */
26asmlinkage void __init unit_init(void)
27{
28#ifndef CONFIG_GDBSTUB_ON_TTYSx
29 /* set the 16550 interrupt line to level 3 if not being used for GDB */
Akira Takeuchi368dd5a2010-10-27 17:28:55 +010030#ifdef CONFIG_EXT_SERIAL_IRQ_LEVEL
31 set_intr_level(XIRQ0, NUM2GxICR_LEVEL(CONFIG_EXT_SERIAL_IRQ_LEVEL));
David Howellsb920de12008-02-08 04:19:31 -080032#endif
Akira Takeuchi368dd5a2010-10-27 17:28:55 +010033#endif /* CONFIG_GDBSTUB_ON_TTYSx */
David Howellsb920de12008-02-08 04:19:31 -080034}
35
36/*
37 * initialise the rest of the unit hardware after gdbstub is ready
38 */
39void __init unit_setup(void)
40{
41#ifdef CONFIG_PCI
42 unit_pci_init();
43#endif
44}
45
46/*
47 * initialise the external interrupts used by a unit of this type
48 */
49void __init unit_init_IRQ(void)
50{
51 unsigned int extnum;
52
53 for (extnum = 0; extnum < NR_XIRQS; extnum++) {
54 switch (GET_XIRQ_TRIGGER(extnum)) {
55 case XIRQ_TRIGGER_HILEVEL:
56 case XIRQ_TRIGGER_LOWLEVEL:
Akira Takeuchi368dd5a2010-10-27 17:28:55 +010057 mn10300_set_lateack_irq_type(XIRQ2IRQ(extnum));
David Howellsb920de12008-02-08 04:19:31 -080058 break;
59 default:
60 break;
61 }
62 }
63}