2020-02-03 12:25:40 +03:00
/* SPDX-License-Identifier: GPL-2.0 */
2009-03-27 16:25:37 +03:00
/*
2009-05-26 18:30:18 +04:00
* Copyright ( C ) 2008 - 2009 Michal Simek < monstr @ monstr . eu >
* Copyright ( C ) 2008 - 2009 PetaLogix
2009-03-27 16:25:37 +03:00
* Copyright ( C ) 2006 Atmark Techno , Inc .
*/
# ifndef _ASM_MICROBLAZE_PROCESSOR_H
# define _ASM_MICROBLAZE_PROCESSOR_H
# include <asm/ptrace.h>
# include <asm/setup.h>
# include <asm/registers.h>
2009-04-21 16:08:47 +04:00
# include <asm/entry.h>
# include <asm/current.h>
2009-03-27 16:25:37 +03:00
# ifndef __ASSEMBLY__
/* from kernel/cpu/mb.c */
extern const struct seq_operations cpuinfo_op ;
# define cpu_relax() barrier()
2009-04-16 13:05:26 +04:00
# define task_pt_regs(tsk) \
( ( ( struct pt_regs * ) ( THREAD_SIZE + task_stack_page ( tsk ) ) ) - 1 )
2009-04-16 13:30:16 +04:00
/* Do necessary setup to start up a newly executed thread. */
void start_thread ( struct pt_regs * regs , unsigned long pc , unsigned long usp ) ;
2012-04-02 14:55:47 +04:00
extern void ret_from_fork ( void ) ;
2012-10-06 21:52:37 +04:00
extern void ret_from_kernel_thread ( void ) ;
2012-04-02 14:55:47 +04:00
2009-05-26 18:30:18 +04:00
# endif /* __ASSEMBLY__ */
# ifndef CONFIG_MMU
2009-03-27 16:25:37 +03:00
/*
* User space process size : memory size
*
* TASK_SIZE on MMU cpu is usually 1 GB . However , on no - MMU arch , both
* user processes and the kernel is on the same memory region . They
* both share the memory space and that is limited by the amount of
* physical memory . thus , we set TASK_SIZE = = amount of total memory .
*/
# define TASK_SIZE (0x81000000 - 0x80000000)
/*
* This decides where the kernel will search for a free chunk of vm
* space during mmap ' s . We won ' t be using it
*/
# define TASK_UNMAPPED_BASE 0
/* definition in include/linux/sched.h */
struct task_struct ;
/* thread_struct is gone. use thread_info instead. */
struct thread_struct { } ;
# define INIT_THREAD { }
/* Free all resources held by a thread. */
static inline void release_thread ( struct task_struct * dead_task )
{
}
extern unsigned long get_wchan ( struct task_struct * p ) ;
# define KSTK_EIP(tsk) (0)
# define KSTK_ESP(tsk) (0)
2009-05-26 18:30:18 +04:00
# else /* CONFIG_MMU */
/*
* This is used to define STACK_TOP , and with MMU it must be below
* kernel base to select the correct PGD when handling MMU exceptions .
*/
# define TASK_SIZE (CONFIG_KERNEL_START)
/*
* This decides where the kernel will search for a free chunk of vm
* space during mmap ' s .
*/
# define TASK_UNMAPPED_BASE (TASK_SIZE / 8 * 3)
# define THREAD_KSP 0
# ifndef __ASSEMBLY__
/* If you change this, you must change the associated assembly-languages
* constants defined below , THREAD_ * .
*/
struct thread_struct {
/* kernel stack pointer (must be first field in structure) */
unsigned long ksp ;
unsigned long ksp_limit ; /* if ksp <= ksp_limit stack overflow */
void * pgdir ; /* root of page-table tree */
struct pt_regs * regs ; /* Pointer to saved register state */
} ;
# define INIT_THREAD { \
. ksp = sizeof init_stack + ( unsigned long ) init_stack , \
. pgdir = swapper_pg_dir , \
}
/* Free all resources held by a thread. */
microblaze: Fix compilation failure because of release_thread
Warning log:
In file included from arch/microblaze/include/asm/thread_info.h:21:0,
from include/linux/thread_info.h:54,
from include/asm-generic/preempt.h:4,
from arch/microblaze/include/generated/asm/preempt.h:1,
from include/linux/preempt.h:18,
from include/linux/spinlock.h:50,
from include/linux/seqlock.h:35,
from include/linux/time.h:5,
from include/linux/stat.h:18,
from include/linux/sysfs.h:20,
from include/linux/kobject.h:21,
from include/linux/device.h:17,
from include/linux/node.h:17,
from include/linux/cpu.h:16,
from arch/microblaze/kernel/process.c:11:
arch/microblaze/include/asm/processor.h:125:20: warning: no previous prototype
for 'release_thread' [-Wmissing-prototypes]
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
2014-02-28 17:00:11 +04:00
static inline void release_thread ( struct task_struct * dead_task )
2009-05-26 18:30:18 +04:00
{
}
unsigned long get_wchan ( struct task_struct * p ) ;
/* The size allocated for kernel stacks. This _must_ be a power of two! */
# define KERNEL_STACK_SIZE 0x2000
/* Return some info about the user process TASK. */
# define task_tos(task) ((unsigned long)(task) + KERNEL_STACK_SIZE)
# define task_regs(task) ((struct pt_regs *)task_tos(task) - 1)
# define task_pt_regs_plus_args(tsk) \
2011-01-31 17:10:04 +03:00
( ( void * ) task_pt_regs ( tsk ) )
2009-05-26 18:30:18 +04:00
# define task_sp(task) (task_regs(task)->r1)
# define task_pc(task) (task_regs(task)->pc)
/* Grotty old names for some. */
# define KSTK_EIP(task) (task_pc(task))
# define KSTK_ESP(task) (task_sp(task))
/* FIXME */
# define deactivate_mm(tsk, mm) do { } while (0)
# define STACK_TOP TASK_SIZE
# define STACK_TOP_MAX STACK_TOP
2012-03-28 21:30:02 +04:00
# ifdef CONFIG_DEBUG_FS
extern struct dentry * of_debugfs_root ;
# endif
2009-05-26 18:30:18 +04:00
# endif /* __ASSEMBLY__ */
# endif /* CONFIG_MMU */
2009-03-27 16:25:37 +03:00
# endif /* _ASM_MICROBLAZE_PROCESSOR_H */