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
b4874a3d
Commit
b4874a3d
authored
Oct 06, 2012
by
Russell King
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'fixes' into for-linus
parents
ceaa1a13
8ef102c6
Changes
42
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
42 changed files
with
508 additions
and
292 deletions
+508
-292
Makefile
Makefile
+1
-1
arch/arm/include/asm/syscall.h
arch/arm/include/asm/syscall.h
+1
-0
arch/um/include/asm/processor-generic.h
arch/um/include/asm/processor-generic.h
+0
-9
arch/um/include/shared/common-offsets.h
arch/um/include/shared/common-offsets.h
+0
-10
arch/um/include/shared/user.h
arch/um/include/shared/user.h
+11
-0
arch/um/kernel/exec.c
arch/um/kernel/exec.c
+6
-19
arch/um/kernel/process.c
arch/um/kernel/process.c
+4
-4
arch/um/kernel/signal.c
arch/um/kernel/signal.c
+5
-1
arch/um/kernel/syscall.c
arch/um/kernel/syscall.c
+12
-12
arch/um/scripts/Makefile.rules
arch/um/scripts/Makefile.rules
+1
-1
arch/x86/um/Kconfig
arch/x86/um/Kconfig
+1
-0
arch/x86/um/shared/sysdep/kernel-offsets.h
arch/x86/um/shared/sysdep/kernel-offsets.h
+0
-3
arch/x86/um/shared/sysdep/syscalls.h
arch/x86/um/shared/sysdep/syscalls.h
+2
-0
arch/x86/um/signal.c
arch/x86/um/signal.c
+0
-6
arch/x86/um/sys_call_table_32.c
arch/x86/um/sys_call_table_32.c
+1
-1
arch/x86/um/syscalls_32.c
arch/x86/um/syscalls_32.c
+7
-20
arch/x86/um/syscalls_64.c
arch/x86/um/syscalls_64.c
+3
-20
drivers/block/nvme.c
drivers/block/nvme.c
+103
-50
drivers/iommu/amd_iommu.c
drivers/iommu/amd_iommu.c
+4
-2
drivers/md/dm-mpath.c
drivers/md/dm-mpath.c
+7
-4
drivers/md/dm-table.c
drivers/md/dm-table.c
+57
-4
drivers/md/dm-thin.c
drivers/md/dm-thin.c
+88
-47
drivers/md/dm-verity.c
drivers/md/dm-verity.c
+4
-4
drivers/md/dm.c
drivers/md/dm.c
+52
-19
drivers/md/dm.h
drivers/md/dm.h
+1
-0
drivers/mtd/mtdchar.c
drivers/mtd/mtdchar.c
+42
-6
drivers/net/ethernet/broadcom/bnx2.c
drivers/net/ethernet/broadcom/bnx2.c
+1
-1
drivers/net/ethernet/octeon/octeon_mgmt.c
drivers/net/ethernet/octeon/octeon_mgmt.c
+1
-3
drivers/net/ethernet/pasemi/pasemi_mac.c
drivers/net/ethernet/pasemi/pasemi_mac.c
+2
-2
drivers/net/ethernet/qlogic/qlcnic/qlcnic_ctx.c
drivers/net/ethernet/qlogic/qlcnic/qlcnic_ctx.c
+2
-2
drivers/net/phy/smsc.c
drivers/net/phy/smsc.c
+27
-1
drivers/net/team/team.c
drivers/net/team/team.c
+6
-6
drivers/net/usb/smsc75xx.c
drivers/net/usb/smsc75xx.c
+1
-0
fs/dcache.c
fs/dcache.c
+6
-0
fs/lockd/svclock.c
fs/lockd/svclock.c
+1
-2
fs/namespace.c
fs/namespace.c
+8
-2
include/linux/iommu.h
include/linux/iommu.h
+24
-18
include/linux/nvme.h
include/linux/nvme.h
+2
-0
mm/huge_memory.c
mm/huge_memory.c
+0
-1
net/ipv4/inetpeer.c
net/ipv4/inetpeer.c
+4
-1
net/l2tp/l2tp_netlink.c
net/l2tp/l2tp_netlink.c
+6
-6
net/netfilter/xt_limit.c
net/netfilter/xt_limit.c
+4
-4
No files found.
Makefile
View file @
b4874a3d
VERSION
=
3
PATCHLEVEL
=
6
SUBLEVEL
=
0
EXTRAVERSION
=
-rc7
EXTRAVERSION
=
NAME
=
Terrified Chipmunk
# *DOCUMENTATION*
...
...
arch/arm/include/asm/syscall.h
View file @
b4874a3d
...
...
@@ -8,6 +8,7 @@
#define _ASM_ARM_SYSCALL_H
#include <linux/err.h>
#include <linux/sched.h>
#include <asm/unistd.h>
...
...
arch/um/include/asm/processor-generic.h
View file @
b4874a3d
...
...
@@ -20,14 +20,6 @@ struct mm_struct;
struct
thread_struct
{
struct
task_struct
*
saved_task
;
/*
* This flag is set to 1 before calling do_fork (and analyzed in
* copy_thread) to mark that we are begin called from userspace (fork /
* vfork / clone), and reset to 0 after. It is left to 0 when called
* from kernelspace (i.e. kernel_thread() or fork_idle(),
* as of 2.6.11).
*/
int
forking
;
struct
pt_regs
regs
;
int
singlestep_syscall
;
void
*
fault_addr
;
...
...
@@ -58,7 +50,6 @@ struct thread_struct {
#define INIT_THREAD \
{ \
.forking = 0, \
.regs = EMPTY_REGS, \
.fault_addr = NULL, \
.prev_sched = NULL, \
...
...
arch/um/include/shared/common-offsets.h
View file @
b4874a3d
...
...
@@ -7,16 +7,6 @@ DEFINE(UM_KERN_PAGE_MASK, PAGE_MASK);
DEFINE
(
UM_KERN_PAGE_SHIFT
,
PAGE_SHIFT
);
DEFINE
(
UM_NSEC_PER_SEC
,
NSEC_PER_SEC
);
DEFINE_STR
(
UM_KERN_EMERG
,
KERN_EMERG
);
DEFINE_STR
(
UM_KERN_ALERT
,
KERN_ALERT
);
DEFINE_STR
(
UM_KERN_CRIT
,
KERN_CRIT
);
DEFINE_STR
(
UM_KERN_ERR
,
KERN_ERR
);
DEFINE_STR
(
UM_KERN_WARNING
,
KERN_WARNING
);
DEFINE_STR
(
UM_KERN_NOTICE
,
KERN_NOTICE
);
DEFINE_STR
(
UM_KERN_INFO
,
KERN_INFO
);
DEFINE_STR
(
UM_KERN_DEBUG
,
KERN_DEBUG
);
DEFINE_STR
(
UM_KERN_CONT
,
KERN_CONT
);
DEFINE
(
UM_ELF_CLASS
,
ELF_CLASS
);
DEFINE
(
UM_ELFCLASS32
,
ELFCLASS32
);
DEFINE
(
UM_ELFCLASS64
,
ELFCLASS64
);
...
...
arch/um/include/shared/user.h
View file @
b4874a3d
...
...
@@ -26,6 +26,17 @@
extern
void
panic
(
const
char
*
fmt
,
...)
__attribute__
((
format
(
printf
,
1
,
2
)));
/* Requires preincluding include/linux/kern_levels.h */
#define UM_KERN_EMERG KERN_EMERG
#define UM_KERN_ALERT KERN_ALERT
#define UM_KERN_CRIT KERN_CRIT
#define UM_KERN_ERR KERN_ERR
#define UM_KERN_WARNING KERN_WARNING
#define UM_KERN_NOTICE KERN_NOTICE
#define UM_KERN_INFO KERN_INFO
#define UM_KERN_DEBUG KERN_DEBUG
#define UM_KERN_CONT KERN_CONT
#ifdef UML_CONFIG_PRINTK
extern
int
printk
(
const
char
*
fmt
,
...)
__attribute__
((
format
(
printf
,
1
,
2
)));
...
...
arch/um/kernel/exec.c
View file @
b4874a3d
...
...
@@ -39,34 +39,21 @@ void flush_thread(void)
void
start_thread
(
struct
pt_regs
*
regs
,
unsigned
long
eip
,
unsigned
long
esp
)
{
get_safe_registers
(
regs
->
regs
.
gp
,
regs
->
regs
.
fp
);
PT_REGS_IP
(
regs
)
=
eip
;
PT_REGS_SP
(
regs
)
=
esp
;
}
EXPORT_SYMBOL
(
start_thread
);
static
long
execve1
(
const
char
*
file
,
const
char
__user
*
const
__user
*
argv
,
const
char
__user
*
const
__user
*
env
)
{
long
error
;
error
=
do_execve
(
file
,
argv
,
env
,
&
current
->
thread
.
regs
);
if
(
error
==
0
)
{
task_lock
(
current
);
current
->
ptrace
&=
~
PT_DTRACE
;
current
->
ptrace
&=
~
PT_DTRACE
;
#ifdef SUBARCH_EXECVE1
SUBARCH_EXECVE1
(
&
current
->
thread
.
regs
.
regs
);
SUBARCH_EXECVE1
(
regs
->
regs
);
#endif
task_unlock
(
current
);
}
return
error
;
}
EXPORT_SYMBOL
(
start_thread
);
long
um_execve
(
const
char
*
file
,
const
char
__user
*
const
__user
*
argv
,
const
char
__user
*
const
__user
*
env
)
{
long
err
;
err
=
execve1
(
file
,
argv
,
env
);
err
=
do_execve
(
file
,
argv
,
env
,
&
current
->
thread
.
regs
);
if
(
!
err
)
UML_LONGJMP
(
current
->
thread
.
exec_buf
,
1
);
return
err
;
...
...
@@ -81,7 +68,7 @@ long sys_execve(const char __user *file, const char __user *const __user *argv,
filename
=
getname
(
file
);
error
=
PTR_ERR
(
filename
);
if
(
IS_ERR
(
filename
))
goto
out
;
error
=
execve1
(
filename
,
argv
,
env
);
error
=
do_execve
(
filename
,
argv
,
env
,
&
current
->
thread
.
regs
);
putname
(
filename
);
out:
return
error
;
...
...
arch/um/kernel/process.c
View file @
b4874a3d
...
...
@@ -181,11 +181,12 @@ int copy_thread(unsigned long clone_flags, unsigned long sp,
struct
pt_regs
*
regs
)
{
void
(
*
handler
)(
void
);
int
kthread
=
current
->
flags
&
PF_KTHREAD
;
int
ret
=
0
;
p
->
thread
=
(
struct
thread_struct
)
INIT_THREAD
;
if
(
current
->
thread
.
forking
)
{
if
(
!
kthread
)
{
memcpy
(
&
p
->
thread
.
regs
.
regs
,
&
regs
->
regs
,
sizeof
(
p
->
thread
.
regs
.
regs
));
PT_REGS_SET_SYSCALL_RETURN
(
&
p
->
thread
.
regs
,
0
);
...
...
@@ -195,8 +196,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp,
handler
=
fork_handler
;
arch_copy_thread
(
&
current
->
thread
.
arch
,
&
p
->
thread
.
arch
);
}
else
{
}
else
{
get_safe_registers
(
p
->
thread
.
regs
.
regs
.
gp
,
p
->
thread
.
regs
.
regs
.
fp
);
p
->
thread
.
request
.
u
.
thread
=
current
->
thread
.
request
.
u
.
thread
;
handler
=
new_thread_handler
;
...
...
@@ -204,7 +204,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp,
new_thread
(
task_stack_page
(
p
),
&
p
->
thread
.
switch_buf
,
handler
);
if
(
current
->
thread
.
forking
)
{
if
(
!
kthread
)
{
clear_flushed_tls
(
p
);
/*
...
...
arch/um/kernel/signal.c
View file @
b4874a3d
...
...
@@ -22,9 +22,13 @@ static void handle_signal(struct pt_regs *regs, unsigned long signr,
struct
k_sigaction
*
ka
,
siginfo_t
*
info
)
{
sigset_t
*
oldset
=
sigmask_to_save
();
int
singlestep
=
0
;
unsigned
long
sp
;
int
err
;
if
((
current
->
ptrace
&
PT_DTRACE
)
&&
(
current
->
ptrace
&
PT_PTRACED
))
singlestep
=
1
;
/* Did we come from a system call? */
if
(
PT_REGS_SYSCALL_NR
(
regs
)
>=
0
)
{
/* If so, check system call restarting.. */
...
...
@@ -61,7 +65,7 @@ static void handle_signal(struct pt_regs *regs, unsigned long signr,
if
(
err
)
force_sigsegv
(
signr
,
current
);
else
signal_delivered
(
signr
,
info
,
ka
,
regs
,
0
);
signal_delivered
(
signr
,
info
,
ka
,
regs
,
singlestep
);
}
static
int
kern_do_signal
(
struct
pt_regs
*
regs
)
...
...
arch/um/kernel/syscall.c
View file @
b4874a3d
...
...
@@ -17,25 +17,25 @@
long
sys_fork
(
void
)
{
long
ret
;
current
->
thread
.
forking
=
1
;
ret
=
do_fork
(
SIGCHLD
,
UPT_SP
(
&
current
->
thread
.
regs
.
regs
),
return
do_fork
(
SIGCHLD
,
UPT_SP
(
&
current
->
thread
.
regs
.
regs
),
&
current
->
thread
.
regs
,
0
,
NULL
,
NULL
);
current
->
thread
.
forking
=
0
;
return
ret
;
}
long
sys_vfork
(
void
)
{
long
ret
;
current
->
thread
.
forking
=
1
;
ret
=
do_fork
(
CLONE_VFORK
|
CLONE_VM
|
SIGCHLD
,
return
do_fork
(
CLONE_VFORK
|
CLONE_VM
|
SIGCHLD
,
UPT_SP
(
&
current
->
thread
.
regs
.
regs
),
&
current
->
thread
.
regs
,
0
,
NULL
,
NULL
);
current
->
thread
.
forking
=
0
;
return
ret
;
}
long
sys_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
void
__user
*
parent_tid
,
void
__user
*
child_tid
)
{
if
(
!
newsp
)
newsp
=
UPT_SP
(
&
current
->
thread
.
regs
.
regs
);
return
do_fork
(
clone_flags
,
newsp
,
&
current
->
thread
.
regs
,
0
,
parent_tid
,
child_tid
);
}
long
old_mmap
(
unsigned
long
addr
,
unsigned
long
len
,
...
...
arch/um/scripts/Makefile.rules
View file @
b4874a3d
...
...
@@ -8,7 +8,7 @@ USER_OBJS += $(filter %_user.o,$(obj-y) $(obj-m) $(USER_SINGLE_OBJS))
USER_OBJS
:=
$(
foreach
file,
$(USER_OBJS)
,
$(obj)
/
$(file)
)
$(USER_OBJS
:
.o=.%):
\
c_flags = -Wp
,
-MD
,
$(depfile) $(USER_CFLAGS) -include user.h $(CFLAGS_$(basetarget).o)
c_flags = -Wp
,
-MD
,
$(depfile) $(USER_CFLAGS) -include
$(srctree)/include/linux/kern_levels.h -include
user.h $(CFLAGS_$(basetarget).o)
# These are like USER_OBJS but filter USER_CFLAGS through unprofile instead of
# using it directly.
...
...
arch/x86/um/Kconfig
View file @
b4874a3d
...
...
@@ -21,6 +21,7 @@ config 64BIT
config X86_32
def_bool !64BIT
select HAVE_AOUT
select ARCH_WANT_IPC_PARSE_VERSION
config X86_64
def_bool 64BIT
...
...
arch/x86/um/shared/sysdep/kernel-offsets.h
View file @
b4874a3d
...
...
@@ -7,9 +7,6 @@
#define DEFINE(sym, val) \
asm volatile("\n->" #sym " %0 " #val : : "i" (val))
#define STR(x) #x
#define DEFINE_STR(sym, val) asm volatile("\n->" #sym " " STR(val) " " #val: : )
#define BLANK() asm volatile("\n->" : : )
#define OFFSET(sym, str, mem) \
...
...
arch/x86/um/shared/sysdep/syscalls.h
View file @
b4874a3d
extern
long
sys_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
void
__user
*
parent_tid
,
void
__user
*
child_tid
);
#ifdef __i386__
#include "syscalls_32.h"
#else
...
...
arch/x86/um/signal.c
View file @
b4874a3d
...
...
@@ -416,9 +416,6 @@ int setup_signal_stack_sc(unsigned long stack_top, int sig,
PT_REGS_AX
(
regs
)
=
(
unsigned
long
)
sig
;
PT_REGS_DX
(
regs
)
=
(
unsigned
long
)
0
;
PT_REGS_CX
(
regs
)
=
(
unsigned
long
)
0
;
if
((
current
->
ptrace
&
PT_DTRACE
)
&&
(
current
->
ptrace
&
PT_PTRACED
))
ptrace_notify
(
SIGTRAP
);
return
0
;
}
...
...
@@ -466,9 +463,6 @@ int setup_signal_stack_si(unsigned long stack_top, int sig,
PT_REGS_AX
(
regs
)
=
(
unsigned
long
)
sig
;
PT_REGS_DX
(
regs
)
=
(
unsigned
long
)
&
frame
->
info
;
PT_REGS_CX
(
regs
)
=
(
unsigned
long
)
&
frame
->
uc
;
if
((
current
->
ptrace
&
PT_DTRACE
)
&&
(
current
->
ptrace
&
PT_PTRACED
))
ptrace_notify
(
SIGTRAP
);
return
0
;
}
...
...
arch/x86/um/sys_call_table_32.c
View file @
b4874a3d
...
...
@@ -28,7 +28,7 @@
#define ptregs_execve sys_execve
#define ptregs_iopl sys_iopl
#define ptregs_vm86old sys_vm86old
#define ptregs_clone
sys
_clone
#define ptregs_clone
i386
_clone
#define ptregs_vm86 sys_vm86
#define ptregs_sigaltstack sys_sigaltstack
#define ptregs_vfork sys_vfork
...
...
arch/x86/um/syscalls_32.c
View file @
b4874a3d
...
...
@@ -3,37 +3,24 @@
* Licensed under the GPL
*/
#include "linux/sched.h"
#include "linux/shm.h"
#include "linux/ipc.h"
#include "linux/syscalls.h"
#include "asm/mman.h"
#include "asm/uaccess.h"
#include "asm/unistd.h"
#include <linux/syscalls.h>
#include <sysdep/syscalls.h>
/*
* The prototype on i386 is:
*
* int clone(int flags, void * child_stack, int * parent_tidptr, struct user_desc * newtls
, int * child_tidptr)
* int clone(int flags, void * child_stack, int * parent_tidptr, struct user_desc * newtls
*
* and the "newtls" arg. on i386 is read by copy_thread directly from the
* register saved on the stack.
*/
long
sys
_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
int
__user
*
parent_tid
,
void
*
newtls
,
int
__user
*
child_tid
)
long
i386
_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
int
__user
*
parent_tid
,
void
*
newtls
,
int
__user
*
child_tid
)
{
long
ret
;
if
(
!
newsp
)
newsp
=
UPT_SP
(
&
current
->
thread
.
regs
.
regs
);
current
->
thread
.
forking
=
1
;
ret
=
do_fork
(
clone_flags
,
newsp
,
&
current
->
thread
.
regs
,
0
,
parent_tid
,
child_tid
);
current
->
thread
.
forking
=
0
;
return
ret
;
return
sys_clone
(
clone_flags
,
newsp
,
parent_tid
,
child_tid
);
}
long
sys_sigaction
(
int
sig
,
const
struct
old_sigaction
__user
*
act
,
struct
old_sigaction
__user
*
oact
)
{
...
...
arch/x86/um/syscalls_64.c
View file @
b4874a3d
...
...
@@ -5,12 +5,9 @@
* Licensed under the GPL
*/
#include "linux/linkage.h"
#include "linux/personality.h"
#include "linux/utsname.h"
#include "asm/prctl.h"
/* XXX This should get the constants from libc */
#include "asm/uaccess.h"
#include "os.h"
#include <linux/sched.h>
#include <asm/prctl.h>
/* XXX This should get the constants from libc */
#include <os.h>
long
arch_prctl
(
struct
task_struct
*
task
,
int
code
,
unsigned
long
__user
*
addr
)
{
...
...
@@ -79,20 +76,6 @@ long sys_arch_prctl(int code, unsigned long addr)
return
arch_prctl
(
current
,
code
,
(
unsigned
long
__user
*
)
addr
);
}
long
sys_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
void
__user
*
parent_tid
,
void
__user
*
child_tid
)
{
long
ret
;
if
(
!
newsp
)
newsp
=
UPT_SP
(
&
current
->
thread
.
regs
.
regs
);
current
->
thread
.
forking
=
1
;
ret
=
do_fork
(
clone_flags
,
newsp
,
&
current
->
thread
.
regs
,
0
,
parent_tid
,
child_tid
);
current
->
thread
.
forking
=
0
;
return
ret
;
}
void
arch_switch_to
(
struct
task_struct
*
to
)
{
if
((
to
->
thread
.
arch
.
fs
==
0
)
||
(
to
->
mm
==
NULL
))
...
...
drivers/block/nvme.c
View file @
b4874a3d
This diff is collapsed.
Click to expand it.
drivers/iommu/amd_iommu.c
View file @
b4874a3d
...
...
@@ -266,7 +266,7 @@ static void swap_pci_ref(struct pci_dev **from, struct pci_dev *to)
static
int
iommu_init_device
(
struct
device
*
dev
)
{
struct
pci_dev
*
dma_pdev
,
*
pdev
=
to_pci_dev
(
dev
);
struct
pci_dev
*
dma_pdev
=
NULL
,
*
pdev
=
to_pci_dev
(
dev
);
struct
iommu_dev_data
*
dev_data
;
struct
iommu_group
*
group
;
u16
alias
;
...
...
@@ -293,7 +293,9 @@ static int iommu_init_device(struct device *dev)
dev_data
->
alias_data
=
alias_data
;
dma_pdev
=
pci_get_bus_and_slot
(
alias
>>
8
,
alias
&
0xff
);
}
else
}
if
(
dma_pdev
==
NULL
)
dma_pdev
=
pci_dev_get
(
pdev
);
/* Account for quirked devices */
...
...
drivers/md/dm-mpath.c
View file @
b4874a3d
...
...
@@ -1555,6 +1555,7 @@ static int multipath_ioctl(struct dm_target *ti, unsigned int cmd,
unsigned
long
arg
)
{
struct
multipath
*
m
=
ti
->
private
;
struct
pgpath
*
pgpath
;
struct
block_device
*
bdev
;
fmode_t
mode
;
unsigned
long
flags
;
...
...
@@ -1570,12 +1571,14 @@ static int multipath_ioctl(struct dm_target *ti, unsigned int cmd,
if
(
!
m
->
current_pgpath
)
__choose_pgpath
(
m
,
0
);
if
(
m
->
current_pgpath
)
{
bdev
=
m
->
current_pgpath
->
path
.
dev
->
bdev
;
mode
=
m
->
current_pgpath
->
path
.
dev
->
mode
;
pgpath
=
m
->
current_pgpath
;
if
(
pgpath
)
{
bdev
=
pgpath
->
path
.
dev
->
bdev
;
mode
=
pgpath
->
path
.
dev
->
mode
;
}
if
(
m
->
queue_io
)
if
(
(
pgpath
&&
m
->
queue_io
)
||
(
!
pgpath
&&
m
->
queue_if_no_path
)
)
r
=
-
EAGAIN
;
else
if
(
!
bdev
)
r
=
-
EIO
;
...
...
drivers/md/dm-table.c
View file @
b4874a3d
...
...
@@ -1212,6 +1212,41 @@ struct dm_target *dm_table_find_target(struct dm_table *t, sector_t sector)
return
&
t
->
targets
[(
KEYS_PER_NODE
*
n
)
+
k
];
}
static
int
count_device
(
struct
dm_target
*
ti
,
struct
dm_dev
*
dev
,
sector_t
start
,
sector_t
len
,
void
*
data
)
{
unsigned
*
num_devices
=
data
;
(
*
num_devices
)
++
;
return
0
;
}
/*
* Check whether a table has no data devices attached using each
* target's iterate_devices method.
* Returns false if the result is unknown because a target doesn't
* support iterate_devices.
*/
bool
dm_table_has_no_data_devices
(
struct
dm_table
*
table
)
{
struct
dm_target
*
uninitialized_var
(
ti
);
unsigned
i
=
0
,
num_devices
=
0
;
while
(
i
<
dm_table_get_num_targets
(
table
))
{
ti
=
dm_table_get_target
(
table
,
i
++
);
if
(
!
ti
->
type
->
iterate_devices
)
return
false
;
ti
->
type
->
iterate_devices
(
ti
,
count_device
,
&
num_devices
);
if
(
num_devices
)
return
false
;
}
return
true
;
}
/*
* Establish the new table's queue_limits and validate them.
*/
...
...
@@ -1354,17 +1389,25 @@ static int device_is_nonrot(struct dm_target *ti, struct dm_dev *dev,
return
q
&&
blk_queue_nonrot
(
q
);
}
static
bool
dm_table_is_nonrot
(
struct
dm_table
*
t
)
static
int
device_is_not_random
(
struct
dm_target
*
ti
,
struct
dm_dev
*
dev
,
sector_t
start
,
sector_t
len
,
void
*
data
)
{
struct
request_queue
*
q
=
bdev_get_queue
(
dev
->
bdev
);
return
q
&&
!
blk_queue_add_random
(
q
);
}
static
bool
dm_table_all_devices_attribute
(
struct
dm_table
*
t
,
iterate_devices_callout_fn
func
)
{
struct
dm_target
*
ti
;
unsigned
i
=
0
;
/* Ensure that all underlying device are non-rotational. */
while
(
i
<
dm_table_get_num_targets
(
t
))
{
ti
=
dm_table_get_target
(
t
,
i
++
);
if
(
!
ti
->
type
->
iterate_devices
||
!
ti
->
type
->
iterate_devices
(
ti
,
device_is_nonrot
,
NULL
))
!
ti
->
type
->
iterate_devices
(
ti
,
func
,
NULL
))
return
0
;
}
...
...
@@ -1396,13 +1439,23 @@ void dm_table_set_restrictions(struct dm_table *t, struct request_queue *q,
if
(
!
dm_table_discard_zeroes_data
(
t
))
q
->
limits
.
discard_zeroes_data
=
0
;
if
(
dm_table_is_nonrot
(
t
))
/* Ensure that all underlying devices are non-rotational. */
if
(
dm_table_all_devices_attribute
(
t
,
device_is_nonrot
))
queue_flag_set_unlocked
(
QUEUE_FLAG_NONROT
,
q
);
else
queue_flag_clear_unlocked
(
QUEUE_FLAG_NONROT
,
q
);
dm_table_set_integrity
(
t
);
/*
* Determine whether or not this queue's I/O timings contribute
* to the entropy pool, Only request-based targets use this.
* Clear QUEUE_FLAG_ADD_RANDOM if any underlying device does not
* have it set.
*/
if
(
blk_queue_add_random
(
q
)
&&
dm_table_all_devices_attribute
(
t
,
device_is_not_random
))
queue_flag_clear_unlocked
(
QUEUE_FLAG_ADD_RANDOM
,
q
);
/*
* QUEUE_FLAG_STACKABLE must be set after all queue settings are
* visible to other CPUs because, once the flag is set, incoming bios
...
...
drivers/md/dm-thin.c
View file @
b4874a3d
...
...
@@ -509,9 +509,9 @@ enum pool_mode {
struct
pool_features
{
enum
pool_mode
mode
;
unsigned
zero_new_blocks
:
1
;
unsigned
discard_enabled
:
1
;
unsigned
discard_passdown
:
1
;
bool
zero_new_blocks
:
1
;
bool
discard_enabled
:
1
;
bool
discard_passdown
:
1
;
};
struct
thin_c
;
...
...
@@ -580,7 +580,8 @@ struct pool_c {
struct
dm_target_callbacks
callbacks
;
dm_block_t
low_water_blocks
;
struct
pool_features
pf
;
struct
pool_features
requested_pf
;
/* Features requested during table load */
struct
pool_features
adjusted_pf
;
/* Features used after adjusting for constituent devices */
};
/*
...
...
@@ -1839,6 +1840,47 @@ static void __requeue_bios(struct pool *pool)
/*----------------------------------------------------------------
* Binding of control targets to a pool object
*--------------------------------------------------------------*/
static
bool
data_dev_supports_discard
(
struct
pool_c
*
pt
)
{
struct
request_queue
*
q
=
bdev_get_queue
(
pt
->
data_dev
->
bdev
);
return
q
&&
blk_queue_discard
(
q
);
}
/*
* If discard_passdown was enabled verify that the data device
* supports discards. Disable discard_passdown if not.
*/
static
void
disable_passdown_if_not_supported
(
struct
pool_c
*
pt
)
{
struct
pool
*
pool
=
pt
->
pool
;
struct
block_device
*
data_bdev
=
pt
->
data_dev
->
bdev
;
struct
queue_limits
*
data_limits
=
&
bdev_get_queue
(
data_bdev
)
->
limits
;
sector_t
block_size
=
pool
->
sectors_per_block
<<
SECTOR_SHIFT
;
const
char
*
reason
=
NULL
;
char
buf
[
BDEVNAME_SIZE
];
if
(
!
pt
->
adjusted_pf
.
discard_passdown
)
return
;
if
(
!
data_dev_supports_discard
(
pt
))
reason
=
"discard unsupported"
;
else
if
(
data_limits
->
max_discard_sectors
<
pool
->
sectors_per_block
)
reason
=
"max discard sectors smaller than a block"
;
else
if
(
data_limits
->
discard_granularity
>
block_size
)
reason
=
"discard granularity larger than a block"
;
else
if
(
block_size
&
(
data_limits
->
discard_granularity
-
1
))
reason
=
"discard granularity not a factor of block size"
;
if
(
reason
)
{
DMWARN
(
"Data device (%s) %s: Disabling discard passdown."
,
bdevname
(
data_bdev
,
buf
),
reason
);
pt
->
adjusted_pf
.
discard_passdown
=
false
;
}
}
static
int
bind_control_target
(
struct
pool
*
pool
,
struct
dm_target
*
ti
)
{
struct
pool_c
*
pt
=
ti
->
private
;
...
...
@@ -1847,31 +1889,16 @@ static int bind_control_target(struct pool *pool, struct dm_target *ti)
* We want to make sure that degraded pools are never upgraded.
*/
enum
pool_mode
old_mode
=
pool
->
pf
.
mode
;
enum
pool_mode
new_mode
=
pt
->
pf
.
mode
;
enum
pool_mode
new_mode
=
pt
->
adjusted_
pf
.
mode
;
if
(
old_mode
>
new_mode
)
new_mode
=
old_mode
;
pool
->
ti
=
ti
;
pool
->
low_water_blocks
=
pt
->
low_water_blocks
;
pool
->
pf
=
pt
->
pf
;
set_pool_mode
(
pool
,
new_mode
);
pool
->
pf
=
pt
->
adjusted_pf
;
/*
* If discard_passdown was enabled verify that the data device
* supports discards. Disable discard_passdown if not; otherwise
* -EOPNOTSUPP will be returned.
*/
/* FIXME: pull this out into a sep fn. */
if
(
pt
->
pf
.
discard_passdown
)
{
struct
request_queue
*
q
=
bdev_get_queue
(
pt
->
data_dev
->
bdev
);
if
(
!
q
||
!
blk_queue_discard
(
q
))
{
char
buf
[
BDEVNAME_SIZE
];
DMWARN
(
"Discard unsupported by data device (%s): Disabling discard passdown."
,
bdevname
(
pt
->
data_dev
->
bdev
,
buf
));
pool
->
pf
.
discard_passdown
=
0
;
}
}
set_pool_mode
(
pool
,
new_mode
);
return
0
;
}
...
...
@@ -1889,9 +1916,9 @@ static void unbind_control_target(struct pool *pool, struct dm_target *ti)
static
void
pool_features_init
(
struct
pool_features
*
pf
)
{
pf
->
mode
=
PM_WRITE
;
pf
->
zero_new_blocks
=
1
;
pf
->
discard_enabled
=
1
;
pf
->
discard_passdown
=
1
;
pf
->
zero_new_blocks
=
true
;
pf
->
discard_enabled
=
true
;
pf
->
discard_passdown
=
true
;
}
static
void
__pool_destroy
(
struct
pool
*
pool
)
...
...
@@ -2119,13 +2146,13 @@ static int parse_pool_features(struct dm_arg_set *as, struct pool_features *pf,
argc
--
;
if
(
!
strcasecmp
(
arg_name
,
"skip_block_zeroing"
))
pf
->
zero_new_blocks
=
0
;
pf
->
zero_new_blocks
=
false
;
else
if
(
!
strcasecmp
(
arg_name
,
"ignore_discard"
))
pf
->
discard_enabled
=
0
;
pf
->
discard_enabled
=
false
;
else
if
(
!
strcasecmp
(
arg_name
,
"no_discard_passdown"
))
pf
->
discard_passdown
=
0
;
pf
->
discard_passdown
=
false
;
else
if
(
!
strcasecmp
(
arg_name
,
"read_only"
))
pf
->
mode
=
PM_READ_ONLY
;
...
...
@@ -2259,8 +2286,9 @@ static int pool_ctr(struct dm_target *ti, unsigned argc, char **argv)
pt
->
metadata_dev
=
metadata_dev
;
pt
->
data_dev
=
data_dev
;
pt
->
low_water_blocks
=
low_water_blocks
;
pt
->
pf
=
pf
;
pt
->
adjusted_pf
=
pt
->
requested_
pf
=
pf
;
ti
->
num_flush_requests
=
1
;
/*
* Only need to enable discards if the pool should pass
* them down to the data device. The thin device's discard
...
...
@@ -2268,12 +2296,14 @@ static int pool_ctr(struct dm_target *ti, unsigned argc, char **argv)
*/
if
(
pf
.
discard_enabled
&&
pf
.
discard_passdown
)
{
ti
->
num_discard_requests
=
1
;
/*
* Setting 'discards_supported' circumvents the normal
* stacking of discard limits (this keeps the pool and
* thin devices' discard limits consistent).
*/
ti
->
discards_supported
=
true
;
ti
->
discard_zeroes_data_unsupported
=
true
;
}
ti
->
private
=
pt
;
...
...
@@ -2703,7 +2733,7 @@ static int pool_status(struct dm_target *ti, status_type_t type,
format_dev_t
(
buf2
,
pt
->
data_dev
->
bdev
->
bd_dev
),
(
unsigned
long
)
pool
->
sectors_per_block
,
(
unsigned
long
long
)
pt
->
low_water_blocks
);
emit_flags
(
&
pt
->
pf
,
result
,
sz
,
maxlen
);
emit_flags
(
&
pt
->
requested_
pf
,
result
,
sz
,
maxlen
);
break
;
}
...
...
@@ -2732,20 +2762,21 @@ static int pool_merge(struct dm_target *ti, struct bvec_merge_data *bvm,
return
min
(
max_size
,
q
->
merge_bvec_fn
(
q
,
bvm
,
biovec
));
}
static
void
set_discard_limits
(
struct
pool
*
pool
,
struct
queue_limits
*
limits
)
static
void
set_discard_limits
(
struct
pool
_c
*
pt
,
struct
queue_limits
*
limits
)
{
/*
* FIXME: these limits may be incompatible with the pool's data device
*/
struct
pool
*
pool
=
pt
->
pool
;
struct
queue_limits
*
data_limits
;
limits
->
max_discard_sectors
=
pool
->
sectors_per_block
;
/*
* This is just a hint, and not enforced. We have to cope with
* bios that cover a block partially. A discard that spans a block
* boundary is not sent to this target.
* discard_granularity is just a hint, and not enforced.
*/
limits
->
discard_granularity
=
pool
->
sectors_per_block
<<
SECTOR_SHIFT
;
limits
->
discard_zeroes_data
=
pool
->
pf
.
zero_new_blocks
;
if
(
pt
->
adjusted_pf
.
discard_passdown
)
{
data_limits
=
&
bdev_get_queue
(
pt
->
data_dev
->
bdev
)
->
limits
;
limits
->
discard_granularity
=
data_limits
->
discard_granularity
;
}
else
limits
->
discard_granularity
=
pool
->
sectors_per_block
<<
SECTOR_SHIFT
;
}
static
void
pool_io_hints
(
struct
dm_target
*
ti
,
struct
queue_limits
*
limits
)
...
...
@@ -2755,15 +2786,25 @@ static void pool_io_hints(struct dm_target *ti, struct queue_limits *limits)
blk_limits_io_min
(
limits
,
0
);
blk_limits_io_opt
(
limits
,
pool
->
sectors_per_block
<<
SECTOR_SHIFT
);
if
(
pool
->
pf
.
discard_enabled
)
set_discard_limits
(
pool
,
limits
);
/*
* pt->adjusted_pf is a staging area for the actual features to use.
* They get transferred to the live pool in bind_control_target()
* called from pool_preresume().
*/
if
(
!
pt
->
adjusted_pf
.
discard_enabled
)
return
;
disable_passdown_if_not_supported
(
pt
);
set_discard_limits
(
pt
,
limits
);
}
static
struct
target_type
pool_target
=
{
.
name
=
"thin-pool"
,
.
features
=
DM_TARGET_SINGLETON
|
DM_TARGET_ALWAYS_WRITEABLE
|
DM_TARGET_IMMUTABLE
,
.
version
=
{
1
,
3
,
0
},
.
version
=
{
1
,
4
,
0
},
.
module
=
THIS_MODULE
,
.
ctr
=
pool_ctr
,
.
dtr
=
pool_dtr
,
...
...
@@ -3042,19 +3083,19 @@ static int thin_iterate_devices(struct dm_target *ti,
return
0
;
}
/*
* A thin device always inherits its queue limits from its pool.
*/
static
void
thin_io_hints
(
struct
dm_target
*
ti
,
struct
queue_limits
*
limits
)
{
struct
thin_c
*
tc
=
ti
->
private
;
struct
pool
*
pool
=
tc
->
pool
;
blk_limits_io_min
(
limits
,
0
);
blk_limits_io_opt
(
limits
,
pool
->
sectors_per_block
<<
SECTOR_SHIFT
);
set_discard_limits
(
pool
,
limits
);
*
limits
=
bdev_get_queue
(
tc
->
pool_dev
->
bdev
)
->
limits
;
}
static
struct
target_type
thin_target
=
{
.
name
=
"thin"
,
.
version
=
{
1
,
3
,
0
},
.
version
=
{
1
,
4
,
0
},
.
module
=
THIS_MODULE
,
.
ctr
=
thin_ctr
,
.
dtr
=
thin_dtr
,
...
...
drivers/md/dm-verity.c
View file @
b4874a3d
...
...
@@ -718,8 +718,8 @@ static int verity_ctr(struct dm_target *ti, unsigned argc, char **argv)
v
->
hash_dev_block_bits
=
ffs
(
num
)
-
1
;
if
(
sscanf
(
argv
[
5
],
"%llu%c"
,
&
num_ll
,
&
dummy
)
!=
1
||
num_ll
<<
(
v
->
data_dev_block_bits
-
SECTOR_SHIFT
)
!=
(
sector_t
)
num_ll
<<
(
v
->
data_dev_block_bits
-
SECTOR_SHIFT
)
)
{
(
sector_t
)(
num_ll
<<
(
v
->
data_dev_block_bits
-
SECTOR_SHIFT
))
>>
(
v
->
data_dev_block_bits
-
SECTOR_SHIFT
)
!=
num_ll
)
{
ti
->
error
=
"Invalid data blocks"
;
r
=
-
EINVAL
;
goto
bad
;
...
...
@@ -733,8 +733,8 @@ static int verity_ctr(struct dm_target *ti, unsigned argc, char **argv)
}
if
(
sscanf
(
argv
[
6
],
"%llu%c"
,
&
num_ll
,
&
dummy
)
!=
1
||
num_ll
<<
(
v
->
hash_dev_block_bits
-
SECTOR_SHIFT
)
!=
(
sector_t
)
num_ll
<<
(
v
->
hash_dev_block_bits
-
SECTOR_SHIFT
)
)
{
(
sector_t
)(
num_ll
<<
(
v
->
hash_dev_block_bits
-
SECTOR_SHIFT
))
>>
(
v
->
hash_dev_block_bits
-
SECTOR_SHIFT
)
!=
num_ll
)
{
ti
->
error
=
"Invalid hash start"
;
r
=
-
EINVAL
;
goto
bad
;
...
...
drivers/md/dm.c
View file @
b4874a3d
...
...
@@ -865,10 +865,14 @@ static void dm_done(struct request *clone, int error, bool mapped)
{
int
r
=
error
;
struct
dm_rq_target_io
*
tio
=
clone
->
end_io_data
;
dm_request_endio_fn
rq_end_io
=
tio
->
ti
->
type
->
rq_end_io
;
dm_request_endio_fn
rq_end_io
=
NULL
;
if
(
mapped
&&
rq_end_io
)
r
=
rq_end_io
(
tio
->
ti
,
clone
,
error
,
&
tio
->
info
);
if
(
tio
->
ti
)
{
rq_end_io
=
tio
->
ti
->
type
->
rq_end_io
;
if
(
mapped
&&
rq_end_io
)
r
=
rq_end_io
(
tio
->
ti
,
clone
,
error
,
&
tio
->
info
);
}
if
(
r
<=
0
)
/* The target wants to complete the I/O */
...
...
@@ -1588,15 +1592,6 @@ static int map_request(struct dm_target *ti, struct request *clone,
int
r
,
requeued
=
0
;
struct
dm_rq_target_io
*
tio
=
clone
->
end_io_data
;
/*
* Hold the md reference here for the in-flight I/O.
* We can't rely on the reference count by device opener,
* because the device may be closed during the request completion
* when all bios are completed.
* See the comment in rq_completed() too.
*/
dm_get
(
md
);
tio
->
ti
=
ti
;
r
=
ti
->
type
->
map_rq
(
ti
,
clone
,
&
tio
->
info
);
switch
(
r
)
{
...
...
@@ -1628,6 +1623,26 @@ static int map_request(struct dm_target *ti, struct request *clone,
return
requeued
;
}
static
struct
request
*
dm_start_request
(
struct
mapped_device
*
md
,
struct
request
*
orig
)
{
struct
request
*
clone
;
blk_start_request
(
orig
);
clone
=
orig
->
special
;
atomic_inc
(
&
md
->
pending
[
rq_data_dir
(
clone
)]);
/*
* Hold the md reference here for the in-flight I/O.
* We can't rely on the reference count by device opener,
* because the device may be closed during the request completion
* when all bios are completed.
* See the comment in rq_completed() too.
*/
dm_get
(
md
);
return
clone
;
}
/*
* q->request_fn for request-based dm.
* Called with the queue lock held.
...
...
@@ -1657,14 +1672,21 @@ static void dm_request_fn(struct request_queue *q)
pos
=
blk_rq_pos
(
rq
);
ti
=
dm_table_find_target
(
map
,
pos
);
BUG_ON
(
!
dm_target_is_valid
(
ti
));
if
(
!
dm_target_is_valid
(
ti
))
{
/*
* Must perform setup, that dm_done() requires,
* before calling dm_kill_unmapped_request
*/
DMERR_LIMIT
(
"request attempted access beyond the end of device"
);
clone
=
dm_start_request
(
md
,
rq
);
dm_kill_unmapped_request
(
clone
,
-
EIO
);
continue
;
}
if
(
ti
->
type
->
busy
&&
ti
->
type
->
busy
(
ti
))
goto
delay_and_out
;
blk_start_request
(
rq
);
clone
=
rq
->
special
;
atomic_inc
(
&
md
->
pending
[
rq_data_dir
(
clone
)]);
clone
=
dm_start_request
(
md
,
rq
);
spin_unlock
(
q
->
queue_lock
);
if
(
map_request
(
ti
,
clone
,
md
))
...
...
@@ -1684,8 +1706,6 @@ static void dm_request_fn(struct request_queue *q)
blk_delay_queue
(
q
,
HZ
/
10
);
out:
dm_table_put
(
map
);
return
;
}
int
dm_underlying_device_busy
(
struct
request_queue
*
q
)
...
...
@@ -2409,7 +2429,7 @@ static void dm_queue_flush(struct mapped_device *md)
*/
struct
dm_table
*
dm_swap_table
(
struct
mapped_device
*
md
,
struct
dm_table
*
table
)
{
struct
dm_table
*
map
=
ERR_PTR
(
-
EINVAL
);
struct
dm_table
*
live_map
,
*
map
=
ERR_PTR
(
-
EINVAL
);
struct
queue_limits
limits
;
int
r
;
...
...
@@ -2419,6 +2439,19 @@ struct dm_table *dm_swap_table(struct mapped_device *md, struct dm_table *table)
if
(
!
dm_suspended_md
(
md
))
goto
out
;
/*
* If the new table has no data devices, retain the existing limits.
* This helps multipath with queue_if_no_path if all paths disappear,
* then new I/O is queued based on these limits, and then some paths
* reappear.
*/
if
(
dm_table_has_no_data_devices
(
table
))
{
live_map
=
dm_get_live_table
(
md
);
if
(
live_map
)
limits
=
md
->
queue
->
limits
;
dm_table_put
(
live_map
);
}
r
=
dm_calculate_queue_limits
(
table
,
&
limits
);
if
(
r
)
{
map
=
ERR_PTR
(
r
);
...
...
drivers/md/dm.h
View file @
b4874a3d
...
...
@@ -54,6 +54,7 @@ void dm_table_event_callback(struct dm_table *t,
void
(
*
fn
)(
void
*
),
void
*
context
);
struct
dm_target
*
dm_table_get_target
(
struct
dm_table
*
t
,
unsigned
int
index
);
struct
dm_target
*
dm_table_find_target
(
struct
dm_table
*
t
,
sector_t
sector
);
bool
dm_table_has_no_data_devices
(
struct
dm_table
*
table
);
int
dm_calculate_queue_limits
(
struct
dm_table
*
table
,
struct
queue_limits
*
limits
);
void
dm_table_set_restrictions
(
struct
dm_table
*
t
,
struct
request_queue
*
q
,
...
...
drivers/mtd/mtdchar.c
View file @
b4874a3d
...
...
@@ -1123,6 +1123,33 @@ static unsigned long mtdchar_get_unmapped_area(struct file *file,
}
#endif
static
inline
unsigned
long
get_vm_size
(
struct
vm_area_struct
*
vma
)
{
return
vma
->
vm_end
-
vma
->
vm_start
;
}
static
inline
resource_size_t
get_vm_offset
(
struct
vm_area_struct
*
vma
)
{
return
(
resource_size_t
)
vma
->
vm_pgoff
<<
PAGE_SHIFT
;
}
/*
* Set a new vm offset.
*
* Verify that the incoming offset really works as a page offset,
* and that the offset and size fit in a resource_size_t.
*/
static
inline
int
set_vm_offset
(
struct
vm_area_struct
*
vma
,
resource_size_t
off
)
{
pgoff_t
pgoff
=
off
>>
PAGE_SHIFT
;
if
(
off
!=
(
resource_size_t
)
pgoff
<<
PAGE_SHIFT
)
return
-
EINVAL
;
if
(
off
+
get_vm_size
(
vma
)
-
1
<
off
)
return
-
EINVAL
;
vma
->
vm_pgoff
=
pgoff
;
return
0
;
}
/*
* set up a mapping for shared memory segments
*/
...
...
@@ -1132,20 +1159,29 @@ static int mtdchar_mmap(struct file *file, struct vm_area_struct *vma)
struct
mtd_file_info
*
mfi
=
file
->
private_data
;
struct
mtd_info
*
mtd
=
mfi
->
mtd
;
struct
map_info
*
map
=
mtd
->
priv
;
unsigned
long
start
;
unsigned
long
off
;
u32
len
;
resource_size_t
start
,
off
;
unsigned
long
len
,
vma_len
;
if
(
mtd
->
type
==
MTD_RAM
||
mtd
->
type
==
MTD_ROM
)
{
off
=
vma
->
vm_pgoff
<<
PAGE_SHIFT
;
off
=
get_vm_offset
(
vma
)
;
start
=
map
->
phys
;
len
=
PAGE_ALIGN
((
start
&
~
PAGE_MASK
)
+
map
->
size
);
start
&=
PAGE_MASK
;
if
((
vma
->
vm_end
-
vma
->
vm_start
+
off
)
>
len
)
vma_len
=
get_vm_size
(
vma
);
/* Overflow in off+len? */
if
(
vma_len
+
off
<
off
)
return
-
EINVAL
;
/* Does it fit in the mapping? */
if
(
vma_len
+
off
>
len
)
return
-
EINVAL
;
off
+=
start
;
vma
->
vm_pgoff
=
off
>>
PAGE_SHIFT
;
/* Did that overflow? */
if
(
off
<
start
)
return
-
EINVAL
;
if
(
set_vm_offset
(
vma
,
off
)
<
0
)
return
-
EINVAL
;
vma
->
vm_flags
|=
VM_IO
|
VM_RESERVED
;
#ifdef pgprot_noncached
...
...
drivers/net/ethernet/broadcom/bnx2.c
View file @
b4874a3d
...
...
@@ -8564,7 +8564,7 @@ bnx2_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
return
0
;
error:
iounmap
(
bp
->
regview
);
pci_iounmap
(
pdev
,
bp
->
regview
);
pci_release_regions
(
pdev
);
pci_disable_device
(
pdev
);
pci_set_drvdata
(
pdev
,
NULL
);
...
...
drivers/net/ethernet/octeon/octeon_mgmt.c
View file @
b4874a3d
...
...
@@ -722,10 +722,8 @@ static int octeon_mgmt_init_phy(struct net_device *netdev)
octeon_mgmt_adjust_link
,
0
,
PHY_INTERFACE_MODE_MII
);
if
(
IS_ERR
(
p
->
phydev
))
{
p
->
phydev
=
NULL
;
if
(
!
p
->
phydev
)
return
-
1
;
}
phy_start_aneg
(
p
->
phydev
);
...
...
drivers/net/ethernet/pasemi/pasemi_mac.c
View file @
b4874a3d
...
...
@@ -1101,9 +1101,9 @@ static int pasemi_mac_phy_init(struct net_device *dev)
phydev
=
of_phy_connect
(
dev
,
phy_dn
,
&
pasemi_adjust_link
,
0
,
PHY_INTERFACE_MODE_SGMII
);
if
(
IS_ERR
(
phydev
)
)
{
if
(
!
phydev
)
{
printk
(
KERN_ERR
"%s: Could not attach to phy
\n
"
,
dev
->
name
);
return
PTR_ERR
(
phydev
)
;
return
-
ENODEV
;
}
mac
->
phydev
=
phydev
;
...
...
drivers/net/ethernet/qlogic/qlcnic/qlcnic_ctx.c
View file @
b4874a3d
...
...
@@ -15,7 +15,7 @@ qlcnic_poll_rsp(struct qlcnic_adapter *adapter)
do
{
/* give atleast 1ms for firmware to respond */
m
sleep
(
1
);
m
delay
(
1
);
if
(
++
timeout
>
QLCNIC_OS_CRB_RETRY_COUNT
)
return
QLCNIC_CDRP_RSP_TIMEOUT
;
...
...
@@ -601,7 +601,7 @@ void qlcnic_fw_destroy_ctx(struct qlcnic_adapter *adapter)
qlcnic_fw_cmd_destroy_tx_ctx
(
adapter
);
/* Allow dma queues to drain after context reset */
m
sleep
(
20
);
m
delay
(
20
);
}
}
...
...
drivers/net/phy/smsc.c
View file @
b4874a3d
...
...
@@ -56,6 +56,32 @@ static int smsc_phy_config_init(struct phy_device *phydev)
return
smsc_phy_ack_interrupt
(
phydev
);
}
static
int
lan87xx_config_init
(
struct
phy_device
*
phydev
)
{
/*
* Make sure the EDPWRDOWN bit is NOT set. Setting this bit on
* LAN8710/LAN8720 PHY causes the PHY to misbehave, likely due
* to a bug on the chip.
*
* When the system is powered on with the network cable being
* disconnected all the way until after ifconfig ethX up is
* issued for the LAN port with this PHY, connecting the cable
* afterwards does not cause LINK change detection, while the
* expected behavior is the Link UP being detected.
*/
int
rc
=
phy_read
(
phydev
,
MII_LAN83C185_CTRL_STATUS
);
if
(
rc
<
0
)
return
rc
;
rc
&=
~
MII_LAN83C185_EDPWRDOWN
;
rc
=
phy_write
(
phydev
,
MII_LAN83C185_CTRL_STATUS
,
rc
);
if
(
rc
<
0
)
return
rc
;
return
smsc_phy_ack_interrupt
(
phydev
);
}
static
int
lan911x_config_init
(
struct
phy_device
*
phydev
)
{
return
smsc_phy_ack_interrupt
(
phydev
);
...
...
@@ -162,7 +188,7 @@ static struct phy_driver smsc_phy_driver[] = {
/* basic functions */
.
config_aneg
=
genphy_config_aneg
,
.
read_status
=
genphy_read_status
,
.
config_init
=
smsc_phy
_config_init
,
.
config_init
=
lan87xx
_config_init
,
/* IRQ related */
.
ack_interrupt
=
smsc_phy_ack_interrupt
,
...
...
drivers/net/team/team.c
View file @
b4874a3d
...
...
@@ -1653,8 +1653,8 @@ static int team_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
hdr
=
genlmsg_put
(
msg
,
info
->
snd_pid
,
info
->
snd_seq
,
&
team_nl_family
,
0
,
TEAM_CMD_NOOP
);
if
(
IS_ERR
(
hdr
)
)
{
err
=
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
{
err
=
-
EMSGSIZE
;
goto
err_msg_put
;
}
...
...
@@ -1848,8 +1848,8 @@ static int team_nl_send_options_get(struct team *team, u32 pid, u32 seq,
hdr
=
genlmsg_put
(
skb
,
pid
,
seq
,
&
team_nl_family
,
flags
|
NLM_F_MULTI
,
TEAM_CMD_OPTIONS_GET
);
if
(
IS_ERR
(
hdr
)
)
return
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
return
-
EMSGSIZE
;
if
(
nla_put_u32
(
skb
,
TEAM_ATTR_TEAM_IFINDEX
,
team
->
dev
->
ifindex
))
goto
nla_put_failure
;
...
...
@@ -2068,8 +2068,8 @@ static int team_nl_fill_port_list_get(struct sk_buff *skb,
hdr
=
genlmsg_put
(
skb
,
pid
,
seq
,
&
team_nl_family
,
flags
,
TEAM_CMD_PORT_LIST_GET
);
if
(
IS_ERR
(
hdr
)
)
return
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
return
-
EMSGSIZE
;
if
(
nla_put_u32
(
skb
,
TEAM_ATTR_TEAM_IFINDEX
,
team
->
dev
->
ifindex
))
goto
nla_put_failure
;
...
...
drivers/net/usb/smsc75xx.c
View file @
b4874a3d
...
...
@@ -1253,6 +1253,7 @@ static struct usb_driver smsc75xx_driver = {
.
probe
=
usbnet_probe
,
.
suspend
=
usbnet_suspend
,
.
resume
=
usbnet_resume
,
.
reset_resume
=
usbnet_resume
,
.
disconnect
=
usbnet_disconnect
,
.
disable_hub_initiated_lpm
=
1
,
};
...
...
fs/dcache.c
View file @
b4874a3d
...
...
@@ -1134,6 +1134,8 @@ int have_submounts(struct dentry *parent)
return
1
;
rename_retry:
if
(
locked
)
goto
again
;
locked
=
1
;
write_seqlock
(
&
rename_lock
);
goto
again
;
...
...
@@ -1236,6 +1238,8 @@ static int select_parent(struct dentry *parent, struct list_head *dispose)
rename_retry:
if
(
found
)
return
found
;
if
(
locked
)
goto
again
;
locked
=
1
;
write_seqlock
(
&
rename_lock
);
goto
again
;
...
...
@@ -3035,6 +3039,8 @@ void d_genocide(struct dentry *root)
return
;
rename_retry:
if
(
locked
)
goto
again
;
locked
=
1
;
write_seqlock
(
&
rename_lock
);
goto
again
;
...
...
fs/lockd/svclock.c
View file @
b4874a3d
...
...
@@ -289,7 +289,6 @@ static void nlmsvc_free_block(struct kref *kref)
dprintk
(
"lockd: freeing block %p...
\n
"
,
block
);
/* Remove block from file's list of blocks */
mutex_lock
(
&
file
->
f_mutex
);
list_del_init
(
&
block
->
b_flist
);
mutex_unlock
(
&
file
->
f_mutex
);
...
...
@@ -303,7 +302,7 @@ static void nlmsvc_free_block(struct kref *kref)
static
void
nlmsvc_release_block
(
struct
nlm_block
*
block
)
{
if
(
block
!=
NULL
)
kref_put
(
&
block
->
b_count
,
nlmsvc_free_block
);
kref_put
_mutex
(
&
block
->
b_count
,
nlmsvc_free_block
,
&
block
->
b_file
->
f_mutex
);
}
/*
...
...
fs/namespace.c
View file @
b4874a3d
...
...
@@ -1886,8 +1886,14 @@ static int do_add_mount(struct mount *newmnt, struct path *path, int mnt_flags)
return
err
;
err
=
-
EINVAL
;
if
(
!
(
mnt_flags
&
MNT_SHRINKABLE
)
&&
!
check_mnt
(
real_mount
(
path
->
mnt
)))
goto
unlock
;
if
(
unlikely
(
!
check_mnt
(
real_mount
(
path
->
mnt
))))
{
/* that's acceptable only for automounts done in private ns */
if
(
!
(
mnt_flags
&
MNT_SHRINKABLE
))
goto
unlock
;
/* ... and for those we'd better have mountpoint still alive */
if
(
!
real_mount
(
path
->
mnt
)
->
mnt_ns
)
goto
unlock
;
}
/* Refuse the same filesystem on the same mount point */
err
=
-
EBUSY
;
...
...
include/linux/iommu.h
View file @
b4874a3d
...
...
@@ -256,72 +256,78 @@ static inline void iommu_set_fault_handler(struct iommu_domain *domain,
{
}
int
iommu_attach_group
(
struct
iommu_domain
*
domain
,
struct
iommu_group
*
group
)
static
inline
int
iommu_attach_group
(
struct
iommu_domain
*
domain
,
struct
iommu_group
*
group
)
{
return
-
ENODEV
;
}
void
iommu_detach_group
(
struct
iommu_domain
*
domain
,
struct
iommu_group
*
group
)
static
inline
void
iommu_detach_group
(
struct
iommu_domain
*
domain
,
struct
iommu_group
*
group
)
{
}
struct
iommu_group
*
iommu_group_alloc
(
void
)
st
atic
inline
st
ruct
iommu_group
*
iommu_group_alloc
(
void
)
{
return
ERR_PTR
(
-
ENODEV
);
}
void
*
iommu_group_get_iommudata
(
struct
iommu_group
*
group
)
static
inline
void
*
iommu_group_get_iommudata
(
struct
iommu_group
*
group
)
{
return
NULL
;
}
void
iommu_group_set_iommudata
(
struct
iommu_group
*
group
,
void
*
iommu_data
,
void
(
*
release
)(
void
*
iommu_data
))
static
inline
void
iommu_group_set_iommudata
(
struct
iommu_group
*
group
,
void
*
iommu_data
,
void
(
*
release
)(
void
*
iommu_data
))
{
}
int
iommu_group_set_name
(
struct
iommu_group
*
group
,
const
char
*
name
)
static
inline
int
iommu_group_set_name
(
struct
iommu_group
*
group
,
const
char
*
name
)
{
return
-
ENODEV
;
}
int
iommu_group_add_device
(
struct
iommu_group
*
group
,
struct
device
*
dev
)
static
inline
int
iommu_group_add_device
(
struct
iommu_group
*
group
,
struct
device
*
dev
)
{
return
-
ENODEV
;
}
void
iommu_group_remove_device
(
struct
device
*
dev
)
static
inline
void
iommu_group_remove_device
(
struct
device
*
dev
)
{
}
int
iommu_group_for_each_dev
(
struct
iommu_group
*
group
,
void
*
data
,
int
(
*
fn
)(
struct
device
*
,
void
*
))
static
inline
int
iommu_group_for_each_dev
(
struct
iommu_group
*
group
,
void
*
data
,
int
(
*
fn
)(
struct
device
*
,
void
*
))
{
return
-
ENODEV
;
}
struct
iommu_group
*
iommu_group_get
(
struct
device
*
dev
)
st
atic
inline
st
ruct
iommu_group
*
iommu_group_get
(
struct
device
*
dev
)
{
return
NULL
;
}
void
iommu_group_put
(
struct
iommu_group
*
group
)
static
inline
void
iommu_group_put
(
struct
iommu_group
*
group
)
{
}
int
iommu_group_register_notifier
(
struct
iommu_group
*
group
,
struct
notifier_block
*
nb
)
static
inline
int
iommu_group_register_notifier
(
struct
iommu_group
*
group
,
struct
notifier_block
*
nb
)
{
return
-
ENODEV
;
}
int
iommu_group_unregister_notifier
(
struct
iommu_group
*
group
,
struct
notifier_block
*
nb
)
static
inline
int
iommu_group_unregister_notifier
(
struct
iommu_group
*
group
,
struct
notifier_block
*
nb
)
{
return
0
;
}
int
iommu_group_id
(
struct
iommu_group
*
group
)
static
inline
int
iommu_group_id
(
struct
iommu_group
*
group
)
{
return
-
ENODEV
;
}
...
...
include/linux/nvme.h
View file @
b4874a3d
...
...
@@ -35,8 +35,10 @@ struct nvme_bar {
__u64
acq
;
/* Admin CQ Base Address */
};
#define NVME_CAP_MQES(cap) ((cap) & 0xffff)
#define NVME_CAP_TIMEOUT(cap) (((cap) >> 24) & 0xff)
#define NVME_CAP_STRIDE(cap) (((cap) >> 32) & 0xf)
#define NVME_CAP_MPSMIN(cap) (((cap) >> 48) & 0xf)
enum
{
NVME_CC_ENABLE
=
1
<<
0
,
...
...
mm/huge_memory.c
View file @
b4874a3d
...
...
@@ -1811,7 +1811,6 @@ static void __collapse_huge_page_copy(pte_t *pte, struct page *page,
src_page
=
pte_page
(
pteval
);
copy_user_highpage
(
page
,
src_page
,
address
,
vma
);
VM_BUG_ON
(
page_mapcount
(
src_page
)
!=
1
);
VM_BUG_ON
(
page_count
(
src_page
)
!=
2
);
release_pte_page
(
src_page
);
/*
* ptl mostly unnecessary, but preempt has to
...
...
net/ipv4/inetpeer.c
View file @
b4874a3d
...
...
@@ -510,7 +510,10 @@ struct inet_peer *inet_getpeer(struct inet_peer_base *base,
secure_ipv6_id
(
daddr
->
addr
.
a6
));
p
->
metrics
[
RTAX_LOCK
-
1
]
=
INETPEER_METRICS_NEW
;
p
->
rate_tokens
=
0
;
p
->
rate_last
=
0
;
/* 60*HZ is arbitrary, but chosen enough high so that the first
* calculation of tokens is at its maximum.
*/
p
->
rate_last
=
jiffies
-
60
*
HZ
;
INIT_LIST_HEAD
(
&
p
->
gc_list
);
/* Link the node. */
...
...
net/l2tp/l2tp_netlink.c
View file @
b4874a3d
...
...
@@ -80,8 +80,8 @@ static int l2tp_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
hdr
=
genlmsg_put
(
msg
,
info
->
snd_pid
,
info
->
snd_seq
,
&
l2tp_nl_family
,
0
,
L2TP_CMD_NOOP
);
if
(
IS_ERR
(
hdr
)
)
{
ret
=
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
{
ret
=
-
EMSGSIZE
;
goto
err_out
;
}
...
...
@@ -250,8 +250,8 @@ static int l2tp_nl_tunnel_send(struct sk_buff *skb, u32 pid, u32 seq, int flags,
hdr
=
genlmsg_put
(
skb
,
pid
,
seq
,
&
l2tp_nl_family
,
flags
,
L2TP_CMD_TUNNEL_GET
);
if
(
IS_ERR
(
hdr
)
)
return
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
return
-
EMSGSIZE
;
if
(
nla_put_u8
(
skb
,
L2TP_ATTR_PROTO_VERSION
,
tunnel
->
version
)
||
nla_put_u32
(
skb
,
L2TP_ATTR_CONN_ID
,
tunnel
->
tunnel_id
)
||
...
...
@@ -617,8 +617,8 @@ static int l2tp_nl_session_send(struct sk_buff *skb, u32 pid, u32 seq, int flags
sk
=
tunnel
->
sock
;
hdr
=
genlmsg_put
(
skb
,
pid
,
seq
,
&
l2tp_nl_family
,
flags
,
L2TP_CMD_SESSION_GET
);
if
(
IS_ERR
(
hdr
)
)
return
PTR_ERR
(
hdr
)
;
if
(
!
hdr
)
return
-
EMSGSIZE
;
if
(
nla_put_u32
(
skb
,
L2TP_ATTR_CONN_ID
,
tunnel
->
tunnel_id
)
||
nla_put_u32
(
skb
,
L2TP_ATTR_SESSION_ID
,
session
->
session_id
)
||
...
...
net/netfilter/xt_limit.c
View file @
b4874a3d
...
...
@@ -117,11 +117,11 @@ static int limit_mt_check(const struct xt_mtchk_param *par)
/* For SMP, we only want to use one set of state. */
r
->
master
=
priv
;
/* User avg in seconds * XT_LIMIT_SCALE: convert to jiffies *
128. */
priv
->
prev
=
jiffies
;
priv
->
credit
=
user2credits
(
r
->
avg
*
r
->
burst
);
/* Credits full. */
if
(
r
->
cost
==
0
)
{
/* User avg in seconds * XT_LIMIT_SCALE: convert to jiffies *
128. */
priv
->
prev
=
jiffies
;
priv
->
credit
=
user2credits
(
r
->
avg
*
r
->
burst
);
/* Credits full. */
r
->
credit_cap
=
priv
->
credit
;
/* Credits full. */
r
->
cost
=
user2credits
(
r
->
avg
);
}
...
...
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