提交 917c3660 编写于 作者: S Sam Ravnborg 提交者: David S. Miller

sparc64: move EXPORT_SYMBOL to the symbols definition

Move all applicable EXPORT_SYMBOL()s to the file where the respective
symbol is defined.

Removed all the includes that are no longer needed in sparc_ksyms_64.c

Comment all remaining EXPORT_SYMBOL()s in sparc_ksyms_64.c
Signed-off-by: NSam Ravnborg <sam@ravnborg.org>

Additions by Julian Calaby:
* Moved EXPORT_SYMBOL()s for prom functions to their rightful places.
* Made some minor cleanups to the includes and comments of sparc_ksyms_64.c
* Updated and tidied commit message.
* Rebased patch over sparc-2.6.git HEAD.
* Ensured that all modified files have the correct includes.
Signed-off-by: NJulian Calaby <julian.calaby@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 6943f3da
...@@ -72,6 +72,7 @@ void auxio_set_led(int on) ...@@ -72,6 +72,7 @@ void auxio_set_led(int on)
bit = (ebus ? AUXIO_PCIO_LED : AUXIO_AUX1_LED); bit = (ebus ? AUXIO_PCIO_LED : AUXIO_AUX1_LED);
__auxio_set_bit(bit, on, ebus); __auxio_set_bit(bit, on, ebus);
} }
EXPORT_SYMBOL(auxio_set_led);
static void __auxio_sbus_set_lte(int on) static void __auxio_sbus_set_lte(int on)
{ {
...@@ -90,6 +91,7 @@ void auxio_set_lte(int on) ...@@ -90,6 +91,7 @@ void auxio_set_lte(int on)
break; break;
} }
} }
EXPORT_SYMBOL(auxio_set_lte);
static struct of_device_id __initdata auxio_match[] = { static struct of_device_id __initdata auxio_match[] = {
{ {
......
...@@ -1077,6 +1077,7 @@ int pci_dma_supported(struct pci_dev *pdev, u64 device_mask) ...@@ -1077,6 +1077,7 @@ int pci_dma_supported(struct pci_dev *pdev, u64 device_mask)
return (device_mask & dma_addr_mask) == dma_addr_mask; return (device_mask & dma_addr_mask) == dma_addr_mask;
} }
EXPORT_SYMBOL(pci_dma_supported);
void pci_resource_to_user(const struct pci_dev *pdev, int bar, void pci_resource_to_user(const struct pci_dev *pdev, int bar,
const struct resource *rp, resource_size_t *start, const struct resource *rp, resource_size_t *start,
......
...@@ -678,6 +678,7 @@ pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags) ...@@ -678,6 +678,7 @@ pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags)
"g1", "g2", "g3", "o0", "o1", "memory", "cc"); "g1", "g2", "g3", "o0", "o1", "memory", "cc");
return retval; return retval;
} }
EXPORT_SYMBOL(kernel_thread);
typedef struct { typedef struct {
union { union {
...@@ -743,6 +744,7 @@ int dump_fpu (struct pt_regs * regs, elf_fpregset_t * fpregs) ...@@ -743,6 +744,7 @@ int dump_fpu (struct pt_regs * regs, elf_fpregset_t * fpregs)
} }
return 1; return 1;
} }
EXPORT_SYMBOL(dump_fpu);
/* /*
* sparc_execve() executes a new program after the asm stub has set * sparc_execve() executes a new program after the asm stub has set
......
...@@ -117,6 +117,7 @@ void sbus_set_sbus64(struct device *dev, int bursts) ...@@ -117,6 +117,7 @@ void sbus_set_sbus64(struct device *dev, int bursts)
val |= (1UL << 4UL); val |= (1UL << 4UL);
upa_writeq(val, cfg_reg); upa_writeq(val, cfg_reg);
} }
EXPORT_SYMBOL(sbus_set_sbus64);
/* INO number to IMAP register offset for SYSIO external IRQ's. /* INO number to IMAP register offset for SYSIO external IRQ's.
* This should conform to both Sunfire/Wildfire server and Fusion * This should conform to both Sunfire/Wildfire server and Fusion
......
...@@ -58,6 +58,7 @@ ...@@ -58,6 +58,7 @@
* operations in asm/ns87303.h * operations in asm/ns87303.h
*/ */
DEFINE_SPINLOCK(ns87303_lock); DEFINE_SPINLOCK(ns87303_lock);
EXPORT_SYMBOL(ns87303_lock);
struct screen_info screen_info = { struct screen_info screen_info = {
0, 0, /* orig-x, orig-y */ 0, 0, /* orig-x, orig-y */
...@@ -425,5 +426,7 @@ void sun_do_break(void) ...@@ -425,5 +426,7 @@ void sun_do_break(void)
prom_cmdline(); prom_cmdline();
} }
EXPORT_SYMBOL(sun_do_break);
int stop_a_enabled = 1; int stop_a_enabled = 1;
EXPORT_SYMBOL(stop_a_enabled);
...@@ -8,43 +8,15 @@ ...@@ -8,43 +8,15 @@
#define PROMLIB_INTERNAL #define PROMLIB_INTERNAL
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h>
#include <linux/sched.h>
#include <linux/in6.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/interrupt.h>
#include <linux/fs_struct.h>
#include <linux/fs.h>
#include <linux/mm.h>
#include <linux/socket.h>
#include <linux/syscalls.h>
#include <linux/percpu.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/rwsem.h>
#include <net/compat.h>
#include <asm/oplib.h> #include <asm/spinlock.h>
#include <asm/system.h> #include <asm/system.h>
#include <asm/auxio.h>
#include <asm/pgtable.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/elf.h>
#include <asm/head.h>
#include <asm/smp.h>
#include <asm/ptrace.h>
#include <asm/uaccess.h>
#include <asm/checksum.h>
#include <asm/fpumacro.h>
#include <asm/pgalloc.h>
#include <asm/cacheflush.h>
#ifdef CONFIG_SBUS
#include <asm/dma.h>
#endif
#include <asm/ns87303.h>
#include <asm/timer.h>
#include <asm/cpudata.h> #include <asm/cpudata.h>
#include <asm/ftrace.h> #include <asm/uaccess.h>
#include <asm/spitfire.h>
#include <asm/oplib.h>
#include <asm/hypervisor.h> #include <asm/hypervisor.h>
struct poll { struct poll {
...@@ -53,19 +25,6 @@ struct poll { ...@@ -53,19 +25,6 @@ struct poll {
short revents; short revents;
}; };
extern void die_if_kernel(char *str, struct pt_regs *regs);
extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags);
extern void sys_sigsuspend(void);
extern int compat_sys_ioctl(unsigned int fd, unsigned int cmd, u32 arg);
extern int (*handle_mathemu)(struct pt_regs *, struct fpustate *);
extern long sparc32_open(const char __user * filename, int flags, int mode);
extern int io_remap_pfn_range(struct vm_area_struct *vma, unsigned long from,
unsigned long pfn, unsigned long size, pgprot_t prot);
extern int __ashrdi3(int, int);
extern int dump_fpu (struct pt_regs * regs, elf_fpregset_t * fpregs);
/* used by various drivers */ /* used by various drivers */
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
/* Out of line rw-locking implementation. */ /* Out of line rw-locking implementation. */
...@@ -76,37 +35,24 @@ EXPORT_SYMBOL(__write_unlock); ...@@ -76,37 +35,24 @@ EXPORT_SYMBOL(__write_unlock);
EXPORT_SYMBOL(__write_trylock); EXPORT_SYMBOL(__write_trylock);
#endif /* CONFIG_SMP */ #endif /* CONFIG_SMP */
EXPORT_SYMBOL(sparc64_get_clock_tick); /* from helpers.S */
EXPORT_SYMBOL(__flushw_user); EXPORT_SYMBOL(__flushw_user);
EXPORT_SYMBOL_GPL(real_hard_smp_processor_id);
/* from head_64.S */
EXPORT_SYMBOL(__ret_efault);
EXPORT_SYMBOL(tlb_type); EXPORT_SYMBOL(tlb_type);
EXPORT_SYMBOL(sun4v_chip_type); EXPORT_SYMBOL(sun4v_chip_type);
EXPORT_SYMBOL(get_fb_unmapped_area); EXPORT_SYMBOL(prom_root_node);
EXPORT_SYMBOL(flush_icache_range);
EXPORT_SYMBOL(flush_dcache_page);
#ifdef DCACHE_ALIASING_POSSIBLE
EXPORT_SYMBOL(__flush_dcache_range);
#endif
/* from hvcalls.S */
EXPORT_SYMBOL(sun4v_niagara_getperf); EXPORT_SYMBOL(sun4v_niagara_getperf);
EXPORT_SYMBOL(sun4v_niagara_setperf); EXPORT_SYMBOL(sun4v_niagara_setperf);
EXPORT_SYMBOL(sun4v_niagara2_getperf); EXPORT_SYMBOL(sun4v_niagara2_getperf);
EXPORT_SYMBOL(sun4v_niagara2_setperf); EXPORT_SYMBOL(sun4v_niagara2_setperf);
EXPORT_SYMBOL(auxio_set_led);
EXPORT_SYMBOL(auxio_set_lte);
#ifdef CONFIG_SBUS
EXPORT_SYMBOL(sbus_set_sbus64);
#endif
EXPORT_SYMBOL(outsb);
EXPORT_SYMBOL(outsw);
EXPORT_SYMBOL(outsl);
EXPORT_SYMBOL(insb);
EXPORT_SYMBOL(insw);
EXPORT_SYMBOL(insl);
#ifdef CONFIG_PCI #ifdef CONFIG_PCI
/* inline functions in asm/pci_64.h */
EXPORT_SYMBOL(pci_alloc_consistent); EXPORT_SYMBOL(pci_alloc_consistent);
EXPORT_SYMBOL(pci_free_consistent); EXPORT_SYMBOL(pci_free_consistent);
EXPORT_SYMBOL(pci_map_single); EXPORT_SYMBOL(pci_map_single);
...@@ -115,65 +61,7 @@ EXPORT_SYMBOL(pci_map_sg); ...@@ -115,65 +61,7 @@ EXPORT_SYMBOL(pci_map_sg);
EXPORT_SYMBOL(pci_unmap_sg); EXPORT_SYMBOL(pci_unmap_sg);
EXPORT_SYMBOL(pci_dma_sync_single_for_cpu); EXPORT_SYMBOL(pci_dma_sync_single_for_cpu);
EXPORT_SYMBOL(pci_dma_sync_sg_for_cpu); EXPORT_SYMBOL(pci_dma_sync_sg_for_cpu);
EXPORT_SYMBOL(pci_dma_supported);
#endif #endif
/* I/O device mmaping on Sparc64. */ /* Exporting a symbol from /init/main.c */
EXPORT_SYMBOL(io_remap_pfn_range);
EXPORT_SYMBOL(dump_fpu);
/* math-emu wants this */
EXPORT_SYMBOL(die_if_kernel);
/* Kernel thread creation. */
EXPORT_SYMBOL(kernel_thread);
/* prom symbols */
EXPORT_SYMBOL(prom_root_node);
EXPORT_SYMBOL(prom_getchild);
EXPORT_SYMBOL(prom_getsibling);
EXPORT_SYMBOL(prom_searchsiblings);
EXPORT_SYMBOL(prom_firstprop);
EXPORT_SYMBOL(prom_nextprop);
EXPORT_SYMBOL(prom_getproplen);
EXPORT_SYMBOL(prom_getproperty);
EXPORT_SYMBOL(prom_node_has_property);
EXPORT_SYMBOL(prom_setprop);
EXPORT_SYMBOL(saved_command_line); EXPORT_SYMBOL(saved_command_line);
EXPORT_SYMBOL(prom_finddevice);
EXPORT_SYMBOL(prom_feval);
EXPORT_SYMBOL(prom_getbool);
EXPORT_SYMBOL(prom_getstring);
EXPORT_SYMBOL(prom_getint);
EXPORT_SYMBOL(prom_getintdefault);
EXPORT_SYMBOL(__prom_getchild);
EXPORT_SYMBOL(__prom_getsibling);
/* Moving data to/from/in userspace. */
EXPORT_SYMBOL(copy_to_user_fixup);
EXPORT_SYMBOL(copy_from_user_fixup);
EXPORT_SYMBOL(copy_in_user_fixup);
/* Various address conversion macros use this. */
EXPORT_SYMBOL(sparc64_valid_addr_bitmap);
/* No version information on this, heavily used in inline asm,
* and will always be 'void __ret_efault(void)'.
*/
EXPORT_SYMBOL(__ret_efault);
/* for input/keybdev */
EXPORT_SYMBOL(sun_do_break);
EXPORT_SYMBOL(stop_a_enabled);
#ifdef CONFIG_DEBUG_BUGVERBOSE
EXPORT_SYMBOL(do_BUG);
#endif
/* for ns8703 */
EXPORT_SYMBOL(ns87303_lock);
EXPORT_SYMBOL(tick_ops);
EXPORT_SYMBOL_GPL(real_hard_smp_processor_id);
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include <linux/ipc.h> #include <linux/ipc.h>
#include <linux/personality.h> #include <linux/personality.h>
#include <linux/random.h> #include <linux/random.h>
#include <linux/module.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/utrap.h> #include <asm/utrap.h>
...@@ -354,6 +355,7 @@ unsigned long get_fb_unmapped_area(struct file *filp, unsigned long orig_addr, u ...@@ -354,6 +355,7 @@ unsigned long get_fb_unmapped_area(struct file *filp, unsigned long orig_addr, u
return addr; return addr;
} }
EXPORT_SYMBOL(get_fb_unmapped_area);
/* Essentially the same as PowerPC... */ /* Essentially the same as PowerPC... */
void arch_pick_mmap_layout(struct mm_struct *mm) void arch_pick_mmap_layout(struct mm_struct *mm)
......
...@@ -176,6 +176,7 @@ static struct sparc64_tick_ops tick_operations __read_mostly = { ...@@ -176,6 +176,7 @@ static struct sparc64_tick_ops tick_operations __read_mostly = {
}; };
struct sparc64_tick_ops *tick_ops __read_mostly = &tick_operations; struct sparc64_tick_ops *tick_ops __read_mostly = &tick_operations;
EXPORT_SYMBOL(tick_ops);
static void stick_disable_irq(void) static void stick_disable_irq(void)
{ {
...@@ -639,6 +640,7 @@ unsigned long sparc64_get_clock_tick(unsigned int cpu) ...@@ -639,6 +640,7 @@ unsigned long sparc64_get_clock_tick(unsigned int cpu)
return ft->clock_tick_ref; return ft->clock_tick_ref;
return cpu_data(cpu).clock_tick; return cpu_data(cpu).clock_tick;
} }
EXPORT_SYMBOL(sparc64_get_clock_tick);
#ifdef CONFIG_CPU_FREQ #ifdef CONFIG_CPU_FREQ
......
...@@ -128,6 +128,7 @@ void do_BUG(const char *file, int line) ...@@ -128,6 +128,7 @@ void do_BUG(const char *file, int line)
bust_spinlocks(1); bust_spinlocks(1);
printk("kernel BUG at %s:%d!\n", file, line); printk("kernel BUG at %s:%d!\n", file, line);
} }
EXPORT_SYMBOL(do_BUG);
#endif #endif
static DEFINE_SPINLOCK(dimm_handler_lock); static DEFINE_SPINLOCK(dimm_handler_lock);
...@@ -2261,6 +2262,7 @@ void die_if_kernel(char *str, struct pt_regs *regs) ...@@ -2261,6 +2262,7 @@ void die_if_kernel(char *str, struct pt_regs *regs)
do_exit(SIGKILL); do_exit(SIGKILL);
do_exit(SIGSEGV); do_exit(SIGSEGV);
} }
EXPORT_SYMBOL(die_if_kernel);
#define VIS_OPCODE_MASK ((0x3 << 30) | (0x3f << 19)) #define VIS_OPCODE_MASK ((0x3 << 30) | (0x3f << 19))
#define VIS_OPCODE_VAL ((0x2 << 30) | (0x36 << 19)) #define VIS_OPCODE_VAL ((0x2 << 30) | (0x36 << 19))
......
...@@ -4,6 +4,8 @@ ...@@ -4,6 +4,8 @@
* Copyright (C) 1997 David S. Miller (davem@caip.rutgers.edu) * Copyright (C) 1997 David S. Miller (davem@caip.rutgers.edu)
*/ */
#include <linux/module.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/byteorder.h> #include <asm/byteorder.h>
...@@ -15,6 +17,7 @@ void outsb(unsigned long __addr, const void *src, unsigned long count) ...@@ -15,6 +17,7 @@ void outsb(unsigned long __addr, const void *src, unsigned long count)
while (count--) while (count--)
outb(*p++, addr); outb(*p++, addr);
} }
EXPORT_SYMBOL(outsb);
void outsw(unsigned long __addr, const void *src, unsigned long count) void outsw(unsigned long __addr, const void *src, unsigned long count)
{ {
...@@ -25,6 +28,7 @@ void outsw(unsigned long __addr, const void *src, unsigned long count) ...@@ -25,6 +28,7 @@ void outsw(unsigned long __addr, const void *src, unsigned long count)
src += sizeof(u16); src += sizeof(u16);
} }
} }
EXPORT_SYMBOL(outsw);
void outsl(unsigned long __addr, const void *src, unsigned long count) void outsl(unsigned long __addr, const void *src, unsigned long count)
{ {
...@@ -78,6 +82,7 @@ void outsl(unsigned long __addr, const void *src, unsigned long count) ...@@ -78,6 +82,7 @@ void outsl(unsigned long __addr, const void *src, unsigned long count)
break; break;
} }
} }
EXPORT_SYMBOL(outsl);
void insb(unsigned long __addr, void *dst, unsigned long count) void insb(unsigned long __addr, void *dst, unsigned long count)
{ {
...@@ -105,6 +110,7 @@ void insb(unsigned long __addr, void *dst, unsigned long count) ...@@ -105,6 +110,7 @@ void insb(unsigned long __addr, void *dst, unsigned long count)
*pb++ = inb(addr); *pb++ = inb(addr);
} }
} }
EXPORT_SYMBOL(insb);
void insw(unsigned long __addr, void *dst, unsigned long count) void insw(unsigned long __addr, void *dst, unsigned long count)
{ {
...@@ -132,6 +138,7 @@ void insw(unsigned long __addr, void *dst, unsigned long count) ...@@ -132,6 +138,7 @@ void insw(unsigned long __addr, void *dst, unsigned long count)
*ps = le16_to_cpu(inw(addr)); *ps = le16_to_cpu(inw(addr));
} }
} }
EXPORT_SYMBOL(insw);
void insl(unsigned long __addr, void *dst, unsigned long count) void insl(unsigned long __addr, void *dst, unsigned long count)
{ {
...@@ -200,4 +207,5 @@ void insl(unsigned long __addr, void *dst, unsigned long count) ...@@ -200,4 +207,5 @@ void insl(unsigned long __addr, void *dst, unsigned long count)
} }
} }
} }
EXPORT_SYMBOL(insl);
...@@ -7,6 +7,8 @@ ...@@ -7,6 +7,8 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/string.h> #include <linux/string.h>
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/module.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
/* Calculating the exact fault address when using /* Calculating the exact fault address when using
...@@ -40,6 +42,7 @@ unsigned long copy_from_user_fixup(void *to, const void __user *from, unsigned l ...@@ -40,6 +42,7 @@ unsigned long copy_from_user_fixup(void *to, const void __user *from, unsigned l
return size; return size;
} }
EXPORT_SYMBOL(copy_from_user_fixup);
unsigned long copy_to_user_fixup(void __user *to, const void *from, unsigned long size) unsigned long copy_to_user_fixup(void __user *to, const void *from, unsigned long size)
{ {
...@@ -47,6 +50,7 @@ unsigned long copy_to_user_fixup(void __user *to, const void *from, unsigned lon ...@@ -47,6 +50,7 @@ unsigned long copy_to_user_fixup(void __user *to, const void *from, unsigned lon
return compute_size((unsigned long) to, size, &offset); return compute_size((unsigned long) to, size, &offset);
} }
EXPORT_SYMBOL(copy_to_user_fixup);
unsigned long copy_in_user_fixup(void __user *to, void __user *from, unsigned long size) unsigned long copy_in_user_fixup(void __user *to, void __user *from, unsigned long size)
{ {
...@@ -64,3 +68,4 @@ unsigned long copy_in_user_fixup(void __user *to, void __user *from, unsigned lo ...@@ -64,3 +68,4 @@ unsigned long copy_in_user_fixup(void __user *to, void __user *from, unsigned lo
return size; return size;
} }
EXPORT_SYMBOL(copy_in_user_fixup);
...@@ -161,3 +161,4 @@ int io_remap_pfn_range(struct vm_area_struct *vma, unsigned long from, ...@@ -161,3 +161,4 @@ int io_remap_pfn_range(struct vm_area_struct *vma, unsigned long from,
flush_tlb_range(vma, beg, end); flush_tlb_range(vma, beg, end);
return error; return error;
} }
EXPORT_SYMBOL(io_remap_pfn_range);
...@@ -146,6 +146,7 @@ static void __init read_obp_memory(const char *property, ...@@ -146,6 +146,7 @@ static void __init read_obp_memory(const char *property,
} }
unsigned long *sparc64_valid_addr_bitmap __read_mostly; unsigned long *sparc64_valid_addr_bitmap __read_mostly;
EXPORT_SYMBOL(sparc64_valid_addr_bitmap);
/* Kernel physical address base and size in bytes. */ /* Kernel physical address base and size in bytes. */
unsigned long kern_base __read_mostly; unsigned long kern_base __read_mostly;
...@@ -369,6 +370,7 @@ void flush_dcache_page(struct page *page) ...@@ -369,6 +370,7 @@ void flush_dcache_page(struct page *page)
out: out:
put_cpu(); put_cpu();
} }
EXPORT_SYMBOL(flush_dcache_page);
void __kprobes flush_icache_range(unsigned long start, unsigned long end) void __kprobes flush_icache_range(unsigned long start, unsigned long end)
{ {
...@@ -396,6 +398,7 @@ void __kprobes flush_icache_range(unsigned long start, unsigned long end) ...@@ -396,6 +398,7 @@ void __kprobes flush_icache_range(unsigned long start, unsigned long end)
} }
} }
} }
EXPORT_SYMBOL(flush_icache_range);
void mmu_info(struct seq_file *m) void mmu_info(struct seq_file *m)
{ {
...@@ -599,6 +602,7 @@ void __flush_dcache_range(unsigned long start, unsigned long end) ...@@ -599,6 +602,7 @@ void __flush_dcache_range(unsigned long start, unsigned long end)
"i" (ASI_DCACHE_INVALIDATE)); "i" (ASI_DCACHE_INVALIDATE));
} }
} }
EXPORT_SYMBOL(__flush_dcache_range);
/* get_new_mmu_context() uses "cache + 1". */ /* get_new_mmu_context() uses "cache + 1". */
DEFINE_SPINLOCK(ctx_alloc_lock); DEFINE_SPINLOCK(ctx_alloc_lock);
......
...@@ -11,6 +11,8 @@ ...@@ -11,6 +11,8 @@
#include <linux/sched.h> #include <linux/sched.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/module.h>
#include <asm/openprom.h> #include <asm/openprom.h>
#include <asm/oplib.h> #include <asm/oplib.h>
#include <asm/system.h> #include <asm/system.h>
...@@ -54,6 +56,7 @@ void prom_feval(const char *fstring) ...@@ -54,6 +56,7 @@ void prom_feval(const char *fstring)
p1275_cmd("interpret", P1275_ARG(0, P1275_ARG_IN_STRING) | p1275_cmd("interpret", P1275_ARG(0, P1275_ARG_IN_STRING) |
P1275_INOUT(1, 1), fstring); P1275_INOUT(1, 1), fstring);
} }
EXPORT_SYMBOL(prom_feval);
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
extern void smp_capture(void); extern void smp_capture(void);
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/sched.h> #include <linux/sched.h>
#include <linux/module.h>
#include <asm/openprom.h> #include <asm/openprom.h>
#include <asm/oplib.h> #include <asm/oplib.h>
...@@ -22,6 +23,7 @@ inline int __prom_getchild(int node) ...@@ -22,6 +23,7 @@ inline int __prom_getchild(int node)
{ {
return p1275_cmd ("child", P1275_INOUT(1, 1), node); return p1275_cmd ("child", P1275_INOUT(1, 1), node);
} }
EXPORT_SYMBOL(__prom_getchild);
inline int prom_getchild(int node) inline int prom_getchild(int node)
{ {
...@@ -32,6 +34,7 @@ inline int prom_getchild(int node) ...@@ -32,6 +34,7 @@ inline int prom_getchild(int node)
if(cnode == -1) return 0; if(cnode == -1) return 0;
return (int)cnode; return (int)cnode;
} }
EXPORT_SYMBOL(prom_getchild);
inline int prom_getparent(int node) inline int prom_getparent(int node)
{ {
...@@ -50,6 +53,7 @@ inline int __prom_getsibling(int node) ...@@ -50,6 +53,7 @@ inline int __prom_getsibling(int node)
{ {
return p1275_cmd(prom_peer_name, P1275_INOUT(1, 1), node); return p1275_cmd(prom_peer_name, P1275_INOUT(1, 1), node);
} }
EXPORT_SYMBOL(__prom_getsibling);
inline int prom_getsibling(int node) inline int prom_getsibling(int node)
{ {
...@@ -63,6 +67,7 @@ inline int prom_getsibling(int node) ...@@ -63,6 +67,7 @@ inline int prom_getsibling(int node)
return sibnode; return sibnode;
} }
EXPORT_SYMBOL(prom_getsibling);
/* Return the length in bytes of property 'prop' at node 'node'. /* Return the length in bytes of property 'prop' at node 'node'.
* Return -1 on error. * Return -1 on error.
...@@ -75,6 +80,7 @@ inline int prom_getproplen(int node, const char *prop) ...@@ -75,6 +80,7 @@ inline int prom_getproplen(int node, const char *prop)
P1275_INOUT(2, 1), P1275_INOUT(2, 1),
node, prop); node, prop);
} }
EXPORT_SYMBOL(prom_getproplen);
/* Acquire a property 'prop' at node 'node' and place it in /* Acquire a property 'prop' at node 'node' and place it in
* 'buffer' which has a size of 'bufsize'. If the acquisition * 'buffer' which has a size of 'bufsize'. If the acquisition
...@@ -97,6 +103,7 @@ inline int prom_getproperty(int node, const char *prop, ...@@ -97,6 +103,7 @@ inline int prom_getproperty(int node, const char *prop,
node, prop, buffer, P1275_SIZE(plen)); node, prop, buffer, P1275_SIZE(plen));
} }
} }
EXPORT_SYMBOL(prom_getproperty);
/* Acquire an integer property and return its value. Returns -1 /* Acquire an integer property and return its value. Returns -1
* on failure. * on failure.
...@@ -110,6 +117,7 @@ inline int prom_getint(int node, const char *prop) ...@@ -110,6 +117,7 @@ inline int prom_getint(int node, const char *prop)
return -1; return -1;
} }
EXPORT_SYMBOL(prom_getint);
/* Acquire an integer property, upon error return the passed default /* Acquire an integer property, upon error return the passed default
* integer. * integer.
...@@ -124,6 +132,7 @@ int prom_getintdefault(int node, const char *property, int deflt) ...@@ -124,6 +132,7 @@ int prom_getintdefault(int node, const char *property, int deflt)
return retval; return retval;
} }
EXPORT_SYMBOL(prom_getintdefault);
/* Acquire a boolean property, 1=TRUE 0=FALSE. */ /* Acquire a boolean property, 1=TRUE 0=FALSE. */
int prom_getbool(int node, const char *prop) int prom_getbool(int node, const char *prop)
...@@ -134,6 +143,7 @@ int prom_getbool(int node, const char *prop) ...@@ -134,6 +143,7 @@ int prom_getbool(int node, const char *prop)
if(retval == -1) return 0; if(retval == -1) return 0;
return 1; return 1;
} }
EXPORT_SYMBOL(prom_getbool);
/* Acquire a property whose value is a string, returns a null /* Acquire a property whose value is a string, returns a null
* string on error. The char pointer is the user supplied string * string on error. The char pointer is the user supplied string
...@@ -148,7 +158,7 @@ void prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size) ...@@ -148,7 +158,7 @@ void prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size)
user_buf[0] = 0; user_buf[0] = 0;
return; return;
} }
EXPORT_SYMBOL(prom_getstring);
/* Does the device at node 'node' have name 'name'? /* Does the device at node 'node' have name 'name'?
* YES = 1 NO = 0 * YES = 1 NO = 0
...@@ -181,6 +191,7 @@ int prom_searchsiblings(int node_start, const char *nodename) ...@@ -181,6 +191,7 @@ int prom_searchsiblings(int node_start, const char *nodename)
return 0; return 0;
} }
EXPORT_SYMBOL(prom_searchsiblings);
/* Return the first property type for node 'node'. /* Return the first property type for node 'node'.
* buffer should be at least 32B in length * buffer should be at least 32B in length
...@@ -194,6 +205,7 @@ inline char *prom_firstprop(int node, char *buffer) ...@@ -194,6 +205,7 @@ inline char *prom_firstprop(int node, char *buffer)
node, (char *) 0x0, buffer); node, (char *) 0x0, buffer);
return buffer; return buffer;
} }
EXPORT_SYMBOL(prom_firstprop);
/* Return the property type string after property type 'oprop' /* Return the property type string after property type 'oprop'
* at node 'node' . Returns NULL string if no more * at node 'node' . Returns NULL string if no more
...@@ -217,6 +229,7 @@ inline char *prom_nextprop(int node, const char *oprop, char *buffer) ...@@ -217,6 +229,7 @@ inline char *prom_nextprop(int node, const char *oprop, char *buffer)
node, oprop, buffer); node, oprop, buffer);
return buffer; return buffer;
} }
EXPORT_SYMBOL(prom_nextprop);
int int
prom_finddevice(const char *name) prom_finddevice(const char *name)
...@@ -228,6 +241,7 @@ prom_finddevice(const char *name) ...@@ -228,6 +241,7 @@ prom_finddevice(const char *name)
P1275_INOUT(1, 1), P1275_INOUT(1, 1),
name); name);
} }
EXPORT_SYMBOL(prom_finddevice);
int prom_node_has_property(int node, const char *prop) int prom_node_has_property(int node, const char *prop)
{ {
...@@ -241,7 +255,8 @@ int prom_node_has_property(int node, const char *prop) ...@@ -241,7 +255,8 @@ int prom_node_has_property(int node, const char *prop)
} while (*buf); } while (*buf);
return 0; return 0;
} }
EXPORT_SYMBOL(prom_node_has_property);
/* Set property 'pname' at node 'node' to value 'value' which has a length /* Set property 'pname' at node 'node' to value 'value' which has a length
* of 'size' bytes. Return the number of bytes the prom accepted. * of 'size' bytes. Return the number of bytes the prom accepted.
*/ */
...@@ -264,6 +279,7 @@ prom_setprop(int node, const char *pname, char *value, int size) ...@@ -264,6 +279,7 @@ prom_setprop(int node, const char *pname, char *value, int size)
P1275_INOUT(4, 1), P1275_INOUT(4, 1),
node, pname, value, P1275_SIZE(size)); node, pname, value, P1275_SIZE(size));
} }
EXPORT_SYMBOL(prom_setprop);
inline int prom_inst2pkg(int inst) inline int prom_inst2pkg(int inst)
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册