|  | // SPDX-License-Identifier: GPL-2.0 | 
|  | /* | 
|  | * p1275.c: Sun IEEE 1275 PROM low level interface routines | 
|  | * | 
|  | * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz) | 
|  | */ | 
|  |  | 
|  | #include <linux/kernel.h> | 
|  | #include <linux/sched.h> | 
|  | #include <linux/smp.h> | 
|  | #include <linux/string.h> | 
|  | #include <linux/spinlock.h> | 
|  | #include <linux/irqflags.h> | 
|  |  | 
|  | #include <asm/openprom.h> | 
|  | #include <asm/oplib.h> | 
|  | #include <asm/spitfire.h> | 
|  | #include <asm/pstate.h> | 
|  | #include <asm/ldc.h> | 
|  |  | 
|  | struct { | 
|  | long prom_callback;			/* 0x00 */ | 
|  | void (*prom_cif_handler)(long *);	/* 0x08 */ | 
|  | } p1275buf; | 
|  |  | 
|  | extern void prom_world(int); | 
|  |  | 
|  | extern void prom_cif_direct(unsigned long *args); | 
|  | extern void prom_cif_callback(void); | 
|  |  | 
|  | /* | 
|  | * This provides SMP safety on the p1275buf. | 
|  | */ | 
|  | DEFINE_RAW_SPINLOCK(prom_entry_lock); | 
|  |  | 
|  | void p1275_cmd_direct(unsigned long *args) | 
|  | { | 
|  | unsigned long flags; | 
|  |  | 
|  | local_save_flags(flags); | 
|  | local_irq_restore((unsigned long)PIL_NMI); | 
|  | raw_spin_lock(&prom_entry_lock); | 
|  |  | 
|  | prom_world(1); | 
|  | prom_cif_direct(args); | 
|  | prom_world(0); | 
|  |  | 
|  | raw_spin_unlock(&prom_entry_lock); | 
|  | local_irq_restore(flags); | 
|  | } | 
|  |  | 
|  | void prom_cif_init(void *cif_handler, void *cif_stack) | 
|  | { | 
|  | p1275buf.prom_cif_handler = (void (*)(long *))cif_handler; | 
|  | } |