pic.c 19.6 KB
Newer Older
1 2 3 4 5 6 7
/*
 *  Support for the interrupt controllers found on Power Macintosh,
 *  currently Apple's "Grand Central" interrupt controller in all
 *  it's incarnations. OpenPIC support used on newer machines is
 *  in a separate file
 *
 *  Copyright (C) 1997 Paul Mackerras (paulus@samba.org)
8 9
 *  Copyright (C) 2005 Benjamin Herrenschmidt (benh@kernel.crashing.org)
 *                     IBM, Corp.
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
 *
 *  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/stddef.h>
#include <linux/init.h>
#include <linux/sched.h>
#include <linux/signal.h>
#include <linux/pci.h>
#include <linux/interrupt.h>
#include <linux/sysdev.h>
#include <linux/adb.h>
#include <linux/pmu.h>
27
#include <linux/module.h>
28 29 30 31 32 33 34 35 36

#include <asm/sections.h>
#include <asm/io.h>
#include <asm/smp.h>
#include <asm/prom.h>
#include <asm/pci-bridge.h>
#include <asm/time.h>
#include <asm/pmac_feature.h>
#include <asm/mpic.h>
37
#include <asm/xmon.h>
38

39
#include "pmac.h"
40

41
#ifdef CONFIG_PPC32
42 43 44 45 46 47 48
struct pmac_irq_hw {
        unsigned int    event;
        unsigned int    enable;
        unsigned int    ack;
        unsigned int    level;
};

49 50 51 52
/* Workaround flags for 32bit powermac machines */
unsigned int of_irq_workarounds;
struct device_node *of_irq_dflt_pic;

53
/* Default addresses */
54
static volatile struct pmac_irq_hw __iomem *pmac_irq_hw[4];
55 56 57 58 59 60 61 62 63

#define GC_LEVEL_MASK		0x3ff00000
#define OHARE_LEVEL_MASK	0x1ff00000
#define HEATHROW_LEVEL_MASK	0x1ff00000

static int max_irqs;
static int max_real_irqs;
static u32 level_mask[4];

64
static DEFINE_RAW_SPINLOCK(pmac_pic_lock);
65

S
Stephen Rothwell 已提交
66 67
#define NR_MASK_WORDS	((NR_IRQS + 31) / 32)
static unsigned long ppc_lost_interrupts[NR_MASK_WORDS];
68 69
static unsigned long ppc_cached_irq_mask[NR_MASK_WORDS];
static int pmac_irq_cascade = -1;
70
static struct irq_host *pmac_pic_host;
S
Stephen Rothwell 已提交
71

72
static void __pmac_retrigger(unsigned int irq_nr)
73
{
74 75 76 77 78 79
	if (irq_nr >= max_real_irqs && pmac_irq_cascade > 0) {
		__set_bit(irq_nr, ppc_lost_interrupts);
		irq_nr = pmac_irq_cascade;
		mb();
	}
	if (!__test_and_set_bit(irq_nr, ppc_lost_interrupts)) {
80
		atomic_inc(&ppc_n_lost_interrupts);
81
		set_dec(1);
82 83 84
	}
}

85
static void pmac_mask_and_ack_irq(unsigned int virq)
86
{
87
	unsigned int src = irq_map[virq].hwirq;
88 89
        unsigned long bit = 1UL << (src & 0x1f);
        int i = src >> 5;
90 91
        unsigned long flags;

92
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
93 94
        __clear_bit(src, ppc_cached_irq_mask);
        if (__test_and_clear_bit(src, ppc_lost_interrupts))
95
                atomic_dec(&ppc_n_lost_interrupts);
96 97 98 99 100 101 102 103
        out_le32(&pmac_irq_hw[i]->enable, ppc_cached_irq_mask[i]);
        out_le32(&pmac_irq_hw[i]->ack, bit);
        do {
                /* make sure ack gets to controller before we enable
                   interrupts */
                mb();
        } while((in_le32(&pmac_irq_hw[i]->enable) & bit)
                != (ppc_cached_irq_mask[i] & bit));
104
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
105 106
}

107
static void pmac_ack_irq(unsigned int virq)
108
{
109 110 111
	unsigned int src = irq_map[virq].hwirq;
        unsigned long bit = 1UL << (src & 0x1f);
        int i = src >> 5;
112 113
        unsigned long flags;

114
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
115
	if (__test_and_clear_bit(src, ppc_lost_interrupts))
116 117 118
                atomic_dec(&ppc_n_lost_interrupts);
        out_le32(&pmac_irq_hw[i]->ack, bit);
        (void)in_le32(&pmac_irq_hw[i]->ack);
119
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
120 121 122 123 124 125 126 127 128 129
}

static void __pmac_set_irq_mask(unsigned int irq_nr, int nokicklost)
{
        unsigned long bit = 1UL << (irq_nr & 0x1f);
        int i = irq_nr >> 5;

        if ((unsigned)irq_nr >= max_irqs)
                return;

130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
        /* enable unmasked interrupts */
        out_le32(&pmac_irq_hw[i]->enable, ppc_cached_irq_mask[i]);

        do {
                /* make sure mask gets to controller before we
                   return to user */
                mb();
        } while((in_le32(&pmac_irq_hw[i]->enable) & bit)
                != (ppc_cached_irq_mask[i] & bit));

        /*
         * Unfortunately, setting the bit in the enable register
         * when the device interrupt is already on *doesn't* set
         * the bit in the flag register or request another interrupt.
         */
        if (bit & ppc_cached_irq_mask[i] & in_le32(&pmac_irq_hw[i]->level))
146
		__pmac_retrigger(irq_nr);
147 148 149 150 151
}

/* When an irq gets requested for the first client, if it's an
 * edge interrupt, we clear any previous one on the controller
 */
152
static unsigned int pmac_startup_irq(unsigned int virq)
153
{
154
	unsigned long flags;
155 156 157
	unsigned int src = irq_map[virq].hwirq;
        unsigned long bit = 1UL << (src & 0x1f);
        int i = src >> 5;
158

159
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
M
Michael Ellerman 已提交
160
	if ((irq_to_desc(virq)->status & IRQ_LEVEL) == 0)
161
		out_le32(&pmac_irq_hw[i]->ack, bit);
162 163
        __set_bit(src, ppc_cached_irq_mask);
        __pmac_set_irq_mask(src, 0);
164
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
165 166 167 168

	return 0;
}

169
static void pmac_mask_irq(unsigned int virq)
170
{
171
	unsigned long flags;
172
	unsigned int src = irq_map[virq].hwirq;
173

174
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
175
        __clear_bit(src, ppc_cached_irq_mask);
176
        __pmac_set_irq_mask(src, 1);
177
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
178 179
}

180
static void pmac_unmask_irq(unsigned int virq)
181
{
182
	unsigned long flags;
183
	unsigned int src = irq_map[virq].hwirq;
184

185
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
186 187
	__set_bit(src, ppc_cached_irq_mask);
        __pmac_set_irq_mask(src, 0);
188
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
189 190
}

191
static int pmac_retrigger(unsigned int virq)
192
{
193
	unsigned long flags;
194

195
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
196
	__pmac_retrigger(irq_map[virq].hwirq);
197
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
198 199
	return 1;
}
200

201
static struct irq_chip pmac_pic = {
202
	.name		= "PMAC-PIC",
203
	.startup	= pmac_startup_irq,
204 205 206 207 208
	.mask		= pmac_mask_irq,
	.ack		= pmac_ack_irq,
	.mask_ack	= pmac_mask_and_ack_irq,
	.unmask		= pmac_unmask_irq,
	.retrigger	= pmac_retrigger,
209 210
};

O
Olaf Hering 已提交
211
static irqreturn_t gatwick_action(int cpl, void *dev_id)
212
{
213
	unsigned long flags;
214
	int irq, bits;
215
	int rc = IRQ_NONE;
216

217
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
218 219 220 221 222 223 224 225 226
	for (irq = max_irqs; (irq -= 32) >= max_real_irqs; ) {
		int i = irq >> 5;
		bits = in_le32(&pmac_irq_hw[i]->event) | ppc_lost_interrupts[i];
		/* We must read level interrupts from the level register */
		bits |= (in_le32(&pmac_irq_hw[i]->level) & level_mask[i]);
		bits &= ppc_cached_irq_mask[i];
		if (bits == 0)
			continue;
		irq += __ilog2(bits);
227
		raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
228
		generic_handle_irq(irq);
229
		raw_spin_lock_irqsave(&pmac_pic_lock, flags);
230
		rc = IRQ_HANDLED;
231
	}
232
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
233
	return rc;
234 235
}

O
Olaf Hering 已提交
236
static unsigned int pmac_pic_get_irq(void)
237 238 239
{
	int irq;
	unsigned long bits = 0;
240
	unsigned long flags;
241 242

#ifdef CONFIG_SMP
O
Olaf Hering 已提交
243
	void psurge_smp_message_recv(void);
244 245 246

       	/* IPI's are a hack on the powersurge -- Cort */
       	if ( smp_processor_id() != 0 ) {
O
Olaf Hering 已提交
247
		psurge_smp_message_recv();
248
		return NO_IRQ_IGNORE;	/* ignore, already handled */
249 250
        }
#endif /* CONFIG_SMP */
251
	raw_spin_lock_irqsave(&pmac_pic_lock, flags);
252 253 254 255 256 257 258 259 260 261 262
	for (irq = max_real_irqs; (irq -= 32) >= 0; ) {
		int i = irq >> 5;
		bits = in_le32(&pmac_irq_hw[i]->event) | ppc_lost_interrupts[i];
		/* We must read level interrupts from the level register */
		bits |= (in_le32(&pmac_irq_hw[i]->level) & level_mask[i]);
		bits &= ppc_cached_irq_mask[i];
		if (bits == 0)
			continue;
		irq += __ilog2(bits);
		break;
	}
263
	raw_spin_unlock_irqrestore(&pmac_pic_lock, flags);
264 265 266
	if (unlikely(irq < 0))
		return NO_IRQ;
	return irq_linear_revmap(pmac_pic_host, irq);
267 268 269 270 271 272 273 274 275 276 277 278
}

#ifdef CONFIG_XMON
static struct irqaction xmon_action = {
	.handler	= xmon_irq,
	.flags		= 0,
	.name		= "NMI - XMON"
};
#endif

static struct irqaction gatwick_cascade_action = {
	.handler	= gatwick_action,
279
	.flags		= IRQF_DISABLED,
280 281
	.name		= "cascade",
};
282

283 284 285 286 287 288 289
static int pmac_pic_host_match(struct irq_host *h, struct device_node *node)
{
	/* We match all, we don't always have a node anyway */
	return 1;
}

static int pmac_pic_host_map(struct irq_host *h, unsigned int virq,
290
			     irq_hw_number_t hw)
291
{
M
Michael Ellerman 已提交
292
	struct irq_desc *desc = irq_to_desc(virq);
293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309
	int level;

	if (hw >= max_irqs)
		return -EINVAL;

	/* Mark level interrupts, set delayed disable for edge ones and set
	 * handlers
	 */
	level = !!(level_mask[hw >> 5] & (1UL << (hw & 0x1f)));
	if (level)
		desc->status |= IRQ_LEVEL;
	set_irq_chip_and_handler(virq, &pmac_pic, level ?
				 handle_level_irq : handle_edge_irq);
	return 0;
}

static int pmac_pic_host_xlate(struct irq_host *h, struct device_node *ct,
310
			       const u32 *intspec, unsigned int intsize,
311 312 313 314
			       irq_hw_number_t *out_hwirq,
			       unsigned int *out_flags)

{
315
	*out_flags = IRQ_TYPE_NONE;
316 317 318 319 320 321 322 323 324 325
	*out_hwirq = *intspec;
	return 0;
}

static struct irq_host_ops pmac_pic_host_ops = {
	.match = pmac_pic_host_match,
	.map = pmac_pic_host_map,
	.xlate = pmac_pic_host_xlate,
};

326
static void __init pmac_pic_probe_oldstyle(void)
327 328
{
        int i;
329 330 331 332
        struct device_node *master = NULL;
	struct device_node *slave = NULL;
	u8 __iomem *addr;
	struct resource r;
333

334
	/* Set our get_irq function */
335
	ppc_md.get_irq = pmac_pic_get_irq;
336

337 338
	/*
	 * Find the interrupt controller type & node
339
	 */
340 341 342

	if ((master = of_find_node_by_name(NULL, "gc")) != NULL) {
		max_irqs = max_real_irqs = 32;
343
		level_mask[0] = GC_LEVEL_MASK;
344 345
	} else if ((master = of_find_node_by_name(NULL, "ohare")) != NULL) {
		max_irqs = max_real_irqs = 32;
346
		level_mask[0] = OHARE_LEVEL_MASK;
347

348
		/* We might have a second cascaded ohare */
349 350 351 352 353 354 355
		slave = of_find_node_by_name(NULL, "pci106b,7");
		if (slave) {
			max_irqs = 64;
			level_mask[1] = OHARE_LEVEL_MASK;
		}
	} else if ((master = of_find_node_by_name(NULL, "mac-io")) != NULL) {
		max_irqs = max_real_irqs = 64;
356 357
		level_mask[0] = HEATHROW_LEVEL_MASK;
		level_mask[1] = 0;
358

359
		/* We might have a second cascaded heathrow */
360 361 362
		slave = of_find_node_by_name(master, "mac-io");

		/* Check ordering of master & slave */
363
		if (of_device_is_compatible(master, "gatwick")) {
364 365 366 367 368 369
			struct device_node *tmp;
			BUG_ON(slave == NULL);
			tmp = master;
			master = slave;
			slave = tmp;
		}
370

371 372
		/* We found a slave */
		if (slave) {
373
			max_irqs = 128;
374 375 376
			level_mask[2] = HEATHROW_LEVEL_MASK;
			level_mask[3] = 0;
		}
377
	}
378 379
	BUG_ON(master == NULL);

380 381 382
	/*
	 * Allocate an irq host
	 */
383
	pmac_pic_host = irq_alloc_host(master, IRQ_HOST_MAP_LINEAR, max_irqs,
384 385 386 387
				       &pmac_pic_host_ops,
				       max_irqs);
	BUG_ON(pmac_pic_host == NULL);
	irq_set_default_host(pmac_pic_host);
388

389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413
	/* Get addresses of first controller if we have a node for it */
	BUG_ON(of_address_to_resource(master, 0, &r));

	/* Map interrupts of primary controller */
	addr = (u8 __iomem *) ioremap(r.start, 0x40);
	i = 0;
	pmac_irq_hw[i++] = (volatile struct pmac_irq_hw __iomem *)
		(addr + 0x20);
	if (max_real_irqs > 32)
		pmac_irq_hw[i++] = (volatile struct pmac_irq_hw __iomem *)
			(addr + 0x10);
	of_node_put(master);

	printk(KERN_INFO "irq: Found primary Apple PIC %s for %d irqs\n",
	       master->full_name, max_real_irqs);

	/* Map interrupts of cascaded controller */
	if (slave && !of_address_to_resource(slave, 0, &r)) {
		addr = (u8 __iomem *)ioremap(r.start, 0x40);
		pmac_irq_hw[i++] = (volatile struct pmac_irq_hw __iomem *)
			(addr + 0x20);
		if (max_irqs > 64)
			pmac_irq_hw[i++] =
				(volatile struct pmac_irq_hw __iomem *)
				(addr + 0x10);
414
		pmac_irq_cascade = irq_of_parse_and_map(slave, 0);
415 416 417

		printk(KERN_INFO "irq: Found slave Apple PIC %s for %d irqs"
		       " cascade: %d\n", slave->full_name,
418
		       max_irqs - max_real_irqs, pmac_irq_cascade);
419
	}
420
	of_node_put(slave);
421

422
	/* Disable all interrupts in all controllers */
423 424
	for (i = 0; i * 32 < max_irqs; ++i)
		out_le32(&pmac_irq_hw[i]->enable, 0);
425

426
	/* Hookup cascade irq */
427
	if (slave && pmac_irq_cascade != NO_IRQ)
428
		setup_irq(pmac_irq_cascade, &gatwick_cascade_action);
429

430
	printk(KERN_INFO "irq: System has %d possible interrupts\n", max_irqs);
431
#ifdef CONFIG_XMON
432
	setup_irq(irq_create_mapping(NULL, 20), &xmon_action);
433 434
#endif
}
435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470

int of_irq_map_oldworld(struct device_node *device, int index,
			struct of_irq *out_irq)
{
	const u32 *ints = NULL;
	int intlen;

	/*
	 * Old machines just have a list of interrupt numbers
	 * and no interrupt-controller nodes. We also have dodgy
	 * cases where the APPL,interrupts property is completely
	 * missing behind pci-pci bridges and we have to get it
	 * from the parent (the bridge itself, as apple just wired
	 * everything together on these)
	 */
	while (device) {
		ints = of_get_property(device, "AAPL,interrupts", &intlen);
		if (ints != NULL)
			break;
		device = device->parent;
		if (device && strcmp(device->type, "pci") != 0)
			break;
	}
	if (ints == NULL)
		return -EINVAL;
	intlen /= sizeof(u32);

	if (index >= intlen)
		return -EINVAL;

	out_irq->controller = NULL;
	out_irq->specifier[0] = ints[index];
	out_irq->size = 1;

	return 0;
}
471 472
#endif /* CONFIG_PPC32 */

473
static void pmac_u3_cascade(unsigned int irq, struct irq_desc *desc)
474
{
475 476
	struct mpic *mpic = desc->handler_data;

O
Olaf Hering 已提交
477
	unsigned int cascade_irq = mpic_get_one_irq(mpic);
478
	if (cascade_irq != NO_IRQ)
479
		generic_handle_irq(cascade_irq);
480
	desc->chip->eoi(irq);
481 482 483 484 485 486 487 488 489
}

static void __init pmac_pic_setup_mpic_nmi(struct mpic *mpic)
{
#if defined(CONFIG_XMON) && defined(CONFIG_PPC32)
	struct device_node* pswitch;
	int nmi_irq;

	pswitch = of_find_node_by_name(NULL, "programmer-switch");
490 491 492 493 494 495 496
	if (pswitch) {
		nmi_irq = irq_of_parse_and_map(pswitch, 0);
		if (nmi_irq != NO_IRQ) {
			mpic_irq_set_priority(nmi_irq, 9);
			setup_irq(nmi_irq, &xmon_action);
		}
		of_node_put(pswitch);
497 498 499 500
	}
#endif	/* defined(CONFIG_XMON) && defined(CONFIG_PPC32) */
}

501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516
static struct mpic * __init pmac_setup_one_mpic(struct device_node *np,
						int master)
{
	const char *name = master ? " MPIC 1   " : " MPIC 2   ";
	struct resource r;
	struct mpic *mpic;
	unsigned int flags = master ? MPIC_PRIMARY : 0;
	int rc;

	rc = of_address_to_resource(np, 0, &r);
	if (rc)
		return NULL;

	pmac_call_feature(PMAC_FTR_ENABLE_MPIC, np, 0, 0);

	flags |= MPIC_WANTS_RESET;
517
	if (of_get_property(np, "big-endian", NULL))
518 519 520 521 522 523
		flags |= MPIC_BIG_ENDIAN;

	/* Primary Big Endian means HT interrupts. This is quite dodgy
	 * but works until I find a better way
	 */
	if (master && (flags & MPIC_BIG_ENDIAN))
524
		flags |= MPIC_U3_HT_IRQS;
525

526
	mpic = mpic_alloc(np, r.start, flags, 0, 0, name);
527 528 529 530 531 532 533 534
	if (mpic == NULL)
		return NULL;

	mpic_init(mpic);

	return mpic;
 }

535 536 537 538
static int __init pmac_pic_probe_mpic(void)
{
	struct mpic *mpic1, *mpic2;
	struct device_node *np, *master = NULL, *slave = NULL;
539
	unsigned int cascade;
540 541 542 543 544

	/* We can have up to 2 MPICs cascaded */
	for (np = NULL; (np = of_find_node_by_type(np, "open-pic"))
		     != NULL;) {
		if (master == NULL &&
545
		    of_get_property(np, "interrupts", NULL) == NULL)
546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566
			master = of_node_get(np);
		else if (slave == NULL)
			slave = of_node_get(np);
		if (master && slave)
			break;
	}

	/* Check for bogus setups */
	if (master == NULL && slave != NULL) {
		master = slave;
		slave = NULL;
	}

	/* Not found, default to good old pmac pic */
	if (master == NULL)
		return -ENODEV;

	/* Set master handler */
	ppc_md.get_irq = mpic_get_irq;

	/* Setup master */
567
	mpic1 = pmac_setup_one_mpic(master, 1);
568 569 570 571 572 573 574 575
	BUG_ON(mpic1 == NULL);

	/* Install NMI if any */
	pmac_pic_setup_mpic_nmi(mpic1);

	of_node_put(master);

	/* No slave, let's go out */
576 577 578 579 580 581 582
	if (slave == NULL)
		return 0;

	/* Get/Map slave interrupt */
	cascade = irq_of_parse_and_map(slave, 0);
	if (cascade == NO_IRQ) {
		printk(KERN_ERR "Failed to map cascade IRQ\n");
583
		return 0;
584
	}
585

586
	mpic2 = pmac_setup_one_mpic(slave, 0);
587
	if (mpic2 == NULL) {
588 589
		printk(KERN_ERR "Failed to setup slave MPIC\n");
		of_node_put(slave);
590 591
		return 0;
	}
592 593
	set_irq_data(cascade, mpic2);
	set_irq_chained_handler(cascade, pmac_u3_cascade);
594 595 596 597 598 599 600 601

	of_node_put(slave);
	return 0;
}


void __init pmac_pic_init(void)
{
602 603 604 605 606
	/* We configure the OF parsing based on our oldworld vs. newworld
	 * platform type and wether we were booted by BootX.
	 */
#ifdef CONFIG_PPC32
	if (!pmac_newworld)
607
		of_irq_workarounds |= OF_IMAP_OLDWORLD_MAC;
608
	if (of_get_property(of_chosen, "linux,bootx", NULL) != NULL)
609
		of_irq_workarounds |= OF_IMAP_NO_PHANDLE;
610

611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634
	/* If we don't have phandles on a newworld, then try to locate a
	 * default interrupt controller (happens when booting with BootX).
	 * We do a first match here, hopefully, that only ever happens on
	 * machines with one controller.
	 */
	if (pmac_newworld && (of_irq_workarounds & OF_IMAP_NO_PHANDLE)) {
		struct device_node *np;

		for_each_node_with_property(np, "interrupt-controller") {
			/* Skip /chosen/interrupt-controller */
			if (strcmp(np->name, "chosen") == 0)
				continue;
			/* It seems like at least one person wants
			 * to use BootX on a machine with an AppleKiwi
			 * controller which happens to pretend to be an
			 * interrupt controller too. */
			if (strcmp(np->name, "AppleKiwi") == 0)
				continue;
			/* I think we found one ! */
			of_irq_dflt_pic = np;
			break;
		}
	}
#endif /* CONFIG_PPC32 */
635

636 637 638 639 640 641 642 643 644
	/* We first try to detect Apple's new Core99 chipset, since mac-io
	 * is quite different on those machines and contains an IBM MPIC2.
	 */
	if (pmac_pic_probe_mpic() == 0)
		return;

#ifdef CONFIG_PPC32
	pmac_pic_probe_oldstyle();
#endif
645 646
}

647
#if defined(CONFIG_PM) && defined(CONFIG_PPC32)
648 649 650 651 652 653 654 655 656 657
/*
 * These procedures are used in implementing sleep on the powerbooks.
 * sleep_save_intrs() saves the states of all interrupt enables
 * and disables all interrupts except for the nominated one.
 * sleep_restore_intrs() restores the states of all interrupt enables.
 */
unsigned long sleep_save_mask[2];

/* This used to be passed by the PMU driver but that link got
 * broken with the new driver model. We use this tweak for now...
658
 * We really want to do things differently though...
659 660 661 662 663 664 665 666 667 668 669 670 671
 */
static int pmacpic_find_viaint(void)
{
	int viaint = -1;

#ifdef CONFIG_ADB_PMU
	struct device_node *np;

	if (pmu_get_model() != PMU_OHARE_BASED)
		goto not_found;
	np = of_find_node_by_name(NULL, "via-pmu");
	if (np == NULL)
		goto not_found;
672
	viaint = irq_of_parse_and_map(np, 0);
673 674

not_found:
675
#endif /* CONFIG_ADB_PMU */
676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714
	return viaint;
}

static int pmacpic_suspend(struct sys_device *sysdev, pm_message_t state)
{
	int viaint = pmacpic_find_viaint();

	sleep_save_mask[0] = ppc_cached_irq_mask[0];
	sleep_save_mask[1] = ppc_cached_irq_mask[1];
	ppc_cached_irq_mask[0] = 0;
	ppc_cached_irq_mask[1] = 0;
	if (viaint > 0)
		set_bit(viaint, ppc_cached_irq_mask);
	out_le32(&pmac_irq_hw[0]->enable, ppc_cached_irq_mask[0]);
	if (max_real_irqs > 32)
		out_le32(&pmac_irq_hw[1]->enable, ppc_cached_irq_mask[1]);
	(void)in_le32(&pmac_irq_hw[0]->event);
	/* make sure mask gets to controller before we return to caller */
	mb();
        (void)in_le32(&pmac_irq_hw[0]->enable);

        return 0;
}

static int pmacpic_resume(struct sys_device *sysdev)
{
	int i;

	out_le32(&pmac_irq_hw[0]->enable, 0);
	if (max_real_irqs > 32)
		out_le32(&pmac_irq_hw[1]->enable, 0);
	mb();
	for (i = 0; i < max_real_irqs; ++i)
		if (test_bit(i, sleep_save_mask))
			pmac_unmask_irq(i);

	return 0;
}

715
#endif /* CONFIG_PM && CONFIG_PPC32 */
716 717

static struct sysdev_class pmacpic_sysclass = {
718
	.name = "pmac_pic",
719 720 721 722 723 724 725 726
};

static struct sys_device device_pmacpic = {
	.id		= 0,
	.cls		= &pmacpic_sysclass,
};

static struct sysdev_driver driver_pmacpic = {
727
#if defined(CONFIG_PM) && defined(CONFIG_PPC32)
728 729
	.suspend	= &pmacpic_suspend,
	.resume		= &pmacpic_resume,
730
#endif /* CONFIG_PM && CONFIG_PPC32 */
731 732 733 734
};

static int __init init_pmacpic_sysfs(void)
{
735
#ifdef CONFIG_PPC32
736 737
	if (max_irqs == 0)
		return -ENODEV;
738
#endif
739 740 741 742 743 744
	printk(KERN_DEBUG "Registering pmac pic with sysfs...\n");
	sysdev_class_register(&pmacpic_sysclass);
	sysdev_register(&device_pmacpic);
	sysdev_driver_register(&pmacpic_sysclass, &driver_pmacpic);
	return 0;
}
745
machine_subsys_initcall(powermac, init_pmacpic_sysfs);
746