blob: 2f1cc59650ab58a1ae6ab8b2cc9ab484c7713bf8 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * Platform dependent support for HP simulator.
4 *
5 * Copyright (C) 1998-2001 Hewlett-Packard Co
6 * Copyright (C) 1998-2001 David Mosberger-Tang <davidm@hpl.hp.com>
7 */
8
9#include <linux/init.h>
10#include <linux/kernel.h>
11#include <linux/sched.h>
12#include <linux/irq.h>
13
Jiri Slaby6efb6b72012-03-08 21:01:18 +010014#include "hpsim_ssc.h"
15
Linus Torvalds1da177e2005-04-16 15:20:36 -070016static unsigned int
Thomas Gleixner35d75b02011-02-04 20:12:06 +010017hpsim_irq_startup(struct irq_data *data)
Linus Torvalds1da177e2005-04-16 15:20:36 -070018{
19 return 0;
20}
21
22static void
Thomas Gleixner35d75b02011-02-04 20:12:06 +010023hpsim_irq_noop(struct irq_data *data)
Linus Torvalds1da177e2005-04-16 15:20:36 -070024{
25}
26
Yinghai Lud5dedd42009-04-27 17:59:21 -070027static int
Thomas Gleixner35d75b02011-02-04 20:12:06 +010028hpsim_set_affinity_noop(struct irq_data *d, const struct cpumask *b, bool f)
Linus Torvalds1da177e2005-04-16 15:20:36 -070029{
Yinghai Lud5dedd42009-04-27 17:59:21 -070030 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070031}
32
Thomas Gleixnerfb824f42009-06-10 12:45:00 -070033static struct irq_chip irq_type_hp_sim = {
Thomas Gleixner35d75b02011-02-04 20:12:06 +010034 .name = "hpsim",
35 .irq_startup = hpsim_irq_startup,
36 .irq_shutdown = hpsim_irq_noop,
37 .irq_enable = hpsim_irq_noop,
38 .irq_disable = hpsim_irq_noop,
39 .irq_ack = hpsim_irq_noop,
40 .irq_set_affinity = hpsim_set_affinity_noop,
Linus Torvalds1da177e2005-04-16 15:20:36 -070041};
42
Jiri Slaby6efb6b72012-03-08 21:01:18 +010043static void hpsim_irq_set_chip(int irq)
44{
45 struct irq_chip *chip = irq_get_chip(irq);
46
47 if (chip == &no_irq_chip)
48 irq_set_chip(irq, &irq_type_hp_sim);
49}
50
51static void hpsim_connect_irq(int intr, int irq)
52{
53 ia64_ssc(intr, irq, 0, 0, SSC_CONNECT_INTERRUPT);
54}
55
56int hpsim_get_irq(int intr)
57{
58 int irq = assign_irq_vector(AUTO_ASSIGN);
59
60 if (irq >= 0) {
61 hpsim_irq_set_chip(irq);
62 irq_set_handler(irq, handle_simple_irq);
63 hpsim_connect_irq(intr, irq);
64 }
65
66 return irq;
67}
68
Linus Torvalds1da177e2005-04-16 15:20:36 -070069void __init
70hpsim_irq_init (void)
71{
Linus Torvalds1da177e2005-04-16 15:20:36 -070072 int i;
73
Jiri Slaby6efb6b72012-03-08 21:01:18 +010074 for_each_active_irq(i)
75 hpsim_irq_set_chip(i);
Linus Torvalds1da177e2005-04-16 15:20:36 -070076}