Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
3cefba2a
Commit
3cefba2a
authored
Oct 03, 2002
by
Martin Schwidefsky
Committed by
Linus Torvalds
Oct 03, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] s390 update (2/27): include.
s390 include file changes for 2.5.39.
parent
8d19f15a
Changes
25
Show whitespace changes
Inline
Side-by-side
Showing
25 changed files
with
537 additions
and
317 deletions
+537
-317
include/asm-s390/hardirq.h
include/asm-s390/hardirq.h
+57
-48
include/asm-s390/irq.h
include/asm-s390/irq.h
+0
-61
include/asm-s390/kmap_types.h
include/asm-s390/kmap_types.h
+21
-0
include/asm-s390/param.h
include/asm-s390/param.h
+6
-4
include/asm-s390/pgalloc.h
include/asm-s390/pgalloc.h
+2
-0
include/asm-s390/pgtable.h
include/asm-s390/pgtable.h
+2
-0
include/asm-s390/rwsem.h
include/asm-s390/rwsem.h
+66
-2
include/asm-s390/smp.h
include/asm-s390/smp.h
+12
-5
include/asm-s390/softirq.h
include/asm-s390/softirq.h
+10
-19
include/asm-s390/spinlock.h
include/asm-s390/spinlock.h
+2
-0
include/asm-s390/system.h
include/asm-s390/system.h
+78
-16
include/asm-s390/tlbflush.h
include/asm-s390/tlbflush.h
+1
-2
include/asm-s390x/bitops.h
include/asm-s390x/bitops.h
+8
-1
include/asm-s390x/hardirq.h
include/asm-s390x/hardirq.h
+56
-46
include/asm-s390x/irq.h
include/asm-s390x/irq.h
+0
-61
include/asm-s390x/kmap_types.h
include/asm-s390x/kmap_types.h
+21
-0
include/asm-s390x/param.h
include/asm-s390x/param.h
+6
-7
include/asm-s390x/pgalloc.h
include/asm-s390x/pgalloc.h
+2
-0
include/asm-s390x/pgtable.h
include/asm-s390x/pgtable.h
+2
-0
include/asm-s390x/rwsem.h
include/asm-s390x/rwsem.h
+66
-2
include/asm-s390x/smp.h
include/asm-s390x/smp.h
+12
-5
include/asm-s390x/softirq.h
include/asm-s390x/softirq.h
+12
-19
include/asm-s390x/spinlock.h
include/asm-s390x/spinlock.h
+9
-0
include/asm-s390x/system.h
include/asm-s390x/system.h
+85
-17
include/asm-s390x/tlbflush.h
include/asm-s390x/tlbflush.h
+1
-2
No files found.
include/asm-s390/hardirq.h
View file @
3cefba2a
...
@@ -14,15 +14,13 @@
...
@@ -14,15 +14,13 @@
#include <linux/config.h>
#include <linux/config.h>
#include <linux/threads.h>
#include <linux/threads.h>
#include <asm/lowcore.h>
#include <linux/sched.h>
#include <linux/sched.h>
#include <linux/cache.h>
#include <linux/cache.h>
#include <asm/lowcore.h>
/* entry.S is sensitive to the offsets of these fields */
/* entry.S is sensitive to the offsets of these fields */
typedef
struct
{
typedef
struct
{
unsigned
int
__softirq_pending
;
unsigned
int
__softirq_pending
;
unsigned
int
__local_irq_count
;
unsigned
int
__local_bh_count
;
unsigned
int
__syscall_count
;
unsigned
int
__syscall_count
;
struct
task_struct
*
__ksoftirqd_task
;
/* waitqueue is too large */
struct
task_struct
*
__ksoftirqd_task
;
/* waitqueue is too large */
}
____cacheline_aligned
irq_cpustat_t
;
}
____cacheline_aligned
irq_cpustat_t
;
...
@@ -30,64 +28,75 @@ typedef struct {
...
@@ -30,64 +28,75 @@ typedef struct {
#include <linux/irq_cpustat.h>
/* Standard mappings for irq_cpustat_t above */
#include <linux/irq_cpustat.h>
/* Standard mappings for irq_cpustat_t above */
/*
/*
* Are we in an interrupt context? Either doing bottom half
* We put the hardirq and softirq counter into the preemption
* or hardware interrupt processing?
* counter. The bitmask has the following meaning:
*
* - bits 0-7 are the preemption count (max preemption depth: 256)
* - bits 8-15 are the softirq count (max # of softirqs: 256)
* - bits 16-23 are the hardirq count (max # of hardirqs: 256)
*
* - ( bit 26 is the PREEMPT_ACTIVE flag. )
*
* PREEMPT_MASK: 0x000000ff
* SOFTIRQ_MASK: 0x0000ff00
* HARDIRQ_MASK: 0x00010000
*/
*/
#define in_interrupt() ({ int __cpu = smp_processor_id(); \
(local_irq_count(__cpu) + local_bh_count(__cpu) != 0); })
#define in_irq() (local_irq_count(smp_processor_id()) != 0)
#define PREEMPT_BITS 8
#define SOFTIRQ_BITS 8
#define HARDIRQ_BITS 1
#ifndef CONFIG_SMP
#define PREEMPT_SHIFT 0
#define SOFTIRQ_SHIFT (PREEMPT_SHIFT + PREEMPT_BITS)
#define HARDIRQ_SHIFT (SOFTIRQ_SHIFT + SOFTIRQ_BITS)
#define hardirq_trylock(cpu) (local_irq_count(cpu) == 0)
#define __MASK(x) ((1UL << (x))-1)
#define hardirq_endlock(cpu) do { } while (0)
#define hardirq_enter(cpu) (local_irq_count(cpu)++)
#define PREEMPT_MASK (__MASK(PREEMPT_BITS) << PREEMPT_SHIFT)
#define hardirq_exit(cpu) (local_irq_count(cpu)--)
#define SOFTIRQ_MASK (__MASK(SOFTIRQ_BITS) << SOFTIRQ_SHIFT)
#define HARDIRQ_MASK (__MASK(HARDIRQ_BITS) << HARDIRQ_SHIFT)
#define synchronize_irq() do { } while (0)
#define hardirq_count() (preempt_count() & HARDIRQ_MASK)
#define softirq_count() (preempt_count() & SOFTIRQ_MASK)
#define irq_count() (preempt_count() & (HARDIRQ_MASK | SOFTIRQ_MASK))
#else
/* CONFIG_SMP */
#define PREEMPT_OFFSET (1UL << PREEMPT_SHIFT)
#define SOFTIRQ_OFFSET (1UL << SOFTIRQ_SHIFT)
#define HARDIRQ_OFFSET (1UL << HARDIRQ_SHIFT)
#include <asm/atomic.h>
/*
#include <asm/smp.h>
* Are we doing bottom half or hardware interrupt processing?
* Are we in a softirq context? Interrupt context?
extern
atomic_t
global_irq_holder
;
*/
extern
atomic_t
global_irq_lock
;
#define in_irq() (hardirq_count())
extern
atomic_t
global_irq_count
;
#define in_softirq() (softirq_count())
#define in_interrupt() (irq_count())
static
inline
void
release_irqlock
(
int
cpu
)
{
/* if we didn't own the irq lock, just ignore.. */
if
(
atomic_read
(
&
global_irq_holder
)
==
cpu
)
{
atomic_set
(
&
global_irq_holder
,
NO_PROC_ID
);
atomic_set
(
&
global_irq_lock
,
0
);
}
}
static
inline
void
hardirq_enter
(
int
cpu
)
#define hardirq_trylock() (!in_interrupt())
{
#define hardirq_endlock() do { } while (0)
++
local_irq_count
(
cpu
);
atomic_inc
(
&
global_irq_count
);
}
static
inline
void
hardirq_exit
(
int
cpu
)
#define irq_enter() (preempt_count() += HARDIRQ_OFFSET)
{
atomic_dec
(
&
global_irq_count
);
--
local_irq_count
(
cpu
);
}
static
inline
int
hardirq_trylock
(
int
cpu
)
extern
void
do_call_softirq
(
void
);
{
return
!
atomic_read
(
&
global_irq_count
)
&&
!
atomic_read
(
&
global_irq_lock
);
}
#define hardirq_endlock(cpu) do { } while (0)
#define in_atomic() (preempt_count() != 0)
#define IRQ_EXIT_OFFSET HARDIRQ_OFFSET
extern
void
synchronize_irq
(
void
);
#define irq_exit() \
do { \
preempt_count() -= HARDIRQ_OFFSET; \
if (!in_interrupt() && softirq_pending(smp_processor_id())) \
/* Use the async. stack for softirq */
\
do_call_softirq(); \
} while (0)
#ifndef CONFIG_SMP
# define synchronize_irq(irq) barrier()
#else
extern
void
synchronize_irq
(
unsigned
int
irq
);
#endif
/* CONFIG_SMP */
#endif
/* CONFIG_SMP */
extern
void
show_stack
(
unsigned
long
*
esp
);
#endif
/* __ASM_HARDIRQ_H */
#endif
/* __ASM_HARDIRQ_H */
include/asm-s390/irq.h
View file @
3cefba2a
...
@@ -897,67 +897,6 @@ extern __inline__ int chsc( chsc_area_t * chsc_area)
...
@@ -897,67 +897,6 @@ extern __inline__ int chsc( chsc_area_t * chsc_area)
return
cc
;
return
cc
;
}
}
/*
* Various low-level irq details needed by irq.c, process.c,
* time.c, io_apic.c and smp.c
*
* Interrupt entry/exit code at both C and assembly level
*/
#ifdef CONFIG_SMP
#include <asm/atomic.h>
static
inline
void
irq_enter
(
int
cpu
,
unsigned
int
irq
)
{
hardirq_enter
(
cpu
);
while
(
atomic_read
(
&
global_irq_lock
)
!=
0
)
{
eieio
();
}
}
static
inline
void
irq_exit
(
int
cpu
,
unsigned
int
irq
)
{
hardirq_exit
(
cpu
);
release_irqlock
(
cpu
);
}
#else
#define irq_enter(cpu, irq) (++local_irq_count(cpu))
#define irq_exit(cpu, irq) (--local_irq_count(cpu))
#endif
#define __STR(x) #x
#define STR(x) __STR(x)
/*
* x86 profiling function, SMP safe. We might want to do this in
* assembly totally?
* is this ever used anyway?
*/
extern
char
_stext
;
static
inline
void
s390_do_profile
(
unsigned
long
addr
)
{
if
(
prof_buffer
&&
current
->
pid
)
{
#ifndef CONFIG_ARCH_S390X
addr
&=
0x7fffffff
;
#endif
addr
-=
(
unsigned
long
)
&
_stext
;
addr
>>=
prof_shift
;
/*
* Don't ignore out-of-bounds EIP values silently,
* put them into the last histogram slot, so if
* present, they will show up as a sharp peak.
*/
if
(
addr
>
prof_len
-
1
)
addr
=
prof_len
-
1
;
atomic_inc
((
atomic_t
*
)
&
prof_buffer
[
addr
]);
}
}
#include <asm/s390io.h>
#include <asm/s390io.h>
#define get_irq_lock(irq) &ioinfo[irq]->irq_lock
#define get_irq_lock(irq) &ioinfo[irq]->irq_lock
...
...
include/asm-s390/kmap_types.h
0 → 100644
View file @
3cefba2a
#ifdef __KERNEL__
#ifndef _ASM_KMAP_TYPES_H
#define _ASM_KMAP_TYPES_H
enum
km_type
{
KM_BOUNCE_READ
,
KM_SKB_SUNRPC_DATA
,
KM_SKB_DATA_SOFTIRQ
,
KM_USER0
,
KM_USER1
,
KM_BIO_SRC_IRQ
,
KM_BIO_DST_IRQ
,
KM_PTE0
,
KM_PTE1
,
KM_IRQ0
,
KM_IRQ1
,
KM_TYPE_NR
};
#endif
#endif
/* __KERNEL__ */
include/asm-s390/param.h
View file @
3cefba2a
...
@@ -9,6 +9,12 @@
...
@@ -9,6 +9,12 @@
#ifndef _ASMS390_PARAM_H
#ifndef _ASMS390_PARAM_H
#define _ASMS390_PARAM_H
#define _ASMS390_PARAM_H
#ifdef __KERNEL__
# define HZ 100
/* Internal kernel timer frequency */
# define USER_HZ 100
/* .. some user interfaces are in "ticks" */
# define CLOCKS_PER_SEC (USER_HZ)
/* like times() */
#endif
#ifndef HZ
#ifndef HZ
#define HZ 100
#define HZ 100
#endif
#endif
...
@@ -25,8 +31,4 @@
...
@@ -25,8 +31,4 @@
#define MAXHOSTNAMELEN 64
/* max length of hostname */
#define MAXHOSTNAMELEN 64
/* max length of hostname */
#ifdef __KERNEL__
# define CLOCKS_PER_SEC HZ
/* frequency at which times() counts */
#endif
#endif
#endif
include/asm-s390/pgalloc.h
View file @
3cefba2a
...
@@ -16,6 +16,8 @@
...
@@ -16,6 +16,8 @@
#include <linux/config.h>
#include <linux/config.h>
#include <asm/processor.h>
#include <asm/processor.h>
#include <linux/threads.h>
#include <linux/threads.h>
#include <linux/gfp.h>
#include <linux/mm.h>
#define check_pgt_cache() do {} while (0)
#define check_pgt_cache() do {} while (0)
...
...
include/asm-s390/pgtable.h
View file @
3cefba2a
...
@@ -176,6 +176,8 @@ extern char empty_zero_page[PAGE_SIZE];
...
@@ -176,6 +176,8 @@ extern char empty_zero_page[PAGE_SIZE];
#define _SEGMENT_TABLE (_USER_SEG_TABLE_LEN|0x80000000|0x100)
#define _SEGMENT_TABLE (_USER_SEG_TABLE_LEN|0x80000000|0x100)
#define _KERNSEG_TABLE (_KERNEL_SEG_TABLE_LEN)
#define _KERNSEG_TABLE (_KERNEL_SEG_TABLE_LEN)
#define USER_STD_MASK 0x00000080UL
/*
/*
* No mapping available
* No mapping available
*/
*/
...
...
include/asm-s390/rwsem.h
View file @
3cefba2a
...
@@ -48,9 +48,11 @@
...
@@ -48,9 +48,11 @@
struct
rwsem_waiter
;
struct
rwsem_waiter
;
extern
struct
rw_semaphore
*
rwsem_down_read_failed
(
struct
rw_semaphore
*
sem
);
extern
struct
rw_semaphore
*
rwsem_down_read_failed
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_down_write_failed
(
struct
rw_semaphore
*
sem
);
extern
struct
rw_semaphore
*
rwsem_down_write_failed
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_downgrade_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_downgrade_write
(
struct
rw_semaphore
*
);
/*
/*
* the semaphore definition
* the semaphore definition
...
@@ -104,6 +106,27 @@ static inline void __down_read(struct rw_semaphore *sem)
...
@@ -104,6 +106,27 @@ static inline void __down_read(struct rw_semaphore *sem)
rwsem_down_read_failed
(
sem
);
rwsem_down_read_failed
(
sem
);
}
}
/*
* trylock for reading -- returns 1 if successful, 0 if contention
*/
static
inline
int
__down_read_trylock
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
,
new
;
__asm__
__volatile__
(
" l %0,0(%2)
\n
"
"0: ltr %1,%0
\n
"
" jm 1f
\n
"
" ahi %1,%3
\n
"
" cs %0,%1,0(%2)
\n
"
" jl 0b
\n
"
"1:"
:
"=&d"
(
old
),
"=&d"
(
new
)
:
"a"
(
&
sem
->
count
),
"i"
(
RWSEM_ACTIVE_READ_BIAS
)
:
"cc"
,
"memory"
);
return
old
>=
0
?
1
:
0
;
}
/*
/*
* lock for writing
* lock for writing
*/
*/
...
@@ -125,6 +148,26 @@ static inline void __down_write(struct rw_semaphore *sem)
...
@@ -125,6 +148,26 @@ static inline void __down_write(struct rw_semaphore *sem)
rwsem_down_write_failed
(
sem
);
rwsem_down_write_failed
(
sem
);
}
}
/*
* trylock for writing -- returns 1 if successful, 0 if contention
*/
static
inline
int
__down_write_trylock
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
;
__asm__
__volatile__
(
" l %0,0(%1)
\n
"
"0: ltr %0,%0
\n
"
" jnz 1f
\n
"
" cs %0,%2,0(%1)
\n
"
" jl 0b
\n
"
"1:"
:
"=&d"
(
old
)
:
"a"
(
&
sem
->
count
),
"d"
(
RWSEM_ACTIVE_WRITE_BIAS
)
:
"cc"
,
"memory"
);
return
(
old
==
RWSEM_UNLOCKED_VALUE
)
?
1
:
0
;
}
/*
/*
* unlock after reading
* unlock after reading
*/
*/
...
@@ -168,6 +211,27 @@ static inline void __up_write(struct rw_semaphore *sem)
...
@@ -168,6 +211,27 @@ static inline void __up_write(struct rw_semaphore *sem)
rwsem_wake
(
sem
);
rwsem_wake
(
sem
);
}
}
/*
* downgrade write lock to read lock
*/
static
inline
void
__downgrade_write
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
,
new
,
tmp
;
tmp
=
-
RWSEM_WAITING_BIAS
;
__asm__
__volatile__
(
" l %0,0(%2)
\n
"
"0: lr %1,%0
\n
"
" a %1,%3
\n
"
" cs %0,%1,0(%2)
\n
"
" jl 0b"
:
"=&d"
(
old
),
"=&d"
(
new
)
:
"a"
(
&
sem
->
count
),
"m"
(
tmp
)
:
"cc"
,
"memory"
);
if
(
new
>
1
)
// FIXME: is this correct ?!?
rwsem_downgrade_wake
(
sem
);
}
/*
/*
* implement atomic add functionality
* implement atomic add functionality
*/
*/
...
...
include/asm-s390/smp.h
View file @
3cefba2a
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
#include <linux/config.h>
#include <linux/config.h>
#include <linux/threads.h>
#include <linux/threads.h>
#include <linux/
ptrace
.h>
#include <linux/
bitops
.h>
#if defined(__KERNEL__) && defined(CONFIG_SMP) && !defined(__ASSEMBLY__)
#if defined(__KERNEL__) && defined(CONFIG_SMP) && !defined(__ASSEMBLY__)
...
@@ -29,6 +29,7 @@ typedef struct
...
@@ -29,6 +29,7 @@ typedef struct
}
sigp_info
;
}
sigp_info
;
extern
volatile
unsigned
long
cpu_online_map
;
extern
volatile
unsigned
long
cpu_online_map
;
extern
unsigned
long
cpu_possible_map
;
#define NO_PROC_ID 0xFF
/* No processor magic marker */
#define NO_PROC_ID 0xFF
/* No processor magic marker */
...
@@ -46,14 +47,20 @@ extern volatile unsigned long cpu_online_map;
...
@@ -46,14 +47,20 @@ extern volatile unsigned long cpu_online_map;
#define smp_processor_id() (current_thread_info()->cpu)
#define smp_processor_id() (current_thread_info()->cpu)
extern
__inline__
int
cpu_logical_map
(
int
cpu
)
#define cpu_online(cpu) (cpu_online_map & (1<<(cpu)))
#define cpu_possible(cpu) (cpu_possible_map & (1<<(cpu)))
extern
inline
unsigned
int
num_online_cpus
(
void
)
{
{
return
cpu
;
return
hweight32
(
cpu_online_map
)
;
}
}
extern
__inline__
int
cpu_number_map
(
int
cpu
)
extern
inline
int
any_online_cpu
(
unsigned
int
mask
)
{
{
return
cpu
;
if
(
mask
&
cpu_online_map
)
return
__ffs
(
mask
&
cpu_online_map
);
return
-
1
;
}
}
extern
__inline__
__u16
hard_smp_processor_id
(
void
)
extern
__inline__
__u16
hard_smp_processor_id
(
void
)
...
...
include/asm-s390/softirq.h
View file @
3cefba2a
...
@@ -9,32 +9,23 @@
...
@@ -9,32 +9,23 @@
#ifndef __ASM_SOFTIRQ_H
#ifndef __ASM_SOFTIRQ_H
#define __ASM_SOFTIRQ_H
#define __ASM_SOFTIRQ_H
#ifndef __LINUX_SMP_H
#include <linux/smp.h>
#include <linux/smp.h>
#endif
#include <asm/atomic.h>
#include <asm/atomic.h>
#include <asm/hardirq.h>
#include <asm/hardirq.h>
#include <asm/lowcore.h>
#include <asm/lowcore.h>
#define __cpu_bh_enable(cpu) \
#define local_bh_disable() \
do { barrier(); local_bh_count(cpu)--; } while (0)
do { preempt_count() += SOFTIRQ_OFFSET; barrier(); } while (0)
#define cpu_bh_disable(cpu) \
#define __local_bh_enable() \
do { local_bh_count(cpu)++; barrier(); } while (0)
do { barrier(); preempt_count() -= SOFTIRQ_OFFSET; } while (0)
#define local_bh_disable() cpu_bh_disable(smp_processor_id())
#define __local_bh_enable() __cpu_bh_enable(smp_processor_id())
#define in_softirq() (local_bh_count(smp_processor_id()) != 0)
extern
void
do_call_softirq
(
void
);
extern
void
do_call_softirq
(
void
);
#define local_bh_enable() \
#define local_bh_enable() \
do { \
do { \
unsigned int *ptr = &local_bh_count(smp_processor_id()); \
__local_bh_enable(); \
barrier(); \
if (!in_interrupt() && softirq_pending(smp_processor_id())) \
if (!--*ptr) \
if (softirq_pending(smp_processor_id())) \
/* Use the async. stack for softirq */
\
/* Use the async. stack for softirq */
\
do_call_softirq(); \
do_call_softirq(); \
} while (0)
} while (0)
...
...
include/asm-s390/spinlock.h
View file @
3cefba2a
...
@@ -76,6 +76,8 @@ typedef struct {
...
@@ -76,6 +76,8 @@ typedef struct {
#define rwlock_init(x) do { *(x) = RW_LOCK_UNLOCKED; } while(0)
#define rwlock_init(x) do { *(x) = RW_LOCK_UNLOCKED; } while(0)
#define rwlock_is_locked(x) ((x)->lock != 0)
#define _raw_read_lock(rw) \
#define _raw_read_lock(rw) \
asm volatile(" l 2,0(%1)\n" \
asm volatile(" l 2,0(%1)\n" \
" j 1f\n" \
" j 1f\n" \
...
...
include/asm-s390/system.h
View file @
3cefba2a
...
@@ -101,6 +101,77 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -101,6 +101,77 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
return
x
;
return
x
;
}
}
/*
* Atomic compare and exchange. Compare OLD with MEM, if identical,
* store NEW in MEM. Return the initial value in MEM. Success is
* indicated by comparing RETURN with OLD.
*/
#define __HAVE_ARCH_CMPXCHG 1
#define cmpxchg(ptr,o,n)\
((__typeof__(*(ptr)))__cmpxchg((ptr),(unsigned long)(o),\
(unsigned long)(n),sizeof(*(ptr))))
static
inline
unsigned
long
__cmpxchg
(
volatile
void
*
ptr
,
unsigned
long
old
,
unsigned
long
new
,
int
size
)
{
unsigned
long
addr
,
prev
,
tmp
;
int
shift
;
switch
(
size
)
{
case
1
:
addr
=
(
unsigned
long
)
ptr
;
shift
=
(
3
^
(
addr
&
3
))
<<
3
;
addr
^=
addr
&
3
;
asm
volatile
(
" l %0,0(%4)
\n
"
"0: nr %0,%5
\n
"
" lr %1,%0
\n
"
" or %0,%2
\n
"
" or %1,%3
\n
"
" cs %0,%1,0(%4)
\n
"
" jnl 1f
\n
"
" xr %1,%0
\n
"
" nr %1,%5
\n
"
" jnz 0b
\n
"
"1:"
:
"=&d"
(
prev
),
"=&d"
(
tmp
)
:
"d"
(
old
<<
shift
),
"d"
(
new
<<
shift
),
"a"
(
ptr
),
"d"
(
~
(
255
<<
shift
))
:
"memory"
,
"cc"
);
return
prev
>>
shift
;
case
2
:
addr
=
(
unsigned
long
)
ptr
;
shift
=
(
2
^
(
addr
&
2
))
<<
3
;
addr
^=
addr
&
2
;
asm
volatile
(
" l %0,0(%4)
\n
"
"0: nr %0,%5
\n
"
" lr %1,%0
\n
"
" or %0,%2
\n
"
" or %1,%3
\n
"
" cs %0,%1,0(%4)
\n
"
" jnl 1f
\n
"
" xr %1,%0
\n
"
" nr %1,%5
\n
"
" jnz 0b
\n
"
"1:"
:
"=&d"
(
prev
),
"=&d"
(
tmp
)
:
"d"
(
old
<<
shift
),
"d"
(
new
<<
shift
),
"a"
(
ptr
),
"d"
(
~
(
65535
<<
shift
))
:
"memory"
,
"cc"
);
return
prev
>>
shift
;
case
4
:
asm
volatile
(
" cs %0,%2,0(%3)
\n
"
:
"=&d"
(
prev
)
:
"0"
(
old
),
"d"
(
new
),
"a"
(
ptr
)
:
"memory"
,
"cc"
);
return
prev
;
}
return
old
;
}
/*
/*
* Force strict CPU ordering.
* Force strict CPU ordering.
* And yes, this is required on UP too when we're talking
* And yes, this is required on UP too when we're talking
...
@@ -146,6 +217,13 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -146,6 +217,13 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
#define local_irq_restore(x) \
#define local_irq_restore(x) \
__asm__ __volatile__("ssm 0(%0)" : : "a" (&x) : "memory")
__asm__ __volatile__("ssm 0(%0)" : : "a" (&x) : "memory")
#define irqs_disabled() \
({ \
unsigned long flags; \
local_save_flags(flags); \
!((flags >> 24) & 3); \
})
#define __load_psw(psw) \
#define __load_psw(psw) \
__asm__ __volatile__("lpsw 0(%0)" : : "a" (&psw) : "cc" );
__asm__ __volatile__("lpsw 0(%0)" : : "a" (&psw) : "cc" );
...
@@ -210,16 +288,6 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -210,16 +288,6 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
#ifdef CONFIG_SMP
#ifdef CONFIG_SMP
extern
void
__global_cli
(
void
);
extern
void
__global_sti
(
void
);
extern
unsigned
long
__global_save_flags
(
void
);
extern
void
__global_restore_flags
(
unsigned
long
);
#define cli() __global_cli()
#define sti() __global_sti()
#define save_flags(x) ((x)=__global_save_flags())
#define restore_flags(x) __global_restore_flags(x)
extern
void
smp_ctl_set_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_set_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_clear_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_clear_bit
(
int
cr
,
int
bit
);
#define ctl_set_bit(cr, bit) smp_ctl_set_bit(cr, bit)
#define ctl_set_bit(cr, bit) smp_ctl_set_bit(cr, bit)
...
@@ -227,15 +295,9 @@ extern void smp_ctl_clear_bit(int cr, int bit);
...
@@ -227,15 +295,9 @@ extern void smp_ctl_clear_bit(int cr, int bit);
#else
#else
#define cli() local_irq_disable()
#define sti() local_irq_enable()
#define save_flags(x) local_save_flags(x)
#define restore_flags(x) local_irq_restore(x)
#define ctl_set_bit(cr, bit) __ctl_set_bit(cr, bit)
#define ctl_set_bit(cr, bit) __ctl_set_bit(cr, bit)
#define ctl_clear_bit(cr, bit) __ctl_clear_bit(cr, bit)
#define ctl_clear_bit(cr, bit) __ctl_clear_bit(cr, bit)
#endif
#endif
#ifdef __KERNEL__
#ifdef __KERNEL__
...
...
include/asm-s390/tlbflush.h
View file @
3cefba2a
...
@@ -91,8 +91,7 @@ static inline void global_flush_tlb(void)
...
@@ -91,8 +91,7 @@ static inline void global_flush_tlb(void)
static
inline
void
__flush_tlb_mm
(
struct
mm_struct
*
mm
)
static
inline
void
__flush_tlb_mm
(
struct
mm_struct
*
mm
)
{
{
if
((
smp_num_cpus
>
1
)
&&
if
(((
atomic_read
(
&
mm
->
mm_count
)
!=
1
)
||
((
atomic_read
(
&
mm
->
mm_count
)
!=
1
)
||
(
mm
->
cpu_vm_mask
!=
(
1UL
<<
smp_processor_id
()))))
{
(
mm
->
cpu_vm_mask
!=
(
1UL
<<
smp_processor_id
()))))
{
mm
->
cpu_vm_mask
=
(
1UL
<<
smp_processor_id
());
mm
->
cpu_vm_mask
=
(
1UL
<<
smp_processor_id
());
global_flush_tlb
();
global_flush_tlb
();
...
...
include/asm-s390x/bitops.h
View file @
3cefba2a
...
@@ -811,7 +811,14 @@ extern __inline__ int fls(int x)
...
@@ -811,7 +811,14 @@ extern __inline__ int fls(int x)
* hweightN: returns the hamming weight (i.e. the number
* hweightN: returns the hamming weight (i.e. the number
* of bits set) of a N-bit word
* of bits set) of a N-bit word
*/
*/
#define hweight64(x) \
({ \
unsigned long __x = (x); \
unsigned int __w; \
__w = generic_hweight32((unsigned int) __x); \
__w += generic_hweight32((unsigned int) (__x>>32)); \
__w; \
})
#define hweight32(x) generic_hweight32(x)
#define hweight32(x) generic_hweight32(x)
#define hweight16(x) generic_hweight16(x)
#define hweight16(x) generic_hweight16(x)
#define hweight8(x) generic_hweight8(x)
#define hweight8(x) generic_hweight8(x)
...
...
include/asm-s390x/hardirq.h
View file @
3cefba2a
...
@@ -21,8 +21,6 @@
...
@@ -21,8 +21,6 @@
/* entry.S is sensitive to the offsets of these fields */
/* entry.S is sensitive to the offsets of these fields */
typedef
struct
{
typedef
struct
{
unsigned
int
__softirq_pending
;
unsigned
int
__softirq_pending
;
unsigned
int
__local_irq_count
;
unsigned
int
__local_bh_count
;
unsigned
int
__syscall_count
;
unsigned
int
__syscall_count
;
struct
task_struct
*
__ksoftirqd_task
;
/* waitqueue is too large */
struct
task_struct
*
__ksoftirqd_task
;
/* waitqueue is too large */
}
____cacheline_aligned
irq_cpustat_t
;
}
____cacheline_aligned
irq_cpustat_t
;
...
@@ -30,64 +28,76 @@ typedef struct {
...
@@ -30,64 +28,76 @@ typedef struct {
#include <linux/irq_cpustat.h>
/* Standard mappings for irq_cpustat_t above */
#include <linux/irq_cpustat.h>
/* Standard mappings for irq_cpustat_t above */
/*
/*
* Are we in an interrupt context? Either doing bottom half
* We put the hardirq and softirq counter into the preemption
* or hardware interrupt processing?
* counter. The bitmask has the following meaning:
*
* - bits 0-7 are the preemption count (max preemption depth: 256)
* - bits 8-15 are the softirq count (max # of softirqs: 256)
* - bits 16-23 are the hardirq count (max # of hardirqs: 256)
*
* - ( bit 26 is the PREEMPT_ACTIVE flag. )
*
* PREEMPT_MASK: 0x000000ff
* SOFTIRQ_MASK: 0x0000ff00
* HARDIRQ_MASK: 0x00010000
*/
*/
#define in_interrupt() ({ int __cpu = smp_processor_id(); \
(local_irq_count(__cpu) + local_bh_count(__cpu) != 0); })
#define in_irq() (local_irq_count(smp_processor_id()) != 0)
#define PREEMPT_BITS 8
#define SOFTIRQ_BITS 8
// FIXME: we have 2^16 i/o and 2^16 external interrupts...
#define HARDIRQ_BITS 1
#ifndef CONFIG_SMP
#define PREEMPT_SHIFT 0
#define SOFTIRQ_SHIFT (PREEMPT_SHIFT + PREEMPT_BITS)
#define hardirq_trylock(cpu) (local_irq_count(cpu) == 0)
#define HARDIRQ_SHIFT (SOFTIRQ_SHIFT + SOFTIRQ_BITS)
#define hardirq_endlock(cpu) do { } while (0)
#define hardirq_enter(cpu) (local_irq_count(cpu)++)
#define __MASK(x) ((1UL << (x))-1)
#define hardirq_exit(cpu) (local_irq_count(cpu)--)
#define synchronize_irq() do { } while (0)
#define PREEMPT_MASK (__MASK(PREEMPT_BITS) << PREEMPT_SHIFT)
#define SOFTIRQ_MASK (__MASK(SOFTIRQ_BITS) << SOFTIRQ_SHIFT)
#define HARDIRQ_MASK (__MASK(HARDIRQ_BITS) << HARDIRQ_SHIFT)
#else
#define hardirq_count() (preempt_count() & HARDIRQ_MASK)
#define softirq_count() (preempt_count() & SOFTIRQ_MASK)
#define irq_count() (preempt_count() & (HARDIRQ_MASK | SOFTIRQ_MASK))
#include <asm/atomic.h>
#define PREEMPT_OFFSET (1UL << PREEMPT_SHIFT)
#include <asm/smp.h>
#define SOFTIRQ_OFFSET (1UL << SOFTIRQ_SHIFT)
#define HARDIRQ_OFFSET (1UL << HARDIRQ_SHIFT)
extern
atomic_t
global_irq_holder
;
/*
extern
atomic_t
global_irq_lock
;
* Are we doing bottom half or hardware interrupt processing?
extern
atomic_t
global_irq_count
;
* Are we in a softirq context? Interrupt context?
*/
#define in_irq() (hardirq_count())
#define in_softirq() (softirq_count())
#define in_interrupt() (irq_count())
static
inline
void
release_irqlock
(
int
cpu
)
{
/* if we didn't own the irq lock, just ignore.. */
if
(
atomic_read
(
&
global_irq_holder
)
==
cpu
)
{
atomic_set
(
&
global_irq_holder
,
NO_PROC_ID
);
atomic_set
(
&
global_irq_lock
,
0
);
}
}
static
inline
void
hardirq_enter
(
int
cpu
)
#define hardirq_trylock() (!in_interrupt())
{
#define hardirq_endlock() do { } while (0)
++
local_irq_count
(
cpu
);
atomic_inc
(
&
global_irq_count
);
}
static
inline
void
hardirq_exit
(
int
cpu
)
#define irq_enter() (preempt_count() += HARDIRQ_OFFSET)
{
atomic_dec
(
&
global_irq_count
);
--
local_irq_count
(
cpu
);
}
static
inline
int
hardirq_trylock
(
int
cpu
)
extern
void
do_call_softirq
(
void
);
{
return
!
atomic_read
(
&
global_irq_count
)
&&
!
atomic_read
(
&
global_irq_lock
);
}
#define hardirq_endlock(cpu) do { } while (0)
#define in_atomic() (preempt_count() != 0)
#define IRQ_EXIT_OFFSET HARDIRQ_OFFSET
extern
void
synchronize_irq
(
void
);
#define irq_exit() \
do { \
preempt_count() -= HARDIRQ_OFFSET; \
if (!in_interrupt() && softirq_pending(smp_processor_id())) \
/* Use the async. stack for softirq */
\
do_call_softirq(); \
} while (0)
#ifndef CONFIG_SMP
# define synchronize_irq(irq) barrier()
#else
extern
void
synchronize_irq
(
unsigned
int
irq
);
#endif
/* CONFIG_SMP */
#endif
/* CONFIG_SMP */
extern
void
show_stack
(
unsigned
long
*
esp
);
#endif
/* __ASM_HARDIRQ_H */
#endif
/* __ASM_HARDIRQ_H */
include/asm-s390x/irq.h
View file @
3cefba2a
...
@@ -897,67 +897,6 @@ extern __inline__ int chsc( chsc_area_t * chsc_area)
...
@@ -897,67 +897,6 @@ extern __inline__ int chsc( chsc_area_t * chsc_area)
return
cc
;
return
cc
;
}
}
/*
* Various low-level irq details needed by irq.c, process.c,
* time.c, io_apic.c and smp.c
*
* Interrupt entry/exit code at both C and assembly level
*/
#ifdef CONFIG_SMP
#include <asm/atomic.h>
static
inline
void
irq_enter
(
int
cpu
,
unsigned
int
irq
)
{
hardirq_enter
(
cpu
);
while
(
atomic_read
(
&
global_irq_lock
)
!=
0
)
{
eieio
();
}
}
static
inline
void
irq_exit
(
int
cpu
,
unsigned
int
irq
)
{
hardirq_exit
(
cpu
);
release_irqlock
(
cpu
);
}
#else
#define irq_enter(cpu, irq) (++local_irq_count(cpu))
#define irq_exit(cpu, irq) (--local_irq_count(cpu))
#endif
#define __STR(x) #x
#define STR(x) __STR(x)
/*
* x86 profiling function, SMP safe. We might want to do this in
* assembly totally?
* is this ever used anyway?
*/
extern
char
_stext
;
static
inline
void
s390_do_profile
(
unsigned
long
addr
)
{
if
(
prof_buffer
&&
current
->
pid
)
{
#ifndef CONFIG_ARCH_S390X
addr
&=
0x7fffffff
;
#endif
addr
-=
(
unsigned
long
)
&
_stext
;
addr
>>=
prof_shift
;
/*
* Don't ignore out-of-bounds EIP values silently,
* put them into the last histogram slot, so if
* present, they will show up as a sharp peak.
*/
if
(
addr
>
prof_len
-
1
)
addr
=
prof_len
-
1
;
atomic_inc
((
atomic_t
*
)
&
prof_buffer
[
addr
]);
}
}
#include <asm/s390io.h>
#include <asm/s390io.h>
#define get_irq_lock(irq) &ioinfo[irq]->irq_lock
#define get_irq_lock(irq) &ioinfo[irq]->irq_lock
...
...
include/asm-s390x/kmap_types.h
0 → 100644
View file @
3cefba2a
#ifdef __KERNEL__
#ifndef _ASM_KMAP_TYPES_H
#define _ASM_KMAP_TYPES_H
enum
km_type
{
KM_BOUNCE_READ
,
KM_SKB_SUNRPC_DATA
,
KM_SKB_DATA_SOFTIRQ
,
KM_USER0
,
KM_USER1
,
KM_BIO_SRC_IRQ
,
KM_BIO_DST_IRQ
,
KM_PTE0
,
KM_PTE1
,
KM_IRQ0
,
KM_IRQ1
,
KM_TYPE_NR
};
#endif
#endif
/* __KERNEL__ */
include/asm-s390x/param.h
View file @
3cefba2a
...
@@ -9,11 +9,14 @@
...
@@ -9,11 +9,14 @@
#ifndef _ASMS390_PARAM_H
#ifndef _ASMS390_PARAM_H
#define _ASMS390_PARAM_H
#define _ASMS390_PARAM_H
#ifndef HZ
#define HZ 100
#ifdef __KERNEL__
#ifdef __KERNEL__
#define hz_to_std(a) (a)
# define HZ 100
/* Internal kernel timer frequency */
# define USER_HZ 100
/* .. some user interfaces are in "ticks" */
# define CLOCKS_PER_SEC (USER_HZ)
/* like times() */
#endif
#endif
#ifndef HZ
#define HZ 100
#endif
#endif
#define EXEC_PAGESIZE 4096
#define EXEC_PAGESIZE 4096
...
@@ -28,8 +31,4 @@
...
@@ -28,8 +31,4 @@
#define MAXHOSTNAMELEN 64
/* max length of hostname */
#define MAXHOSTNAMELEN 64
/* max length of hostname */
#ifdef __KERNEL__
# define CLOCKS_PER_SEC HZ
/* frequency at which times() counts */
#endif
#endif
#endif
include/asm-s390x/pgalloc.h
View file @
3cefba2a
...
@@ -16,6 +16,8 @@
...
@@ -16,6 +16,8 @@
#include <linux/config.h>
#include <linux/config.h>
#include <asm/processor.h>
#include <asm/processor.h>
#include <linux/threads.h>
#include <linux/threads.h>
#include <linux/gfp.h>
#include <linux/mm.h>
#define check_pgt_cache() do { } while (0)
#define check_pgt_cache() do { } while (0)
...
...
include/asm-s390x/pgtable.h
View file @
3cefba2a
...
@@ -168,6 +168,8 @@ extern char empty_zero_page[PAGE_SIZE];
...
@@ -168,6 +168,8 @@ extern char empty_zero_page[PAGE_SIZE];
#define _REGION_TABLE (_REGION_THIRD|_REGION_THIRD_LEN|0x40|0x100)
#define _REGION_TABLE (_REGION_THIRD|_REGION_THIRD_LEN|0x40|0x100)
#define _KERN_REGION_TABLE (_REGION_THIRD|_REGION_THIRD_LEN)
#define _KERN_REGION_TABLE (_REGION_THIRD|_REGION_THIRD_LEN)
#define USER_STD_MASK 0x0000000000000080UL
/* Bits in the storage key */
/* Bits in the storage key */
#define _PAGE_CHANGED 0x02
/* HW changed bit */
#define _PAGE_CHANGED 0x02
/* HW changed bit */
#define _PAGE_REFERENCED 0x04
/* HW referenced bit */
#define _PAGE_REFERENCED 0x04
/* HW referenced bit */
...
...
include/asm-s390x/rwsem.h
View file @
3cefba2a
...
@@ -48,9 +48,11 @@
...
@@ -48,9 +48,11 @@
struct
rwsem_waiter
;
struct
rwsem_waiter
;
extern
struct
rw_semaphore
*
rwsem_down_read_failed
(
struct
rw_semaphore
*
sem
);
extern
struct
rw_semaphore
*
rwsem_down_read_failed
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_down_write_failed
(
struct
rw_semaphore
*
sem
);
extern
struct
rw_semaphore
*
rwsem_down_write_failed
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_downgrade_wake
(
struct
rw_semaphore
*
);
extern
struct
rw_semaphore
*
rwsem_downgrade_write
(
struct
rw_semaphore
*
);
/*
/*
* the semaphore definition
* the semaphore definition
...
@@ -104,6 +106,27 @@ static inline void __down_read(struct rw_semaphore *sem)
...
@@ -104,6 +106,27 @@ static inline void __down_read(struct rw_semaphore *sem)
rwsem_down_read_failed
(
sem
);
rwsem_down_read_failed
(
sem
);
}
}
/*
* trylock for reading -- returns 1 if successful, 0 if contention
*/
static
inline
int
__down_read_trylock
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
,
new
;
__asm__
__volatile__
(
" lg %0,0(%2)
\n
"
"0: ltgr %1,%0
\n
"
" jm 1f
\n
"
" aghi %1,%3
\n
"
" csg %0,%1,0(%2)
\n
"
" jl 0b
\n
"
"1:"
:
"=&d"
(
old
),
"=&d"
(
new
)
:
"a"
(
&
sem
->
count
),
"i"
(
RWSEM_ACTIVE_READ_BIAS
)
:
"cc"
,
"memory"
);
return
old
>=
0
?
1
:
0
;
}
/*
/*
* lock for writing
* lock for writing
*/
*/
...
@@ -125,6 +148,26 @@ static inline void __down_write(struct rw_semaphore *sem)
...
@@ -125,6 +148,26 @@ static inline void __down_write(struct rw_semaphore *sem)
rwsem_down_write_failed
(
sem
);
rwsem_down_write_failed
(
sem
);
}
}
/*
* trylock for writing -- returns 1 if successful, 0 if contention
*/
static
inline
int
__down_write_trylock
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
;
__asm__
__volatile__
(
" lg %0,0(%1)
\n
"
"0: ltgr %0,%0
\n
"
" jnz 1f
\n
"
" csg %0,%2,0(%1)
\n
"
" jl 0b
\n
"
"1:"
:
"=&d"
(
old
)
:
"a"
(
&
sem
->
count
),
"d"
(
RWSEM_ACTIVE_WRITE_BIAS
)
:
"cc"
,
"memory"
);
return
(
old
==
RWSEM_UNLOCKED_VALUE
)
?
1
:
0
;
}
/*
/*
* unlock after reading
* unlock after reading
*/
*/
...
@@ -168,6 +211,27 @@ static inline void __up_write(struct rw_semaphore *sem)
...
@@ -168,6 +211,27 @@ static inline void __up_write(struct rw_semaphore *sem)
rwsem_wake
(
sem
);
rwsem_wake
(
sem
);
}
}
/*
* downgrade write lock to read lock
*/
static
inline
void
__downgrade_write
(
struct
rw_semaphore
*
sem
)
{
signed
long
old
,
new
,
tmp
;
tmp
=
-
RWSEM_WAITING_BIAS
;
__asm__
__volatile__
(
" lg %0,0(%2)
\n
"
"0: lgr %1,%0
\n
"
" ag %1,%3
\n
"
" csg %0,%1,0(%2)
\n
"
" jl 0b"
:
"=&d"
(
old
),
"=&d"
(
new
)
:
"a"
(
&
sem
->
count
),
"m"
(
tmp
)
:
"cc"
,
"memory"
);
if
(
new
>
1
)
// FIXME: is this correct ?!?
rwsem_downgrade_wake
(
sem
);
}
/*
/*
* implement atomic add functionality
* implement atomic add functionality
*/
*/
...
...
include/asm-s390x/smp.h
View file @
3cefba2a
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
#include <linux/config.h>
#include <linux/config.h>
#include <linux/threads.h>
#include <linux/threads.h>
#include <linux/
ptrace
.h>
#include <linux/
bitops
.h>
#if defined(__KERNEL__) && defined(CONFIG_SMP) && !defined(__ASSEMBLY__)
#if defined(__KERNEL__) && defined(CONFIG_SMP) && !defined(__ASSEMBLY__)
...
@@ -29,6 +29,7 @@ typedef struct
...
@@ -29,6 +29,7 @@ typedef struct
}
sigp_info
;
}
sigp_info
;
extern
volatile
unsigned
long
cpu_online_map
;
extern
volatile
unsigned
long
cpu_online_map
;
extern
volatile
unsigned
long
cpu_possible_map
;
#define NO_PROC_ID 0xFF
/* No processor magic marker */
#define NO_PROC_ID 0xFF
/* No processor magic marker */
...
@@ -46,14 +47,20 @@ extern volatile unsigned long cpu_online_map;
...
@@ -46,14 +47,20 @@ extern volatile unsigned long cpu_online_map;
#define smp_processor_id() (current_thread_info()->cpu)
#define smp_processor_id() (current_thread_info()->cpu)
extern
__inline__
int
cpu_logical_map
(
int
cpu
)
#define cpu_online(cpu) (cpu_online_map & (1<<(cpu)))
#define cpu_possible(cpu) (cpu_possible_map & (1<<(cpu)))
extern
inline
unsigned
int
num_online_cpus
(
void
)
{
{
return
cpu
;
return
hweight64
(
cpu_online_map
)
;
}
}
extern
__inline__
int
cpu_number_map
(
int
cpu
)
extern
inline
int
any_online_cpu
(
unsigned
int
mask
)
{
{
return
cpu
;
if
(
mask
&
cpu_online_map
)
return
__ffs
(
mask
&
cpu_online_map
);
return
-
1
;
}
}
extern
__inline__
__u16
hard_smp_processor_id
(
void
)
extern
__inline__
__u16
hard_smp_processor_id
(
void
)
...
...
include/asm-s390x/softirq.h
View file @
3cefba2a
...
@@ -9,34 +9,27 @@
...
@@ -9,34 +9,27 @@
#ifndef __ASM_SOFTIRQ_H
#ifndef __ASM_SOFTIRQ_H
#define __ASM_SOFTIRQ_H
#define __ASM_SOFTIRQ_H
#ifndef __LINUX_SMP_H
#include <linux/smp.h>
#include <linux/smp.h>
#
endif
#
include <linux/preempt.h>
#include <asm/atomic.h>
#include <asm/atomic.h>
#include <asm/hardirq.h>
#include <asm/hardirq.h>
#include <asm/lowcore.h>
#include <asm/lowcore.h>
#define __cpu_bh_enable(cpu) \
#define local_bh_disable() \
do { barrier(); local_bh_count(cpu)--; } while (0)
do { preempt_count() += SOFTIRQ_OFFSET; barrier(); } while (0)
#define cpu_bh_disable(cpu) \
#define __local_bh_enable() \
do { local_bh_count(cpu)++; barrier(); } while (0)
do { barrier(); preempt_count() -= SOFTIRQ_OFFSET; } while (0)
#define local_bh_disable() cpu_bh_disable(smp_processor_id())
#define __local_bh_enable() __cpu_bh_enable(smp_processor_id())
#define in_softirq() (local_bh_count(smp_processor_id()) != 0)
extern
void
do_call_softirq
(
void
);
extern
void
do_call_softirq
(
void
);
#define local_bh_enable() \
#define local_bh_enable() \
do { \
do { \
unsigned int *ptr = &local_bh_count(smp_processor_id()); \
__local_bh_enable(); \
barrier(); \
if (!in_interrupt() && softirq_pending(smp_processor_id())) \
if (!--*ptr) \
if (softirq_pending(smp_processor_id())) \
/* Use the async. stack for softirq */
\
/* Use the async. stack for softirq */
\
do_call_softirq(); \
do_call_softirq(); \
preempt_check_resched(); \
} while (0)
} while (0)
#endif
/* __ASM_SOFTIRQ_H */
#endif
/* __ASM_SOFTIRQ_H */
...
...
include/asm-s390x/spinlock.h
View file @
3cefba2a
...
@@ -11,6 +11,13 @@
...
@@ -11,6 +11,13 @@
#ifndef __ASM_SPINLOCK_H
#ifndef __ASM_SPINLOCK_H
#define __ASM_SPINLOCK_H
#define __ASM_SPINLOCK_H
/*
* Grmph, take care of %&#! user space programs that include
* asm/spinlock.h. The diagnose is only available in kernel
* context.
*/
#include <asm/lowcore.h>
/*
/*
* Simple spin lock operations. There are two variants, one clears IRQ's
* Simple spin lock operations. There are two variants, one clears IRQ's
* on the local processor, one does not.
* on the local processor, one does not.
...
@@ -76,6 +83,8 @@ typedef struct {
...
@@ -76,6 +83,8 @@ typedef struct {
#define rwlock_init(x) do { *(x) = RW_LOCK_UNLOCKED; } while(0)
#define rwlock_init(x) do { *(x) = RW_LOCK_UNLOCKED; } while(0)
#define rwlock_is_locked(x) ((x)->lock != 0)
#define _raw_read_lock(rw) \
#define _raw_read_lock(rw) \
asm volatile(" lg 2,0(%1)\n" \
asm volatile(" lg 2,0(%1)\n" \
" j 1f\n" \
" j 1f\n" \
...
...
include/asm-s390x/system.h
View file @
3cefba2a
...
@@ -18,7 +18,7 @@
...
@@ -18,7 +18,7 @@
#endif
#endif
#include <linux/kernel.h>
#include <linux/kernel.h>
#define switch_to(prev,next
),last
do { \
#define switch_to(prev,next
,last)
do { \
if (prev == next) \
if (prev == next) \
break; \
break; \
save_fp_regs(&prev->thread.fp_regs); \
save_fp_regs(&prev->thread.fp_regs); \
...
@@ -114,6 +114,83 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -114,6 +114,83 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
return
x
;
return
x
;
}
}
/*
* Atomic compare and exchange. Compare OLD with MEM, if identical,
* store NEW in MEM. Return the initial value in MEM. Success is
* indicated by comparing RETURN with OLD.
*/
#define __HAVE_ARCH_CMPXCHG 1
#define cmpxchg(ptr,o,n)\
((__typeof__(*(ptr)))__cmpxchg((ptr),(unsigned long)(o),\
(unsigned long)(n),sizeof(*(ptr))))
static
inline
unsigned
long
__cmpxchg
(
volatile
void
*
ptr
,
unsigned
long
old
,
unsigned
long
new
,
int
size
)
{
unsigned
long
addr
,
prev
,
tmp
;
int
shift
;
switch
(
size
)
{
case
1
:
addr
=
(
unsigned
long
)
ptr
;
shift
=
(
3
^
(
addr
&
3
))
<<
3
;
addr
^=
addr
&
3
;
asm
volatile
(
" l %0,0(%4)
\n
"
"0: nr %0,%5
\n
"
" lr %1,%0
\n
"
" or %0,%2
\n
"
" or %1,%3
\n
"
" cs %0,%1,0(%4)
\n
"
" jnl 1f
\n
"
" xr %1,%0
\n
"
" nr %1,%5
\n
"
" jnz 0b
\n
"
"1:"
:
"=&d"
(
prev
),
"=&d"
(
tmp
)
:
"d"
(
old
<<
shift
),
"d"
(
new
<<
shift
),
"a"
(
ptr
),
"d"
(
~
(
255
<<
shift
))
:
"memory"
,
"cc"
);
return
prev
>>
shift
;
case
2
:
addr
=
(
unsigned
long
)
ptr
;
shift
=
(
2
^
(
addr
&
2
))
<<
3
;
addr
^=
addr
&
2
;
asm
volatile
(
" l %0,0(%4)
\n
"
"0: nr %0,%5
\n
"
" lr %1,%0
\n
"
" or %0,%2
\n
"
" or %1,%3
\n
"
" cs %0,%1,0(%4)
\n
"
" jnl 1f
\n
"
" xr %1,%0
\n
"
" nr %1,%5
\n
"
" jnz 0b
\n
"
"1:"
:
"=&d"
(
prev
),
"=&d"
(
tmp
)
:
"d"
(
old
<<
shift
),
"d"
(
new
<<
shift
),
"a"
(
ptr
),
"d"
(
~
(
65535
<<
shift
))
:
"memory"
,
"cc"
);
return
prev
>>
shift
;
case
4
:
asm
volatile
(
" cs %0,%2,0(%3)
\n
"
:
"=&d"
(
prev
)
:
"0"
(
old
),
"d"
(
new
),
"a"
(
ptr
)
:
"memory"
,
"cc"
);
return
prev
;
case
8
:
asm
volatile
(
" csg %0,%2,0(%3)
\n
"
:
"=&d"
(
prev
)
:
"0"
(
old
),
"d"
(
new
),
"a"
(
ptr
)
:
"memory"
,
"cc"
);
return
prev
;
}
return
old
;
}
/*
/*
* Force strict CPU ordering.
* Force strict CPU ordering.
* And yes, this is required on UP too when we're talking
* And yes, this is required on UP too when we're talking
...
@@ -158,6 +235,13 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -158,6 +235,13 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
#define local_irq_restore(x) \
#define local_irq_restore(x) \
__asm__ __volatile__("ssm 0(%0)" : : "a" (&x) : "memory")
__asm__ __volatile__("ssm 0(%0)" : : "a" (&x) : "memory")
#define irqs_disabled() \
({ \
unsigned long flags; \
local_save_flags(flags); \
!((flags >> 56) & 3); \
})
#define __load_psw(psw) \
#define __load_psw(psw) \
__asm__ __volatile__("lpswe 0(%0)" : : "a" (&psw) : "cc" );
__asm__ __volatile__("lpswe 0(%0)" : : "a" (&psw) : "cc" );
...
@@ -220,16 +304,6 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
...
@@ -220,16 +304,6 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
#ifdef CONFIG_SMP
#ifdef CONFIG_SMP
extern
void
__global_cli
(
void
);
extern
void
__global_sti
(
void
);
extern
unsigned
long
__global_save_flags
(
void
);
extern
void
__global_restore_flags
(
unsigned
long
);
#define cli() __global_cli()
#define sti() __global_sti()
#define save_flags(x) ((x)=__global_save_flags())
#define restore_flags(x) __global_restore_flags(x)
extern
void
smp_ctl_set_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_set_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_clear_bit
(
int
cr
,
int
bit
);
extern
void
smp_ctl_clear_bit
(
int
cr
,
int
bit
);
#define ctl_set_bit(cr, bit) smp_ctl_set_bit(cr, bit)
#define ctl_set_bit(cr, bit) smp_ctl_set_bit(cr, bit)
...
@@ -237,15 +311,9 @@ extern void smp_ctl_clear_bit(int cr, int bit);
...
@@ -237,15 +311,9 @@ extern void smp_ctl_clear_bit(int cr, int bit);
#else
#else
#define cli() local_irq_disable()
#define sti() local_irq_enable()
#define save_flags(x) local_save_flags(x)
#define restore_flags(x) local_irq_restore(x)
#define ctl_set_bit(cr, bit) __ctl_set_bit(cr, bit)
#define ctl_set_bit(cr, bit) __ctl_set_bit(cr, bit)
#define ctl_clear_bit(cr, bit) __ctl_clear_bit(cr, bit)
#define ctl_clear_bit(cr, bit) __ctl_clear_bit(cr, bit)
#endif
#endif
#ifdef __KERNEL__
#ifdef __KERNEL__
...
...
include/asm-s390x/tlbflush.h
View file @
3cefba2a
...
@@ -88,8 +88,7 @@ static inline void global_flush_tlb(void)
...
@@ -88,8 +88,7 @@ static inline void global_flush_tlb(void)
static
inline
void
__flush_tlb_mm
(
struct
mm_struct
*
mm
)
static
inline
void
__flush_tlb_mm
(
struct
mm_struct
*
mm
)
{
{
if
((
smp_num_cpus
>
1
)
&&
if
(((
atomic_read
(
&
mm
->
mm_count
)
!=
1
)
||
((
atomic_read
(
&
mm
->
mm_count
)
!=
1
)
||
(
mm
->
cpu_vm_mask
!=
(
1UL
<<
smp_processor_id
()))))
{
(
mm
->
cpu_vm_mask
!=
(
1UL
<<
smp_processor_id
()))))
{
mm
->
cpu_vm_mask
=
(
1UL
<<
smp_processor_id
());
mm
->
cpu_vm_mask
=
(
1UL
<<
smp_processor_id
());
global_flush_tlb
();
global_flush_tlb
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment