2008-12-08 12:07:47 +03:00
# ifndef __SPARC_KERNEL_H
# define __SPARC_KERNEL_H
2008-12-08 12:08:24 +03:00
# include <linux/interrupt.h>
2014-05-17 01:25:57 +04:00
# include <linux/ftrace.h>
2008-12-08 12:08:24 +03:00
2011-02-26 09:59:20 +03:00
# include <asm/traps.h>
2011-08-02 10:27:17 +04:00
# include <asm/head.h>
# include <asm/io.h>
2011-02-26 09:59:20 +03:00
2008-12-07 11:02:08 +03:00
/* cpu.c */
2009-01-22 10:16:40 +03:00
extern const char * sparc_pmu_type ;
2008-12-07 11:02:08 +03:00
extern unsigned int fsr_storage ;
2011-04-22 02:45:45 +04:00
extern int ncpus_probed ;
2008-12-07 11:02:08 +03:00
2011-07-29 10:31:26 +04:00
# ifdef CONFIG_SPARC64
/* setup_64.c */
struct seq_file ;
2014-05-17 01:25:51 +04:00
void cpucap_info ( struct seq_file * ) ;
2011-08-02 10:27:17 +04:00
2014-05-17 01:25:57 +04:00
static inline unsigned long kimage_addr_to_ra ( const void * p )
2011-08-02 10:27:17 +04:00
{
unsigned long val = ( unsigned long ) p ;
return kern_base + ( val - KERNBASE ) ;
}
2014-05-17 01:25:54 +04:00
/* sys_sparc_64.c */
asmlinkage long sys_kern_features ( void ) ;
/* unaligned_64.c */
asmlinkage void kernel_unaligned_trap ( struct pt_regs * regs , unsigned int insn ) ;
int handle_popc ( u32 insn , struct pt_regs * regs ) ;
void handle_lddfmna ( struct pt_regs * regs , unsigned long sfar , unsigned long sfsr ) ;
void handle_stdfmna ( struct pt_regs * regs , unsigned long sfar , unsigned long sfsr ) ;
2014-05-17 01:25:57 +04:00
/* smp_64.c */
void __irq_entry smp_call_function_client ( int irq , struct pt_regs * regs ) ;
void __irq_entry smp_call_function_single_client ( int irq , struct pt_regs * regs ) ;
void __irq_entry smp_penguin_jailcell ( int irq , struct pt_regs * regs ) ;
void __irq_entry smp_receive_signal_client ( int irq , struct pt_regs * regs ) ;
2014-05-17 01:26:09 +04:00
/* kgdb_64.c */
void __irq_entry smp_kgdb_capture_client ( int irq , struct pt_regs * regs ) ;
2014-05-17 01:25:58 +04:00
/* pci.c */
int pci64_dma_supported ( struct pci_dev * pdev , u64 device_mask ) ;
2014-05-17 01:26:00 +04:00
/* signal32.c */
void do_sigreturn32 ( struct pt_regs * regs ) ;
asmlinkage void do_rt_sigreturn32 ( struct pt_regs * regs ) ;
void do_signal32 ( struct pt_regs * regs ) ;
asmlinkage int do_sys32_sigstack ( u32 u_ssptr , u32 u_ossptr , unsigned long sp ) ;
2017-06-12 23:41:46 +03:00
/* time_64.c */
void __init time_init_early ( void ) ;
2014-05-17 01:26:08 +04:00
/* compat_audit.c */
2016-03-11 02:21:43 +03:00
extern unsigned int sparc32_dir_class [ ] ;
extern unsigned int sparc32_chattr_class [ ] ;
extern unsigned int sparc32_write_class [ ] ;
extern unsigned int sparc32_read_class [ ] ;
extern unsigned int sparc32_signal_class [ ] ;
int sparc32_classify_syscall ( unsigned int syscall ) ;
2011-07-29 10:31:26 +04:00
# endif
2008-12-08 12:04:59 +03:00
# ifdef CONFIG_SPARC32
2012-05-26 01:20:08 +04:00
/* setup_32.c */
2014-05-17 01:25:39 +04:00
struct linux_romvec ;
2012-05-26 01:20:08 +04:00
void sparc32_start_kernel ( struct linux_romvec * rp ) ;
2008-12-08 12:04:59 +03:00
/* cpu.c */
2014-05-17 01:25:51 +04:00
void cpu_probe ( void ) ;
2008-12-07 11:02:08 +03:00
2008-12-08 12:04:59 +03:00
/* traps_32.c */
2014-05-17 01:25:51 +04:00
void handle_hw_divzero ( struct pt_regs * regs , unsigned long pc ,
unsigned long npc , unsigned long psr ) ;
2008-12-08 12:08:24 +03:00
/* irq_32.c */
extern struct irqaction static_irqaction [ ] ;
extern int static_irq_count ;
extern spinlock_t irq_action_lock ;
2014-05-17 01:25:51 +04:00
void unexpected_irq ( int irq , void * dev_id , struct pt_regs * regs ) ;
void init_IRQ ( void ) ;
2011-01-29 01:08:18 +03:00
/* sun4m_irq.c */
2014-05-17 01:25:51 +04:00
void sun4m_init_IRQ ( void ) ;
void sun4m_unmask_profile_irq ( void ) ;
void sun4m_clear_profile_irq ( int cpu ) ;
2011-01-29 01:08:18 +03:00
2013-02-15 18:52:06 +04:00
/* sun4m_smp.c */
void sun4m_cpu_pre_starting ( void * arg ) ;
void sun4m_cpu_pre_online ( void * arg ) ;
2014-04-21 23:39:42 +04:00
void __init smp4m_boot_cpus ( void ) ;
int smp4m_boot_one_cpu ( int i , struct task_struct * idle ) ;
void __init smp4m_smp_done ( void ) ;
void smp4m_cross_call_irq ( void ) ;
void smp4m_percpu_timer_interrupt ( struct pt_regs * regs ) ;
2013-02-15 18:52:06 +04:00
2011-01-29 01:08:18 +03:00
/* sun4d_irq.c */
extern spinlock_t sun4d_imsk_lock ;
2014-05-17 01:25:51 +04:00
void sun4d_init_IRQ ( void ) ;
int sun4d_request_irq ( unsigned int irq ,
irq_handler_t handler ,
unsigned long irqflags ,
const char * devname , void * dev_id ) ;
int show_sun4d_interrupts ( struct seq_file * , void * ) ;
void sun4d_distribute_irqs ( void ) ;
void sun4d_free_irq ( unsigned int irq , void * dev_id ) ;
2011-01-29 01:08:18 +03:00
2013-02-15 18:52:06 +04:00
/* sun4d_smp.c */
void sun4d_cpu_pre_starting ( void * arg ) ;
void sun4d_cpu_pre_online ( void * arg ) ;
2014-04-21 23:39:43 +04:00
void __init smp4d_boot_cpus ( void ) ;
int smp4d_boot_one_cpu ( int i , struct task_struct * idle ) ;
void __init smp4d_smp_done ( void ) ;
void smp4d_cross_call_irq ( void ) ;
void smp4d_percpu_timer_interrupt ( struct pt_regs * regs ) ;
2013-02-15 18:52:06 +04:00
/* leon_smp.c */
void leon_cpu_pre_starting ( void * arg ) ;
void leon_cpu_pre_online ( void * arg ) ;
2014-04-21 23:39:44 +04:00
void leonsmp_ipi_interrupt ( void ) ;
void leon_cross_call_irq ( void ) ;
2013-02-15 18:52:06 +04:00
2011-01-29 01:08:18 +03:00
/* head_32.S */
extern unsigned int t_nmi [ ] ;
extern unsigned int linux_trap_ipi15_sun4d [ ] ;
extern unsigned int linux_trap_ipi15_sun4m [ ] ;
2016-04-22 20:41:05 +03:00
extern struct tt_entry trapbase ;
2011-02-26 09:59:20 +03:00
extern struct tt_entry trapbase_cpu1 ;
extern struct tt_entry trapbase_cpu2 ;
extern struct tt_entry trapbase_cpu3 ;
2011-01-29 01:08:18 +03:00
extern char cputypval [ ] ;
/* entry.S */
extern unsigned long lvl14_save [ 4 ] ;
extern unsigned int real_irq_entry [ ] ;
extern unsigned int smp4d_ticker [ ] ;
extern unsigned int patchme_maybe_smp_msg [ ] ;
2014-05-17 01:25:51 +04:00
void floppy_hardint ( void ) ;
2011-01-29 01:08:18 +03:00
/* trampoline_32.S */
extern unsigned long sun4m_cpu_startup ;
extern unsigned long sun4d_cpu_startup ;
2008-12-08 12:08:24 +03:00
2014-04-21 23:39:25 +04:00
/* process_32.c */
asmlinkage int sparc_do_fork ( unsigned long clone_flags ,
unsigned long stack_start ,
struct pt_regs * regs ,
unsigned long stack_size ) ;
2014-04-21 23:39:26 +04:00
/* signal_32.c */
asmlinkage void do_sigreturn ( struct pt_regs * regs ) ;
asmlinkage void do_rt_sigreturn ( struct pt_regs * regs ) ;
void do_notify_resume ( struct pt_regs * regs , unsigned long orig_i0 ,
unsigned long thread_info_flags ) ;
asmlinkage int do_sys_sigstack ( struct sigstack __user * ssptr ,
struct sigstack __user * ossptr ,
unsigned long sp ) ;
2014-04-21 23:39:29 +04:00
2014-04-21 23:39:37 +04:00
/* ptrace_32.c */
asmlinkage int syscall_trace ( struct pt_regs * regs , int syscall_exit_p ) ;
2014-04-21 23:39:38 +04:00
/* unaligned_32.c */
asmlinkage void kernel_unaligned_trap ( struct pt_regs * regs , unsigned int insn ) ;
asmlinkage void user_unaligned_trap ( struct pt_regs * regs , unsigned int insn ) ;
2014-04-21 23:39:29 +04:00
/* windows.c */
void try_to_clear_window_buffer ( struct pt_regs * regs , int who ) ;
2014-04-21 23:39:35 +04:00
/* auxio_32.c */
void __init auxio_probe ( void ) ;
void __init auxio_power_probe ( void ) ;
2014-05-17 01:25:42 +04:00
/* pcic.c */
extern void __iomem * pcic_regs ;
void pcic_nmi ( unsigned int pend , struct pt_regs * regs ) ;
2014-05-17 01:25:44 +04:00
/* time_32.c */
void __init time_init ( void ) ;
2008-12-08 12:04:59 +03:00
# else /* CONFIG_SPARC32 */
2008-12-08 12:07:47 +03:00
# endif /* CONFIG_SPARC32 */
# endif /* !(__SPARC_KERNEL_H) */