* [PATCH] SUNRPC: fix use-after-free of rpc pipes
@ 2012-02-23 17:48 Fred Isaman
2012-02-24 11:03 ` Stanislav Kinsbursky
` (2 more replies)
0 siblings, 3 replies; 12+ messages in thread
From: Fred Isaman @ 2012-02-23 17:48 UTC (permalink / raw)
To: linux-nfs; +Cc: Stanislav Kinsbursky
This needs to be looked at closely by someone more familiar with the
pipe code.
It fixes an issue with the current nfs_for_next branch which causes a
chain of oopses on umount every time if sufficient CONFIG_* debug
options are set.
A git-bisect shows that the problem was introduced by
commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
A typical oops starts with:
general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
CPU 0
Modules linked in: nfs_layout_nfsv41_files nfs auth_rpcgss nfs_acl lockd ppdev parport_pc parport e1000 i2c_piix4 shpchp i2c_core sunrpc autofs4 mptspi mptscsih mptbase scsi_transport_spi floppy [last unloaded: scsi_wait_scan]
Pid: 834, comm: rpc.idmapd Not tainted 3.3.0-rc2-kitchensink+ #51 VMware, Inc. VMware Virtual Platform/440BX Desktop
Reference Platform
RIP: 0010:[<ffffffff81079979>] [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2
RSP: 0018:ffff8800367bfcb8 EFLAGS: 00010002
RAX: 6b6b6b6b6b6b6b6b RBX: ffff88003bb8a0b0 RCX: 0000000000000000
RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff88002ca779c0
RBP: ffff8800367bfd88 R08: 0000000000000002 R09: 0000000000000001
R10: 0000000000000000 R11: ffff88002ca779c0 R12: 0000000000000286
R13: ffff88002ca779c0 R14: 0000000000000002 R15: 0000000000000000
FS: 00007f7ff3dab700(0000) GS:ffff88003fa00000(0000) knlGS:0000000000000000
CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
CR2: 00007f5305ae1000 CR3: 000000003ae4e000 CR4: 00000000000406f0
DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
Process rpc.idmapd (pid: 834, threadinfo ffff8800367be000, task ffff88003bb8a0b0)
Stack:
0000000000000000 ffffffff81235f78 ffff8800367bfd08 ffffffff810788c4
ffff8800367bfd18 ffff880000000000 ffff880000000000 ffffffff00000000
00000000000001df ffff880000000001 ffff88003bb8a730 ffffffff81a24730
Call Trace:
[<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff8107a775>] lock_acquire+0x102/0x12f
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
[<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
[<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
[<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
[<ffffffff8115379b>] ep_remove+0x25/0x9f
[<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
[<ffffffff8143e415>] ? sysret_check+0x22/0x5d
[<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
[<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
Code: 8d 58 ff ff ff 44 89 8d 48 ff ff ff 4c 89 ef e8 f6 fa ff ff 48 8b 8d 58 ff ff ff 48 85 c0 44 8b 8d 48 ff ff ff
0f 84 99 0c 00 00 <3e> ff 80 98 01 00 00 8b 93 78 06 00 00 83 3d 87 83 b8 00 00 89
RIP [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2 RSP <ffff8800367bfcb8>
---[ end trace ffe7d1c1af2c62f6 ]---
BUG: sleeping function called from invalid context at /home/iisaman/projects/pnfs-file/src/linux-pnfs/kernel/rwsem.c
:21
in_atomic(): 1, irqs_disabled(): 1, pid: 834, name: rpc.idmapd
INFO: lockdep is turned off.
irq event stamp: 4308
hardirqs last enabled at (4307): [<ffffffff81434d53>] __mutex_lock_common+0x37b/0x3af
hardirqs last disabled at (4308): [<ffffffff81436c87>] _raw_spin_lock_irqsave+0x29/0x6a
softirqs last enabled at (3992): [<ffffffff810378e3>] __do_softirq+0x1e6/0x205
softirqs last disabled at (3783): [<ffffffff8143f92c>] call_softirq+0x1c/0x30
Pid: 834, comm: rpc.idmapd Tainted: G D 3.3.0-rc2-kitchensink+ #51
Call Trace:
[<ffffffff81059bb7>] __might_sleep+0x107/0x10c
[<ffffffff81435499>] down_read+0x24/0x61
[<ffffffff810433e5>] exit_signals+0x26/0x12c
[<ffffffff81053fdc>] ? blocking_notifier_call_chain+0x14/0x16
[<ffffffff81034e53>] do_exit+0x118/0x7d9
[<ffffffff81031cda>] ? kmsg_dump+0x126/0x144
[<ffffffff81031c3c>] ? kmsg_dump+0x88/0x144
[<ffffffff81438422>] oops_end+0xc0/0xc8
[<ffffffff81004d96>] die+0x5a/0x63
[<ffffffff81438272>] do_general_protection+0x12a/0x132
[<ffffffff81437764>] ? restore_args+0x30/0x30
[<ffffffff81437915>] general_protection+0x25/0x30
[<ffffffff81079979>] ? __lock_acquire+0xd8/0xdd2
[<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff8107a775>] lock_acquire+0x102/0x12f
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
[<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
[<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
[<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
[<ffffffff8115379b>] ep_remove+0x25/0x9f
[<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
[<ffffffff8143e415>] ? sysret_check+0x22/0x5d
[<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d
[<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
[<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
note: rpc.idmapd[834] exited with preempt_count 1
BUG: scheduling while atomic: rpc.idmapd/834/0x10000002
INFO: lockdep is turned off.
Signed-off-by: Fred Isaman <iisaman@netapp.com>
---
fs/nfs/blocklayout/blocklayout.c | 1 -
fs/nfs/idmap.c | 1 -
net/sunrpc/auth_gss/auth_gss.c | 2 --
net/sunrpc/rpc_pipe.c | 2 ++
4 files changed, 2 insertions(+), 4 deletions(-)
diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
index 783ebd5..26fcbd1 100644
--- a/fs/nfs/blocklayout/blocklayout.c
+++ b/fs/nfs/blocklayout/blocklayout.c
@@ -1134,7 +1134,6 @@ static void nfs4blocklayout_net_exit(struct net *net)
struct nfs_net *nn = net_generic(net, nfs_net_id);
nfs4blocklayout_unregister_net(net, nn->bl_device_pipe);
- rpc_destroy_pipe_data(nn->bl_device_pipe);
nn->bl_device_pipe = NULL;
}
diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c
index b5c6d8e..384fbed 100644
--- a/fs/nfs/idmap.c
+++ b/fs/nfs/idmap.c
@@ -508,7 +508,6 @@ nfs_idmap_delete(struct nfs_client *clp)
if (!idmap)
return;
nfs_idmap_unregister(clp, idmap->idmap_pipe);
- rpc_destroy_pipe_data(idmap->idmap_pipe);
clp->cl_idmap = NULL;
idmap_free_hashtable(&idmap->idmap_user_hash);
idmap_free_hashtable(&idmap->idmap_group_hash);
diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
index cb2e564..6be27ec 100644
--- a/net/sunrpc/auth_gss/auth_gss.c
+++ b/net/sunrpc/auth_gss/auth_gss.c
@@ -908,8 +908,6 @@ static void
gss_free(struct gss_auth *gss_auth)
{
gss_pipes_dentries_destroy_net(gss_auth->client, &gss_auth->rpc_auth);
- rpc_destroy_pipe_data(gss_auth->pipe[0]);
- rpc_destroy_pipe_data(gss_auth->pipe[1]);
gss_mech_put(gss_auth->mech);
kfree(gss_auth);
diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
index 6873c9b..61ad698 100644
--- a/net/sunrpc/rpc_pipe.c
+++ b/net/sunrpc/rpc_pipe.c
@@ -191,6 +191,8 @@ static void
rpc_i_callback(struct rcu_head *head)
{
struct inode *inode = container_of(head, struct inode, i_rcu);
+ rpc_destroy_pipe_data(RPC_I(inode)->pipe);
+ RPC_I(inode)->pipe = NULL;
kmem_cache_free(rpc_inode_cachep, RPC_I(inode));
}
--
1.7.2.1
^ permalink raw reply related [flat|nested] 12+ messages in thread* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-23 17:48 [PATCH] SUNRPC: fix use-after-free of rpc pipes Fred Isaman
@ 2012-02-24 11:03 ` Stanislav Kinsbursky
2012-02-24 13:11 ` Fred Isaman
2012-02-24 11:47 ` Stanislav Kinsbursky
2012-02-24 18:14 ` Stanislav Kinsbursky
2 siblings, 1 reply; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-24 11:03 UTC (permalink / raw)
To: Fred Isaman; +Cc: linux-nfs@vger.kernel.org
23.02.2012 21:48, Fred Isaman пишет:
> This needs to be looked at closely by someone more familiar with the
> pipe code.
>
> It fixes an issue with the current nfs_for_next branch which causes a
> chain of oopses on umount every time if sufficient CONFIG_* debug
> options are set.
>
> A git-bisect shows that the problem was introduced by
> commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
>
NAK, the whole patch idea is bad.
Currently, pipe data is created during NFS kernel part initialization, when
PipeFS inode is created only on PipeFS mount and destroyed on PipeFS umount. And
this creation/destruction has to have nothing with kernel pipes at all - these
inodes are just a kind of front-end to kernel data.
Please, provide exact CONFIG_* debug options for investigation.
> A typical oops starts with:
>
> general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
> CPU 0
> Modules linked in: nfs_layout_nfsv41_files nfs auth_rpcgss nfs_acl lockd ppdev parport_pc parport e1000 i2c_piix4 shpchp i2c_core sunrpc autofs4 mptspi mptscsih mptbase scsi_transport_spi floppy [last unloaded: scsi_wait_scan]
>
> Pid: 834, comm: rpc.idmapd Not tainted 3.3.0-rc2-kitchensink+ #51 VMware, Inc. VMware Virtual Platform/440BX Desktop
> Reference Platform
> RIP: 0010:[<ffffffff81079979>] [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2
> RSP: 0018:ffff8800367bfcb8 EFLAGS: 00010002
> RAX: 6b6b6b6b6b6b6b6b RBX: ffff88003bb8a0b0 RCX: 0000000000000000
> RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff88002ca779c0
> RBP: ffff8800367bfd88 R08: 0000000000000002 R09: 0000000000000001
> R10: 0000000000000000 R11: ffff88002ca779c0 R12: 0000000000000286
> R13: ffff88002ca779c0 R14: 0000000000000002 R15: 0000000000000000
> FS: 00007f7ff3dab700(0000) GS:ffff88003fa00000(0000) knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> CR2: 00007f5305ae1000 CR3: 000000003ae4e000 CR4: 00000000000406f0
> DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
> Process rpc.idmapd (pid: 834, threadinfo ffff8800367be000, task ffff88003bb8a0b0)
> Stack:
> 0000000000000000 ffffffff81235f78 ffff8800367bfd08 ffffffff810788c4
> ffff8800367bfd18 ffff880000000000 ffff880000000000 ffffffff00000000
> 00000000000001df ffff880000000001 ffff88003bb8a730 ffffffff81a24730
> Call Trace:
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> Code: 8d 58 ff ff ff 44 89 8d 48 ff ff ff 4c 89 ef e8 f6 fa ff ff 48 8b 8d 58 ff ff ff 48 85 c0 44 8b 8d 48 ff ff ff
> 0f 84 99 0c 00 00<3e> ff 80 98 01 00 00 8b 93 78 06 00 00 83 3d 87 83 b8 00 00 89
> RIP [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2 RSP<ffff8800367bfcb8>
> ---[ end trace ffe7d1c1af2c62f6 ]---
> BUG: sleeping function called from invalid context at /home/iisaman/projects/pnfs-file/src/linux-pnfs/kernel/rwsem.c
> :21
> in_atomic(): 1, irqs_disabled(): 1, pid: 834, name: rpc.idmapd
> INFO: lockdep is turned off.
> irq event stamp: 4308
> hardirqs last enabled at (4307): [<ffffffff81434d53>] __mutex_lock_common+0x37b/0x3af
> hardirqs last disabled at (4308): [<ffffffff81436c87>] _raw_spin_lock_irqsave+0x29/0x6a
> softirqs last enabled at (3992): [<ffffffff810378e3>] __do_softirq+0x1e6/0x205
> softirqs last disabled at (3783): [<ffffffff8143f92c>] call_softirq+0x1c/0x30
> Pid: 834, comm: rpc.idmapd Tainted: G D 3.3.0-rc2-kitchensink+ #51
> Call Trace:
> [<ffffffff81059bb7>] __might_sleep+0x107/0x10c
> [<ffffffff81435499>] down_read+0x24/0x61
> [<ffffffff810433e5>] exit_signals+0x26/0x12c
> [<ffffffff81053fdc>] ? blocking_notifier_call_chain+0x14/0x16
> [<ffffffff81034e53>] do_exit+0x118/0x7d9
> [<ffffffff81031cda>] ? kmsg_dump+0x126/0x144
> [<ffffffff81031c3c>] ? kmsg_dump+0x88/0x144
> [<ffffffff81438422>] oops_end+0xc0/0xc8
> [<ffffffff81004d96>] die+0x5a/0x63
> [<ffffffff81438272>] do_general_protection+0x12a/0x132
> [<ffffffff81437764>] ? restore_args+0x30/0x30
> [<ffffffff81437915>] general_protection+0x25/0x30
> [<ffffffff81079979>] ? __lock_acquire+0xd8/0xdd2
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d
> [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> note: rpc.idmapd[834] exited with preempt_count 1
> BUG: scheduling while atomic: rpc.idmapd/834/0x10000002
> INFO: lockdep is turned off.
>
> Signed-off-by: Fred Isaman<iisaman@netapp.com>
> ---
> fs/nfs/blocklayout/blocklayout.c | 1 -
> fs/nfs/idmap.c | 1 -
> net/sunrpc/auth_gss/auth_gss.c | 2 --
> net/sunrpc/rpc_pipe.c | 2 ++
> 4 files changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
> index 783ebd5..26fcbd1 100644
> --- a/fs/nfs/blocklayout/blocklayout.c
> +++ b/fs/nfs/blocklayout/blocklayout.c
> @@ -1134,7 +1134,6 @@ static void nfs4blocklayout_net_exit(struct net *net)
> struct nfs_net *nn = net_generic(net, nfs_net_id);
>
> nfs4blocklayout_unregister_net(net, nn->bl_device_pipe);
> - rpc_destroy_pipe_data(nn->bl_device_pipe);
> nn->bl_device_pipe = NULL;
> }
>
> diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c
> index b5c6d8e..384fbed 100644
> --- a/fs/nfs/idmap.c
> +++ b/fs/nfs/idmap.c
> @@ -508,7 +508,6 @@ nfs_idmap_delete(struct nfs_client *clp)
> if (!idmap)
> return;
> nfs_idmap_unregister(clp, idmap->idmap_pipe);
> - rpc_destroy_pipe_data(idmap->idmap_pipe);
> clp->cl_idmap = NULL;
> idmap_free_hashtable(&idmap->idmap_user_hash);
> idmap_free_hashtable(&idmap->idmap_group_hash);
> diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
> index cb2e564..6be27ec 100644
> --- a/net/sunrpc/auth_gss/auth_gss.c
> +++ b/net/sunrpc/auth_gss/auth_gss.c
> @@ -908,8 +908,6 @@ static void
> gss_free(struct gss_auth *gss_auth)
> {
> gss_pipes_dentries_destroy_net(gss_auth->client,&gss_auth->rpc_auth);
> - rpc_destroy_pipe_data(gss_auth->pipe[0]);
> - rpc_destroy_pipe_data(gss_auth->pipe[1]);
> gss_mech_put(gss_auth->mech);
>
> kfree(gss_auth);
> diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
> index 6873c9b..61ad698 100644
> --- a/net/sunrpc/rpc_pipe.c
> +++ b/net/sunrpc/rpc_pipe.c
> @@ -191,6 +191,8 @@ static void
> rpc_i_callback(struct rcu_head *head)
> {
> struct inode *inode = container_of(head, struct inode, i_rcu);
> + rpc_destroy_pipe_data(RPC_I(inode)->pipe);
> + RPC_I(inode)->pipe = NULL;
> kmem_cache_free(rpc_inode_cachep, RPC_I(inode));
> }
>
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-24 11:03 ` Stanislav Kinsbursky
@ 2012-02-24 13:11 ` Fred Isaman
0 siblings, 0 replies; 12+ messages in thread
From: Fred Isaman @ 2012-02-24 13:11 UTC (permalink / raw)
To: Stanislav Kinsbursky; +Cc: linux-nfs@vger.kernel.org
[-- Attachment #1: Type: text/plain, Size: 1819 bytes --]
On Feb 24, 2012, at 3:03 AM, Stanislav Kinsbursky wrote:
> 23.02.2012 21:48, Fred Isaman пишет:
>> This needs to be looked at closely by someone more familiar with the
>> pipe code.
>>
>> It fixes an issue with the current nfs_for_next branch which causes a
>> chain of oopses on umount every time if sufficient CONFIG_* debug
>> options are set.
>>
>> A git-bisect shows that the problem was introduced by
>> commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
>>
>
>
>
> NAK, the whole patch idea is bad.
> Currently, pipe data is created during NFS kernel part initialization, when PipeFS inode is created only on PipeFS mount and destroyed on PipeFS umount. And this creation/destruction has to have nothing with kernel pipes at all - these inodes are just a kind of front-end to kernel data.
> Please, provide exact CONFIG_* debug options for investigation.
>
>
I've attached my .config, which is run on a vmware fusion guest. I was testing on a fresh install of Fedora 16 with Trond's nfs-for-next kernel. Just doing a nfs4.1 mount/umount against any server with no intervening io causes the oops.
Below are some notes I took while investigating:
with the recent nfs-for-next code, umount always oopses (if CONFIG_PROVE_LOCKING is set?). (Note this is using the old idmapper, which is the default Fedora 16 configuration)
This behavior starts with commit e6499c6f NFS: Fall back on old idmapper if request_key() fails, which removes the CONFIG_NFS_USE_NEW_IDMAPPER option.
Prior to this, it works correctly if the option is set, but has the same bad behavior if clear.
commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
is the commit that actually introduces the bad behavior.
Fred
[-- Attachment #2: FUSION64-FED16 --]
[-- Type: application/octet-stream, Size: 59179 bytes --]
#
# Automatically generated file; DO NOT EDIT.
# Linux/x86_64 3.3.0-rc2 Kernel Configuration
#
CONFIG_64BIT=y
# CONFIG_X86_32 is not set
CONFIG_X86_64=y
CONFIG_X86=y
CONFIG_INSTRUCTION_DECODER=y
CONFIG_OUTPUT_FORMAT="elf64-x86-64"
CONFIG_ARCH_DEFCONFIG="arch/x86/configs/x86_64_defconfig"
CONFIG_GENERIC_CMOS_UPDATE=y
CONFIG_CLOCKSOURCE_WATCHDOG=y
CONFIG_GENERIC_CLOCKEVENTS=y
CONFIG_ARCH_CLOCKSOURCE_DATA=y
CONFIG_GENERIC_CLOCKEVENTS_BROADCAST=y
CONFIG_LOCKDEP_SUPPORT=y
CONFIG_STACKTRACE_SUPPORT=y
CONFIG_HAVE_LATENCYTOP_SUPPORT=y
CONFIG_MMU=y
CONFIG_NEED_DMA_MAP_STATE=y
CONFIG_NEED_SG_DMA_LENGTH=y
CONFIG_GENERIC_ISA_DMA=y
CONFIG_GENERIC_BUG=y
CONFIG_GENERIC_BUG_RELATIVE_POINTERS=y
CONFIG_GENERIC_HWEIGHT=y
CONFIG_ARCH_MAY_HAVE_PC_FDC=y
# CONFIG_RWSEM_GENERIC_SPINLOCK is not set
CONFIG_RWSEM_XCHGADD_ALGORITHM=y
CONFIG_ARCH_HAS_CPU_IDLE_WAIT=y
CONFIG_GENERIC_CALIBRATE_DELAY=y
CONFIG_GENERIC_TIME_VSYSCALL=y
CONFIG_ARCH_HAS_CPU_RELAX=y
CONFIG_ARCH_HAS_DEFAULT_IDLE=y
CONFIG_ARCH_HAS_CACHE_LINE_SIZE=y
CONFIG_HAVE_SETUP_PER_CPU_AREA=y
CONFIG_NEED_PER_CPU_EMBED_FIRST_CHUNK=y
CONFIG_NEED_PER_CPU_PAGE_FIRST_CHUNK=y
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
CONFIG_ARCH_SUSPEND_POSSIBLE=y
CONFIG_ZONE_DMA32=y
CONFIG_AUDIT_ARCH=y
CONFIG_ARCH_SUPPORTS_OPTIMIZED_INLINING=y
CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y
CONFIG_X86_64_SMP=y
CONFIG_X86_HT=y
CONFIG_ARCH_HWEIGHT_CFLAGS="-fcall-saved-rdi -fcall-saved-rsi -fcall-saved-rdx -fcall-saved-rcx -fcall-saved-r8 -fcall-saved-r9 -fcall-saved-r10 -fcall-saved-r11"
# CONFIG_KTIME_SCALAR is not set
CONFIG_ARCH_CPU_PROBE_RELEASE=y
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
CONFIG_HAVE_IRQ_WORK=y
CONFIG_IRQ_WORK=y
#
# General setup
#
CONFIG_EXPERIMENTAL=y
CONFIG_INIT_ENV_ARG_LIMIT=32
CONFIG_CROSS_COMPILE=""
CONFIG_LOCALVERSION="-kitchensink"
# CONFIG_LOCALVERSION_AUTO is not set
CONFIG_HAVE_KERNEL_GZIP=y
CONFIG_HAVE_KERNEL_BZIP2=y
CONFIG_HAVE_KERNEL_LZMA=y
CONFIG_HAVE_KERNEL_XZ=y
CONFIG_HAVE_KERNEL_LZO=y
CONFIG_KERNEL_GZIP=y
# CONFIG_KERNEL_BZIP2 is not set
# CONFIG_KERNEL_LZMA is not set
# CONFIG_KERNEL_XZ is not set
# CONFIG_KERNEL_LZO is not set
CONFIG_DEFAULT_HOSTNAME="(none)"
CONFIG_SWAP=y
CONFIG_SYSVIPC=y
CONFIG_SYSVIPC_SYSCTL=y
CONFIG_POSIX_MQUEUE=y
CONFIG_POSIX_MQUEUE_SYSCTL=y
CONFIG_BSD_PROCESS_ACCT=y
# CONFIG_BSD_PROCESS_ACCT_V3 is not set
# CONFIG_FHANDLE is not set
CONFIG_TASKSTATS=y
CONFIG_TASK_DELAY_ACCT=y
CONFIG_TASK_XACCT=y
CONFIG_TASK_IO_ACCOUNTING=y
CONFIG_AUDIT=y
CONFIG_AUDITSYSCALL=y
CONFIG_AUDIT_WATCH=y
CONFIG_AUDIT_TREE=y
# CONFIG_AUDIT_LOGINUID_IMMUTABLE is not set
CONFIG_HAVE_GENERIC_HARDIRQS=y
#
# IRQ subsystem
#
CONFIG_GENERIC_HARDIRQS=y
CONFIG_HAVE_SPARSE_IRQ=y
CONFIG_GENERIC_IRQ_PROBE=y
CONFIG_GENERIC_IRQ_SHOW=y
CONFIG_GENERIC_PENDING_IRQ=y
CONFIG_IRQ_FORCED_THREADING=y
CONFIG_SPARSE_IRQ=y
#
# RCU Subsystem
#
CONFIG_TREE_RCU=y
# CONFIG_PREEMPT_RCU is not set
# CONFIG_RCU_TRACE is not set
CONFIG_RCU_FANOUT=64
# CONFIG_RCU_FANOUT_EXACT is not set
# CONFIG_RCU_FAST_NO_HZ is not set
# CONFIG_TREE_RCU_TRACE is not set
# CONFIG_IKCONFIG is not set
CONFIG_LOG_BUF_SHIFT=17
CONFIG_HAVE_UNSTABLE_SCHED_CLOCK=y
CONFIG_CGROUPS=y
# CONFIG_CGROUP_DEBUG is not set
CONFIG_CGROUP_FREEZER=y
CONFIG_CGROUP_DEVICE=y
CONFIG_CPUSETS=y
CONFIG_PROC_PID_CPUSET=y
# CONFIG_CGROUP_CPUACCT is not set
CONFIG_RESOURCE_COUNTERS=y
# CONFIG_CGROUP_MEM_RES_CTLR is not set
# CONFIG_CGROUP_PERF is not set
# CONFIG_CGROUP_SCHED is not set
CONFIG_BLK_CGROUP=y
# CONFIG_DEBUG_BLK_CGROUP is not set
# CONFIG_CHECKPOINT_RESTORE is not set
CONFIG_NAMESPACES=y
CONFIG_UTS_NS=y
CONFIG_IPC_NS=y
CONFIG_USER_NS=y
CONFIG_PID_NS=y
CONFIG_NET_NS=y
# CONFIG_SCHED_AUTOGROUP is not set
# CONFIG_SYSFS_DEPRECATED is not set
CONFIG_RELAY=y
CONFIG_BLK_DEV_INITRD=y
CONFIG_INITRAMFS_SOURCE=""
CONFIG_RD_GZIP=y
CONFIG_RD_BZIP2=y
CONFIG_RD_LZMA=y
CONFIG_RD_XZ=y
CONFIG_RD_LZO=y
CONFIG_CC_OPTIMIZE_FOR_SIZE=y
CONFIG_SYSCTL=y
CONFIG_ANON_INODES=y
# CONFIG_EXPERT is not set
CONFIG_UID16=y
# CONFIG_SYSCTL_SYSCALL is not set
CONFIG_KALLSYMS=y
CONFIG_KALLSYMS_ALL=y
CONFIG_HOTPLUG=y
CONFIG_PRINTK=y
CONFIG_BUG=y
CONFIG_ELF_CORE=y
CONFIG_PCSPKR_PLATFORM=y
CONFIG_HAVE_PCSPKR_PLATFORM=y
CONFIG_BASE_FULL=y
CONFIG_FUTEX=y
CONFIG_EPOLL=y
CONFIG_SIGNALFD=y
CONFIG_TIMERFD=y
CONFIG_EVENTFD=y
CONFIG_SHMEM=y
CONFIG_AIO=y
# CONFIG_EMBEDDED is not set
CONFIG_HAVE_PERF_EVENTS=y
#
# Kernel Performance Events And Counters
#
CONFIG_PERF_EVENTS=y
# CONFIG_PERF_COUNTERS is not set
# CONFIG_DEBUG_PERF_USE_VMALLOC is not set
CONFIG_VM_EVENT_COUNTERS=y
CONFIG_PCI_QUIRKS=y
CONFIG_SLUB_DEBUG=y
# CONFIG_COMPAT_BRK is not set
# CONFIG_SLAB is not set
CONFIG_SLUB=y
CONFIG_PROFILING=y
CONFIG_TRACEPOINTS=y
CONFIG_OPROFILE=m
CONFIG_OPROFILE_EVENT_MULTIPLEX=y
CONFIG_HAVE_OPROFILE=y
CONFIG_OPROFILE_NMI_TIMER=y
CONFIG_KPROBES=y
# CONFIG_JUMP_LABEL is not set
CONFIG_OPTPROBES=y
CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS=y
CONFIG_KRETPROBES=y
CONFIG_HAVE_IOREMAP_PROT=y
CONFIG_HAVE_KPROBES=y
CONFIG_HAVE_KRETPROBES=y
CONFIG_HAVE_OPTPROBES=y
CONFIG_HAVE_ARCH_TRACEHOOK=y
CONFIG_HAVE_DMA_ATTRS=y
CONFIG_USE_GENERIC_SMP_HELPERS=y
CONFIG_HAVE_REGS_AND_STACK_ACCESS_API=y
CONFIG_HAVE_DMA_API_DEBUG=y
CONFIG_HAVE_HW_BREAKPOINT=y
CONFIG_HAVE_MIXED_BREAKPOINTS_REGS=y
CONFIG_HAVE_USER_RETURN_NOTIFIER=y
CONFIG_HAVE_PERF_EVENTS_NMI=y
CONFIG_HAVE_ARCH_JUMP_LABEL=y
CONFIG_ARCH_HAVE_NMI_SAFE_CMPXCHG=y
CONFIG_HAVE_ALIGNED_STRUCT_PAGE=y
CONFIG_HAVE_CMPXCHG_LOCAL=y
CONFIG_HAVE_CMPXCHG_DOUBLE=y
#
# GCOV-based kernel profiling
#
# CONFIG_GCOV_KERNEL is not set
# CONFIG_HAVE_GENERIC_DMA_COHERENT is not set
CONFIG_SLABINFO=y
CONFIG_RT_MUTEXES=y
CONFIG_BASE_SMALL=0
CONFIG_MODULES=y
# CONFIG_MODULE_FORCE_LOAD is not set
CONFIG_MODULE_UNLOAD=y
# CONFIG_MODULE_FORCE_UNLOAD is not set
# CONFIG_MODVERSIONS is not set
CONFIG_MODULE_SRCVERSION_ALL=y
CONFIG_STOP_MACHINE=y
CONFIG_BLOCK=y
CONFIG_BLK_DEV_BSG=y
CONFIG_BLK_DEV_BSGLIB=y
CONFIG_BLK_DEV_INTEGRITY=y
# CONFIG_BLK_DEV_THROTTLING is not set
#
# Partition Types
#
CONFIG_PARTITION_ADVANCED=y
# CONFIG_ACORN_PARTITION is not set
# CONFIG_OSF_PARTITION is not set
# CONFIG_AMIGA_PARTITION is not set
# CONFIG_ATARI_PARTITION is not set
CONFIG_MAC_PARTITION=y
CONFIG_MSDOS_PARTITION=y
CONFIG_BSD_DISKLABEL=y
CONFIG_MINIX_SUBPARTITION=y
CONFIG_SOLARIS_X86_PARTITION=y
CONFIG_UNIXWARE_DISKLABEL=y
# CONFIG_LDM_PARTITION is not set
# CONFIG_SGI_PARTITION is not set
# CONFIG_ULTRIX_PARTITION is not set
# CONFIG_SUN_PARTITION is not set
# CONFIG_KARMA_PARTITION is not set
CONFIG_EFI_PARTITION=y
# CONFIG_SYSV68_PARTITION is not set
CONFIG_BLOCK_COMPAT=y
#
# IO Schedulers
#
CONFIG_IOSCHED_NOOP=y
CONFIG_IOSCHED_DEADLINE=y
CONFIG_IOSCHED_CFQ=y
# CONFIG_CFQ_GROUP_IOSCHED is not set
# CONFIG_DEFAULT_DEADLINE is not set
CONFIG_DEFAULT_CFQ=y
# CONFIG_DEFAULT_NOOP is not set
CONFIG_DEFAULT_IOSCHED="cfq"
# CONFIG_INLINE_SPIN_TRYLOCK is not set
# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
# CONFIG_INLINE_SPIN_LOCK is not set
# CONFIG_INLINE_SPIN_LOCK_BH is not set
# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
# CONFIG_INLINE_SPIN_UNLOCK is not set
# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
# CONFIG_INLINE_SPIN_UNLOCK_IRQ is not set
# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
# CONFIG_INLINE_READ_TRYLOCK is not set
# CONFIG_INLINE_READ_LOCK is not set
# CONFIG_INLINE_READ_LOCK_BH is not set
# CONFIG_INLINE_READ_LOCK_IRQ is not set
# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
# CONFIG_INLINE_READ_UNLOCK is not set
# CONFIG_INLINE_READ_UNLOCK_BH is not set
# CONFIG_INLINE_READ_UNLOCK_IRQ is not set
# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
# CONFIG_INLINE_WRITE_TRYLOCK is not set
# CONFIG_INLINE_WRITE_LOCK is not set
# CONFIG_INLINE_WRITE_LOCK_BH is not set
# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
# CONFIG_INLINE_WRITE_UNLOCK is not set
# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
# CONFIG_INLINE_WRITE_UNLOCK_IRQ is not set
# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
# CONFIG_MUTEX_SPIN_ON_OWNER is not set
CONFIG_FREEZER=y
#
# Processor type and features
#
CONFIG_ZONE_DMA=y
CONFIG_TICK_ONESHOT=y
CONFIG_NO_HZ=y
CONFIG_HIGH_RES_TIMERS=y
CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
CONFIG_GENERIC_CLOCKEVENTS_MIN_ADJUST=y
CONFIG_SMP=y
CONFIG_X86_MPPARSE=y
# CONFIG_X86_EXTENDED_PLATFORM is not set
CONFIG_X86_SUPPORTS_MEMORY_FAILURE=y
CONFIG_SCHED_OMIT_FRAME_POINTER=y
CONFIG_PARAVIRT_GUEST=y
# CONFIG_PARAVIRT_TIME_ACCOUNTING is not set
# CONFIG_XEN is not set
# CONFIG_XEN_PRIVILEGED_GUEST is not set
# CONFIG_KVM_CLOCK is not set
# CONFIG_KVM_GUEST is not set
CONFIG_PARAVIRT=y
# CONFIG_PARAVIRT_SPINLOCKS is not set
# CONFIG_PARAVIRT_DEBUG is not set
CONFIG_NO_BOOTMEM=y
# CONFIG_MEMTEST is not set
# CONFIG_MK8 is not set
# CONFIG_MPSC is not set
CONFIG_MCORE2=y
# CONFIG_MATOM is not set
# CONFIG_GENERIC_CPU is not set
CONFIG_X86_INTERNODE_CACHE_SHIFT=7
CONFIG_X86_CMPXCHG=y
CONFIG_X86_L1_CACHE_SHIFT=6
CONFIG_X86_XADD=y
CONFIG_X86_WP_WORKS_OK=y
CONFIG_X86_INTEL_USERCOPY=y
CONFIG_X86_USE_PPRO_CHECKSUM=y
CONFIG_X86_P6_NOP=y
CONFIG_X86_TSC=y
CONFIG_X86_CMPXCHG64=y
CONFIG_X86_CMOV=y
CONFIG_X86_MINIMUM_CPU_FAMILY=64
CONFIG_X86_DEBUGCTLMSR=y
CONFIG_CPU_SUP_INTEL=y
CONFIG_CPU_SUP_AMD=y
CONFIG_CPU_SUP_CENTAUR=y
CONFIG_HPET_TIMER=y
CONFIG_HPET_EMULATE_RTC=y
CONFIG_DMI=y
CONFIG_GART_IOMMU=y
CONFIG_CALGARY_IOMMU=y
CONFIG_CALGARY_IOMMU_ENABLED_BY_DEFAULT=y
CONFIG_SWIOTLB=y
CONFIG_IOMMU_HELPER=y
# CONFIG_MAXSMP is not set
CONFIG_NR_CPUS=256
CONFIG_SCHED_SMT=y
CONFIG_SCHED_MC=y
# CONFIG_IRQ_TIME_ACCOUNTING is not set
# CONFIG_PREEMPT_NONE is not set
CONFIG_PREEMPT_VOLUNTARY=y
# CONFIG_PREEMPT is not set
CONFIG_PREEMPT_COUNT=y
CONFIG_X86_LOCAL_APIC=y
CONFIG_X86_IO_APIC=y
CONFIG_X86_REROUTE_FOR_BROKEN_BOOT_IRQS=y
CONFIG_X86_MCE=y
CONFIG_X86_MCE_INTEL=y
CONFIG_X86_MCE_AMD=y
CONFIG_X86_MCE_THRESHOLD=y
# CONFIG_X86_MCE_INJECT is not set
CONFIG_X86_THERMAL_VECTOR=y
# CONFIG_I8K is not set
CONFIG_MICROCODE=y
CONFIG_MICROCODE_INTEL=y
# CONFIG_MICROCODE_AMD is not set
CONFIG_MICROCODE_OLD_INTERFACE=y
CONFIG_X86_MSR=y
CONFIG_X86_CPUID=y
CONFIG_ARCH_PHYS_ADDR_T_64BIT=y
CONFIG_ARCH_DMA_ADDR_T_64BIT=y
CONFIG_DIRECT_GBPAGES=y
CONFIG_NUMA=y
CONFIG_AMD_NUMA=y
CONFIG_X86_64_ACPI_NUMA=y
CONFIG_NODES_SPAN_OTHER_NODES=y
# CONFIG_NUMA_EMU is not set
CONFIG_NODES_SHIFT=9
CONFIG_ARCH_SPARSEMEM_ENABLE=y
CONFIG_ARCH_SPARSEMEM_DEFAULT=y
CONFIG_ARCH_SELECT_MEMORY_MODEL=y
CONFIG_ARCH_PROC_KCORE_TEXT=y
CONFIG_ILLEGAL_POINTER_VALUE=0xdead000000000000
CONFIG_SELECT_MEMORY_MODEL=y
CONFIG_SPARSEMEM_MANUAL=y
CONFIG_SPARSEMEM=y
CONFIG_NEED_MULTIPLE_NODES=y
CONFIG_HAVE_MEMORY_PRESENT=y
CONFIG_SPARSEMEM_EXTREME=y
CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y
CONFIG_SPARSEMEM_ALLOC_MEM_MAP_TOGETHER=y
CONFIG_SPARSEMEM_VMEMMAP=y
CONFIG_HAVE_MEMBLOCK=y
CONFIG_HAVE_MEMBLOCK_NODE_MAP=y
CONFIG_ARCH_DISCARD_MEMBLOCK=y
# CONFIG_MEMORY_HOTPLUG is not set
CONFIG_PAGEFLAGS_EXTENDED=y
CONFIG_SPLIT_PTLOCK_CPUS=999999
# CONFIG_COMPACTION is not set
CONFIG_MIGRATION=y
CONFIG_PHYS_ADDR_T_64BIT=y
CONFIG_ZONE_DMA_FLAG=1
CONFIG_BOUNCE=y
CONFIG_VIRT_TO_BUS=y
CONFIG_KSM=y
CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
CONFIG_ARCH_SUPPORTS_MEMORY_FAILURE=y
CONFIG_MEMORY_FAILURE=y
CONFIG_HWPOISON_INJECT=m
# CONFIG_TRANSPARENT_HUGEPAGE is not set
# CONFIG_CLEANCACHE is not set
# CONFIG_X86_CHECK_BIOS_CORRUPTION is not set
CONFIG_X86_RESERVE_LOW=64
CONFIG_MTRR=y
CONFIG_MTRR_SANITIZER=y
CONFIG_MTRR_SANITIZER_ENABLE_DEFAULT=1
CONFIG_MTRR_SANITIZER_SPARE_REG_NR_DEFAULT=1
CONFIG_X86_PAT=y
CONFIG_ARCH_USES_PG_UNCACHED=y
CONFIG_ARCH_RANDOM=y
CONFIG_EFI=y
# CONFIG_EFI_STUB is not set
CONFIG_SECCOMP=y
CONFIG_CC_STACKPROTECTOR=y
# CONFIG_HZ_100 is not set
# CONFIG_HZ_250 is not set
# CONFIG_HZ_300 is not set
CONFIG_HZ_1000=y
CONFIG_HZ=1000
CONFIG_SCHED_HRTICK=y
CONFIG_KEXEC=y
CONFIG_CRASH_DUMP=y
CONFIG_KEXEC_JUMP=y
CONFIG_PHYSICAL_START=0x1000000
CONFIG_RELOCATABLE=y
CONFIG_PHYSICAL_ALIGN=0x1000000
CONFIG_HOTPLUG_CPU=y
# CONFIG_COMPAT_VDSO is not set
# CONFIG_CMDLINE_BOOL is not set
CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y
CONFIG_USE_PERCPU_NUMA_NODE_ID=y
#
# Power management and ACPI options
#
CONFIG_ARCH_HIBERNATION_HEADER=y
# CONFIG_SUSPEND is not set
CONFIG_HIBERNATE_CALLBACKS=y
CONFIG_HIBERNATION=y
CONFIG_PM_STD_PARTITION=""
CONFIG_PM_SLEEP=y
CONFIG_PM_SLEEP_SMP=y
CONFIG_PM_RUNTIME=y
CONFIG_PM=y
# CONFIG_PM_DEBUG is not set
CONFIG_ACPI=y
CONFIG_ACPI_SLEEP=y
CONFIG_ACPI_PROCFS=y
CONFIG_ACPI_PROCFS_POWER=y
# CONFIG_ACPI_EC_DEBUGFS is not set
CONFIG_ACPI_PROC_EVENT=y
CONFIG_ACPI_AC=y
CONFIG_ACPI_BATTERY=y
CONFIG_ACPI_BUTTON=y
CONFIG_ACPI_FAN=y
CONFIG_ACPI_DOCK=y
CONFIG_ACPI_PROCESSOR=y
CONFIG_ACPI_HOTPLUG_CPU=y
CONFIG_ACPI_PROCESSOR_AGGREGATOR=m
CONFIG_ACPI_THERMAL=y
CONFIG_ACPI_NUMA=y
# CONFIG_ACPI_CUSTOM_DSDT is not set
CONFIG_ACPI_BLACKLIST_YEAR=0
# CONFIG_ACPI_DEBUG is not set
CONFIG_ACPI_PCI_SLOT=y
CONFIG_X86_PM_TIMER=y
CONFIG_ACPI_CONTAINER=y
CONFIG_ACPI_SBS=m
# CONFIG_ACPI_HED is not set
# CONFIG_ACPI_CUSTOM_METHOD is not set
# CONFIG_ACPI_APEI is not set
CONFIG_SFI=y
#
# CPU Frequency scaling
#
CONFIG_CPU_FREQ=y
CONFIG_CPU_FREQ_TABLE=m
CONFIG_CPU_FREQ_STAT=m
CONFIG_CPU_FREQ_STAT_DETAILS=y
# CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE is not set
CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE=y
# CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set
# CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set
CONFIG_CPU_FREQ_GOV_PERFORMANCE=y
CONFIG_CPU_FREQ_GOV_POWERSAVE=m
CONFIG_CPU_FREQ_GOV_USERSPACE=y
CONFIG_CPU_FREQ_GOV_ONDEMAND=m
CONFIG_CPU_FREQ_GOV_CONSERVATIVE=m
#
# x86 CPU frequency scaling drivers
#
# CONFIG_X86_PCC_CPUFREQ is not set
CONFIG_X86_ACPI_CPUFREQ=m
CONFIG_X86_POWERNOW_K8=m
# CONFIG_X86_SPEEDSTEP_CENTRINO is not set
CONFIG_X86_P4_CLOCKMOD=m
#
# shared options
#
CONFIG_X86_SPEEDSTEP_LIB=m
CONFIG_CPU_IDLE=y
CONFIG_CPU_IDLE_GOV_LADDER=y
CONFIG_CPU_IDLE_GOV_MENU=y
# CONFIG_INTEL_IDLE is not set
#
# Memory power savings
#
# CONFIG_I7300_IDLE is not set
#
# Bus options (PCI etc.)
#
CONFIG_PCI=y
CONFIG_PCI_DIRECT=y
CONFIG_PCI_MMCONFIG=y
CONFIG_PCI_DOMAINS=y
# CONFIG_PCI_CNB20LE_QUIRK is not set
CONFIG_PCIEPORTBUS=y
CONFIG_HOTPLUG_PCI_PCIE=y
CONFIG_PCIEAER=y
CONFIG_PCIE_ECRC=y
CONFIG_PCIEAER_INJECT=m
CONFIG_PCIEASPM=y
# CONFIG_PCIEASPM_DEBUG is not set
CONFIG_PCIE_PME=y
CONFIG_ARCH_SUPPORTS_MSI=y
CONFIG_PCI_MSI=y
# CONFIG_PCI_DEBUG is not set
CONFIG_PCI_STUB=y
CONFIG_HT_IRQ=y
CONFIG_PCI_ATS=y
CONFIG_PCI_IOV=y
CONFIG_PCI_PRI=y
CONFIG_PCI_PASID=y
CONFIG_PCI_IOAPIC=y
CONFIG_PCI_LABEL=y
CONFIG_ISA_DMA_API=y
CONFIG_AMD_NB=y
# CONFIG_PCCARD is not set
CONFIG_HOTPLUG_PCI=y
CONFIG_HOTPLUG_PCI_FAKE=m
CONFIG_HOTPLUG_PCI_ACPI=y
CONFIG_HOTPLUG_PCI_ACPI_IBM=m
# CONFIG_HOTPLUG_PCI_CPCI is not set
CONFIG_HOTPLUG_PCI_SHPC=m
# CONFIG_RAPIDIO is not set
#
# Executable file formats / Emulations
#
CONFIG_BINFMT_ELF=y
CONFIG_COMPAT_BINFMT_ELF=y
CONFIG_ARCH_BINFMT_ELF_RANDOMIZE_PIE=y
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
# CONFIG_HAVE_AOUT is not set
CONFIG_BINFMT_MISC=y
CONFIG_IA32_EMULATION=y
# CONFIG_IA32_AOUT is not set
CONFIG_COMPAT=y
CONFIG_COMPAT_FOR_U64_ALIGNMENT=y
CONFIG_SYSVIPC_COMPAT=y
CONFIG_KEYS_COMPAT=y
CONFIG_HAVE_TEXT_POKE_SMP=y
CONFIG_NET=y
#
# Networking options
#
CONFIG_PACKET=y
CONFIG_UNIX=y
# CONFIG_UNIX_DIAG is not set
CONFIG_XFRM=y
CONFIG_XFRM_USER=y
# CONFIG_XFRM_SUB_POLICY is not set
CONFIG_XFRM_MIGRATE=y
# CONFIG_XFRM_STATISTICS is not set
CONFIG_XFRM_IPCOMP=m
CONFIG_NET_KEY=m
CONFIG_NET_KEY_MIGRATE=y
CONFIG_INET=y
# CONFIG_IP_MULTICAST is not set
# CONFIG_IP_ADVANCED_ROUTER is not set
# CONFIG_IP_PNP is not set
# CONFIG_NET_IPIP is not set
# CONFIG_NET_IPGRE_DEMUX is not set
# CONFIG_ARPD is not set
# CONFIG_SYN_COOKIES is not set
CONFIG_INET_AH=m
CONFIG_INET_ESP=m
CONFIG_INET_IPCOMP=m
CONFIG_INET_XFRM_TUNNEL=m
CONFIG_INET_TUNNEL=m
CONFIG_INET_XFRM_MODE_TRANSPORT=m
CONFIG_INET_XFRM_MODE_TUNNEL=m
CONFIG_INET_XFRM_MODE_BEET=m
CONFIG_INET_LRO=y
CONFIG_INET_DIAG=m
CONFIG_INET_TCP_DIAG=m
# CONFIG_INET_UDP_DIAG is not set
# CONFIG_TCP_CONG_ADVANCED is not set
CONFIG_TCP_CONG_CUBIC=y
CONFIG_DEFAULT_TCP_CONG="cubic"
# CONFIG_TCP_MD5SIG is not set
# CONFIG_IPV6 is not set
# CONFIG_NETLABEL is not set
# CONFIG_NETWORK_SECMARK is not set
# CONFIG_NETWORK_PHY_TIMESTAMPING is not set
CONFIG_NETFILTER=y
# CONFIG_NETFILTER_DEBUG is not set
# CONFIG_NETFILTER_ADVANCED is not set
#
# Core Netfilter Configuration
#
CONFIG_NETFILTER_NETLINK=m
CONFIG_NETFILTER_NETLINK_LOG=m
CONFIG_NF_CONNTRACK=y
CONFIG_NF_CONNTRACK_PROCFS=y
# CONFIG_NF_CONNTRACK_FTP is not set
# CONFIG_NF_CONNTRACK_IRC is not set
# CONFIG_NF_CONNTRACK_NETBIOS_NS is not set
# CONFIG_NF_CONNTRACK_SIP is not set
CONFIG_NF_CT_NETLINK=m
CONFIG_NETFILTER_XTABLES=y
#
# Xtables combined modules
#
# CONFIG_NETFILTER_XT_MARK is not set
#
# Xtables targets
#
CONFIG_NETFILTER_XT_TARGET_NFLOG=m
CONFIG_NETFILTER_XT_TARGET_TCPMSS=m
#
# Xtables matches
#
CONFIG_NETFILTER_XT_MATCH_CONNTRACK=y
CONFIG_NETFILTER_XT_MATCH_POLICY=m
CONFIG_NETFILTER_XT_MATCH_STATE=y
# CONFIG_IP_SET is not set
# CONFIG_IP_VS is not set
#
# IP: Netfilter Configuration
#
CONFIG_NF_DEFRAG_IPV4=y
CONFIG_NF_CONNTRACK_IPV4=y
# CONFIG_NF_CONNTRACK_PROC_COMPAT is not set
CONFIG_IP_NF_IPTABLES=y
CONFIG_IP_NF_FILTER=y
CONFIG_IP_NF_TARGET_REJECT=y
CONFIG_IP_NF_TARGET_LOG=m
CONFIG_IP_NF_TARGET_ULOG=m
CONFIG_NF_NAT=m
CONFIG_NF_NAT_NEEDED=y
CONFIG_IP_NF_TARGET_MASQUERADE=m
# CONFIG_NF_NAT_FTP is not set
# CONFIG_NF_NAT_IRC is not set
# CONFIG_NF_NAT_TFTP is not set
# CONFIG_NF_NAT_AMANDA is not set
# CONFIG_NF_NAT_PPTP is not set
# CONFIG_NF_NAT_H323 is not set
# CONFIG_NF_NAT_SIP is not set
CONFIG_IP_NF_MANGLE=m
# CONFIG_IP_NF_RAW is not set
# CONFIG_IP_DCCP is not set
CONFIG_IP_SCTP=m
# CONFIG_NET_SCTPPROBE is not set
# CONFIG_SCTP_DBG_MSG is not set
# CONFIG_SCTP_DBG_OBJCNT is not set
# CONFIG_SCTP_HMAC_NONE is not set
CONFIG_SCTP_HMAC_SHA1=y
# CONFIG_SCTP_HMAC_MD5 is not set
# CONFIG_RDS is not set
# CONFIG_TIPC is not set
# CONFIG_ATM is not set
# CONFIG_L2TP is not set
# CONFIG_BRIDGE is not set
# CONFIG_NET_DSA is not set
# CONFIG_VLAN_8021Q is not set
# CONFIG_DECNET is not set
# CONFIG_LLC2 is not set
# CONFIG_IPX is not set
# CONFIG_ATALK is not set
# CONFIG_X25 is not set
# CONFIG_LAPB is not set
# CONFIG_ECONET is not set
# CONFIG_WAN_ROUTER is not set
# CONFIG_PHONET is not set
# CONFIG_IEEE802154 is not set
# CONFIG_NET_SCHED is not set
# CONFIG_DCB is not set
CONFIG_DNS_RESOLVER=y
# CONFIG_BATMAN_ADV is not set
# CONFIG_OPENVSWITCH is not set
CONFIG_RPS=y
CONFIG_RFS_ACCEL=y
CONFIG_XPS=y
# CONFIG_NETPRIO_CGROUP is not set
CONFIG_BQL=y
CONFIG_HAVE_BPF_JIT=y
# CONFIG_BPF_JIT is not set
#
# Network testing
#
CONFIG_NET_PKTGEN=m
# CONFIG_NET_TCPPROBE is not set
CONFIG_NET_DROP_MONITOR=y
# CONFIG_HAMRADIO is not set
# CONFIG_CAN is not set
# CONFIG_IRDA is not set
# CONFIG_BT is not set
# CONFIG_AF_RXRPC is not set
# CONFIG_WIRELESS is not set
# CONFIG_WIMAX is not set
# CONFIG_RFKILL is not set
# CONFIG_NET_9P is not set
# CONFIG_CAIF is not set
# CONFIG_CEPH_LIB is not set
# CONFIG_NFC is not set
#
# Device Drivers
#
#
# Generic Driver Options
#
CONFIG_UEVENT_HELPER_PATH=""
CONFIG_DEVTMPFS=y
CONFIG_DEVTMPFS_MOUNT=y
CONFIG_STANDALONE=y
CONFIG_PREVENT_FIRMWARE_BUILD=y
CONFIG_FW_LOADER=y
# CONFIG_FIRMWARE_IN_KERNEL is not set
CONFIG_EXTRA_FIRMWARE=""
# CONFIG_DEBUG_DRIVER is not set
CONFIG_DEBUG_DEVRES=y
# CONFIG_SYS_HYPERVISOR is not set
# CONFIG_GENERIC_CPU_DEVICES is not set
# CONFIG_DMA_SHARED_BUFFER is not set
CONFIG_CONNECTOR=y
CONFIG_PROC_EVENTS=y
# CONFIG_MTD is not set
CONFIG_PARPORT=m
CONFIG_PARPORT_PC=m
CONFIG_PARPORT_SERIAL=m
# CONFIG_PARPORT_PC_FIFO is not set
# CONFIG_PARPORT_PC_SUPERIO is not set
# CONFIG_PARPORT_GSC is not set
# CONFIG_PARPORT_AX88796 is not set
CONFIG_PARPORT_1284=y
CONFIG_PNP=y
# CONFIG_PNP_DEBUG_MESSAGES is not set
#
# Protocols
#
CONFIG_PNPACPI=y
CONFIG_BLK_DEV=y
CONFIG_BLK_DEV_FD=m
# CONFIG_PARIDE is not set
# CONFIG_BLK_DEV_PCIESSD_MTIP32XX is not set
# CONFIG_BLK_CPQ_DA is not set
# CONFIG_BLK_CPQ_CISS_DA is not set
# CONFIG_BLK_DEV_DAC960 is not set
# CONFIG_BLK_DEV_UMEM is not set
# CONFIG_BLK_DEV_COW_COMMON is not set
CONFIG_BLK_DEV_LOOP=y
CONFIG_BLK_DEV_LOOP_MIN_COUNT=8
CONFIG_BLK_DEV_CRYPTOLOOP=m
# CONFIG_BLK_DEV_DRBD is not set
CONFIG_BLK_DEV_NBD=m
# CONFIG_BLK_DEV_NVME is not set
CONFIG_BLK_DEV_OSD=m
# CONFIG_BLK_DEV_SX8 is not set
# CONFIG_BLK_DEV_UB is not set
CONFIG_BLK_DEV_RAM=y
CONFIG_BLK_DEV_RAM_COUNT=16
CONFIG_BLK_DEV_RAM_SIZE=16384
# CONFIG_BLK_DEV_XIP is not set
CONFIG_CDROM_PKTCDVD=m
CONFIG_CDROM_PKTCDVD_BUFFERS=8
# CONFIG_CDROM_PKTCDVD_WCACHE is not set
# CONFIG_ATA_OVER_ETH is not set
# CONFIG_BLK_DEV_HD is not set
# CONFIG_BLK_DEV_RBD is not set
# CONFIG_SENSORS_LIS3LV02D is not set
# CONFIG_MISC_DEVICES is not set
CONFIG_HAVE_IDE=y
# CONFIG_IDE is not set
#
# SCSI device support
#
CONFIG_SCSI_MOD=y
CONFIG_RAID_ATTRS=m
CONFIG_SCSI=y
CONFIG_SCSI_DMA=y
CONFIG_SCSI_TGT=m
# CONFIG_SCSI_NETLINK is not set
CONFIG_SCSI_PROC_FS=y
#
# SCSI support type (disk, tape, CD-ROM)
#
CONFIG_BLK_DEV_SD=y
# CONFIG_CHR_DEV_ST is not set
# CONFIG_CHR_DEV_OSST is not set
CONFIG_BLK_DEV_SR=y
CONFIG_BLK_DEV_SR_VENDOR=y
CONFIG_CHR_DEV_SG=y
# CONFIG_CHR_DEV_SCH is not set
CONFIG_SCSI_MULTI_LUN=y
CONFIG_SCSI_CONSTANTS=y
CONFIG_SCSI_LOGGING=y
CONFIG_SCSI_SCAN_ASYNC=y
CONFIG_SCSI_WAIT_SCAN=m
#
# SCSI Transports
#
CONFIG_SCSI_SPI_ATTRS=m
# CONFIG_SCSI_FC_ATTRS is not set
CONFIG_SCSI_ISCSI_ATTRS=m
CONFIG_SCSI_SAS_ATTRS=m
# CONFIG_SCSI_SAS_LIBSAS is not set
# CONFIG_SCSI_SRP_ATTRS is not set
CONFIG_SCSI_LOWLEVEL=y
CONFIG_ISCSI_TCP=m
# CONFIG_ISCSI_BOOT_SYSFS is not set
# CONFIG_SCSI_CXGB3_ISCSI is not set
# CONFIG_SCSI_CXGB4_ISCSI is not set
# CONFIG_SCSI_BNX2_ISCSI is not set
# CONFIG_SCSI_BNX2X_FCOE is not set
# CONFIG_BE2ISCSI is not set
# CONFIG_BLK_DEV_3W_XXXX_RAID is not set
# CONFIG_SCSI_HPSA is not set
# CONFIG_SCSI_3W_9XXX is not set
# CONFIG_SCSI_3W_SAS is not set
# CONFIG_SCSI_ACARD is not set
# CONFIG_SCSI_AACRAID is not set
# CONFIG_SCSI_AIC7XXX is not set
# CONFIG_SCSI_AIC7XXX_OLD is not set
# CONFIG_SCSI_AIC79XX is not set
# CONFIG_SCSI_AIC94XX is not set
# CONFIG_SCSI_MVSAS is not set
# CONFIG_SCSI_MVUMI is not set
# CONFIG_SCSI_DPT_I2O is not set
# CONFIG_SCSI_ADVANSYS is not set
# CONFIG_SCSI_ARCMSR is not set
# CONFIG_MEGARAID_NEWGEN is not set
# CONFIG_MEGARAID_LEGACY is not set
CONFIG_MEGARAID_SAS=m
# CONFIG_SCSI_MPT2SAS is not set
# CONFIG_SCSI_HPTIOP is not set
CONFIG_SCSI_BUSLOGIC=m
CONFIG_VMWARE_PVSCSI=m
# CONFIG_LIBFC is not set
# CONFIG_LIBFCOE is not set
# CONFIG_FCOE is not set
# CONFIG_FCOE_FNIC is not set
# CONFIG_SCSI_DMX3191D is not set
# CONFIG_SCSI_EATA is not set
# CONFIG_SCSI_FUTURE_DOMAIN is not set
# CONFIG_SCSI_GDTH is not set
# CONFIG_SCSI_ISCI is not set
# CONFIG_SCSI_IPS is not set
# CONFIG_SCSI_INITIO is not set
# CONFIG_SCSI_INIA100 is not set
# CONFIG_SCSI_PPA is not set
# CONFIG_SCSI_IMM is not set
# CONFIG_SCSI_STEX is not set
# CONFIG_SCSI_SYM53C8XX_2 is not set
# CONFIG_SCSI_IPR is not set
# CONFIG_SCSI_QLOGIC_1280 is not set
# CONFIG_SCSI_QLA_FC is not set
# CONFIG_SCSI_QLA_ISCSI is not set
# CONFIG_SCSI_LPFC is not set
# CONFIG_SCSI_DC395x is not set
# CONFIG_SCSI_DC390T is not set
# CONFIG_SCSI_DEBUG is not set
# CONFIG_SCSI_PMCRAID is not set
# CONFIG_SCSI_PM8001 is not set
# CONFIG_SCSI_SRP is not set
# CONFIG_SCSI_BFA_FC is not set
# CONFIG_SCSI_DH is not set
CONFIG_SCSI_OSD_INITIATOR=m
CONFIG_SCSI_OSD_ULD=m
CONFIG_SCSI_OSD_DPRINT_SENSE=1
# CONFIG_SCSI_OSD_DEBUG is not set
CONFIG_ATA=y
# CONFIG_ATA_NONSTANDARD is not set
CONFIG_ATA_VERBOSE_ERROR=y
CONFIG_ATA_ACPI=y
CONFIG_SATA_PMP=y
#
# Controllers with non-SFF native interface
#
CONFIG_SATA_AHCI=y
# CONFIG_SATA_AHCI_PLATFORM is not set
# CONFIG_SATA_INIC162X is not set
# CONFIG_SATA_ACARD_AHCI is not set
# CONFIG_SATA_SIL24 is not set
CONFIG_ATA_SFF=y
#
# SFF controllers with custom DMA interface
#
# CONFIG_PDC_ADMA is not set
# CONFIG_SATA_QSTOR is not set
# CONFIG_SATA_SX4 is not set
CONFIG_ATA_BMDMA=y
#
# SATA SFF controllers with BMDMA
#
CONFIG_ATA_PIIX=y
# CONFIG_SATA_MV is not set
# CONFIG_SATA_NV is not set
# CONFIG_SATA_PROMISE is not set
# CONFIG_SATA_SIL is not set
# CONFIG_SATA_SIS is not set
# CONFIG_SATA_SVW is not set
# CONFIG_SATA_ULI is not set
# CONFIG_SATA_VIA is not set
# CONFIG_SATA_VITESSE is not set
#
# PATA SFF controllers with BMDMA
#
# CONFIG_PATA_ALI is not set
# CONFIG_PATA_AMD is not set
# CONFIG_PATA_ARASAN_CF is not set
# CONFIG_PATA_ARTOP is not set
# CONFIG_PATA_ATIIXP is not set
# CONFIG_PATA_ATP867X is not set
# CONFIG_PATA_CMD64X is not set
# CONFIG_PATA_CS5520 is not set
# CONFIG_PATA_CS5530 is not set
# CONFIG_PATA_CS5536 is not set
# CONFIG_PATA_CYPRESS is not set
# CONFIG_PATA_EFAR is not set
# CONFIG_PATA_HPT366 is not set
# CONFIG_PATA_HPT37X is not set
# CONFIG_PATA_HPT3X2N is not set
# CONFIG_PATA_HPT3X3 is not set
# CONFIG_PATA_IT8213 is not set
# CONFIG_PATA_IT821X is not set
# CONFIG_PATA_JMICRON is not set
# CONFIG_PATA_MARVELL is not set
# CONFIG_PATA_NETCELL is not set
# CONFIG_PATA_NINJA32 is not set
# CONFIG_PATA_NS87415 is not set
CONFIG_PATA_OLDPIIX=m
# CONFIG_PATA_OPTIDMA is not set
# CONFIG_PATA_PDC2027X is not set
# CONFIG_PATA_PDC_OLD is not set
# CONFIG_PATA_RADISYS is not set
# CONFIG_PATA_RDC is not set
# CONFIG_PATA_SC1200 is not set
CONFIG_PATA_SCH=m
# CONFIG_PATA_SERVERWORKS is not set
# CONFIG_PATA_SIL680 is not set
# CONFIG_PATA_SIS is not set
# CONFIG_PATA_TOSHIBA is not set
# CONFIG_PATA_TRIFLEX is not set
# CONFIG_PATA_VIA is not set
# CONFIG_PATA_WINBOND is not set
#
# PIO-only SFF controllers
#
# CONFIG_PATA_CMD640_PCI is not set
CONFIG_PATA_MPIIX=m
# CONFIG_PATA_NS87410 is not set
# CONFIG_PATA_OPTI is not set
# CONFIG_PATA_RZ1000 is not set
#
# Generic fallback / legacy drivers
#
# CONFIG_PATA_ACPI is not set
CONFIG_ATA_GENERIC=m
# CONFIG_PATA_LEGACY is not set
CONFIG_MD=y
CONFIG_BLK_DEV_MD=y
CONFIG_MD_AUTODETECT=y
CONFIG_MD_LINEAR=m
CONFIG_MD_RAID0=m
CONFIG_MD_RAID1=m
CONFIG_MD_RAID10=m
CONFIG_MD_RAID456=m
# CONFIG_MULTICORE_RAID456 is not set
# CONFIG_MD_MULTIPATH is not set
# CONFIG_MD_FAULTY is not set
CONFIG_BLK_DEV_DM=y
CONFIG_DM_DEBUG=y
CONFIG_DM_CRYPT=m
CONFIG_DM_SNAPSHOT=y
# CONFIG_DM_THIN_PROVISIONING is not set
CONFIG_DM_MIRROR=y
# CONFIG_DM_RAID is not set
CONFIG_DM_LOG_USERSPACE=m
CONFIG_DM_ZERO=y
CONFIG_DM_MULTIPATH=m
CONFIG_DM_MULTIPATH_QL=m
CONFIG_DM_MULTIPATH_ST=m
# CONFIG_DM_DELAY is not set
CONFIG_DM_UEVENT=y
# CONFIG_DM_FLAKEY is not set
# CONFIG_TARGET_CORE is not set
CONFIG_FUSION=y
CONFIG_FUSION_SPI=m
# CONFIG_FUSION_FC is not set
CONFIG_FUSION_SAS=m
CONFIG_FUSION_MAX_SGE=128
# CONFIG_FUSION_CTL is not set
# CONFIG_FUSION_LOGGING is not set
#
# IEEE 1394 (FireWire) support
#
# CONFIG_FIREWIRE is not set
# CONFIG_FIREWIRE_NOSY is not set
# CONFIG_I2O is not set
# CONFIG_MACINTOSH_DRIVERS is not set
CONFIG_NETDEVICES=y
CONFIG_NET_CORE=y
# CONFIG_BONDING is not set
# CONFIG_DUMMY is not set
# CONFIG_EQUALIZER is not set
# CONFIG_NET_FC is not set
CONFIG_MII=m
# CONFIG_NET_TEAM is not set
# CONFIG_MACVLAN is not set
# CONFIG_NETCONSOLE is not set
# CONFIG_NETPOLL is not set
# CONFIG_NET_POLL_CONTROLLER is not set
# CONFIG_TUN is not set
# CONFIG_VETH is not set
# CONFIG_ARCNET is not set
#
# CAIF transport drivers
#
CONFIG_ETHERNET=y
# CONFIG_NET_VENDOR_3COM is not set
# CONFIG_NET_VENDOR_ADAPTEC is not set
# CONFIG_NET_VENDOR_ALTEON is not set
CONFIG_NET_VENDOR_AMD=y
# CONFIG_AMD8111_ETH is not set
CONFIG_PCNET32=m
# CONFIG_NET_VENDOR_ATHEROS is not set
# CONFIG_NET_VENDOR_BROADCOM is not set
# CONFIG_NET_VENDOR_BROCADE is not set
# CONFIG_NET_CALXEDA_XGMAC is not set
# CONFIG_NET_VENDOR_CHELSIO is not set
# CONFIG_NET_VENDOR_CISCO is not set
# CONFIG_DNET is not set
# CONFIG_NET_VENDOR_DEC is not set
# CONFIG_NET_VENDOR_DLINK is not set
# CONFIG_NET_VENDOR_EMULEX is not set
# CONFIG_NET_VENDOR_EXAR is not set
# CONFIG_NET_VENDOR_HP is not set
CONFIG_NET_VENDOR_INTEL=y
# CONFIG_E100 is not set
CONFIG_E1000=m
# CONFIG_E1000E is not set
# CONFIG_IGB is not set
# CONFIG_IGBVF is not set
# CONFIG_IXGB is not set
# CONFIG_IXGBE is not set
# CONFIG_IXGBEVF is not set
CONFIG_NET_VENDOR_I825XX=y
# CONFIG_ZNET is not set
# CONFIG_IP1000 is not set
# CONFIG_JME is not set
# CONFIG_NET_VENDOR_MARVELL is not set
# CONFIG_NET_VENDOR_MELLANOX is not set
# CONFIG_NET_VENDOR_MICREL is not set
# CONFIG_NET_VENDOR_MYRI is not set
# CONFIG_FEALNX is not set
# CONFIG_NET_VENDOR_NATSEMI is not set
# CONFIG_NET_VENDOR_NVIDIA is not set
# CONFIG_NET_VENDOR_OKI is not set
# CONFIG_ETHOC is not set
# CONFIG_NET_PACKET_ENGINE is not set
# CONFIG_NET_VENDOR_QLOGIC is not set
# CONFIG_NET_VENDOR_REALTEK is not set
# CONFIG_NET_VENDOR_RDC is not set
# CONFIG_NET_VENDOR_SEEQ is not set
# CONFIG_NET_VENDOR_SILAN is not set
# CONFIG_NET_VENDOR_SIS is not set
# CONFIG_SFC is not set
# CONFIG_NET_VENDOR_SMSC is not set
# CONFIG_NET_VENDOR_STMICRO is not set
# CONFIG_NET_VENDOR_SUN is not set
# CONFIG_NET_VENDOR_TEHUTI is not set
# CONFIG_NET_VENDOR_TI is not set
# CONFIG_NET_VENDOR_VIA is not set
CONFIG_FDDI=y
# CONFIG_DEFXX is not set
CONFIG_SKFP=m
# CONFIG_HIPPI is not set
CONFIG_NET_SB1000=m
CONFIG_PHYLIB=y
#
# MII PHY device drivers
#
# CONFIG_MARVELL_PHY is not set
# CONFIG_DAVICOM_PHY is not set
# CONFIG_QSEMI_PHY is not set
# CONFIG_LXT_PHY is not set
# CONFIG_CICADA_PHY is not set
# CONFIG_VITESSE_PHY is not set
# CONFIG_SMSC_PHY is not set
# CONFIG_BROADCOM_PHY is not set
# CONFIG_ICPLUS_PHY is not set
# CONFIG_REALTEK_PHY is not set
# CONFIG_NATIONAL_PHY is not set
# CONFIG_STE10XP is not set
# CONFIG_LSI_ET1011C_PHY is not set
# CONFIG_MICREL_PHY is not set
# CONFIG_FIXED_PHY is not set
# CONFIG_MDIO_BITBANG is not set
CONFIG_PLIP=m
CONFIG_PPP=m
# CONFIG_PPP_BSDCOMP is not set
CONFIG_PPP_DEFLATE=m
CONFIG_PPP_FILTER=y
CONFIG_PPP_MPPE=m
CONFIG_PPP_MULTILINK=y
CONFIG_PPPOE=m
CONFIG_PPP_ASYNC=m
CONFIG_PPP_SYNC_TTY=m
CONFIG_SLIP=m
CONFIG_SLHC=m
CONFIG_SLIP_COMPRESSED=y
CONFIG_SLIP_SMART=y
# CONFIG_SLIP_MODE_SLIP6 is not set
# CONFIG_TR is not set
#
# USB Network Adapters
#
# CONFIG_USB_CATC is not set
# CONFIG_USB_KAWETH is not set
# CONFIG_USB_PEGASUS is not set
# CONFIG_USB_RTL8150 is not set
# CONFIG_USB_USBNET is not set
# CONFIG_USB_IPHETH is not set
# CONFIG_WLAN is not set
#
# Enable WiMAX (Networking options) to see the WiMAX drivers
#
# CONFIG_WAN is not set
CONFIG_VMXNET3=m
# CONFIG_ISDN is not set
# CONFIG_PHONE is not set
#
# Input device support
#
CONFIG_INPUT=y
# CONFIG_INPUT_FF_MEMLESS is not set
# CONFIG_INPUT_POLLDEV is not set
# CONFIG_INPUT_SPARSEKMAP is not set
#
# Userland interfaces
#
CONFIG_INPUT_MOUSEDEV=y
# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024
CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768
# CONFIG_INPUT_JOYDEV is not set
CONFIG_INPUT_EVDEV=y
# CONFIG_INPUT_EVBUG is not set
#
# Input Device Drivers
#
CONFIG_INPUT_KEYBOARD=y
# CONFIG_KEYBOARD_ADP5588 is not set
# CONFIG_KEYBOARD_ADP5589 is not set
CONFIG_KEYBOARD_ATKBD=y
# CONFIG_KEYBOARD_QT1070 is not set
# CONFIG_KEYBOARD_QT2160 is not set
# CONFIG_KEYBOARD_LKKBD is not set
# CONFIG_KEYBOARD_TCA6416 is not set
# CONFIG_KEYBOARD_TCA8418 is not set
# CONFIG_KEYBOARD_MAX7359 is not set
# CONFIG_KEYBOARD_MCS is not set
# CONFIG_KEYBOARD_MPR121 is not set
# CONFIG_KEYBOARD_NEWTON is not set
CONFIG_KEYBOARD_OPENCORES=y
# CONFIG_KEYBOARD_STOWAWAY is not set
# CONFIG_KEYBOARD_SUNKBD is not set
# CONFIG_KEYBOARD_XTKBD is not set
CONFIG_INPUT_MOUSE=y
CONFIG_MOUSE_PS2=y
CONFIG_MOUSE_PS2_ALPS=y
CONFIG_MOUSE_PS2_LOGIPS2PP=y
CONFIG_MOUSE_PS2_SYNAPTICS=y
CONFIG_MOUSE_PS2_LIFEBOOK=y
CONFIG_MOUSE_PS2_TRACKPOINT=y
CONFIG_MOUSE_PS2_ELANTECH=y
CONFIG_MOUSE_PS2_SENTELIC=y
# CONFIG_MOUSE_PS2_TOUCHKIT is not set
# CONFIG_MOUSE_SERIAL is not set
# CONFIG_MOUSE_APPLETOUCH is not set
# CONFIG_MOUSE_BCM5974 is not set
# CONFIG_MOUSE_VSXXXAA is not set
# CONFIG_MOUSE_SYNAPTICS_I2C is not set
# CONFIG_INPUT_JOYSTICK is not set
# CONFIG_INPUT_TABLET is not set
# CONFIG_INPUT_TOUCHSCREEN is not set
# CONFIG_INPUT_MISC is not set
#
# Hardware I/O ports
#
CONFIG_SERIO=y
CONFIG_SERIO_I8042=y
CONFIG_SERIO_SERPORT=y
# CONFIG_SERIO_CT82C710 is not set
# CONFIG_SERIO_PARKBD is not set
# CONFIG_SERIO_PCIPS2 is not set
CONFIG_SERIO_LIBPS2=y
CONFIG_SERIO_RAW=m
# CONFIG_SERIO_ALTERA_PS2 is not set
# CONFIG_SERIO_PS2MULT is not set
# CONFIG_GAMEPORT is not set
#
# Character devices
#
CONFIG_VT=y
CONFIG_CONSOLE_TRANSLATIONS=y
CONFIG_VT_CONSOLE=y
CONFIG_VT_CONSOLE_SLEEP=y
CONFIG_HW_CONSOLE=y
CONFIG_VT_HW_CONSOLE_BINDING=y
CONFIG_UNIX98_PTYS=y
CONFIG_DEVPTS_MULTIPLE_INSTANCES=y
# CONFIG_LEGACY_PTYS is not set
# CONFIG_SERIAL_NONSTANDARD is not set
CONFIG_NOZOMI=m
# CONFIG_N_GSM is not set
# CONFIG_TRACE_SINK is not set
# CONFIG_DEVKMEM is not set
#
# Serial drivers
#
CONFIG_SERIAL_8250=y
CONFIG_SERIAL_8250_CONSOLE=y
CONFIG_FIX_EARLYCON_MEM=y
CONFIG_SERIAL_8250_PCI=y
CONFIG_SERIAL_8250_PNP=y
CONFIG_SERIAL_8250_NR_UARTS=32
CONFIG_SERIAL_8250_RUNTIME_UARTS=4
CONFIG_SERIAL_8250_EXTENDED=y
CONFIG_SERIAL_8250_MANY_PORTS=y
CONFIG_SERIAL_8250_SHARE_IRQ=y
CONFIG_SERIAL_8250_DETECT_IRQ=y
CONFIG_SERIAL_8250_RSA=y
#
# Non-8250 serial port support
#
# CONFIG_SERIAL_MFD_HSU is not set
CONFIG_SERIAL_CORE=y
CONFIG_SERIAL_CORE_CONSOLE=y
CONFIG_CONSOLE_POLL=y
# CONFIG_SERIAL_JSM is not set
# CONFIG_SERIAL_TIMBERDALE is not set
# CONFIG_SERIAL_ALTERA_JTAGUART is not set
# CONFIG_SERIAL_ALTERA_UART is not set
# CONFIG_SERIAL_PCH_UART is not set
# CONFIG_SERIAL_XILINX_PS_UART is not set
CONFIG_PRINTER=m
CONFIG_LP_CONSOLE=y
CONFIG_PPDEV=m
# CONFIG_IPMI_HANDLER is not set
# CONFIG_HW_RANDOM is not set
CONFIG_NVRAM=y
# CONFIG_R3964 is not set
# CONFIG_APPLICOM is not set
# CONFIG_MWAVE is not set
CONFIG_RAW_DRIVER=y
CONFIG_MAX_RAW_DEVS=8192
CONFIG_HPET=y
# CONFIG_HPET_MMAP is not set
CONFIG_HANGCHECK_TIMER=m
CONFIG_TCG_TPM=y
CONFIG_TCG_TIS=y
# CONFIG_TCG_NSC is not set
# CONFIG_TCG_ATMEL is not set
# CONFIG_TCG_INFINEON is not set
# CONFIG_TELCLOCK is not set
CONFIG_DEVPORT=y
# CONFIG_RAMOOPS is not set
CONFIG_I2C=m
CONFIG_I2C_BOARDINFO=y
CONFIG_I2C_COMPAT=y
CONFIG_I2C_CHARDEV=m
# CONFIG_I2C_MUX is not set
CONFIG_I2C_HELPER_AUTO=y
CONFIG_I2C_SMBUS=m
CONFIG_I2C_ALGOBIT=m
CONFIG_I2C_ALGOPCA=m
#
# I2C Hardware Bus support
#
#
# PC SMBus host controller drivers
#
# CONFIG_I2C_ALI1535 is not set
# CONFIG_I2C_ALI1563 is not set
# CONFIG_I2C_ALI15X3 is not set
# CONFIG_I2C_AMD756 is not set
# CONFIG_I2C_AMD8111 is not set
# CONFIG_I2C_I801 is not set
# CONFIG_I2C_ISCH is not set
CONFIG_I2C_PIIX4=m
# CONFIG_I2C_NFORCE2 is not set
# CONFIG_I2C_SIS5595 is not set
# CONFIG_I2C_SIS630 is not set
# CONFIG_I2C_SIS96X is not set
# CONFIG_I2C_VIA is not set
# CONFIG_I2C_VIAPRO is not set
#
# ACPI drivers
#
CONFIG_I2C_SCMI=m
#
# I2C system bus drivers (mostly embedded / system-on-chip)
#
# CONFIG_I2C_DESIGNWARE_PCI is not set
# CONFIG_I2C_INTEL_MID is not set
# CONFIG_I2C_OCORES is not set
CONFIG_I2C_PCA_PLATFORM=m
# CONFIG_I2C_PXA_PCI is not set
CONFIG_I2C_SIMTEC=m
# CONFIG_I2C_XILINX is not set
# CONFIG_I2C_EG20T is not set
#
# External I2C/SMBus adapter drivers
#
# CONFIG_I2C_DIOLAN_U2C is not set
CONFIG_I2C_PARPORT=m
CONFIG_I2C_PARPORT_LIGHT=m
# CONFIG_I2C_TAOS_EVM is not set
CONFIG_I2C_TINY_USB=m
#
# Other I2C/SMBus bus drivers
#
CONFIG_I2C_STUB=m
# CONFIG_I2C_DEBUG_CORE is not set
# CONFIG_I2C_DEBUG_ALGO is not set
# CONFIG_I2C_DEBUG_BUS is not set
# CONFIG_SPI is not set
#
# PPS support
#
# CONFIG_PPS is not set
#
# PPS generators support
#
#
# PTP clock support
#
#
# Enable Device Drivers -> PPS to see the PTP clock options.
#
CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y
# CONFIG_GPIOLIB is not set
# CONFIG_W1 is not set
CONFIG_POWER_SUPPLY=y
# CONFIG_POWER_SUPPLY_DEBUG is not set
# CONFIG_PDA_POWER is not set
# CONFIG_TEST_POWER is not set
# CONFIG_BATTERY_DS2780 is not set
# CONFIG_BATTERY_DS2782 is not set
# CONFIG_BATTERY_SBS is not set
# CONFIG_BATTERY_BQ27x00 is not set
# CONFIG_BATTERY_MAX17040 is not set
# CONFIG_BATTERY_MAX17042 is not set
# CONFIG_CHARGER_ISP1704 is not set
# CONFIG_CHARGER_MAX8903 is not set
# CONFIG_CHARGER_LP8727 is not set
# CONFIG_HWMON is not set
CONFIG_THERMAL=y
# CONFIG_WATCHDOG is not set
CONFIG_SSB_POSSIBLE=y
#
# Sonics Silicon Backplane
#
# CONFIG_SSB is not set
CONFIG_BCMA_POSSIBLE=y
#
# Broadcom specific AMBA
#
# CONFIG_BCMA is not set
#
# Multifunction device drivers
#
# CONFIG_MFD_CORE is not set
# CONFIG_MFD_SM501 is not set
# CONFIG_HTC_PASIC3 is not set
# CONFIG_TPS6105X is not set
# CONFIG_TPS6507X is not set
# CONFIG_MFD_TMIO is not set
# CONFIG_MFD_WM8400 is not set
# CONFIG_MFD_PCF50633 is not set
# CONFIG_ABX500_CORE is not set
# CONFIG_MFD_CS5535 is not set
# CONFIG_LPC_SCH is not set
# CONFIG_MFD_RDC321X is not set
# CONFIG_MFD_JANZ_CMODIO is not set
# CONFIG_MFD_VX855 is not set
# CONFIG_MFD_WL1273_CORE is not set
# CONFIG_REGULATOR is not set
# CONFIG_MEDIA_SUPPORT is not set
#
# Graphics support
#
CONFIG_AGP=y
# CONFIG_AGP_AMD64 is not set
CONFIG_AGP_INTEL=y
# CONFIG_AGP_SIS is not set
# CONFIG_AGP_VIA is not set
CONFIG_VGA_ARB=y
CONFIG_VGA_ARB_MAX_GPUS=16
# CONFIG_VGA_SWITCHEROO is not set
# CONFIG_DRM is not set
# CONFIG_STUB_POULSBO is not set
# CONFIG_VGASTATE is not set
# CONFIG_VIDEO_OUTPUT_CONTROL is not set
CONFIG_FB=y
# CONFIG_FIRMWARE_EDID is not set
# CONFIG_FB_DDC is not set
CONFIG_FB_BOOT_VESA_SUPPORT=y
CONFIG_FB_CFB_FILLRECT=y
CONFIG_FB_CFB_COPYAREA=y
CONFIG_FB_CFB_IMAGEBLIT=y
# CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set
# CONFIG_FB_SYS_FILLRECT is not set
# CONFIG_FB_SYS_COPYAREA is not set
# CONFIG_FB_SYS_IMAGEBLIT is not set
# CONFIG_FB_FOREIGN_ENDIAN is not set
# CONFIG_FB_SYS_FOPS is not set
# CONFIG_FB_WMT_GE_ROPS is not set
# CONFIG_FB_SVGALIB is not set
# CONFIG_FB_MACMODES is not set
# CONFIG_FB_BACKLIGHT is not set
CONFIG_FB_MODE_HELPERS=y
CONFIG_FB_TILEBLITTING=y
#
# Frame buffer hardware drivers
#
# CONFIG_FB_CIRRUS is not set
# CONFIG_FB_PM2 is not set
# CONFIG_FB_CYBER2000 is not set
# CONFIG_FB_ARC is not set
# CONFIG_FB_ASILIANT is not set
# CONFIG_FB_IMSTT is not set
# CONFIG_FB_VGA16 is not set
# CONFIG_FB_UVESA is not set
CONFIG_FB_VESA=y
CONFIG_FB_EFI=y
# CONFIG_FB_N411 is not set
# CONFIG_FB_HGA is not set
# CONFIG_FB_S1D13XXX is not set
# CONFIG_FB_NVIDIA is not set
# CONFIG_FB_RIVA is not set
# CONFIG_FB_LE80578 is not set
# CONFIG_FB_MATROX is not set
# CONFIG_FB_RADEON is not set
# CONFIG_FB_ATY128 is not set
# CONFIG_FB_ATY is not set
# CONFIG_FB_S3 is not set
# CONFIG_FB_SAVAGE is not set
# CONFIG_FB_SIS is not set
# CONFIG_FB_VIA is not set
# CONFIG_FB_NEOMAGIC is not set
# CONFIG_FB_KYRO is not set
# CONFIG_FB_3DFX is not set
# CONFIG_FB_VOODOO1 is not set
# CONFIG_FB_VT8623 is not set
# CONFIG_FB_TRIDENT is not set
# CONFIG_FB_ARK is not set
# CONFIG_FB_PM3 is not set
# CONFIG_FB_CARMINE is not set
# CONFIG_FB_GEODE is not set
# CONFIG_FB_SMSCUFX is not set
# CONFIG_FB_UDL is not set
# CONFIG_FB_VIRTUAL is not set
# CONFIG_FB_METRONOME is not set
# CONFIG_FB_MB862XX is not set
# CONFIG_FB_BROADSHEET is not set
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
#
# Console display driver support
#
CONFIG_VGA_CONSOLE=y
CONFIG_VGACON_SOFT_SCROLLBACK=y
CONFIG_VGACON_SOFT_SCROLLBACK_SIZE=64
CONFIG_DUMMY_CONSOLE=y
CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y
CONFIG_FRAMEBUFFER_CONSOLE_ROTATION=y
# CONFIG_FONTS is not set
CONFIG_FONT_8x8=y
CONFIG_FONT_8x16=y
CONFIG_LOGO=y
# CONFIG_LOGO_LINUX_MONO is not set
# CONFIG_LOGO_LINUX_VGA16 is not set
CONFIG_LOGO_LINUX_CLUT224=y
# CONFIG_SOUND is not set
# CONFIG_HID_SUPPORT is not set
CONFIG_USB_SUPPORT=y
CONFIG_USB_COMMON=y
CONFIG_USB_ARCH_HAS_HCD=y
CONFIG_USB_ARCH_HAS_OHCI=y
CONFIG_USB_ARCH_HAS_EHCI=y
CONFIG_USB_ARCH_HAS_XHCI=y
CONFIG_USB=y
# CONFIG_USB_DEBUG is not set
CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
#
# Miscellaneous USB options
#
CONFIG_USB_DEVICEFS=y
# CONFIG_USB_DEVICE_CLASS is not set
# CONFIG_USB_DYNAMIC_MINORS is not set
CONFIG_USB_SUSPEND=y
# CONFIG_USB_OTG is not set
CONFIG_USB_MON=y
# CONFIG_USB_WUSB_CBAF is not set
#
# USB Host Controller Drivers
#
# CONFIG_USB_C67X00_HCD is not set
CONFIG_USB_XHCI_HCD=m
# CONFIG_USB_XHCI_HCD_DEBUGGING is not set
CONFIG_USB_EHCI_HCD=y
CONFIG_USB_EHCI_ROOT_HUB_TT=y
CONFIG_USB_EHCI_TT_NEWSCHED=y
# CONFIG_USB_EHCI_MV is not set
# CONFIG_USB_OXU210HP_HCD is not set
# CONFIG_USB_ISP116X_HCD is not set
# CONFIG_USB_ISP1760_HCD is not set
# CONFIG_USB_ISP1362_HCD is not set
CONFIG_USB_OHCI_HCD=y
# CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set
# CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set
CONFIG_USB_OHCI_LITTLE_ENDIAN=y
CONFIG_USB_UHCI_HCD=y
# CONFIG_USB_SL811_HCD is not set
# CONFIG_USB_R8A66597_HCD is not set
# CONFIG_USB_WHCI_HCD is not set
# CONFIG_USB_HWA_HCD is not set
#
# USB Device Class drivers
#
# CONFIG_USB_ACM is not set
# CONFIG_USB_PRINTER is not set
# CONFIG_USB_WDM is not set
# CONFIG_USB_TMC is not set
#
# NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may
#
#
# also be needed; see USB_STORAGE Help for more info
#
CONFIG_USB_STORAGE=m
# CONFIG_USB_STORAGE_DEBUG is not set
# CONFIG_USB_STORAGE_REALTEK is not set
# CONFIG_USB_STORAGE_DATAFAB is not set
# CONFIG_USB_STORAGE_FREECOM is not set
# CONFIG_USB_STORAGE_ISD200 is not set
# CONFIG_USB_STORAGE_USBAT is not set
# CONFIG_USB_STORAGE_SDDR09 is not set
# CONFIG_USB_STORAGE_SDDR55 is not set
# CONFIG_USB_STORAGE_JUMPSHOT is not set
# CONFIG_USB_STORAGE_ALAUDA is not set
# CONFIG_USB_STORAGE_ONETOUCH is not set
# CONFIG_USB_STORAGE_KARMA is not set
# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set
# CONFIG_USB_STORAGE_ENE_UB6250 is not set
# CONFIG_USB_UAS is not set
# CONFIG_USB_LIBUSUAL is not set
#
# USB Imaging devices
#
# CONFIG_USB_MDC800 is not set
# CONFIG_USB_MICROTEK is not set
#
# USB port drivers
#
# CONFIG_USB_USS720 is not set
# CONFIG_USB_SERIAL is not set
#
# USB Miscellaneous drivers
#
# CONFIG_USB_EMI62 is not set
# CONFIG_USB_EMI26 is not set
# CONFIG_USB_ADUTUX is not set
# CONFIG_USB_SEVSEG is not set
# CONFIG_USB_RIO500 is not set
# CONFIG_USB_LEGOTOWER is not set
# CONFIG_USB_LCD is not set
# CONFIG_USB_LED is not set
# CONFIG_USB_CYPRESS_CY7C63 is not set
# CONFIG_USB_CYTHERM is not set
# CONFIG_USB_IDMOUSE is not set
# CONFIG_USB_FTDI_ELAN is not set
# CONFIG_USB_APPLEDISPLAY is not set
# CONFIG_USB_SISUSBVGA is not set
# CONFIG_USB_LD is not set
# CONFIG_USB_TRANCEVIBRATOR is not set
# CONFIG_USB_IOWARRIOR is not set
# CONFIG_USB_TEST is not set
# CONFIG_USB_ISIGHTFW is not set
# CONFIG_USB_YUREX is not set
# CONFIG_USB_GADGET is not set
#
# OTG and related infrastructure
#
CONFIG_USB_OTG_UTILS=y
CONFIG_NOP_USB_XCEIV=m
# CONFIG_UWB is not set
# CONFIG_MMC is not set
# CONFIG_MEMSTICK is not set
# CONFIG_NEW_LEDS is not set
# CONFIG_ACCESSIBILITY is not set
# CONFIG_INFINIBAND is not set
CONFIG_EDAC=y
#
# Reporting subsystems
#
# CONFIG_EDAC_DEBUG is not set
# CONFIG_EDAC_DECODE_MCE is not set
# CONFIG_EDAC_MM_EDAC is not set
CONFIG_RTC_LIB=y
CONFIG_RTC_CLASS=y
CONFIG_RTC_HCTOSYS=y
CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
# CONFIG_RTC_DEBUG is not set
#
# RTC interfaces
#
CONFIG_RTC_INTF_SYSFS=y
CONFIG_RTC_INTF_PROC=y
CONFIG_RTC_INTF_DEV=y
# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
# CONFIG_RTC_DRV_TEST is not set
#
# I2C RTC drivers
#
# CONFIG_RTC_DRV_DS1307 is not set
# CONFIG_RTC_DRV_DS1374 is not set
# CONFIG_RTC_DRV_DS1672 is not set
# CONFIG_RTC_DRV_DS3232 is not set
# CONFIG_RTC_DRV_MAX6900 is not set
# CONFIG_RTC_DRV_RS5C372 is not set
# CONFIG_RTC_DRV_ISL1208 is not set
# CONFIG_RTC_DRV_ISL12022 is not set
# CONFIG_RTC_DRV_X1205 is not set
# CONFIG_RTC_DRV_PCF8563 is not set
# CONFIG_RTC_DRV_PCF8583 is not set
# CONFIG_RTC_DRV_M41T80 is not set
# CONFIG_RTC_DRV_BQ32K is not set
# CONFIG_RTC_DRV_S35390A is not set
# CONFIG_RTC_DRV_FM3130 is not set
# CONFIG_RTC_DRV_RX8581 is not set
# CONFIG_RTC_DRV_RX8025 is not set
# CONFIG_RTC_DRV_EM3027 is not set
# CONFIG_RTC_DRV_RV3029C2 is not set
#
# SPI RTC drivers
#
#
# Platform RTC drivers
#
CONFIG_RTC_DRV_CMOS=y
# CONFIG_RTC_DRV_DS1286 is not set
# CONFIG_RTC_DRV_DS1511 is not set
# CONFIG_RTC_DRV_DS1553 is not set
# CONFIG_RTC_DRV_DS1742 is not set
# CONFIG_RTC_DRV_STK17TA8 is not set
# CONFIG_RTC_DRV_M48T86 is not set
# CONFIG_RTC_DRV_M48T35 is not set
# CONFIG_RTC_DRV_M48T59 is not set
# CONFIG_RTC_DRV_MSM6242 is not set
# CONFIG_RTC_DRV_BQ4802 is not set
# CONFIG_RTC_DRV_RP5C01 is not set
# CONFIG_RTC_DRV_V3020 is not set
#
# on-CPU RTC drivers
#
CONFIG_DMADEVICES=y
# CONFIG_DMADEVICES_DEBUG is not set
#
# DMA Devices
#
# CONFIG_INTEL_MID_DMAC is not set
CONFIG_INTEL_IOATDMA=m
# CONFIG_TIMB_DMA is not set
# CONFIG_PCH_DMA is not set
CONFIG_DMA_ENGINE=y
#
# DMA Clients
#
CONFIG_NET_DMA=y
CONFIG_ASYNC_TX_DMA=y
# CONFIG_DMATEST is not set
CONFIG_DCA=m
# CONFIG_AUXDISPLAY is not set
# CONFIG_UIO is not set
#
# Virtio drivers
#
# CONFIG_VIRTIO_PCI is not set
# CONFIG_VIRTIO_BALLOON is not set
# CONFIG_VIRTIO_MMIO is not set
#
# Microsoft Hyper-V guest support
#
# CONFIG_HYPERV is not set
# CONFIG_STAGING is not set
# CONFIG_X86_PLATFORM_DEVICES is not set
#
# Hardware Spinlock drivers
#
CONFIG_CLKEVT_I8253=y
CONFIG_I8253_LOCK=y
CONFIG_CLKBLD_I8253=y
CONFIG_IOMMU_API=y
CONFIG_IOMMU_SUPPORT=y
CONFIG_AMD_IOMMU=y
CONFIG_AMD_IOMMU_STATS=y
# CONFIG_AMD_IOMMU_V2 is not set
# CONFIG_INTEL_IOMMU is not set
# CONFIG_IRQ_REMAP is not set
# CONFIG_VIRT_DRIVERS is not set
# CONFIG_PM_DEVFREQ is not set
#
# Firmware Drivers
#
# CONFIG_EDD is not set
CONFIG_FIRMWARE_MEMMAP=y
CONFIG_EFI_VARS=y
# CONFIG_DELL_RBU is not set
# CONFIG_DCDBAS is not set
CONFIG_DMIID=y
# CONFIG_DMI_SYSFS is not set
CONFIG_ISCSI_IBFT_FIND=y
# CONFIG_ISCSI_IBFT is not set
# CONFIG_GOOGLE_FIRMWARE is not set
#
# File systems
#
CONFIG_EXT2_FS=m
CONFIG_EXT2_FS_XATTR=y
CONFIG_EXT2_FS_POSIX_ACL=y
CONFIG_EXT2_FS_SECURITY=y
CONFIG_EXT2_FS_XIP=y
CONFIG_EXT3_FS=y
CONFIG_EXT3_DEFAULTS_TO_ORDERED=y
CONFIG_EXT3_FS_XATTR=y
CONFIG_EXT3_FS_POSIX_ACL=y
CONFIG_EXT3_FS_SECURITY=y
CONFIG_EXT4_FS=y
CONFIG_EXT4_FS_XATTR=y
CONFIG_EXT4_FS_POSIX_ACL=y
CONFIG_EXT4_FS_SECURITY=y
# CONFIG_EXT4_DEBUG is not set
CONFIG_FS_XIP=y
CONFIG_JBD=y
# CONFIG_JBD_DEBUG is not set
CONFIG_JBD2=y
# CONFIG_JBD2_DEBUG is not set
CONFIG_FS_MBCACHE=y
# CONFIG_REISERFS_FS is not set
# CONFIG_JFS_FS is not set
# CONFIG_XFS_FS is not set
CONFIG_GFS2_FS=m
CONFIG_GFS2_FS_LOCKING_DLM=y
# CONFIG_OCFS2_FS is not set
# CONFIG_BTRFS_FS is not set
# CONFIG_NILFS2_FS is not set
CONFIG_FS_POSIX_ACL=y
CONFIG_EXPORTFS=m
CONFIG_FILE_LOCKING=y
CONFIG_FSNOTIFY=y
CONFIG_DNOTIFY=y
CONFIG_INOTIFY_USER=y
# CONFIG_FANOTIFY is not set
CONFIG_QUOTA=y
CONFIG_QUOTA_NETLINK_INTERFACE=y
# CONFIG_PRINT_QUOTA_WARNING is not set
# CONFIG_QUOTA_DEBUG is not set
CONFIG_QUOTA_TREE=y
# CONFIG_QFMT_V1 is not set
CONFIG_QFMT_V2=y
CONFIG_QUOTACTL=y
CONFIG_QUOTACTL_COMPAT=y
CONFIG_AUTOFS4_FS=m
CONFIG_FUSE_FS=m
CONFIG_CUSE=m
CONFIG_GENERIC_ACL=y
#
# Caches
#
CONFIG_FSCACHE=m
CONFIG_FSCACHE_STATS=y
# CONFIG_FSCACHE_HISTOGRAM is not set
# CONFIG_FSCACHE_DEBUG is not set
CONFIG_FSCACHE_OBJECT_LIST=y
CONFIG_CACHEFILES=m
# CONFIG_CACHEFILES_DEBUG is not set
# CONFIG_CACHEFILES_HISTOGRAM is not set
#
# CD-ROM/DVD Filesystems
#
CONFIG_ISO9660_FS=y
CONFIG_JOLIET=y
CONFIG_ZISOFS=y
CONFIG_UDF_FS=m
CONFIG_UDF_NLS=y
#
# DOS/FAT/NT Filesystems
#
CONFIG_FAT_FS=m
CONFIG_MSDOS_FS=m
CONFIG_VFAT_FS=m
CONFIG_FAT_DEFAULT_CODEPAGE=437
CONFIG_FAT_DEFAULT_IOCHARSET="ascii"
# CONFIG_NTFS_FS is not set
#
# Pseudo filesystems
#
CONFIG_PROC_FS=y
CONFIG_PROC_KCORE=y
CONFIG_PROC_VMCORE=y
CONFIG_PROC_SYSCTL=y
CONFIG_PROC_PAGE_MONITOR=y
CONFIG_SYSFS=y
CONFIG_TMPFS=y
CONFIG_TMPFS_POSIX_ACL=y
CONFIG_TMPFS_XATTR=y
CONFIG_HUGETLBFS=y
CONFIG_HUGETLB_PAGE=y
CONFIG_CONFIGFS_FS=m
# CONFIG_MISC_FILESYSTEMS is not set
CONFIG_ORE=m
CONFIG_NETWORK_FILESYSTEMS=y
CONFIG_NFS_FS=m
CONFIG_NFS_V3=y
CONFIG_NFS_V3_ACL=y
CONFIG_NFS_V4=y
CONFIG_NFS_V4_1=y
CONFIG_PNFS_FILE_LAYOUT=m
CONFIG_PNFS_BLOCK=m
CONFIG_PNFS_OBJLAYOUT=m
# CONFIG_NFS_FSCACHE is not set
# CONFIG_NFS_USE_LEGACY_DNS is not set
CONFIG_NFS_USE_KERNEL_DNS=y
CONFIG_NFSD=m
CONFIG_NFSD_V2_ACL=y
CONFIG_NFSD_V3=y
CONFIG_NFSD_V3_ACL=y
CONFIG_NFSD_V4=y
# CONFIG_NFSD_FAULT_INJECTION is not set
CONFIG_LOCKD=m
CONFIG_LOCKD_V4=y
CONFIG_NFS_ACL_SUPPORT=m
CONFIG_NFS_COMMON=y
CONFIG_SUNRPC=m
CONFIG_SUNRPC_GSS=m
CONFIG_SUNRPC_BACKCHANNEL=y
# CONFIG_CEPH_FS is not set
# CONFIG_CIFS is not set
# CONFIG_NCP_FS is not set
# CONFIG_CODA_FS is not set
# CONFIG_AFS_FS is not set
CONFIG_NLS=y
CONFIG_NLS_DEFAULT="utf8"
CONFIG_NLS_CODEPAGE_437=y
# CONFIG_NLS_CODEPAGE_737 is not set
# CONFIG_NLS_CODEPAGE_775 is not set
# CONFIG_NLS_CODEPAGE_850 is not set
# CONFIG_NLS_CODEPAGE_852 is not set
# CONFIG_NLS_CODEPAGE_855 is not set
# CONFIG_NLS_CODEPAGE_857 is not set
# CONFIG_NLS_CODEPAGE_860 is not set
# CONFIG_NLS_CODEPAGE_861 is not set
# CONFIG_NLS_CODEPAGE_862 is not set
# CONFIG_NLS_CODEPAGE_863 is not set
# CONFIG_NLS_CODEPAGE_864 is not set
# CONFIG_NLS_CODEPAGE_865 is not set
# CONFIG_NLS_CODEPAGE_866 is not set
# CONFIG_NLS_CODEPAGE_869 is not set
# CONFIG_NLS_CODEPAGE_936 is not set
# CONFIG_NLS_CODEPAGE_950 is not set
# CONFIG_NLS_CODEPAGE_932 is not set
# CONFIG_NLS_CODEPAGE_949 is not set
# CONFIG_NLS_CODEPAGE_874 is not set
# CONFIG_NLS_ISO8859_8 is not set
# CONFIG_NLS_CODEPAGE_1250 is not set
# CONFIG_NLS_CODEPAGE_1251 is not set
CONFIG_NLS_ASCII=y
CONFIG_NLS_ISO8859_1=m
CONFIG_NLS_ISO8859_2=m
CONFIG_NLS_ISO8859_3=m
CONFIG_NLS_ISO8859_4=m
# CONFIG_NLS_ISO8859_5 is not set
# CONFIG_NLS_ISO8859_6 is not set
# CONFIG_NLS_ISO8859_7 is not set
# CONFIG_NLS_ISO8859_9 is not set
# CONFIG_NLS_ISO8859_13 is not set
# CONFIG_NLS_ISO8859_14 is not set
# CONFIG_NLS_ISO8859_15 is not set
# CONFIG_NLS_KOI8_R is not set
# CONFIG_NLS_KOI8_U is not set
CONFIG_NLS_UTF8=m
CONFIG_DLM=m
CONFIG_DLM_DEBUG=y
#
# Kernel hacking
#
CONFIG_TRACE_IRQFLAGS_SUPPORT=y
# CONFIG_PRINTK_TIME is not set
CONFIG_DEFAULT_MESSAGE_LOGLEVEL=4
# CONFIG_ENABLE_WARN_DEPRECATED is not set
CONFIG_ENABLE_MUST_CHECK=y
CONFIG_FRAME_WARN=2048
CONFIG_MAGIC_SYSRQ=y
CONFIG_STRIP_ASM_SYMS=y
CONFIG_UNUSED_SYMBOLS=y
CONFIG_DEBUG_FS=y
CONFIG_HEADERS_CHECK=y
# CONFIG_DEBUG_SECTION_MISMATCH is not set
CONFIG_DEBUG_KERNEL=y
CONFIG_DEBUG_SHIRQ=y
CONFIG_LOCKUP_DETECTOR=y
CONFIG_HARDLOCKUP_DETECTOR=y
# CONFIG_BOOTPARAM_HARDLOCKUP_PANIC is not set
CONFIG_BOOTPARAM_HARDLOCKUP_PANIC_VALUE=0
# CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set
CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0
CONFIG_DETECT_HUNG_TASK=y
CONFIG_DEFAULT_HUNG_TASK_TIMEOUT=120
# CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set
CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0
CONFIG_SCHED_DEBUG=y
CONFIG_SCHEDSTATS=y
CONFIG_TIMER_STATS=y
CONFIG_DEBUG_OBJECTS=y
# CONFIG_DEBUG_OBJECTS_SELFTEST is not set
CONFIG_DEBUG_OBJECTS_FREE=y
CONFIG_DEBUG_OBJECTS_TIMERS=y
CONFIG_DEBUG_OBJECTS_WORK=y
CONFIG_DEBUG_OBJECTS_RCU_HEAD=y
# CONFIG_DEBUG_OBJECTS_PERCPU_COUNTER is not set
CONFIG_DEBUG_OBJECTS_ENABLE_DEFAULT=1
CONFIG_SLUB_DEBUG_ON=y
# CONFIG_SLUB_STATS is not set
CONFIG_DEBUG_KMEMLEAK=y
CONFIG_DEBUG_KMEMLEAK_EARLY_LOG_SIZE=400
# CONFIG_DEBUG_KMEMLEAK_TEST is not set
# CONFIG_DEBUG_KMEMLEAK_DEFAULT_OFF is not set
CONFIG_DEBUG_RT_MUTEXES=y
CONFIG_DEBUG_PI_LIST=y
# CONFIG_RT_MUTEX_TESTER is not set
CONFIG_DEBUG_SPINLOCK=y
CONFIG_DEBUG_MUTEXES=y
CONFIG_DEBUG_LOCK_ALLOC=y
CONFIG_PROVE_LOCKING=y
# CONFIG_PROVE_RCU is not set
CONFIG_SPARSE_RCU_POINTER=y
CONFIG_LOCKDEP=y
# CONFIG_LOCK_STAT is not set
# CONFIG_DEBUG_LOCKDEP is not set
CONFIG_TRACE_IRQFLAGS=y
CONFIG_DEBUG_ATOMIC_SLEEP=y
# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
CONFIG_STACKTRACE=y
CONFIG_DEBUG_STACK_USAGE=y
# CONFIG_DEBUG_KOBJECT is not set
CONFIG_DEBUG_BUGVERBOSE=y
CONFIG_DEBUG_INFO=y
# CONFIG_DEBUG_INFO_REDUCED is not set
CONFIG_DEBUG_VM=y
# CONFIG_DEBUG_VIRTUAL is not set
# CONFIG_DEBUG_WRITECOUNT is not set
CONFIG_DEBUG_MEMORY_INIT=y
CONFIG_DEBUG_LIST=y
# CONFIG_TEST_LIST_SORT is not set
# CONFIG_DEBUG_SG is not set
CONFIG_DEBUG_NOTIFIERS=y
# CONFIG_DEBUG_CREDENTIALS is not set
CONFIG_ARCH_WANT_FRAME_POINTERS=y
CONFIG_FRAME_POINTER=y
CONFIG_BOOT_PRINTK_DELAY=y
# CONFIG_RCU_TORTURE_TEST is not set
CONFIG_RCU_CPU_STALL_TIMEOUT=60
# CONFIG_KPROBES_SANITY_TEST is not set
# CONFIG_BACKTRACE_SELF_TEST is not set
# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
# CONFIG_DEBUG_PER_CPU_MAPS is not set
# CONFIG_LKDTM is not set
# CONFIG_CPU_NOTIFIER_ERROR_INJECT is not set
# CONFIG_FAULT_INJECTION is not set
CONFIG_LATENCYTOP=y
# CONFIG_SYSCTL_SYSCALL_CHECK is not set
CONFIG_DEBUG_PAGEALLOC=y
CONFIG_WANT_PAGE_DEBUG_FLAGS=y
CONFIG_PAGE_GUARD=y
CONFIG_USER_STACKTRACE_SUPPORT=y
CONFIG_NOP_TRACER=y
CONFIG_HAVE_FTRACE_NMI_ENTER=y
CONFIG_HAVE_FUNCTION_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_FP_TEST=y
CONFIG_HAVE_FUNCTION_TRACE_MCOUNT_TEST=y
CONFIG_HAVE_DYNAMIC_FTRACE=y
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
CONFIG_HAVE_SYSCALL_TRACEPOINTS=y
CONFIG_HAVE_C_RECORDMCOUNT=y
CONFIG_TRACER_MAX_TRACE=y
CONFIG_RING_BUFFER=y
CONFIG_FTRACE_NMI_ENTER=y
CONFIG_EVENT_TRACING=y
CONFIG_EVENT_POWER_TRACING_DEPRECATED=y
CONFIG_CONTEXT_SWITCH_TRACER=y
CONFIG_RING_BUFFER_ALLOW_SWAP=y
CONFIG_TRACING=y
CONFIG_GENERIC_TRACER=y
CONFIG_TRACING_SUPPORT=y
CONFIG_FTRACE=y
CONFIG_FUNCTION_TRACER=y
CONFIG_FUNCTION_GRAPH_TRACER=y
# CONFIG_IRQSOFF_TRACER is not set
CONFIG_SCHED_TRACER=y
CONFIG_FTRACE_SYSCALLS=y
CONFIG_BRANCH_PROFILE_NONE=y
# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set
# CONFIG_PROFILE_ALL_BRANCHES is not set
CONFIG_STACK_TRACER=y
CONFIG_BLK_DEV_IO_TRACE=y
CONFIG_KPROBE_EVENT=y
CONFIG_DYNAMIC_FTRACE=y
CONFIG_FUNCTION_PROFILER=y
CONFIG_FTRACE_MCOUNT_RECORD=y
# CONFIG_FTRACE_STARTUP_TEST is not set
# CONFIG_MMIOTRACE is not set
CONFIG_RING_BUFFER_BENCHMARK=m
CONFIG_PROVIDE_OHCI1394_DMA_INIT=y
CONFIG_BUILD_DOCSRC=y
CONFIG_DYNAMIC_DEBUG=y
# CONFIG_DMA_API_DEBUG is not set
# CONFIG_ATOMIC64_SELFTEST is not set
# CONFIG_ASYNC_RAID6_TEST is not set
# CONFIG_SAMPLES is not set
CONFIG_HAVE_ARCH_KGDB=y
CONFIG_KGDB=y
CONFIG_KGDB_SERIAL_CONSOLE=y
CONFIG_KGDB_TESTS=y
# CONFIG_KGDB_TESTS_ON_BOOT is not set
CONFIG_KGDB_LOW_LEVEL_TRAP=y
CONFIG_KGDB_KDB=y
# CONFIG_KDB_KEYBOARD is not set
CONFIG_HAVE_ARCH_KMEMCHECK=y
# CONFIG_TEST_KSTRTOX is not set
CONFIG_STRICT_DEVMEM=y
# CONFIG_X86_VERBOSE_BOOTUP is not set
CONFIG_EARLY_PRINTK=y
CONFIG_EARLY_PRINTK_DBGP=y
CONFIG_DEBUG_STACKOVERFLOW=y
# CONFIG_X86_PTDUMP is not set
CONFIG_DEBUG_RODATA=y
CONFIG_DEBUG_RODATA_TEST=y
# CONFIG_DEBUG_SET_MODULE_RONX is not set
CONFIG_DEBUG_NX_TEST=m
# CONFIG_IOMMU_DEBUG is not set
# CONFIG_IOMMU_STRESS is not set
CONFIG_HAVE_MMIOTRACE_SUPPORT=y
# CONFIG_X86_DECODER_SELFTEST is not set
CONFIG_IO_DELAY_TYPE_0X80=0
CONFIG_IO_DELAY_TYPE_0XED=1
CONFIG_IO_DELAY_TYPE_UDELAY=2
CONFIG_IO_DELAY_TYPE_NONE=3
CONFIG_IO_DELAY_0X80=y
# CONFIG_IO_DELAY_0XED is not set
# CONFIG_IO_DELAY_UDELAY is not set
# CONFIG_IO_DELAY_NONE is not set
CONFIG_DEFAULT_IO_DELAY_TYPE=0
CONFIG_DEBUG_BOOT_PARAMS=y
# CONFIG_CPA_DEBUG is not set
CONFIG_OPTIMIZE_INLINING=y
# CONFIG_DEBUG_STRICT_USER_COPY_CHECKS is not set
# CONFIG_DEBUG_NMI_SELFTEST is not set
#
# Security options
#
CONFIG_KEYS=y
# CONFIG_TRUSTED_KEYS is not set
# CONFIG_ENCRYPTED_KEYS is not set
CONFIG_KEYS_DEBUG_PROC_KEYS=y
# CONFIG_SECURITY_DMESG_RESTRICT is not set
CONFIG_SECURITY=y
CONFIG_SECURITYFS=y
CONFIG_SECURITY_NETWORK=y
CONFIG_SECURITY_NETWORK_XFRM=y
# CONFIG_SECURITY_PATH is not set
# CONFIG_SECURITY_SELINUX is not set
# CONFIG_SECURITY_TOMOYO is not set
# CONFIG_SECURITY_APPARMOR is not set
CONFIG_INTEGRITY=y
# CONFIG_INTEGRITY_SIGNATURE is not set
CONFIG_IMA=y
CONFIG_IMA_MEASURE_PCR_IDX=10
CONFIG_IMA_AUDIT=y
# CONFIG_EVM is not set
CONFIG_DEFAULT_SECURITY_DAC=y
CONFIG_DEFAULT_SECURITY=""
CONFIG_XOR_BLOCKS=m
CONFIG_ASYNC_CORE=m
CONFIG_ASYNC_MEMCPY=m
CONFIG_ASYNC_XOR=m
CONFIG_ASYNC_PQ=m
CONFIG_ASYNC_RAID6_RECOV=m
CONFIG_ASYNC_TX_DISABLE_PQ_VAL_DMA=y
CONFIG_ASYNC_TX_DISABLE_XOR_VAL_DMA=y
CONFIG_CRYPTO=y
#
# Crypto core or helper
#
CONFIG_CRYPTO_ALGAPI=y
CONFIG_CRYPTO_ALGAPI2=y
CONFIG_CRYPTO_AEAD=m
CONFIG_CRYPTO_AEAD2=y
CONFIG_CRYPTO_BLKCIPHER=y
CONFIG_CRYPTO_BLKCIPHER2=y
CONFIG_CRYPTO_HASH=y
CONFIG_CRYPTO_HASH2=y
CONFIG_CRYPTO_RNG=m
CONFIG_CRYPTO_RNG2=y
CONFIG_CRYPTO_PCOMP=m
CONFIG_CRYPTO_PCOMP2=y
CONFIG_CRYPTO_MANAGER=y
CONFIG_CRYPTO_MANAGER2=y
# CONFIG_CRYPTO_USER is not set
CONFIG_CRYPTO_MANAGER_DISABLE_TESTS=y
CONFIG_CRYPTO_GF128MUL=m
CONFIG_CRYPTO_NULL=m
# CONFIG_CRYPTO_PCRYPT is not set
CONFIG_CRYPTO_WORKQUEUE=y
CONFIG_CRYPTO_CRYPTD=m
CONFIG_CRYPTO_AUTHENC=m
# CONFIG_CRYPTO_TEST is not set
#
# Authenticated Encryption with Associated Data
#
CONFIG_CRYPTO_CCM=m
CONFIG_CRYPTO_GCM=m
CONFIG_CRYPTO_SEQIV=m
#
# Block modes
#
CONFIG_CRYPTO_CBC=y
CONFIG_CRYPTO_CTR=m
# CONFIG_CRYPTO_CTS is not set
CONFIG_CRYPTO_ECB=m
# CONFIG_CRYPTO_LRW is not set
# CONFIG_CRYPTO_PCBC is not set
# CONFIG_CRYPTO_XTS is not set
#
# Hash modes
#
CONFIG_CRYPTO_HMAC=y
# CONFIG_CRYPTO_XCBC is not set
CONFIG_CRYPTO_VMAC=m
#
# Digest
#
CONFIG_CRYPTO_CRC32C=y
CONFIG_CRYPTO_CRC32C_INTEL=m
CONFIG_CRYPTO_GHASH=m
# CONFIG_CRYPTO_MD4 is not set
CONFIG_CRYPTO_MD5=y
# CONFIG_CRYPTO_MICHAEL_MIC is not set
# CONFIG_CRYPTO_RMD128 is not set
# CONFIG_CRYPTO_RMD160 is not set
# CONFIG_CRYPTO_RMD256 is not set
# CONFIG_CRYPTO_RMD320 is not set
CONFIG_CRYPTO_SHA1=y
# CONFIG_CRYPTO_SHA1_SSSE3 is not set
CONFIG_CRYPTO_SHA256=m
CONFIG_CRYPTO_SHA512=m
# CONFIG_CRYPTO_TGR192 is not set
# CONFIG_CRYPTO_WP512 is not set
# CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL is not set
#
# Ciphers
#
CONFIG_CRYPTO_AES=m
CONFIG_CRYPTO_AES_X86_64=m
CONFIG_CRYPTO_AES_NI_INTEL=m
# CONFIG_CRYPTO_ANUBIS is not set
CONFIG_CRYPTO_ARC4=m
# CONFIG_CRYPTO_BLOWFISH is not set
# CONFIG_CRYPTO_BLOWFISH_X86_64 is not set
# CONFIG_CRYPTO_CAMELLIA is not set
CONFIG_CRYPTO_CAST5=m
# CONFIG_CRYPTO_CAST6 is not set
CONFIG_CRYPTO_DES=y
# CONFIG_CRYPTO_FCRYPT is not set
# CONFIG_CRYPTO_KHAZAD is not set
# CONFIG_CRYPTO_SALSA20 is not set
# CONFIG_CRYPTO_SALSA20_X86_64 is not set
# CONFIG_CRYPTO_SEED is not set
# CONFIG_CRYPTO_SERPENT is not set
# CONFIG_CRYPTO_SERPENT_SSE2_X86_64 is not set
# CONFIG_CRYPTO_TEA is not set
# CONFIG_CRYPTO_TWOFISH is not set
# CONFIG_CRYPTO_TWOFISH_X86_64 is not set
# CONFIG_CRYPTO_TWOFISH_X86_64_3WAY is not set
#
# Compression
#
CONFIG_CRYPTO_DEFLATE=m
CONFIG_CRYPTO_ZLIB=m
CONFIG_CRYPTO_LZO=m
#
# Random Number Generation
#
CONFIG_CRYPTO_ANSI_CPRNG=m
# CONFIG_CRYPTO_USER_API_HASH is not set
# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
# CONFIG_CRYPTO_HW is not set
CONFIG_HAVE_KVM=y
# CONFIG_VIRTUALIZATION is not set
CONFIG_BINARY_PRINTF=y
#
# Library routines
#
CONFIG_RAID6_PQ=m
CONFIG_BITREVERSE=y
CONFIG_GENERIC_FIND_FIRST_BIT=y
CONFIG_GENERIC_PCI_IOMAP=y
CONFIG_GENERIC_IOMAP=y
CONFIG_CRC_CCITT=m
CONFIG_CRC16=y
CONFIG_CRC_T10DIF=y
CONFIG_CRC_ITU_T=m
CONFIG_CRC32=y
# CONFIG_CRC7 is not set
CONFIG_LIBCRC32C=m
# CONFIG_CRC8 is not set
CONFIG_ZLIB_INFLATE=y
CONFIG_ZLIB_DEFLATE=m
CONFIG_LZO_COMPRESS=y
CONFIG_LZO_DECOMPRESS=y
CONFIG_XZ_DEC=y
CONFIG_XZ_DEC_X86=y
CONFIG_XZ_DEC_POWERPC=y
CONFIG_XZ_DEC_IA64=y
CONFIG_XZ_DEC_ARM=y
CONFIG_XZ_DEC_ARMTHUMB=y
CONFIG_XZ_DEC_SPARC=y
CONFIG_XZ_DEC_BCJ=y
# CONFIG_XZ_DEC_TEST is not set
CONFIG_DECOMPRESS_GZIP=y
CONFIG_DECOMPRESS_BZIP2=y
CONFIG_DECOMPRESS_LZMA=y
CONFIG_DECOMPRESS_XZ=y
CONFIG_DECOMPRESS_LZO=y
CONFIG_HAS_IOMEM=y
CONFIG_HAS_IOPORT=y
CONFIG_HAS_DMA=y
CONFIG_CPU_RMAP=y
CONFIG_DQL=y
CONFIG_NLATTR=y
# CONFIG_AVERAGE is not set
# CONFIG_CORDIC is not set
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-23 17:48 [PATCH] SUNRPC: fix use-after-free of rpc pipes Fred Isaman
2012-02-24 11:03 ` Stanislav Kinsbursky
@ 2012-02-24 11:47 ` Stanislav Kinsbursky
2012-02-24 13:17 ` Fred Isaman
2012-02-24 18:14 ` Stanislav Kinsbursky
2 siblings, 1 reply; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-24 11:47 UTC (permalink / raw)
To: Fred Isaman; +Cc: linux-nfs@vger.kernel.org
BTW, it looks very strange...
Now many networks namespaces do you use?
23.02.2012 21:48, Fred Isaman пишет:
> This needs to be looked at closely by someone more familiar with the
> pipe code.
>
> It fixes an issue with the current nfs_for_next branch which causes a
> chain of oopses on umount every time if sufficient CONFIG_* debug
> options are set.
>
> A git-bisect shows that the problem was introduced by
> commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
>
> A typical oops starts with:
>
> general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
> CPU 0
> Modules linked in: nfs_layout_nfsv41_files nfs auth_rpcgss nfs_acl lockd ppdev parport_pc parport e1000 i2c_piix4 shpchp i2c_core sunrpc autofs4 mptspi mptscsih mptbase scsi_transport_spi floppy [last unloaded: scsi_wait_scan]
>
> Pid: 834, comm: rpc.idmapd Not tainted 3.3.0-rc2-kitchensink+ #51 VMware, Inc. VMware Virtual Platform/440BX Desktop
> Reference Platform
> RIP: 0010:[<ffffffff81079979>] [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2
> RSP: 0018:ffff8800367bfcb8 EFLAGS: 00010002
> RAX: 6b6b6b6b6b6b6b6b RBX: ffff88003bb8a0b0 RCX: 0000000000000000
> RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff88002ca779c0
> RBP: ffff8800367bfd88 R08: 0000000000000002 R09: 0000000000000001
> R10: 0000000000000000 R11: ffff88002ca779c0 R12: 0000000000000286
> R13: ffff88002ca779c0 R14: 0000000000000002 R15: 0000000000000000
> FS: 00007f7ff3dab700(0000) GS:ffff88003fa00000(0000) knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> CR2: 00007f5305ae1000 CR3: 000000003ae4e000 CR4: 00000000000406f0
> DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
> Process rpc.idmapd (pid: 834, threadinfo ffff8800367be000, task ffff88003bb8a0b0)
> Stack:
> 0000000000000000 ffffffff81235f78 ffff8800367bfd08 ffffffff810788c4
> ffff8800367bfd18 ffff880000000000 ffff880000000000 ffffffff00000000
> 00000000000001df ffff880000000001 ffff88003bb8a730 ffffffff81a24730
> Call Trace:
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> Code: 8d 58 ff ff ff 44 89 8d 48 ff ff ff 4c 89 ef e8 f6 fa ff ff 48 8b 8d 58 ff ff ff 48 85 c0 44 8b 8d 48 ff ff ff
> 0f 84 99 0c 00 00<3e> ff 80 98 01 00 00 8b 93 78 06 00 00 83 3d 87 83 b8 00 00 89
> RIP [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2 RSP<ffff8800367bfcb8>
> ---[ end trace ffe7d1c1af2c62f6 ]---
> BUG: sleeping function called from invalid context at /home/iisaman/projects/pnfs-file/src/linux-pnfs/kernel/rwsem.c
> :21
> in_atomic(): 1, irqs_disabled(): 1, pid: 834, name: rpc.idmapd
> INFO: lockdep is turned off.
> irq event stamp: 4308
> hardirqs last enabled at (4307): [<ffffffff81434d53>] __mutex_lock_common+0x37b/0x3af
> hardirqs last disabled at (4308): [<ffffffff81436c87>] _raw_spin_lock_irqsave+0x29/0x6a
> softirqs last enabled at (3992): [<ffffffff810378e3>] __do_softirq+0x1e6/0x205
> softirqs last disabled at (3783): [<ffffffff8143f92c>] call_softirq+0x1c/0x30
> Pid: 834, comm: rpc.idmapd Tainted: G D 3.3.0-rc2-kitchensink+ #51
> Call Trace:
> [<ffffffff81059bb7>] __might_sleep+0x107/0x10c
> [<ffffffff81435499>] down_read+0x24/0x61
> [<ffffffff810433e5>] exit_signals+0x26/0x12c
> [<ffffffff81053fdc>] ? blocking_notifier_call_chain+0x14/0x16
> [<ffffffff81034e53>] do_exit+0x118/0x7d9
> [<ffffffff81031cda>] ? kmsg_dump+0x126/0x144
> [<ffffffff81031c3c>] ? kmsg_dump+0x88/0x144
> [<ffffffff81438422>] oops_end+0xc0/0xc8
> [<ffffffff81004d96>] die+0x5a/0x63
> [<ffffffff81438272>] do_general_protection+0x12a/0x132
> [<ffffffff81437764>] ? restore_args+0x30/0x30
> [<ffffffff81437915>] general_protection+0x25/0x30
> [<ffffffff81079979>] ? __lock_acquire+0xd8/0xdd2
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d
> [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> note: rpc.idmapd[834] exited with preempt_count 1
> BUG: scheduling while atomic: rpc.idmapd/834/0x10000002
> INFO: lockdep is turned off.
>
> Signed-off-by: Fred Isaman<iisaman@netapp.com>
> ---
> fs/nfs/blocklayout/blocklayout.c | 1 -
> fs/nfs/idmap.c | 1 -
> net/sunrpc/auth_gss/auth_gss.c | 2 --
> net/sunrpc/rpc_pipe.c | 2 ++
> 4 files changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
> index 783ebd5..26fcbd1 100644
> --- a/fs/nfs/blocklayout/blocklayout.c
> +++ b/fs/nfs/blocklayout/blocklayout.c
> @@ -1134,7 +1134,6 @@ static void nfs4blocklayout_net_exit(struct net *net)
> struct nfs_net *nn = net_generic(net, nfs_net_id);
>
> nfs4blocklayout_unregister_net(net, nn->bl_device_pipe);
> - rpc_destroy_pipe_data(nn->bl_device_pipe);
> nn->bl_device_pipe = NULL;
> }
>
> diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c
> index b5c6d8e..384fbed 100644
> --- a/fs/nfs/idmap.c
> +++ b/fs/nfs/idmap.c
> @@ -508,7 +508,6 @@ nfs_idmap_delete(struct nfs_client *clp)
> if (!idmap)
> return;
> nfs_idmap_unregister(clp, idmap->idmap_pipe);
> - rpc_destroy_pipe_data(idmap->idmap_pipe);
> clp->cl_idmap = NULL;
> idmap_free_hashtable(&idmap->idmap_user_hash);
> idmap_free_hashtable(&idmap->idmap_group_hash);
> diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
> index cb2e564..6be27ec 100644
> --- a/net/sunrpc/auth_gss/auth_gss.c
> +++ b/net/sunrpc/auth_gss/auth_gss.c
> @@ -908,8 +908,6 @@ static void
> gss_free(struct gss_auth *gss_auth)
> {
> gss_pipes_dentries_destroy_net(gss_auth->client,&gss_auth->rpc_auth);
> - rpc_destroy_pipe_data(gss_auth->pipe[0]);
> - rpc_destroy_pipe_data(gss_auth->pipe[1]);
> gss_mech_put(gss_auth->mech);
>
> kfree(gss_auth);
> diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
> index 6873c9b..61ad698 100644
> --- a/net/sunrpc/rpc_pipe.c
> +++ b/net/sunrpc/rpc_pipe.c
> @@ -191,6 +191,8 @@ static void
> rpc_i_callback(struct rcu_head *head)
> {
> struct inode *inode = container_of(head, struct inode, i_rcu);
> + rpc_destroy_pipe_data(RPC_I(inode)->pipe);
> + RPC_I(inode)->pipe = NULL;
> kmem_cache_free(rpc_inode_cachep, RPC_I(inode));
> }
>
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-24 11:47 ` Stanislav Kinsbursky
@ 2012-02-24 13:17 ` Fred Isaman
2012-02-24 14:01 ` Stanislav Kinsbursky
0 siblings, 1 reply; 12+ messages in thread
From: Fred Isaman @ 2012-02-24 13:17 UTC (permalink / raw)
To: Stanislav Kinsbursky; +Cc: linux-nfs@vger.kernel.org
On Feb 24, 2012, at 3:47 AM, Stanislav Kinsbursky wrote:
> BTW, it looks very strange...
> Now many networks namespaces do you use?
>
Not sure, I definitely was not intentionally adding any, so I assume one. This was reproduced on Fedora 12, Fedora 16 and recent RHEL distros with custom kernels installed.
The Fedora 16 install was a fresh install onto a VMWare Fusion guest with two NICs (one NAT and one bridged), though the bridged one was turned off.
Fred
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-24 13:17 ` Fred Isaman
@ 2012-02-24 14:01 ` Stanislav Kinsbursky
0 siblings, 0 replies; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-24 14:01 UTC (permalink / raw)
To: Fred Isaman; +Cc: linux-nfs@vger.kernel.org
24.02.2012 17:17, Fred Isaman пишет:
>
> On Feb 24, 2012, at 3:47 AM, Stanislav Kinsbursky wrote:
>
>> BTW, it looks very strange...
>> Now many networks namespaces do you use?
>>
>
> Not sure, I definitely was not intentionally adding any, so I assume one. This was reproduced on Fedora 12, Fedora 16 and recent RHEL distros with custom kernels installed.
>
> The Fedora 16 install was a fresh install onto a VMWare Fusion guest with two NICs (one NAT and one bridged), though the bridged one was turned off.
>
>
Ok, thanks, Fred.
Will try to reproduce.
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-23 17:48 [PATCH] SUNRPC: fix use-after-free of rpc pipes Fred Isaman
2012-02-24 11:03 ` Stanislav Kinsbursky
2012-02-24 11:47 ` Stanislav Kinsbursky
@ 2012-02-24 18:14 ` Stanislav Kinsbursky
2012-02-26 23:52 ` Myklebust, Trond
2 siblings, 1 reply; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-24 18:14 UTC (permalink / raw)
To: Fred Isaman; +Cc: linux-nfs@vger.kernel.org
23.02.2012 21:48, Fred Isaman пишет:
> This needs to be looked at closely by someone more familiar with the
> pipe code.
>
> It fixes an issue with the current nfs_for_next branch which causes a
> chain of oopses on umount every time if sufficient CONFIG_* debug
> options are set.
>
> A git-bisect shows that the problem was introduced by
> commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
>
Fred, thanks for the config.
The problem is caused by destroying pipe data on NFS client umount after
unlinking pipe dentry. This is valid approach, but it looks like idmap daemon
holds dentry by eventfd.
This is a race between idmap daemon release of this dentry and releasing of pipe
data...
I need some time to find out how to fix this properly.
> A typical oops starts with:
>
> general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
> CPU 0
> Modules linked in: nfs_layout_nfsv41_files nfs auth_rpcgss nfs_acl lockd ppdev parport_pc parport e1000 i2c_piix4 shpchp i2c_core sunrpc autofs4 mptspi mptscsih mptbase scsi_transport_spi floppy [last unloaded: scsi_wait_scan]
>
> Pid: 834, comm: rpc.idmapd Not tainted 3.3.0-rc2-kitchensink+ #51 VMware, Inc. VMware Virtual Platform/440BX Desktop
> Reference Platform
> RIP: 0010:[<ffffffff81079979>] [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2
> RSP: 0018:ffff8800367bfcb8 EFLAGS: 00010002
> RAX: 6b6b6b6b6b6b6b6b RBX: ffff88003bb8a0b0 RCX: 0000000000000000
> RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff88002ca779c0
> RBP: ffff8800367bfd88 R08: 0000000000000002 R09: 0000000000000001
> R10: 0000000000000000 R11: ffff88002ca779c0 R12: 0000000000000286
> R13: ffff88002ca779c0 R14: 0000000000000002 R15: 0000000000000000
> FS: 00007f7ff3dab700(0000) GS:ffff88003fa00000(0000) knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> CR2: 00007f5305ae1000 CR3: 000000003ae4e000 CR4: 00000000000406f0
> DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
> Process rpc.idmapd (pid: 834, threadinfo ffff8800367be000, task ffff88003bb8a0b0)
> Stack:
> 0000000000000000 ffffffff81235f78 ffff8800367bfd08 ffffffff810788c4
> ffff8800367bfd18 ffff880000000000 ffff880000000000 ffffffff00000000
> 00000000000001df ffff880000000001 ffff88003bb8a730 ffffffff81a24730
> Call Trace:
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> Code: 8d 58 ff ff ff 44 89 8d 48 ff ff ff 4c 89 ef e8 f6 fa ff ff 48 8b 8d 58 ff ff ff 48 85 c0 44 8b 8d 48 ff ff ff
> 0f 84 99 0c 00 00<3e> ff 80 98 01 00 00 8b 93 78 06 00 00 83 3d 87 83 b8 00 00 89
> RIP [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2 RSP<ffff8800367bfcb8>
> ---[ end trace ffe7d1c1af2c62f6 ]---
> BUG: sleeping function called from invalid context at /home/iisaman/projects/pnfs-file/src/linux-pnfs/kernel/rwsem.c
> :21
> in_atomic(): 1, irqs_disabled(): 1, pid: 834, name: rpc.idmapd
> INFO: lockdep is turned off.
> irq event stamp: 4308
> hardirqs last enabled at (4307): [<ffffffff81434d53>] __mutex_lock_common+0x37b/0x3af
> hardirqs last disabled at (4308): [<ffffffff81436c87>] _raw_spin_lock_irqsave+0x29/0x6a
> softirqs last enabled at (3992): [<ffffffff810378e3>] __do_softirq+0x1e6/0x205
> softirqs last disabled at (3783): [<ffffffff8143f92c>] call_softirq+0x1c/0x30
> Pid: 834, comm: rpc.idmapd Tainted: G D 3.3.0-rc2-kitchensink+ #51
> Call Trace:
> [<ffffffff81059bb7>] __might_sleep+0x107/0x10c
> [<ffffffff81435499>] down_read+0x24/0x61
> [<ffffffff810433e5>] exit_signals+0x26/0x12c
> [<ffffffff81053fdc>] ? blocking_notifier_call_chain+0x14/0x16
> [<ffffffff81034e53>] do_exit+0x118/0x7d9
> [<ffffffff81031cda>] ? kmsg_dump+0x126/0x144
> [<ffffffff81031c3c>] ? kmsg_dump+0x88/0x144
> [<ffffffff81438422>] oops_end+0xc0/0xc8
> [<ffffffff81004d96>] die+0x5a/0x63
> [<ffffffff81438272>] do_general_protection+0x12a/0x132
> [<ffffffff81437764>] ? restore_args+0x30/0x30
> [<ffffffff81437915>] general_protection+0x25/0x30
> [<ffffffff81079979>] ? __lock_acquire+0xd8/0xdd2
> [<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
> [<ffffffff810788c4>] ? mark_lock+0x2d/0x233
> [<ffffffff8107a775>] lock_acquire+0x102/0x12f
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
> [<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
> [<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
> [<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
> [<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
> [<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
> [<ffffffff8115379b>] ep_remove+0x25/0x9f
> [<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
> [<ffffffff8143e415>] ? sysret_check+0x22/0x5d
> [<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d
> [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
> [<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
> note: rpc.idmapd[834] exited with preempt_count 1
> BUG: scheduling while atomic: rpc.idmapd/834/0x10000002
> INFO: lockdep is turned off.
>
> Signed-off-by: Fred Isaman<iisaman@netapp.com>
> ---
> fs/nfs/blocklayout/blocklayout.c | 1 -
> fs/nfs/idmap.c | 1 -
> net/sunrpc/auth_gss/auth_gss.c | 2 --
> net/sunrpc/rpc_pipe.c | 2 ++
> 4 files changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
> index 783ebd5..26fcbd1 100644
> --- a/fs/nfs/blocklayout/blocklayout.c
> +++ b/fs/nfs/blocklayout/blocklayout.c
> @@ -1134,7 +1134,6 @@ static void nfs4blocklayout_net_exit(struct net *net)
> struct nfs_net *nn = net_generic(net, nfs_net_id);
>
> nfs4blocklayout_unregister_net(net, nn->bl_device_pipe);
> - rpc_destroy_pipe_data(nn->bl_device_pipe);
> nn->bl_device_pipe = NULL;
> }
>
> diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c
> index b5c6d8e..384fbed 100644
> --- a/fs/nfs/idmap.c
> +++ b/fs/nfs/idmap.c
> @@ -508,7 +508,6 @@ nfs_idmap_delete(struct nfs_client *clp)
> if (!idmap)
> return;
> nfs_idmap_unregister(clp, idmap->idmap_pipe);
> - rpc_destroy_pipe_data(idmap->idmap_pipe);
> clp->cl_idmap = NULL;
> idmap_free_hashtable(&idmap->idmap_user_hash);
> idmap_free_hashtable(&idmap->idmap_group_hash);
> diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
> index cb2e564..6be27ec 100644
> --- a/net/sunrpc/auth_gss/auth_gss.c
> +++ b/net/sunrpc/auth_gss/auth_gss.c
> @@ -908,8 +908,6 @@ static void
> gss_free(struct gss_auth *gss_auth)
> {
> gss_pipes_dentries_destroy_net(gss_auth->client,&gss_auth->rpc_auth);
> - rpc_destroy_pipe_data(gss_auth->pipe[0]);
> - rpc_destroy_pipe_data(gss_auth->pipe[1]);
> gss_mech_put(gss_auth->mech);
>
> kfree(gss_auth);
> diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
> index 6873c9b..61ad698 100644
> --- a/net/sunrpc/rpc_pipe.c
> +++ b/net/sunrpc/rpc_pipe.c
> @@ -191,6 +191,8 @@ static void
> rpc_i_callback(struct rcu_head *head)
> {
> struct inode *inode = container_of(head, struct inode, i_rcu);
> + rpc_destroy_pipe_data(RPC_I(inode)->pipe);
> + RPC_I(inode)->pipe = NULL;
> kmem_cache_free(rpc_inode_cachep, RPC_I(inode));
> }
>
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-24 18:14 ` Stanislav Kinsbursky
@ 2012-02-26 23:52 ` Myklebust, Trond
2012-02-27 12:51 ` Stanislav Kinsbursky
0 siblings, 1 reply; 12+ messages in thread
From: Myklebust, Trond @ 2012-02-26 23:52 UTC (permalink / raw)
To: Stanislav Kinsbursky; +Cc: Isaman, Fred, linux-nfs@vger.kernel.org
T24gRnJpLCAyMDEyLTAyLTI0IGF0IDIyOjE0ICswNDAwLCBTdGFuaXNsYXYgS2luc2J1cnNreSB3
cm90ZToNCj4gMjMuMDIuMjAxMiAyMTo0OCwgRnJlZCBJc2FtYW4g0L/QuNGI0LXRgjoNCj4gPiBU
aGlzIG5lZWRzIHRvIGJlIGxvb2tlZCBhdCBjbG9zZWx5IGJ5IHNvbWVvbmUgbW9yZSBmYW1pbGlh
ciB3aXRoIHRoZQ0KPiA+IHBpcGUgY29kZS4NCj4gPg0KPiA+IEl0IGZpeGVzIGFuIGlzc3VlIHdp
dGggdGhlIGN1cnJlbnQgbmZzX2Zvcl9uZXh0IGJyYW5jaCB3aGljaCBjYXVzZXMgYQ0KPiA+IGNo
YWluIG9mIG9vcHNlcyBvbiB1bW91bnQgZXZlcnkgdGltZSBpZiBzdWZmaWNpZW50IENPTkZJR18q
IGRlYnVnDQo+ID4gb3B0aW9ucyBhcmUgc2V0Lg0KPiA+DQo+ID4gQSBnaXQtYmlzZWN0IHNob3dz
IHRoYXQgdGhlIHByb2JsZW0gd2FzIGludHJvZHVjZWQgYnkNCj4gPiBjb21taXQgYzIzOWQ4M2Ig
IFNVTlJQQzogc3BsaXQgU1VOUFJDIFBpcGVGUyBkZW50cnkgYW5kIHByaXZhdGUgcGlwZSBkYXRh
IGNyZWF0aW9uDQo+ID4NCj4gDQo+IA0KPiANCj4gRnJlZCwgdGhhbmtzIGZvciB0aGUgY29uZmln
Lg0KPiBUaGUgcHJvYmxlbSBpcyBjYXVzZWQgYnkgZGVzdHJveWluZyBwaXBlIGRhdGEgb24gTkZT
IGNsaWVudCB1bW91bnQgYWZ0ZXIgDQo+IHVubGlua2luZyBwaXBlIGRlbnRyeS4gVGhpcyBpcyB2
YWxpZCBhcHByb2FjaCwgYnV0IGl0IGxvb2tzIGxpa2UgaWRtYXAgZGFlbW9uIA0KPiBob2xkcyBk
ZW50cnkgYnkgZXZlbnRmZC4NCj4gVGhpcyBpcyBhIHJhY2UgYmV0d2VlbiBpZG1hcCBkYWVtb24g
cmVsZWFzZSBvZiB0aGlzIGRlbnRyeSBhbmQgcmVsZWFzaW5nIG9mIHBpcGUgDQo+IGRhdGEuLi4N
Cj4gSSBuZWVkIHNvbWUgdGltZSB0byBmaW5kIG91dCBob3cgdG8gZml4IHRoaXMgcHJvcGVybHku
DQo+IA0KDQpIb3cgYWJvdXQgc29tZXRoaW5nIGxpa2UgdGhlIGZvbGxvd2luZyAoc3RpbGwgdW50
ZXN0ZWQpIHBhdGNoPw0KDQpDaGVlcnMNCiAgVHJvbmQNCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t
LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t
LS0tLS0tLS0NCkZyb20gNTRiYWE0NGJhMDE1NTliOWJiMzM3ZDY4Nzc0NThkZDZlMTJkMzZhYSBN
b24gU2VwIDE3IDAwOjAwOjAwIDIwMDENCkZyb206IFRyb25kIE15a2xlYnVzdCA8VHJvbmQuTXlr
bGVidXN0QG5ldGFwcC5jb20+DQpEYXRlOiBTdW4sIDI2IEZlYiAyMDEyIDE4OjI1OjU2IC0wNTAw
DQpTdWJqZWN0OiBbUEFUQ0hdIFNVTlJQQzogRW5zdXJlIHRoYXQgdGhlIHJwY19waXBlIGxpZmV0
aW1lIG1hdGNoZXMgdGhhdCBvZg0KIHRoZSBkZW50cnkNCg0KSXQgaXMgZXhwZWN0ZWQgdGhhdCBk
YWVtb25zIG1heSBob2xkIG9udG8gdGhlIHJwY19waXBlZnMgZGVudHJpZXMNCmV2ZW4gaWYgdGhl
IGxpc3RlbmVycyBoYXZlIGRpc2FwcGVhcmVkLiBDdXJyZW50bHksIHdlIGVuZCB1cCBPb3BzaW5n
DQppbiB0aGlzIGNhc2UsIGJlY2F1c2UgdGhlIHJwY19waXBlIGlzIGRlc3Ryb3llZCBiZWZvcmUg
dGhlIGRlbnRyeS4NCg0KVGhpcyBwYXRjaCBhZGRzIHJlZmNvdW50aW5nIHRvIHRoZSBycGNfcGlw
ZSwgYW5kIGVuc3VyZXMgdGhhdCBpdCBjYW4NCmJlIHNhZmVseSBzaGFyZWQsIGJlaW5nIGRlc3Ry
b3llZCBvbmx5IHdoZW4gdGhlIGxhc3QgZGVudHJ5IHRoYXQNCnJlZmVyZW5jZXMgaXQgaXMgZGVz
dHJveWVkLg0KDQpTaWduZWQtb2ZmLWJ5OiBUcm9uZCBNeWtsZWJ1c3QgPFRyb25kLk15a2xlYnVz
dEBuZXRhcHAuY29tPg0KLS0tDQogZnMvbmZzL2Jsb2NrbGF5b3V0L2Jsb2NrbGF5b3V0LmMgICB8
ICAgIDggKystLS0tLS0NCiBmcy9uZnMvaWRtYXAuYyAgICAgICAgICAgICAgICAgICAgIHwgICAx
MSArKysrKy0tLS0tLQ0KIGluY2x1ZGUvbGludXgvc3VucnBjL3JwY19waXBlX2ZzLmggfCAgIDEw
ICsrKysrKysrKy0NCiBuZXQvc3VucnBjL2F1dGhfZ3NzL2F1dGhfZ3NzLmMgICAgIHwgICAxOSAr
KysrKysrKystLS0tLS0tLS0tDQogbmV0L3N1bnJwYy9ycGNfcGlwZS5jICAgICAgICAgICAgICB8
ICAgMjUgKysrKysrKysrKysrKysrKysrKysrKy0tLQ0KIDUgZmlsZXMgY2hhbmdlZCwgNDcgaW5z
ZXJ0aW9ucygrKSwgMjYgZGVsZXRpb25zKC0pDQoNCmRpZmYgLS1naXQgYS9mcy9uZnMvYmxvY2ts
YXlvdXQvYmxvY2tsYXlvdXQuYyBiL2ZzL25mcy9ibG9ja2xheW91dC9ibG9ja2xheW91dC5jDQpp
bmRleCA3ODNlYmQ1Li4yNjM5ZDUzIDEwMDY0NA0KLS0tIGEvZnMvbmZzL2Jsb2NrbGF5b3V0L2Js
b2NrbGF5b3V0LmMNCisrKyBiL2ZzL25mcy9ibG9ja2xheW91dC9ibG9ja2xheW91dC5jDQpAQCAt
MTA2Myw2ICsxMDYzLDcgQEAgc3RhdGljIGludCBycGNfcGlwZWZzX2V2ZW50KHN0cnVjdCBub3Rp
Zmllcl9ibG9jayAqbmIsIHVuc2lnbmVkIGxvbmcgZXZlbnQsDQogDQogCXN3aXRjaCAoZXZlbnQp
IHsNCiAJY2FzZSBSUENfUElQRUZTX01PVU5UOg0KKwkJcnBjX2dldF9waXBlX2RhdGEobm4tPmJs
X2RldmljZV9waXBlKTsNCiAJCWRlbnRyeSA9IG5mczRibG9ja2xheW91dF9yZWdpc3Rlcl9zYihz
Yiwgbm4tPmJsX2RldmljZV9waXBlKTsNCiAJCWlmIChJU19FUlIoZGVudHJ5KSkgew0KIAkJCXJl
dCA9IFBUUl9FUlIoZGVudHJ5KTsNCkBAIC0xMDk2LDcgKzEwOTcsNiBAQCBzdGF0aWMgc3RydWN0
IGRlbnRyeSAqbmZzNGJsb2NrbGF5b3V0X3JlZ2lzdGVyX25ldChzdHJ1Y3QgbmV0ICpuZXQsDQog
CWlmICghcGlwZWZzX3NiKQ0KIAkJcmV0dXJuIE5VTEw7DQogCWRlbnRyeSA9IG5mczRibG9ja2xh
eW91dF9yZWdpc3Rlcl9zYihwaXBlZnNfc2IsIHBpcGUpOw0KLQlycGNfcHV0X3NiX25ldChuZXQp
Ow0KIAlyZXR1cm4gZGVudHJ5Ow0KIH0NCiANCkBAIC0xMTA4LDcgKzExMDgsNiBAQCBzdGF0aWMg
dm9pZCBuZnM0YmxvY2tsYXlvdXRfdW5yZWdpc3Rlcl9uZXQoc3RydWN0IG5ldCAqbmV0LA0KIAlw
aXBlZnNfc2IgPSBycGNfZ2V0X3NiX25ldChuZXQpOw0KIAlpZiAocGlwZWZzX3NiKSB7DQogCQlu
ZnM0YmxvY2tsYXlvdXRfdW5yZWdpc3Rlcl9zYihwaXBlZnNfc2IsIHBpcGUpOw0KLQkJcnBjX3B1
dF9zYl9uZXQobmV0KTsNCiAJfQ0KIH0NCiANCkBAIC0xMTIxLDEwICsxMTIwLDggQEAgc3RhdGlj
IGludCBuZnM0YmxvY2tsYXlvdXRfbmV0X2luaXQoc3RydWN0IG5ldCAqbmV0KQ0KIAlpZiAoSVNf
RVJSKG5uLT5ibF9kZXZpY2VfcGlwZSkpDQogCQlyZXR1cm4gUFRSX0VSUihubi0+YmxfZGV2aWNl
X3BpcGUpOw0KIAlkZW50cnkgPSBuZnM0YmxvY2tsYXlvdXRfcmVnaXN0ZXJfbmV0KG5ldCwgbm4t
PmJsX2RldmljZV9waXBlKTsNCi0JaWYgKElTX0VSUihkZW50cnkpKSB7DQotCQlycGNfZGVzdHJv
eV9waXBlX2RhdGEobm4tPmJsX2RldmljZV9waXBlKTsNCisJaWYgKElTX0VSUihkZW50cnkpKQ0K
IAkJcmV0dXJuIFBUUl9FUlIoZGVudHJ5KTsNCi0JfQ0KIAlubi0+YmxfZGV2aWNlX3BpcGUtPmRl
bnRyeSA9IGRlbnRyeTsNCiAJcmV0dXJuIDA7DQogfQ0KQEAgLTExMzQsNyArMTEzMSw2IEBAIHN0
YXRpYyB2b2lkIG5mczRibG9ja2xheW91dF9uZXRfZXhpdChzdHJ1Y3QgbmV0ICpuZXQpDQogCXN0
cnVjdCBuZnNfbmV0ICpubiA9IG5ldF9nZW5lcmljKG5ldCwgbmZzX25ldF9pZCk7DQogDQogCW5m
czRibG9ja2xheW91dF91bnJlZ2lzdGVyX25ldChuZXQsIG5uLT5ibF9kZXZpY2VfcGlwZSk7DQot
CXJwY19kZXN0cm95X3BpcGVfZGF0YShubi0+YmxfZGV2aWNlX3BpcGUpOw0KIAlubi0+YmxfZGV2
aWNlX3BpcGUgPSBOVUxMOw0KIH0NCiANCmRpZmYgLS1naXQgYS9mcy9uZnMvaWRtYXAuYyBiL2Zz
L25mcy9pZG1hcC5jDQppbmRleCBiNWM2ZDhlLi4yMzRjMGE0IDEwMDY0NA0KLS0tIGEvZnMvbmZz
L2lkbWFwLmMNCisrKyBiL2ZzL25mcy9pZG1hcC5jDQpAQCAtNDYzLDcgKzQ2Myw2IEBAIG5mc19p
ZG1hcF9uZXcoc3RydWN0IG5mc19jbGllbnQgKmNscCkNCiAJfQ0KIAllcnJvciA9IG5mc19pZG1h
cF9yZWdpc3RlcihjbHAsIGlkbWFwLCBwaXBlKTsNCiAJaWYgKGVycm9yKSB7DQotCQlycGNfZGVz
dHJveV9waXBlX2RhdGEocGlwZSk7DQogCQlrZnJlZShpZG1hcCk7DQogCQlyZXR1cm4gZXJyb3I7
DQogCX0NCkBAIC01MDgsNyArNTA3LDYgQEAgbmZzX2lkbWFwX2RlbGV0ZShzdHJ1Y3QgbmZzX2Ns
aWVudCAqY2xwKQ0KIAlpZiAoIWlkbWFwKQ0KIAkJcmV0dXJuOw0KIAluZnNfaWRtYXBfdW5yZWdp
c3RlcihjbHAsIGlkbWFwLT5pZG1hcF9waXBlKTsNCi0JcnBjX2Rlc3Ryb3lfcGlwZV9kYXRhKGlk
bWFwLT5pZG1hcF9waXBlKTsNCiAJY2xwLT5jbF9pZG1hcCA9IE5VTEw7DQogCWlkbWFwX2ZyZWVf
aGFzaHRhYmxlKCZpZG1hcC0+aWRtYXBfdXNlcl9oYXNoKTsNCiAJaWRtYXBfZnJlZV9oYXNodGFi
bGUoJmlkbWFwLT5pZG1hcF9ncm91cF9oYXNoKTsNCkBAIC01MTgsNiArNTE2LDcgQEAgbmZzX2lk
bWFwX2RlbGV0ZShzdHJ1Y3QgbmZzX2NsaWVudCAqY2xwKQ0KIHN0YXRpYyBpbnQgX19ycGNfcGlw
ZWZzX2V2ZW50KHN0cnVjdCBuZnNfY2xpZW50ICpjbHAsIHVuc2lnbmVkIGxvbmcgZXZlbnQsDQog
CQkJICAgICAgc3RydWN0IHN1cGVyX2Jsb2NrICpzYikNCiB7DQorCXN0cnVjdCBycGNfcGlwZSAq
cGlwZSA9IGNscC0+Y2xfaWRtYXAtPmlkbWFwX3BpcGU7DQogCWludCBlcnIgPSAwOw0KIA0KIAlz
d2l0Y2ggKGV2ZW50KSB7DQpAQCAtNTI1LDE0ICs1MjQsMTQgQEAgc3RhdGljIGludCBfX3JwY19w
aXBlZnNfZXZlbnQoc3RydWN0IG5mc19jbGllbnQgKmNscCwgdW5zaWduZWQgbG9uZyBldmVudCwN
CiAJCUJVR19PTihjbHAtPmNsX3JwY2NsaWVudC0+Y2xfZGVudHJ5ID09IE5VTEwpOw0KIAkJZXJy
ID0gX19uZnNfaWRtYXBfcmVnaXN0ZXIoY2xwLT5jbF9ycGNjbGllbnQtPmNsX2RlbnRyeSwNCiAJ
CQkJCQljbHAtPmNsX2lkbWFwLA0KLQkJCQkJCWNscC0+Y2xfaWRtYXAtPmlkbWFwX3BpcGUpOw0K
KwkJCQkJCXJwY19nZXRfcGlwZV9kYXRhKHBpcGUpKTsNCiAJCWJyZWFrOw0KIAljYXNlIFJQQ19Q
SVBFRlNfVU1PVU5UOg0KLQkJaWYgKGNscC0+Y2xfaWRtYXAtPmlkbWFwX3BpcGUpIHsNCisJCWlm
IChwaXBlKSB7DQogCQkJc3RydWN0IGRlbnRyeSAqcGFyZW50Ow0KIA0KLQkJCXBhcmVudCA9IGNs
cC0+Y2xfaWRtYXAtPmlkbWFwX3BpcGUtPmRlbnRyeS0+ZF9wYXJlbnQ7DQotCQkJX19uZnNfaWRt
YXBfdW5yZWdpc3RlcihjbHAtPmNsX2lkbWFwLT5pZG1hcF9waXBlKTsNCisJCQlwYXJlbnQgPSBw
aXBlLT5kZW50cnktPmRfcGFyZW50Ow0KKwkJCV9fbmZzX2lkbWFwX3VucmVnaXN0ZXIocGlwZSk7
DQogCQkJLyoNCiAJCQkgKiBOb3RlOiBUaGlzIGlzIGEgZGlydHkgaGFjay4gU1VOUlBDIGhvb2sg
aGFzIGJlZW4NCiAJCQkgKiBjYWxsZWQgYWxyZWFkeSBidXQgc2ltcGxlX3JtZGlyKCkgY2FsbCBm
b3IgdGhlDQpkaWZmIC0tZ2l0IGEvaW5jbHVkZS9saW51eC9zdW5ycGMvcnBjX3BpcGVfZnMuaCBi
L2luY2x1ZGUvbGludXgvc3VucnBjL3JwY19waXBlX2ZzLmgNCmluZGV4IDQyNmNlNmUuLjBjZmFl
ZjAgMTAwNjQ0DQotLS0gYS9pbmNsdWRlL2xpbnV4L3N1bnJwYy9ycGNfcGlwZV9mcy5oDQorKysg
Yi9pbmNsdWRlL2xpbnV4L3N1bnJwYy9ycGNfcGlwZV9mcy5oDQpAQCAtMzUsNiArMzUsNyBAQCBz
dHJ1Y3QgcnBjX3BpcGUgew0KIAljb25zdCBzdHJ1Y3QgcnBjX3BpcGVfb3BzICpvcHM7DQogCXNw
aW5sb2NrX3QgbG9jazsNCiAJc3RydWN0IGRlbnRyeSAqZGVudHJ5Ow0KKwlhdG9taWNfdCBjb3Vu
dDsNCiB9Ow0KIA0KIHN0cnVjdCBycGNfaW5vZGUgew0KQEAgLTg2LDEyICs4NywxOSBAQCBleHRl
cm4gdm9pZCBycGNfcmVtb3ZlX2NhY2hlX2RpcihzdHJ1Y3QgZGVudHJ5ICopOw0KIGV4dGVybiBp
bnQgcnBjX3JtZGlyKHN0cnVjdCBkZW50cnkgKmRlbnRyeSk7DQogDQogc3RydWN0IHJwY19waXBl
ICpycGNfbWtwaXBlX2RhdGEoY29uc3Qgc3RydWN0IHJwY19waXBlX29wcyAqb3BzLCBpbnQgZmxh
Z3MpOw0KLXZvaWQgcnBjX2Rlc3Ryb3lfcGlwZV9kYXRhKHN0cnVjdCBycGNfcGlwZSAqcGlwZSk7
DQogZXh0ZXJuIHN0cnVjdCBkZW50cnkgKnJwY19ta3BpcGVfZGVudHJ5KHN0cnVjdCBkZW50cnkg
KiwgY29uc3QgY2hhciAqLCB2b2lkICosDQogCQkJCQlzdHJ1Y3QgcnBjX3BpcGUgKik7DQogZXh0
ZXJuIGludCBycGNfdW5saW5rKHN0cnVjdCBkZW50cnkgKik7DQogZXh0ZXJuIGludCByZWdpc3Rl
cl9ycGNfcGlwZWZzKHZvaWQpOw0KIGV4dGVybiB2b2lkIHVucmVnaXN0ZXJfcnBjX3BpcGVmcyh2
b2lkKTsNCiANCitzdGF0aWMgaW5saW5lIHN0cnVjdCBycGNfcGlwZSAqcnBjX2dldF9waXBlX2Rh
dGEoc3RydWN0IHJwY19waXBlICpwaXBlKQ0KK3sNCisJYXRvbWljX2luYygmcGlwZS0+Y291bnQp
Ow0KKwlyZXR1cm4gcGlwZTsNCit9DQorDQorZXh0ZXJuIHZvaWQgcnBjX3B1dF9waXBlX2RhdGEo
c3RydWN0IHJwY19waXBlICpwaXBlKTsNCisNCiAjZW5kaWYNCiAjZW5kaWYNCmRpZmYgLS1naXQg
YS9uZXQvc3VucnBjL2F1dGhfZ3NzL2F1dGhfZ3NzLmMgYi9uZXQvc3VucnBjL2F1dGhfZ3NzL2F1
dGhfZ3NzLmMNCmluZGV4IGNiMmU1NjQuLjA0MWQxMTEgMTAwNjQ0DQotLS0gYS9uZXQvc3VucnBj
L2F1dGhfZ3NzL2F1dGhfZ3NzLmMNCisrKyBiL25ldC9zdW5ycGMvYXV0aF9nc3MvYXV0aF9nc3Mu
Yw0KQEAgLTc4MCw4ICs3ODAsMTEgQEAgc3RhdGljIGludCBnc3NfcGlwZXNfZGVudHJpZXNfY3Jl
YXRlKHN0cnVjdCBycGNfYXV0aCAqYXV0aCkNCiAJZ3NzX2F1dGgtPnBpcGVbMV0tPmRlbnRyeSA9
IHJwY19ta3BpcGVfZGVudHJ5KGNsbnQtPmNsX2RlbnRyeSwNCiAJCQkJCQkgICAgICAiZ3NzZCIs
DQogCQkJCQkJICAgICAgY2xudCwgZ3NzX2F1dGgtPnBpcGVbMV0pOw0KLQlpZiAoSVNfRVJSKGdz
c19hdXRoLT5waXBlWzFdLT5kZW50cnkpKQ0KLQkJcmV0dXJuIFBUUl9FUlIoZ3NzX2F1dGgtPnBp
cGVbMV0tPmRlbnRyeSk7DQorCWlmIChJU19FUlIoZ3NzX2F1dGgtPnBpcGVbMV0tPmRlbnRyeSkp
IHsNCisJCWVyciA9IFBUUl9FUlIoZ3NzX2F1dGgtPnBpcGVbMV0tPmRlbnRyeSk7DQorCQlycGNf
cHV0X3BpcGVfZGF0YShnc3NfYXV0aC0+cGlwZVswXSk7DQorCQlnb3RvIGVycjsNCisJfQ0KIAln
c3NfYXV0aC0+cGlwZVswXS0+ZGVudHJ5ID0gcnBjX21rcGlwZV9kZW50cnkoY2xudC0+Y2xfZGVu
dHJ5LA0KIAkJCQkJCSAgICAgIGdzc19hdXRoLT5tZWNoLT5nbV9uYW1lLA0KIAkJCQkJCSAgICAg
IGNsbnQsIGdzc19hdXRoLT5waXBlWzBdKTsNCkBAIC03OTMsNiArNzk2LDcgQEAgc3RhdGljIGlu
dCBnc3NfcGlwZXNfZGVudHJpZXNfY3JlYXRlKHN0cnVjdCBycGNfYXV0aCAqYXV0aCkNCiANCiBl
cnJfdW5saW5rX3BpcGVfMToNCiAJcnBjX3VubGluayhnc3NfYXV0aC0+cGlwZVsxXS0+ZGVudHJ5
KTsNCitlcnI6DQogCXJldHVybiBlcnI7DQogfQ0KIA0KQEAgLTg3OSwxMSArODgzLDEyIEBAIGdz
c19jcmVhdGUoc3RydWN0IHJwY19jbG50ICpjbG50LCBycGNfYXV0aGZsYXZvcl90IGZsYXZvcikN
CiAJCQkJCSAgICBSUENfUElQRV9XQUlUX0ZPUl9PUEVOKTsNCiAJaWYgKElTX0VSUihnc3NfYXV0
aC0+cGlwZVswXSkpIHsNCiAJCWVyciA9IFBUUl9FUlIoZ3NzX2F1dGgtPnBpcGVbMF0pOw0KLQkJ
Z290byBlcnJfZGVzdHJveV9waXBlXzE7DQorCQlycGNfcHV0X3BpcGVfZGF0YShnc3NfYXV0aC0+
cGlwZVsxXSk7DQorCQlnb3RvIGVycl9wdXRfbWVjaDsNCiAJfQ0KIAllcnIgPSBnc3NfcGlwZXNf
ZGVudHJpZXNfY3JlYXRlX25ldChjbG50LCBhdXRoKTsNCiAJaWYgKGVycikNCi0JCWdvdG8gZXJy
X2Rlc3Ryb3lfcGlwZV8wOw0KKwkJZ290byBlcnJfcHV0X21lY2g7DQogCWVyciA9IHJwY2F1dGhf
aW5pdF9jcmVkY2FjaGUoYXV0aCk7DQogCWlmIChlcnIpDQogCQlnb3RvIGVycl91bmxpbmtfcGlw
ZXM7DQpAQCAtODkxLDEwICs4OTYsNiBAQCBnc3NfY3JlYXRlKHN0cnVjdCBycGNfY2xudCAqY2xu
dCwgcnBjX2F1dGhmbGF2b3JfdCBmbGF2b3IpDQogCXJldHVybiBhdXRoOw0KIGVycl91bmxpbmtf
cGlwZXM6DQogCWdzc19waXBlc19kZW50cmllc19kZXN0cm95X25ldChjbG50LCBhdXRoKTsNCi1l
cnJfZGVzdHJveV9waXBlXzA6DQotCXJwY19kZXN0cm95X3BpcGVfZGF0YShnc3NfYXV0aC0+cGlw
ZVswXSk7DQotZXJyX2Rlc3Ryb3lfcGlwZV8xOg0KLQlycGNfZGVzdHJveV9waXBlX2RhdGEoZ3Nz
X2F1dGgtPnBpcGVbMV0pOw0KIGVycl9wdXRfbWVjaDoNCiAJZ3NzX21lY2hfcHV0KGdzc19hdXRo
LT5tZWNoKTsNCiBlcnJfZnJlZToNCkBAIC05MDgsOCArOTA5LDYgQEAgc3RhdGljIHZvaWQNCiBn
c3NfZnJlZShzdHJ1Y3QgZ3NzX2F1dGggKmdzc19hdXRoKQ0KIHsNCiAJZ3NzX3BpcGVzX2RlbnRy
aWVzX2Rlc3Ryb3lfbmV0KGdzc19hdXRoLT5jbGllbnQsICZnc3NfYXV0aC0+cnBjX2F1dGgpOw0K
LQlycGNfZGVzdHJveV9waXBlX2RhdGEoZ3NzX2F1dGgtPnBpcGVbMF0pOw0KLQlycGNfZGVzdHJv
eV9waXBlX2RhdGEoZ3NzX2F1dGgtPnBpcGVbMV0pOw0KIAlnc3NfbWVjaF9wdXQoZ3NzX2F1dGgt
Pm1lY2gpOw0KIA0KIAlrZnJlZShnc3NfYXV0aCk7DQpkaWZmIC0tZ2l0IGEvbmV0L3N1bnJwYy9y
cGNfcGlwZS5jIGIvbmV0L3N1bnJwYy9ycGNfcGlwZS5jDQppbmRleCA2ODczYzliLi5jN2FhZDg4
IDEwMDY0NA0KLS0tIGEvbmV0L3N1bnJwYy9ycGNfcGlwZS5jDQorKysgYi9uZXQvc3VucnBjL3Jw
Y19waXBlLmMNCkBAIC00NTAsOCArNDUwLDE5IEBAIHN0YXRpYyBpbnQgcnBjX2RlbGV0ZV9kZW50
cnkoY29uc3Qgc3RydWN0IGRlbnRyeSAqZGVudHJ5KQ0KIAlyZXR1cm4gMTsNCiB9DQogDQorc3Rh
dGljIHZvaWQgcnBjX2RlbnRyeV9pcHV0KHN0cnVjdCBkZW50cnkgKmRlbnRyeSwgc3RydWN0IGlu
b2RlICppbm9kZSkNCit7DQorCXN0cnVjdCBycGNfcGlwZSAqcGlwZSA9IFJQQ19JKGlub2RlKS0+
cGlwZTsNCisNCisJUlBDX0koaW5vZGUpLT5waXBlID0gTlVMTDsNCisJaWYgKHBpcGUgIT0gTlVM
TCkNCisJCXJwY19wdXRfcGlwZV9kYXRhKHBpcGUpOw0KKwlpcHV0KGlub2RlKTsNCit9DQorDQog
c3RhdGljIGNvbnN0IHN0cnVjdCBkZW50cnlfb3BlcmF0aW9ucyBycGNfZGVudHJ5X29wZXJhdGlv
bnMgPSB7DQogCS5kX2RlbGV0ZSA9IHJwY19kZWxldGVfZGVudHJ5LA0KKwkuZF9pcHV0ID0gcnBj
X2RlbnRyeV9pcHV0LA0KIH07DQogDQogc3RhdGljIHN0cnVjdCBpbm9kZSAqDQpAQCAtNTQzLDEz
ICs1NTQsMjAgQEAgaW5pdF9waXBlKHN0cnVjdCBycGNfcGlwZSAqcGlwZSkNCiAJcGlwZS0+b3Bz
ID0gTlVMTDsNCiAJc3Bpbl9sb2NrX2luaXQoJnBpcGUtPmxvY2spOw0KIAlwaXBlLT5kZW50cnkg
PSBOVUxMOw0KKwlhdG9taWNfc2V0KCZwaXBlLT5jb3VudCwgMSk7DQorfQ0KKw0KK3N0YXRpYyB2
b2lkIHJwY19kZXN0cm95X3BpcGVfZGF0YShzdHJ1Y3QgcnBjX3BpcGUgKnBpcGUpDQorew0KKwkJ
a2ZyZWUocGlwZSk7DQogfQ0KIA0KLXZvaWQgcnBjX2Rlc3Ryb3lfcGlwZV9kYXRhKHN0cnVjdCBy
cGNfcGlwZSAqcGlwZSkNCit2b2lkIHJwY19wdXRfcGlwZV9kYXRhKHN0cnVjdCBycGNfcGlwZSAq
cGlwZSkNCiB7DQotCWtmcmVlKHBpcGUpOw0KKwlpZiAoYXRvbWljX2RlY19hbmRfdGVzdCgmcGlw
ZS0+Y291bnQpKQ0KKwkJcnBjX2Rlc3Ryb3lfcGlwZV9kYXRhKHBpcGUpOw0KIH0NCi1FWFBPUlRf
U1lNQk9MX0dQTChycGNfZGVzdHJveV9waXBlX2RhdGEpOw0KK0VYUE9SVF9TWU1CT0xfR1BMKHJw
Y19wdXRfcGlwZV9kYXRhKTsNCiANCiBzdHJ1Y3QgcnBjX3BpcGUgKnJwY19ta3BpcGVfZGF0YShj
b25zdCBzdHJ1Y3QgcnBjX3BpcGVfb3BzICpvcHMsIGludCBmbGFncykNCiB7DQpAQCAtODQyLDYg
Kzg2MCw3IEBAIG91dDoNCiAJbXV0ZXhfdW5sb2NrKCZkaXItPmlfbXV0ZXgpOw0KIAlyZXR1cm4g
ZGVudHJ5Ow0KIG91dF9lcnI6DQorCXJwY19wdXRfcGlwZV9kYXRhKHBpcGUpOw0KIAlkZW50cnkg
PSBFUlJfUFRSKGVycik7DQogCXByaW50ayhLRVJOX1dBUk5JTkcgIiVzOiAlcygpIGZhaWxlZCB0
byBjcmVhdGUgcGlwZSAlcy8lcyAoZXJybm8gPSAlZClcbiIsDQogCQkJX19GSUxFX18sIF9fZnVu
Y19fLCBwYXJlbnQtPmRfbmFtZS5uYW1lLCBuYW1lLA0KLS0gDQoxLjcuNy42DQoNCg0K
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-26 23:52 ` Myklebust, Trond
@ 2012-02-27 12:51 ` Stanislav Kinsbursky
2012-02-27 13:44 ` Myklebust, Trond
0 siblings, 1 reply; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-27 12:51 UTC (permalink / raw)
To: Myklebust, Trond; +Cc: Isaman, Fred, linux-nfs@vger.kernel.org
27.02.2012 03:52, Myklebust, Trond пишет:
> On Fri, 2012-02-24 at 22:14 +0400, Stanislav Kinsbursky wrote:
>> 23.02.2012 21:48, Fred Isaman пишет:
>>> This needs to be looked at closely by someone more familiar with the
>>> pipe code.
>>>
>>> It fixes an issue with the current nfs_for_next branch which causes a
>>> chain of oopses on umount every time if sufficient CONFIG_* debug
>>> options are set.
>>>
>>> A git-bisect shows that the problem was introduced by
>>> commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
>>>
>>
>>
>>
>> Fred, thanks for the config.
>> The problem is caused by destroying pipe data on NFS client umount after
>> unlinking pipe dentry. This is valid approach, but it looks like idmap daemon
>> holds dentry by eventfd.
>> This is a race between idmap daemon release of this dentry and releasing of pipe
>> data...
>> I need some time to find out how to fix this properly.
>>
>
> How about something like the following (still untested) patch?
>
> Cheers
> Trond
Hi, Trond. Thanks for participating.
Frankly, I don't like the idea of put'ing pipe data on dentry unlink. IOW, I
don't like that this data will be controlled somehow in PipeFS.
I'll send my version soon.
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-27 12:51 ` Stanislav Kinsbursky
@ 2012-02-27 13:44 ` Myklebust, Trond
2012-02-27 13:55 ` Stanislav Kinsbursky
0 siblings, 1 reply; 12+ messages in thread
From: Myklebust, Trond @ 2012-02-27 13:44 UTC (permalink / raw)
To: Stanislav Kinsbursky; +Cc: Isaman, Fred, linux-nfs@vger.kernel.org
T24gTW9uLCAyMDEyLTAyLTI3IGF0IDE2OjUxICswNDAwLCBTdGFuaXNsYXYgS2luc2J1cnNreSB3
cm90ZToNCj4gRnJhbmtseSwgSSBkb24ndCBsaWtlIHRoZSBpZGVhIG9mIHB1dCdpbmcgcGlwZSBk
YXRhIG9uIGRlbnRyeSB1bmxpbmsuIElPVywgSSANCj4gZG9uJ3QgbGlrZSB0aGF0IHRoaXMgZGF0
YSB3aWxsIGJlIGNvbnRyb2xsZWQgc29tZWhvdyBpbiBQaXBlRlMuDQo+IEknbGwgc2VuZCBteSB2
ZXJzaW9uIHNvb24uDQo+IA0KDQpJIGRvbid0IHVuZGVyc3RhbmQgdGhhdCBvYmplY3Rpb24uIFRo
ZSBsaWZldGltZSBvZiB0aGF0IGRhdGEgbmVlZHMgdG8gYmUNCmJvdW5kZWQgYnkgdGhlIGxpZmV0
aW1lIG9mIHRoZSBwaXBlIGl0c2VsZiwgd2hpY2ggbWVhbnMgdGhhdCBpdCBfaGFzXyB0bw0KYmUg
Y29udHJvbGxlZCBieSB0aGUgcGlwZWZzLg0KDQpCVFc6IGl0IGlzbid0IGJlaW5nIHB1dCBvbiBk
ZW50cnkgdW5saW5rLiBJdCBpcyBiZWluZyBwdXQgb24gZGVudHJ5DQpfZGVzdHJ1Y3Rpb25fLiBU
aG9zZSBhcmUgdHdvIGRpZmZlcmVudCBldmVudHMgKHdoaWNoIGlzIHdoeSB3ZSBoYXZlIGENCnBy
b2JsZW0gdG9kYXkpLg0KDQpDaGVlcnMNCiAgVHJvbmQNCg==
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] SUNRPC: fix use-after-free of rpc pipes
2012-02-27 13:44 ` Myklebust, Trond
@ 2012-02-27 13:55 ` Stanislav Kinsbursky
0 siblings, 0 replies; 12+ messages in thread
From: Stanislav Kinsbursky @ 2012-02-27 13:55 UTC (permalink / raw)
To: Myklebust, Trond; +Cc: Isaman, Fred, linux-nfs@vger.kernel.org
27.02.2012 17:44, Myklebust, Trond пишет:
> On Mon, 2012-02-27 at 16:51 +0400, Stanislav Kinsbursky wrote:
>> Frankly, I don't like the idea of put'ing pipe data on dentry unlink. IOW, I
>> don't like that this data will be controlled somehow in PipeFS.
>> I'll send my version soon.
>>
>
> I don't understand that objection. The lifetime of that data needs to be
> bounded by the lifetime of the pipe itself, which means that it _has_ to
> be controlled by the pipefs.
>
> BTW: it isn't being put on dentry unlink. It is being put on dentry
> _destruction_. Those are two different events (which is why we have a
> problem today).
>
Please, have a look at "SUNRPC: several fixes around PipeFS objects" patch set.
Briefly, pipe data is created on some kernel event (mount or module install),
while PipeFS dentry/inode is created on user-space event (PipeFS mount/umount
request). Thus this two objects are created independently.
And I believe, that they have to be destroyed independently too.
--
Best regards,
Stanislav Kinsbursky
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] SUNRPC: fix use-after-free of rpc pipes
@ 2012-02-22 18:44 Fred Isaman
0 siblings, 0 replies; 12+ messages in thread
From: Fred Isaman @ 2012-02-22 18:44 UTC (permalink / raw)
To: linux-nfs; +Cc: Stanislav Kinsbursky
This needs to be looked at closely by someone more familiar with the
pipe code.
It fixes an issue with the current nfs_for_next branch which causes a
chain of oopses on umount every time if sufficient CONFIG_* debug
options are set.
A git-bisect shows that the problem was introduced by
commit c239d83b SUNRPC: split SUNPRC PipeFS dentry and private pipe data creation
A typical oops starts with:
general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
CPU 0
Modules linked in: nfs_layout_nfsv41_files nfs auth_rpcgss nfs_acl lockd ppdev parport_pc parport e1000 i2c_piix4 shpchp i2c_core sunrpc autofs4 mptspi mptscsih mptbase scsi_transport_spi floppy [last unloaded: scsi_wait_scan]
Pid: 834, comm: rpc.idmapd Not tainted 3.3.0-rc2-kitchensink+ #51 VMware, Inc. VMware Virtual Platform/440BX Desktop
Reference Platform
RIP: 0010:[<ffffffff81079979>] [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2
RSP: 0018:ffff8800367bfcb8 EFLAGS: 00010002
RAX: 6b6b6b6b6b6b6b6b RBX: ffff88003bb8a0b0 RCX: 0000000000000000
RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff88002ca779c0
RBP: ffff8800367bfd88 R08: 0000000000000002 R09: 0000000000000001
R10: 0000000000000000 R11: ffff88002ca779c0 R12: 0000000000000286
R13: ffff88002ca779c0 R14: 0000000000000002 R15: 0000000000000000
FS: 00007f7ff3dab700(0000) GS:ffff88003fa00000(0000) knlGS:0000000000000000
CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
CR2: 00007f5305ae1000 CR3: 000000003ae4e000 CR4: 00000000000406f0
DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
Process rpc.idmapd (pid: 834, threadinfo ffff8800367be000, task ffff88003bb8a0b0)
Stack:
0000000000000000 ffffffff81235f78 ffff8800367bfd08 ffffffff810788c4
ffff8800367bfd18 ffff880000000000 ffff880000000000 ffffffff00000000
00000000000001df ffff880000000001 ffff88003bb8a730 ffffffff81a24730
Call Trace:
[<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff8107a775>] lock_acquire+0x102/0x12f
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
[<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
[<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
[<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
[<ffffffff8115379b>] ep_remove+0x25/0x9f
[<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
[<ffffffff8143e415>] ? sysret_check+0x22/0x5d
[<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d [<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
[<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
Code: 8d 58 ff ff ff 44 89 8d 48 ff ff ff 4c 89 ef e8 f6 fa ff ff 48 8b 8d 58 ff ff ff 48 85 c0 44 8b 8d 48 ff ff ff
0f 84 99 0c 00 00 <3e> ff 80 98 01 00 00 8b 93 78 06 00 00 83 3d 87 83 b8 00 00 89
RIP [<ffffffff81079979>] __lock_acquire+0xd8/0xdd2 RSP <ffff8800367bfcb8>
---[ end trace ffe7d1c1af2c62f6 ]---
BUG: sleeping function called from invalid context at /home/iisaman/projects/pnfs-file/src/linux-pnfs/kernel/rwsem.c
:21
in_atomic(): 1, irqs_disabled(): 1, pid: 834, name: rpc.idmapd
INFO: lockdep is turned off.
irq event stamp: 4308
hardirqs last enabled at (4307): [<ffffffff81434d53>] __mutex_lock_common+0x37b/0x3af
hardirqs last disabled at (4308): [<ffffffff81436c87>] _raw_spin_lock_irqsave+0x29/0x6a
softirqs last enabled at (3992): [<ffffffff810378e3>] __do_softirq+0x1e6/0x205
softirqs last disabled at (3783): [<ffffffff8143f92c>] call_softirq+0x1c/0x30
Pid: 834, comm: rpc.idmapd Tainted: G D 3.3.0-rc2-kitchensink+ #51
Call Trace:
[<ffffffff81059bb7>] __might_sleep+0x107/0x10c
[<ffffffff81435499>] down_read+0x24/0x61
[<ffffffff810433e5>] exit_signals+0x26/0x12c
[<ffffffff81053fdc>] ? blocking_notifier_call_chain+0x14/0x16
[<ffffffff81034e53>] do_exit+0x118/0x7d9
[<ffffffff81031cda>] ? kmsg_dump+0x126/0x144
[<ffffffff81031c3c>] ? kmsg_dump+0x88/0x144
[<ffffffff81438422>] oops_end+0xc0/0xc8
[<ffffffff81004d96>] die+0x5a/0x63
[<ffffffff81438272>] do_general_protection+0x12a/0x132
[<ffffffff81437764>] ? restore_args+0x30/0x30
[<ffffffff81437915>] general_protection+0x25/0x30
[<ffffffff81079979>] ? __lock_acquire+0xd8/0xdd2
[<ffffffff81235f78>] ? debug_object_activate+0x57/0x13b
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff81079c40>] ? __lock_acquire+0x39f/0xdd2
[<ffffffff810788c4>] ? mark_lock+0x2d/0x233
[<ffffffff8107a775>] lock_acquire+0x102/0x12f
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff81434d53>] ? __mutex_lock_common+0x37b/0x3af
[<ffffffff81436cb6>] _raw_spin_lock_irqsave+0x58/0x6a
[<ffffffff8104f3a5>] ? remove_wait_queue+0x1d/0x3e
[<ffffffff8111f4b2>] ? file_free_rcu+0x35/0x35
[<ffffffff8104f3a5>] remove_wait_queue+0x1d/0x3e
[<ffffffff81153739>] ep_unregister_pollwait+0x30/0x51
[<ffffffff8115379b>] ep_remove+0x25/0x9f
[<ffffffff81154cc4>] sys_epoll_ctl+0x58b/0x6cb
[<ffffffff8143e415>] ? sysret_check+0x22/0x5d
[<ffffffff8109a75a>] ? __audit_syscall_entry+0x121/0x14d
[<ffffffff8123084e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
[<ffffffff8143e3e9>] system_call_fastpath+0x16/0x1b
note: rpc.idmapd[834] exited with preempt_count 1
BUG: scheduling while atomic: rpc.idmapd/834/0x10000002
INFO: lockdep is turned off.
Signed-off-by: Fred Isaman <iisaman@netapp.com>
---
fs/nfs/blocklayout/blocklayout.c | 1 -
fs/nfs/idmap.c | 1 -
net/sunrpc/auth_gss/auth_gss.c | 2 --
net/sunrpc/rpc_pipe.c | 1 +
4 files changed, 1 insertions(+), 4 deletions(-)
diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
index 783ebd5..26fcbd1 100644
--- a/fs/nfs/blocklayout/blocklayout.c
+++ b/fs/nfs/blocklayout/blocklayout.c
@@ -1134,7 +1134,6 @@ static void nfs4blocklayout_net_exit(struct net *net)
struct nfs_net *nn = net_generic(net, nfs_net_id);
nfs4blocklayout_unregister_net(net, nn->bl_device_pipe);
- rpc_destroy_pipe_data(nn->bl_device_pipe);
nn->bl_device_pipe = NULL;
}
diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c
index b5c6d8e..384fbed 100644
--- a/fs/nfs/idmap.c
+++ b/fs/nfs/idmap.c
@@ -508,7 +508,6 @@ nfs_idmap_delete(struct nfs_client *clp)
if (!idmap)
return;
nfs_idmap_unregister(clp, idmap->idmap_pipe);
- rpc_destroy_pipe_data(idmap->idmap_pipe);
clp->cl_idmap = NULL;
idmap_free_hashtable(&idmap->idmap_user_hash);
idmap_free_hashtable(&idmap->idmap_group_hash);
diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
index cb2e564..6be27ec 100644
--- a/net/sunrpc/auth_gss/auth_gss.c
+++ b/net/sunrpc/auth_gss/auth_gss.c
@@ -908,8 +908,6 @@ static void
gss_free(struct gss_auth *gss_auth)
{
gss_pipes_dentries_destroy_net(gss_auth->client, &gss_auth->rpc_auth);
- rpc_destroy_pipe_data(gss_auth->pipe[0]);
- rpc_destroy_pipe_data(gss_auth->pipe[1]);
gss_mech_put(gss_auth->mech);
kfree(gss_auth);
diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
index 6873c9b..1f58c92 100644
--- a/net/sunrpc/rpc_pipe.c
+++ b/net/sunrpc/rpc_pipe.c
@@ -191,6 +191,7 @@ static void
rpc_i_callback(struct rcu_head *head)
{
struct inode *inode = container_of(head, struct inode, i_rcu);
+ rpc_destroy_pipe_data(RPC_I(inode)->pipe);
kmem_cache_free(rpc_inode_cachep, RPC_I(inode));
}
--
1.7.2.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
end of thread, other threads:[~2012-02-27 13:55 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-02-23 17:48 [PATCH] SUNRPC: fix use-after-free of rpc pipes Fred Isaman
2012-02-24 11:03 ` Stanislav Kinsbursky
2012-02-24 13:11 ` Fred Isaman
2012-02-24 11:47 ` Stanislav Kinsbursky
2012-02-24 13:17 ` Fred Isaman
2012-02-24 14:01 ` Stanislav Kinsbursky
2012-02-24 18:14 ` Stanislav Kinsbursky
2012-02-26 23:52 ` Myklebust, Trond
2012-02-27 12:51 ` Stanislav Kinsbursky
2012-02-27 13:44 ` Myklebust, Trond
2012-02-27 13:55 ` Stanislav Kinsbursky
-- strict thread matches above, loose matches on Subject: below --
2012-02-22 18:44 Fred Isaman
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).