* Re: linux-next: Tree for Dec 21 [not found] <20111221174733.9ba0861e762e8d96844b060b@canb.auug.org.au> @ 2011-12-21 23:15 ` Andrew Morton 2011-12-22 23:08 ` Andrew Morton 0 siblings, 1 reply; 41+ messages in thread From: Andrew Morton @ 2011-12-21 23:15 UTC (permalink / raw) To: Stephen Rothwell; +Cc: linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Wed, 21 Dec 2011 17:47:33 +1100 Stephen Rothwell <sfr@canb.auug.org.au> wrote: > I have created today's linux-next tree at > git://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git > (patches at http://www.kernel.org/pub/linux/kernel/next/ ). This kernel is seriously busted. Sometime between the Dec 15 tree and the Dec 31 tree someone added something which appears to be causing writes to the (ata_piix controlled) disk to get lost. Processes are getting stuck in D state, usually before it reaches a login prompt. Suspects would be block, ata, scsi and possibly x86/acpi interrupt handling. And no, I'd rather not bisect - it would take ages. If the maintainers of the relevant trees can suggest specific patches to revert then I can take a look at that tomorrow. [ 558.576528] SysRq : Show Blocked State [ 558.576633] task PC stack pid father [ 558.576738] sh D 0000000000000001 0 4701 4700 0x00000080 [ 558.576882] ffff8802493f78b8 0000000000000046 000000014a1121c0 ffff8802493f6010 [ 558.577109] ffff88024a1121c0 00000000001d1100 ffff8802493f7fd8 0000000000004000 [ 558.577336] ffff8802493f7fd8 00000000001d1100 ffff880255db66c0 ffff88024a1121c0 [ 558.577568] Call Trace: [ 558.577623] [<ffffffff81051592>] ? sched_clock_cpu+0xc3/0xd1 [ 558.577679] [<ffffffff81051469>] ? sched_clock_local+0x1c/0x82 [ 558.577736] [<ffffffff81051592>] ? sched_clock_cpu+0xc3/0xd1 [ 558.577793] [<ffffffff810631ae>] ? trace_hardirqs_off+0xd/0xf [ 558.577848] [<ffffffff810515cb>] ? local_clock+0x2b/0x3c [ 558.577905] [<ffffffff813d2744>] schedule+0x55/0x57 [ 558.577960] [<ffffffff813d27cd>] io_schedule+0x87/0xca [ 558.578017] [<ffffffff811a1e72>] get_request_wait+0xbd/0x19e [ 558.578073] [<ffffffff810446a7>] ? wake_up_bit+0x25/0x25 [ 558.578127] [<ffffffff8119e225>] ? elv_merge+0x9a/0xaa [ 558.578182] [<ffffffff811a20cc>] blk_queue_bio+0x179/0x271 [ 558.578238] [<ffffffff811a02a9>] generic_make_request+0x9c/0xde [ 558.578293] [<ffffffff811a03a4>] submit_bio+0xb9/0xc4 [ 558.578348] [<ffffffff810ffcc6>] submit_bh+0xe6/0x108 [ 558.578404] [<ffffffff8110273c>] __block_write_full_page+0x1ec/0x2e3 [ 558.578462] [<ffffffff81101fbe>] ? end_buffer_async_read+0x14b/0x14b [ 558.578518] [<ffffffff811028fb>] block_write_full_page_endio+0xc8/0xcc [ 558.578573] [<ffffffff8110290f>] block_write_full_page+0x10/0x12 [ 558.578631] [<ffffffff811417cd>] ext3_writeback_writepage+0xaa/0x11d [ 558.578690] [<ffffffff810a0ed0>] __writepage+0x15/0x34 [ 558.578744] [<ffffffff810a1913>] write_cache_pages+0x240/0x33e [ 558.578799] [<ffffffff810a0ebb>] ? set_page_dirty+0x65/0x65 [ 558.578855] [<ffffffff81064abf>] ? trace_hardirqs_on+0xd/0xf [ 558.578911] [<ffffffff810a1a54>] generic_writepages+0x43/0x5a [ 558.578967] [<ffffffff810a1a91>] do_writepages+0x26/0x28 [ 558.579022] [<ffffffff8109a8cf>] __filemap_fdatawrite_range+0x4e/0x50 [ 558.579078] [<ffffffff8109aee8>] filemap_flush+0x17/0x19 [ 558.579134] [<ffffffff8113f2c2>] ext3_release_file+0x2e/0xa4 [ 558.579190] [<ffffffff810dbdce>] fput+0x10f/0x1cd [ 558.579244] [<ffffffff810d86e0>] filp_close+0x70/0x7b [ 558.579300] [<ffffffff8102c09b>] put_files_struct+0x16c/0x2c1 [ 558.579356] [<ffffffff8102bf7b>] ? put_files_struct+0x4c/0x2c1 [ 558.579412] [<ffffffff8102c236>] exit_files+0x46/0x4e [ 558.579465] [<ffffffff8102dd2a>] do_exit+0x246/0x73c [ 558.579521] [<ffffffff813d3c4a>] ? retint_swapgs+0xe/0x13 [ 558.579576] [<ffffffff8102e2a4>] do_group_exit+0x84/0xb2 [ 558.579743] [<ffffffff8102e2e4>] sys_exit_group+0x12/0x16 [ 558.579910] [<ffffffff813d9562>] system_call_fastpath+0x16/0x1b ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-21 23:15 ` linux-next: Tree for Dec 21 Andrew Morton @ 2011-12-22 23:08 ` Andrew Morton 2011-12-22 23:20 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Andrew Morton @ 2011-12-22 23:08 UTC (permalink / raw) To: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86, Tejun Heo On Wed, 21 Dec 2011 15:15:03 -0800 Andrew Morton <akpm@linux-foundation.org> wrote: > On Wed, 21 Dec 2011 17:47:33 +1100 > Stephen Rothwell <sfr@canb.auug.org.au> wrote: > > > I have created today's linux-next tree at > > git://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git > > (patches at http://www.kernel.org/pub/linux/kernel/next/ ). > > This kernel is seriously busted. Too much eggnog? > Sometime between the Dec 15 tree and > the Dec 31 tree someone added something which appears to be causing > writes to the (ata_piix controlled) disk to get lost. Processes are > getting stuck in D state, usually before it reaches a login prompt. > > Suspects would be block, ata, scsi and possibly x86/acpi interrupt > handling. > > And no, I'd rather not bisect - it would take ages. If the maintainers > of the relevant trees can suggest specific patches to revert then I can > take a look at that tomorrow. > > > [ 558.576528] SysRq : Show Blocked State > [ 558.576633] task PC stack pid father > [ 558.576738] sh D 0000000000000001 0 4701 4700 0x00000080 > [ 558.576882] ffff8802493f78b8 0000000000000046 000000014a1121c0 ffff8802493f6010 > [ 558.577109] ffff88024a1121c0 00000000001d1100 ffff8802493f7fd8 0000000000004000 > [ 558.577336] ffff8802493f7fd8 00000000001d1100 ffff880255db66c0 ffff88024a1121c0 > [ 558.577568] Call Trace: > [ 558.577623] [<ffffffff81051592>] ? sched_clock_cpu+0xc3/0xd1 > [ 558.577679] [<ffffffff81051469>] ? sched_clock_local+0x1c/0x82 > [ 558.577736] [<ffffffff81051592>] ? sched_clock_cpu+0xc3/0xd1 > [ 558.577793] [<ffffffff810631ae>] ? trace_hardirqs_off+0xd/0xf > [ 558.577848] [<ffffffff810515cb>] ? local_clock+0x2b/0x3c > [ 558.577905] [<ffffffff813d2744>] schedule+0x55/0x57 > [ 558.577960] [<ffffffff813d27cd>] io_schedule+0x87/0xca > [ 558.578017] [<ffffffff811a1e72>] get_request_wait+0xbd/0x19e > [ 558.578073] [<ffffffff810446a7>] ? wake_up_bit+0x25/0x25 > [ 558.578127] [<ffffffff8119e225>] ? elv_merge+0x9a/0xaa > [ 558.578182] [<ffffffff811a20cc>] blk_queue_bio+0x179/0x271 > [ 558.578238] [<ffffffff811a02a9>] generic_make_request+0x9c/0xde > [ 558.578293] [<ffffffff811a03a4>] submit_bio+0xb9/0xc4 > [ 558.578348] [<ffffffff810ffcc6>] submit_bh+0xe6/0x108 > [ 558.578404] [<ffffffff8110273c>] __block_write_full_page+0x1ec/0x2e3 > [ 558.578462] [<ffffffff81101fbe>] ? end_buffer_async_read+0x14b/0x14b > [ 558.578518] [<ffffffff811028fb>] block_write_full_page_endio+0xc8/0xcc > [ 558.578573] [<ffffffff8110290f>] block_write_full_page+0x10/0x12 > [ 558.578631] [<ffffffff811417cd>] ext3_writeback_writepage+0xaa/0x11d > [ 558.578690] [<ffffffff810a0ed0>] __writepage+0x15/0x34 > [ 558.578744] [<ffffffff810a1913>] write_cache_pages+0x240/0x33e > [ 558.578799] [<ffffffff810a0ebb>] ? set_page_dirty+0x65/0x65 > [ 558.578855] [<ffffffff81064abf>] ? trace_hardirqs_on+0xd/0xf > [ 558.578911] [<ffffffff810a1a54>] generic_writepages+0x43/0x5a > [ 558.578967] [<ffffffff810a1a91>] do_writepages+0x26/0x28 > [ 558.579022] [<ffffffff8109a8cf>] __filemap_fdatawrite_range+0x4e/0x50 > [ 558.579078] [<ffffffff8109aee8>] filemap_flush+0x17/0x19 > [ 558.579134] [<ffffffff8113f2c2>] ext3_release_file+0x2e/0xa4 > [ 558.579190] [<ffffffff810dbdce>] fput+0x10f/0x1cd > [ 558.579244] [<ffffffff810d86e0>] filp_close+0x70/0x7b > [ 558.579300] [<ffffffff8102c09b>] put_files_struct+0x16c/0x2c1 > [ 558.579356] [<ffffffff8102bf7b>] ? put_files_struct+0x4c/0x2c1 > [ 558.579412] [<ffffffff8102c236>] exit_files+0x46/0x4e > [ 558.579465] [<ffffffff8102dd2a>] do_exit+0x246/0x73c > [ 558.579521] [<ffffffff813d3c4a>] ? retint_swapgs+0xe/0x13 > [ 558.579576] [<ffffffff8102e2a4>] do_group_exit+0x84/0xb2 > [ 558.579743] [<ffffffff8102e2e4>] sys_exit_group+0x12/0x16 > [ 558.579910] [<ffffffff813d9562>] system_call_fastpath+0x16/0x1b A large amount of block core code was merged in the Dec 15 - Dec 21 window. Tejun... I sucked all the patches out of git, reverted them in reverse order and did a quilt bisect (having been repeatedly traumatised by git bisect, due to all the bisection holes we're adding, due to that never-rebase-your-tree thing). revert-64c42998f14d5894ea3138625897d620b30c8e4e.patch revert-274193224cdabd687d804a26e0150bb20f2dd52c.patch revert-4a0b75c7d02c2bd46ed227d4ba5941ba8a0aba5d.patch revert-ff56c895cf43c7896e5a5f31e2d55bb7fdbdb63e.patch revert-4eabc941259f9d8c8fb71746d3f30c87e1d9e49b.patch revert-f1f8cc94651738b418ba54c039df536303b91704.patch revert-9b84cacd013996f244d85b3d873287c2a8f88658.patch revert-7e5a8794492e43e9eebb68a98a23be055888ccd0.patch revert-3d3c2379feb177a5fd55bb0ed76776dc9d4f3243.patch revert-47fdd4ca96bf4b28ac4d05d7a6e382df31d3d758.patch revert-a612fddf0d8090f2877305c9168b6c1a34fb5d90.patch revert-c58698073218f2c8f2fc5982fa3938c2d3803b9f.patch revert-22f746e235a5cbee2a6ca9887b1be2aa7d31fe71.patch revert-f8fc877d3c1f10457d0d73d8540a0c51a1fa718a.patch revert-f2dbd76a0a994bc1d5a3d0e7c844cc373832e86c.patch BAD revert-1238033c79e92e5c315af12e45396f1a78c73dec.patch revert-b50b636bce6293fa858cc7ff6c3ffe4920d90006.patch revert-b9a1920837bc53430d339380e393a6e4c372939f.patch revert-b2efa05265d62bc29f3a64400fad4b44340eedb8.patch revert-f1a4f4d35ff30a328d5ea28f6cc826b2083111d2.patch revert-216284c352a0061f5b20acff2c4e50fb43fea183.patch revert-dc86900e0a8f665122de6faadd27fb4c6d2b3e4d.patch revert-283287a52e3c3f7f8f9da747f4b8c5202740d776.patch revert-09ac46c429464c919d04bb737b27edd84d944f02.patch BAD revert-6e736be7f282fff705db7c34a15313281b372a76.patch GOOD revert-42ec57a8f68311bbbf4ff96a5d33c8a2e90b9d05.patch GOOD revert-a73f730d013ff2788389fd0c46ad3e5510f124e6.patch revert-8ba61435d73f2274e12d4d823fde06735e8f6a54.patch GOOD revert-481a7d64790cd7ca61a8bbcbd9d017ce58e6fe39.patch revert-34f6055c80285e4efb3f602a9119db75239744dc.patch revert-1ba64edef6051d2ec79bb2fbd3a0c8f0df00ab55.patch GOOD At the f2dbd76a0a994bc1d5a3d0e7c844cc373832e86 pivot point the kernel went odd, got stuck, slowly emitting "cfq: cic link failed!" messages. So we've added yet another bisection hole in there somewhere. And the bisection indicates that this (drop-dead show-stopping box-killing) regression was added by 6e736be7f282fff705db7c34a15313281b372a76 ("block: make ioc get/put interface more conventional and fix race on alloction"). Please don't add another bisection hole when fixing this.</troll> ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:08 ` Andrew Morton @ 2011-12-22 23:20 ` Tejun Heo 2011-12-22 23:24 ` Andrew Morton 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-22 23:20 UTC (permalink / raw) To: Andrew Morton Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 Hello, Andrew. On Thu, Dec 22, 2011 at 03:08:36PM -0800, Andrew Morton wrote: > > [ 558.576528] SysRq : Show Blocked State > > [ 558.576633] task PC stack pid father > > [ 558.576738] sh D 0000000000000001 0 4701 4700 0x00000080 > > [ 558.576882] ffff8802493f78b8 0000000000000046 000000014a1121c0 ffff8802493f6010 > > [ 558.577109] ffff88024a1121c0 00000000001d1100 ffff8802493f7fd8 0000000000004000 > > [ 558.577336] ffff8802493f7fd8 00000000001d1100 ffff880255db66c0 ffff88024a1121c0 > > [ 558.577568] Call Trace: > > [ 558.577905] [<ffffffff813d2744>] schedule+0x55/0x57 > > [ 558.577960] [<ffffffff813d27cd>] io_schedule+0x87/0xca > > [ 558.578017] [<ffffffff811a1e72>] get_request_wait+0xbd/0x19e > > [ 558.578182] [<ffffffff811a20cc>] blk_queue_bio+0x179/0x271 > > [ 558.578238] [<ffffffff811a02a9>] generic_make_request+0x9c/0xde > > [ 558.578293] [<ffffffff811a03a4>] submit_bio+0xb9/0xc4 > > [ 558.578348] [<ffffffff810ffcc6>] submit_bh+0xe6/0x108 > > [ 558.578404] [<ffffffff8110273c>] __block_write_full_page+0x1ec/0x2e3 > > [ 558.578518] [<ffffffff811028fb>] block_write_full_page_endio+0xc8/0xcc > > [ 558.578573] [<ffffffff8110290f>] block_write_full_page+0x10/0x12 > > [ 558.578631] [<ffffffff811417cd>] ext3_writeback_writepage+0xaa/0x11d > > [ 558.578690] [<ffffffff810a0ed0>] __writepage+0x15/0x34 > > [ 558.578744] [<ffffffff810a1913>] write_cache_pages+0x240/0x33e > > [ 558.578911] [<ffffffff810a1a54>] generic_writepages+0x43/0x5a > > [ 558.578967] [<ffffffff810a1a91>] do_writepages+0x26/0x28 > > [ 558.579022] [<ffffffff8109a8cf>] __filemap_fdatawrite_range+0x4e/0x50 > > [ 558.579078] [<ffffffff8109aee8>] filemap_flush+0x17/0x19 > > [ 558.579134] [<ffffffff8113f2c2>] ext3_release_file+0x2e/0xa4 > > [ 558.579190] [<ffffffff810dbdce>] fput+0x10f/0x1cd > > [ 558.579244] [<ffffffff810d86e0>] filp_close+0x70/0x7b > > [ 558.579300] [<ffffffff8102c09b>] put_files_struct+0x16c/0x2c1 > > [ 558.579412] [<ffffffff8102c236>] exit_files+0x46/0x4e > > [ 558.579465] [<ffffffff8102dd2a>] do_exit+0x246/0x73c > > [ 558.579576] [<ffffffff8102e2a4>] do_group_exit+0x84/0xb2 > > [ 558.579743] [<ffffffff8102e2e4>] sys_exit_group+0x12/0x16 > > [ 558.579910] [<ffffffff813d9562>] system_call_fastpath+0x16/0x1b Hmmm... probably cic allocation failure? > A large amount of block core code was merged in the Dec 15 - Dec 21 > window. Tejun... Yeah, those are blk-ioc cleanup patches. I was wishing to merge them earlier. > revert-f2dbd76a0a994bc1d5a3d0e7c844cc373832e86c.patch BAD > revert-1238033c79e92e5c315af12e45396f1a78c73dec.patch > revert-b50b636bce6293fa858cc7ff6c3ffe4920d90006.patch > revert-b9a1920837bc53430d339380e393a6e4c372939f.patch > revert-b2efa05265d62bc29f3a64400fad4b44340eedb8.patch > revert-f1a4f4d35ff30a328d5ea28f6cc826b2083111d2.patch > revert-216284c352a0061f5b20acff2c4e50fb43fea183.patch > revert-dc86900e0a8f665122de6faadd27fb4c6d2b3e4d.patch > revert-283287a52e3c3f7f8f9da747f4b8c5202740d776.patch > revert-09ac46c429464c919d04bb737b27edd84d944f02.patch BAD > revert-6e736be7f282fff705db7c34a15313281b372a76.patch GOOD > revert-42ec57a8f68311bbbf4ff96a5d33c8a2e90b9d05.patch GOOD > revert-a73f730d013ff2788389fd0c46ad3e5510f124e6.patch > revert-8ba61435d73f2274e12d4d823fde06735e8f6a54.patch GOOD > revert-481a7d64790cd7ca61a8bbcbd9d017ce58e6fe39.patch > revert-34f6055c80285e4efb3f602a9119db75239744dc.patch > revert-1ba64edef6051d2ec79bb2fbd3a0c8f0df00ab55.patch GOOD > > At the f2dbd76a0a994bc1d5a3d0e7c844cc373832e86 pivot point the kernel > went odd, got stuck, slowly emitting "cfq: cic link failed!" messages. > So we've added yet another bisection hole in there somewhere. You were likely seeing the same problem, just showing up differently. Hmm.... we always had the problem of allocation failure in cfq could lead to deadlock. It's just that those cases happened infrequently enough that nobody really noticed (or at least tracked it down). How can you reproduce the problem? Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:20 ` Tejun Heo @ 2011-12-22 23:24 ` Andrew Morton 2011-12-22 23:38 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Andrew Morton @ 2011-12-22 23:24 UTC (permalink / raw) To: Tejun Heo Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Thu, 22 Dec 2011 15:20:36 -0800 Tejun Heo <tj@kernel.org> wrote: > Hello, Andrew. > > On Thu, Dec 22, 2011 at 03:08:36PM -0800, Andrew Morton wrote: > > > [ 558.576528] SysRq : Show Blocked State > > > [ 558.576633] task PC stack pid father > > > [ 558.576738] sh D 0000000000000001 0 4701 4700 0x00000080 > > > [ 558.576882] ffff8802493f78b8 0000000000000046 000000014a1121c0 ffff8802493f6010 > > > [ 558.577109] ffff88024a1121c0 00000000001d1100 ffff8802493f7fd8 0000000000004000 > > > [ 558.577336] ffff8802493f7fd8 00000000001d1100 ffff880255db66c0 ffff88024a1121c0 > > > [ 558.577568] Call Trace: > > > [ 558.577905] [<ffffffff813d2744>] schedule+0x55/0x57 > > > [ 558.577960] [<ffffffff813d27cd>] io_schedule+0x87/0xca > > > [ 558.578017] [<ffffffff811a1e72>] get_request_wait+0xbd/0x19e > > > [ 558.578182] [<ffffffff811a20cc>] blk_queue_bio+0x179/0x271 > > > [ 558.578238] [<ffffffff811a02a9>] generic_make_request+0x9c/0xde > > > [ 558.578293] [<ffffffff811a03a4>] submit_bio+0xb9/0xc4 > > > [ 558.578348] [<ffffffff810ffcc6>] submit_bh+0xe6/0x108 > > > [ 558.578404] [<ffffffff8110273c>] __block_write_full_page+0x1ec/0x2e3 > > > [ 558.578518] [<ffffffff811028fb>] block_write_full_page_endio+0xc8/0xcc > > > [ 558.578573] [<ffffffff8110290f>] block_write_full_page+0x10/0x12 > > > [ 558.578631] [<ffffffff811417cd>] ext3_writeback_writepage+0xaa/0x11d > > > [ 558.578690] [<ffffffff810a0ed0>] __writepage+0x15/0x34 > > > [ 558.578744] [<ffffffff810a1913>] write_cache_pages+0x240/0x33e > > > [ 558.578911] [<ffffffff810a1a54>] generic_writepages+0x43/0x5a > > > [ 558.578967] [<ffffffff810a1a91>] do_writepages+0x26/0x28 > > > [ 558.579022] [<ffffffff8109a8cf>] __filemap_fdatawrite_range+0x4e/0x50 > > > [ 558.579078] [<ffffffff8109aee8>] filemap_flush+0x17/0x19 > > > [ 558.579134] [<ffffffff8113f2c2>] ext3_release_file+0x2e/0xa4 > > > [ 558.579190] [<ffffffff810dbdce>] fput+0x10f/0x1cd > > > [ 558.579244] [<ffffffff810d86e0>] filp_close+0x70/0x7b > > > [ 558.579300] [<ffffffff8102c09b>] put_files_struct+0x16c/0x2c1 > > > [ 558.579412] [<ffffffff8102c236>] exit_files+0x46/0x4e > > > [ 558.579465] [<ffffffff8102dd2a>] do_exit+0x246/0x73c > > > [ 558.579576] [<ffffffff8102e2a4>] do_group_exit+0x84/0xb2 > > > [ 558.579743] [<ffffffff8102e2e4>] sys_exit_group+0x12/0x16 > > > [ 558.579910] [<ffffffff813d9562>] system_call_fastpath+0x16/0x1b > > Hmmm... probably cic allocation failure? Dunno, it's an 8Gb 8 CPU x86_64 box. > > A large amount of block core code was merged in the Dec 15 - Dec 21 > > window. Tejun... > > Yeah, those are blk-ioc cleanup patches. I was wishing to merge them > earlier. > > > revert-f2dbd76a0a994bc1d5a3d0e7c844cc373832e86c.patch BAD > > revert-1238033c79e92e5c315af12e45396f1a78c73dec.patch > > revert-b50b636bce6293fa858cc7ff6c3ffe4920d90006.patch > > revert-b9a1920837bc53430d339380e393a6e4c372939f.patch > > revert-b2efa05265d62bc29f3a64400fad4b44340eedb8.patch > > revert-f1a4f4d35ff30a328d5ea28f6cc826b2083111d2.patch > > revert-216284c352a0061f5b20acff2c4e50fb43fea183.patch > > revert-dc86900e0a8f665122de6faadd27fb4c6d2b3e4d.patch > > revert-283287a52e3c3f7f8f9da747f4b8c5202740d776.patch > > revert-09ac46c429464c919d04bb737b27edd84d944f02.patch BAD > > revert-6e736be7f282fff705db7c34a15313281b372a76.patch GOOD > > revert-42ec57a8f68311bbbf4ff96a5d33c8a2e90b9d05.patch GOOD > > revert-a73f730d013ff2788389fd0c46ad3e5510f124e6.patch > > revert-8ba61435d73f2274e12d4d823fde06735e8f6a54.patch GOOD > > revert-481a7d64790cd7ca61a8bbcbd9d017ce58e6fe39.patch > > revert-34f6055c80285e4efb3f602a9119db75239744dc.patch > > revert-1ba64edef6051d2ec79bb2fbd3a0c8f0df00ab55.patch GOOD > > > > At the f2dbd76a0a994bc1d5a3d0e7c844cc373832e86 pivot point the kernel > > went odd, got stuck, slowly emitting "cfq: cic link failed!" messages. > > So we've added yet another bisection hole in there somewhere. > > You were likely seeing the same problem, just showing up differently. > Hmm.... we always had the problem of allocation failure in cfq could > lead to deadlock. This looks like a lost I/O completion. > It's just that those cases happened infrequently > enough that nobody really noticed (or at least tracked it down). How > can you reproduce the problem? Easily. One time it got to a login prompt and hung quickly during a make. Every other time (ten times, maybe) it hung during initscripts. ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:24 ` Andrew Morton @ 2011-12-22 23:38 ` Tejun Heo 2011-12-22 23:44 ` Andrew Morton 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-22 23:38 UTC (permalink / raw) To: Andrew Morton Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Thu, Dec 22, 2011 at 03:24:27PM -0800, Andrew Morton wrote: > > Hmmm... probably cic allocation failure? > > Dunno, it's an 8Gb 8 CPU x86_64 box. > > > It's just that those cases happened infrequently > > enough that nobody really noticed (or at least tracked it down). How > > can you reproduce the problem? > > Easily. One time it got to a login prompt and hung quickly during a > make. Every other time (ten times, maybe) it hung during initscripts. Weird, I can't reproduce the problem on block/for-3.3/core. Trying linux-next... hmmm, it works there too. Can you please share .config? Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:38 ` Tejun Heo @ 2011-12-22 23:44 ` Andrew Morton 2011-12-22 23:46 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Andrew Morton @ 2011-12-22 23:44 UTC (permalink / raw) To: Tejun Heo Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Thu, 22 Dec 2011 15:38:43 -0800 Tejun Heo <tj@kernel.org> wrote: > On Thu, Dec 22, 2011 at 03:24:27PM -0800, Andrew Morton wrote: > > > Hmmm... probably cic allocation failure? > > > > Dunno, it's an 8Gb 8 CPU x86_64 box. > > > > > It's just that those cases happened infrequently > > > enough that nobody really noticed (or at least tracked it down). How > > > can you reproduce the problem? > > > > Easily. One time it got to a login prompt and hung quickly during a > > make. Every other time (ten times, maybe) it hung during initscripts. > > Weird, I can't reproduce the problem on block/for-3.3/core. Trying > linux-next... hmmm, it works there too. This machine is next to my desk, about 50 yards from your cube ;) > Can you please share .config? # # Automatically generated file; DO NOT EDIT. # Linux/x86_64 3.2.0-rc6 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_ZONE_DMA=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_ARCH_SUPPORTS_UPROBES=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="" # 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 is not set CONFIG_AUDIT=y CONFIG_AUDITSYSCALL=y CONFIG_AUDIT_WATCH=y CONFIG_AUDIT_TREE=y 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 is not set CONFIG_NAMESPACES=y # CONFIG_UTS_NS is not set # CONFIG_IPC_NS is not set # CONFIG_USER_NS is not set # CONFIG_PID_NS is not set # CONFIG_NET_NS is not set # CONFIG_SCHED_AUTOGROUP is not set CONFIG_SYSFS_DEPRECATED=y CONFIG_SYSFS_DEPRECATED_V2=y 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_COMPAT_BRK=y CONFIG_SLAB=y # CONFIG_SLUB is not set CONFIG_PROFILING=y CONFIG_OPROFILE=m # CONFIG_OPROFILE_EVENT_MULTIPLEX is not set CONFIG_HAVE_OPROFILE=y CONFIG_OPROFILE_NMI_TIMER=y CONFIG_KPROBES=y # CONFIG_JUMP_LABEL is not set CONFIG_OPTPROBES=y # CONFIG_UPROBES is not set 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 # # 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=y 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 is not set CONFIG_BLOCK_COMPAT=y # # IO Schedulers # CONFIG_IOSCHED_NOOP=y CONFIG_IOSCHED_DEADLINE=y CONFIG_IOSCHED_CFQ=y # 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_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=y # CONFIG_X86_VSMP is not set CONFIG_X86_SUPPORTS_MEMORY_FAILURE=y CONFIG_SCHED_OMIT_FRAME_POINTER=y # CONFIG_KVMTOOL_TEST_ENABLE is not set # CONFIG_PARAVIRT_GUEST is not set CONFIG_NO_BOOTMEM=y # CONFIG_MEMTEST is not set # CONFIG_MK8 is not set # CONFIG_MPSC is not set # CONFIG_MCORE2 is not set # CONFIG_MATOM is not set CONFIG_GENERIC_CPU=y CONFIG_X86_INTERNODE_CACHE_SHIFT=7 CONFIG_X86_CMPXCHG=y CONFIG_CMPXCHG_LOCAL=y CONFIG_CMPXCHG_DOUBLE=y CONFIG_X86_L1_CACHE_SHIFT=6 CONFIG_X86_XADD=y CONFIG_X86_WP_WORKS_OK=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_DMI=y CONFIG_GART_IOMMU=y CONFIG_CALGARY_IOMMU=y # CONFIG_CALGARY_IOMMU_ENABLED_BY_DEFAULT is not set CONFIG_SWIOTLB=y CONFIG_IOMMU_HELPER=y # CONFIG_MAXSMP is not set CONFIG_NR_CPUS=255 CONFIG_SCHED_SMT=y CONFIG_SCHED_MC=y CONFIG_IRQ_TIME_ACCOUNTING=y # CONFIG_PREEMPT_NONE is not set CONFIG_PREEMPT_VOLUNTARY=y # CONFIG_PREEMPT is not set CONFIG_X86_LOCAL_APIC=y CONFIG_X86_IO_APIC=y # CONFIG_X86_REROUTE_FOR_BROKEN_BOOT_IRQS is not set 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=m 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=6 CONFIG_ARCH_SPARSEMEM_ENABLE=y CONFIG_ARCH_SPARSEMEM_DEFAULT=y CONFIG_ARCH_SELECT_MEMORY_MODEL=y CONFIG_ARCH_MEMORY_PROBE=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=y CONFIG_MEMORY_HOTPLUG_SPARSE=y CONFIG_MEMORY_HOTREMOVE=y CONFIG_PAGEFLAGS_EXTENDED=y CONFIG_SPLIT_PTLOCK_CPUS=999999 CONFIG_COMPACTION=y 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=y CONFIG_TRANSPARENT_HUGEPAGE=y # CONFIG_TRANSPARENT_HUGEPAGE_ALWAYS is not set CONFIG_TRANSPARENT_HUGEPAGE_MADVISE=y # CONFIG_CLEANCACHE is not set # CONFIG_FRONTSWAP is not set CONFIG_X86_CHECK_BIOS_CORRUPTION=y CONFIG_X86_BOOTPARAM_MEMORY_CORRUPTION_CHECK=y CONFIG_X86_RESERVE_LOW=64 CONFIG_MTRR=y # CONFIG_MTRR_SANITIZER is not set CONFIG_X86_PAT=y CONFIG_ARCH_USES_PG_UNCACHED=y CONFIG_ARCH_RANDOM=y # CONFIG_EFI is not set # CONFIG_SECCOMP is not set # CONFIG_CC_STACKPROTECTOR is not set # CONFIG_HZ_100 is not set CONFIG_HZ_250=y # CONFIG_HZ_300 is not set # CONFIG_HZ_1000 is not set CONFIG_HZ=250 CONFIG_SCHED_HRTICK=y CONFIG_KEXEC=y # CONFIG_CRASH_DUMP is not set CONFIG_PHYSICAL_START=0x1000000 # CONFIG_RELOCATABLE is not set CONFIG_PHYSICAL_ALIGN=0x1000000 CONFIG_HOTPLUG_CPU=y CONFIG_COMPAT_VDSO=y # CONFIG_CMDLINE_BOOL is not set CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y CONFIG_USE_PERCPU_NUMA_NODE_ID=y # # Power management and ACPI options # CONFIG_SUSPEND=y CONFIG_SUSPEND_FREEZER=y # CONFIG_HIBERNATION is not set CONFIG_PM_SLEEP=y CONFIG_PM_SLEEP_SMP=y # CONFIG_PM_RUNTIME is not set CONFIG_PM=y # CONFIG_PM_DEBUG is not set CONFIG_ACPI=y CONFIG_ACPI_SLEEP=y # CONFIG_ACPI_PROCFS is not set CONFIG_ACPI_PROCFS_POWER=y # CONFIG_ACPI_EC_DEBUGFS is not set CONFIG_ACPI_PROC_EVENT=y CONFIG_ACPI_AC=m CONFIG_ACPI_BATTERY=m CONFIG_ACPI_BUTTON=m CONFIG_ACPI_VIDEO=m CONFIG_ACPI_FAN=y CONFIG_ACPI_DOCK=y CONFIG_ACPI_PROCESSOR=y # CONFIG_ACPI_IPMI is not set CONFIG_ACPI_HOTPLUG_CPU=y # CONFIG_ACPI_PROCESSOR_AGGREGATOR is not set 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 is not set CONFIG_X86_PM_TIMER=y CONFIG_ACPI_CONTAINER=y # CONFIG_ACPI_HOTPLUG_MEMORY is not set 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 is not set # # CPU Frequency scaling # CONFIG_CPU_FREQ=y CONFIG_CPU_FREQ_TABLE=y 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=y CONFIG_X86_SPEEDSTEP_CENTRINO=y # CONFIG_X86_P4_CLOCKMOD is not set # # shared options # # CONFIG_X86_SPEEDSTEP_LIB is not set 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=m CONFIG_PCIEAER=y # CONFIG_PCIE_ECRC is not set # CONFIG_PCIEAER_INJECT is not set CONFIG_PCIEASPM=y # CONFIG_PCIEASPM_DEBUG is not set CONFIG_ARCH_SUPPORTS_MSI=y CONFIG_PCI_MSI=y # CONFIG_PCI_DEBUG is not set # CONFIG_PCI_STUB is not set CONFIG_HT_IRQ=y # CONFIG_PCI_IOV is not set # CONFIG_PCI_PRI is not set # CONFIG_PCI_PASID is not set CONFIG_PCI_IOAPIC=y CONFIG_PCI_LABEL=y CONFIG_ISA_DMA_API=y CONFIG_AMD_NB=y CONFIG_PCCARD=y CONFIG_PCMCIA=y CONFIG_PCMCIA_LOAD_CIS=y CONFIG_CARDBUS=y # # PC-card bridges # CONFIG_YENTA=y CONFIG_YENTA_O2=y CONFIG_YENTA_RICOH=y CONFIG_YENTA_TI=y CONFIG_YENTA_ENE_TUNE=y CONFIG_YENTA_TOSHIBA=y CONFIG_PD6729=m CONFIG_I82092=m CONFIG_PCCARD_NONSTATIC=y CONFIG_HOTPLUG_PCI=y CONFIG_HOTPLUG_PCI_FAKE=m CONFIG_HOTPLUG_PCI_ACPI=m 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_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=y CONFIG_XFRM=y CONFIG_XFRM_USER=y # CONFIG_XFRM_SUB_POLICY is not set # CONFIG_XFRM_MIGRATE is not set # CONFIG_XFRM_STATISTICS is not set CONFIG_XFRM_IPCOMP=m CONFIG_NET_KEY=m # CONFIG_NET_KEY_MIGRATE is not set CONFIG_INET=y CONFIG_IP_MULTICAST=y CONFIG_IP_ADVANCED_ROUTER=y # CONFIG_IP_FIB_TRIE_STATS is not set CONFIG_IP_MULTIPLE_TABLES=y CONFIG_IP_ROUTE_MULTIPATH=y CONFIG_IP_ROUTE_VERBOSE=y CONFIG_IP_ROUTE_CLASSID=y # CONFIG_IP_PNP is not set CONFIG_NET_IPIP=m # CONFIG_NET_IPGRE_DEMUX is not set CONFIG_IP_MROUTE=y # CONFIG_IP_MROUTE_MULTIPLE_TABLES is not set CONFIG_IP_PIMSM_V1=y CONFIG_IP_PIMSM_V2=y # CONFIG_ARPD is not set CONFIG_SYN_COOKIES=y 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=y CONFIG_INET_LRO=y CONFIG_INET_DIAG=m CONFIG_INET_TCP_DIAG=m CONFIG_INET_UDP_DIAG=m CONFIG_TCP_CONG_ADVANCED=y CONFIG_TCP_CONG_BIC=y CONFIG_TCP_CONG_CUBIC=m CONFIG_TCP_CONG_WESTWOOD=m CONFIG_TCP_CONG_HTCP=m CONFIG_TCP_CONG_HSTCP=m CONFIG_TCP_CONG_HYBLA=m CONFIG_TCP_CONG_VEGAS=m CONFIG_TCP_CONG_SCALABLE=m CONFIG_TCP_CONG_LP=m CONFIG_TCP_CONG_VENO=m # CONFIG_TCP_CONG_YEAH is not set # CONFIG_TCP_CONG_ILLINOIS is not set CONFIG_DEFAULT_BIC=y # CONFIG_DEFAULT_RENO is not set CONFIG_DEFAULT_TCP_CONG="bic" # CONFIG_TCP_MD5SIG is not set CONFIG_IPV6=m CONFIG_IPV6_PRIVACY=y CONFIG_IPV6_ROUTER_PREF=y CONFIG_IPV6_ROUTE_INFO=y # CONFIG_IPV6_OPTIMISTIC_DAD is not set CONFIG_INET6_AH=m CONFIG_INET6_ESP=m CONFIG_INET6_IPCOMP=m # CONFIG_IPV6_MIP6 is not set CONFIG_INET6_XFRM_TUNNEL=m CONFIG_INET6_TUNNEL=m CONFIG_INET6_XFRM_MODE_TRANSPORT=m CONFIG_INET6_XFRM_MODE_TUNNEL=m CONFIG_INET6_XFRM_MODE_BEET=m # CONFIG_INET6_XFRM_MODE_ROUTEOPTIMIZATION is not set CONFIG_IPV6_SIT=m # CONFIG_IPV6_SIT_6RD is not set CONFIG_IPV6_NDISC_NODETYPE=y CONFIG_IPV6_TUNNEL=m # CONFIG_IPV6_MULTIPLE_TABLES is not set # CONFIG_IPV6_MROUTE is not set CONFIG_NETLABEL=y CONFIG_NETWORK_SECMARK=y # CONFIG_NETWORK_PHY_TIMESTAMPING is not set CONFIG_NETFILTER=y # CONFIG_NETFILTER_DEBUG is not set CONFIG_NETFILTER_ADVANCED=y CONFIG_BRIDGE_NETFILTER=y # # Core Netfilter Configuration # CONFIG_NETFILTER_NETLINK=m CONFIG_NETFILTER_NETLINK_QUEUE=m CONFIG_NETFILTER_NETLINK_LOG=m # CONFIG_NF_CONNTRACK is not set # CONFIG_NETFILTER_TPROXY is not set CONFIG_NETFILTER_XTABLES=m # # Xtables combined modules # CONFIG_NETFILTER_XT_MARK=m # # Xtables targets # # CONFIG_NETFILTER_XT_TARGET_AUDIT is not set # CONFIG_NETFILTER_XT_TARGET_CHECKSUM is not set CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m # CONFIG_NETFILTER_XT_TARGET_DSCP is not set CONFIG_NETFILTER_XT_TARGET_HL=m # CONFIG_NETFILTER_XT_TARGET_IDLETIMER is not set # CONFIG_NETFILTER_XT_TARGET_LED is not set CONFIG_NETFILTER_XT_TARGET_MARK=m # CONFIG_NETFILTER_XT_TARGET_NFLOG is not set CONFIG_NETFILTER_XT_TARGET_NFQUEUE=m # CONFIG_NETFILTER_XT_TARGET_RATEEST is not set # CONFIG_NETFILTER_XT_TARGET_TEE is not set # CONFIG_NETFILTER_XT_TARGET_TRACE is not set CONFIG_NETFILTER_XT_TARGET_SECMARK=m # CONFIG_NETFILTER_XT_TARGET_TCPMSS is not set # CONFIG_NETFILTER_XT_TARGET_TCPOPTSTRIP is not set # # Xtables matches # # CONFIG_NETFILTER_XT_MATCH_ADDRTYPE is not set CONFIG_NETFILTER_XT_MATCH_COMMENT=m # CONFIG_NETFILTER_XT_MATCH_CPU is not set CONFIG_NETFILTER_XT_MATCH_DCCP=m # CONFIG_NETFILTER_XT_MATCH_DEVGROUP is not set # CONFIG_NETFILTER_XT_MATCH_DSCP is not set CONFIG_NETFILTER_XT_MATCH_ESP=m # CONFIG_NETFILTER_XT_MATCH_HASHLIMIT is not set CONFIG_NETFILTER_XT_MATCH_HL=m # CONFIG_NETFILTER_XT_MATCH_IPRANGE is not set CONFIG_NETFILTER_XT_MATCH_LENGTH=m CONFIG_NETFILTER_XT_MATCH_LIMIT=m CONFIG_NETFILTER_XT_MATCH_MAC=m CONFIG_NETFILTER_XT_MATCH_MARK=m CONFIG_NETFILTER_XT_MATCH_MULTIPORT=m # CONFIG_NETFILTER_XT_MATCH_OSF is not set # CONFIG_NETFILTER_XT_MATCH_OWNER is not set CONFIG_NETFILTER_XT_MATCH_POLICY=m CONFIG_NETFILTER_XT_MATCH_PHYSDEV=m CONFIG_NETFILTER_XT_MATCH_PKTTYPE=m CONFIG_NETFILTER_XT_MATCH_QUOTA=m # CONFIG_NETFILTER_XT_MATCH_RATEEST is not set CONFIG_NETFILTER_XT_MATCH_REALM=m # CONFIG_NETFILTER_XT_MATCH_RECENT is not set CONFIG_NETFILTER_XT_MATCH_SCTP=m CONFIG_NETFILTER_XT_MATCH_STATISTIC=m CONFIG_NETFILTER_XT_MATCH_STRING=m CONFIG_NETFILTER_XT_MATCH_TCPMSS=m # CONFIG_NETFILTER_XT_MATCH_TIME is not set # CONFIG_NETFILTER_XT_MATCH_U32 is not set # CONFIG_IP_SET is not set CONFIG_IP_VS=m # CONFIG_IP_VS_IPV6 is not set # CONFIG_IP_VS_DEBUG is not set CONFIG_IP_VS_TAB_BITS=12 # # IPVS transport protocol load balancing support # CONFIG_IP_VS_PROTO_TCP=y CONFIG_IP_VS_PROTO_UDP=y CONFIG_IP_VS_PROTO_AH_ESP=y CONFIG_IP_VS_PROTO_ESP=y CONFIG_IP_VS_PROTO_AH=y # CONFIG_IP_VS_PROTO_SCTP is not set # # IPVS scheduler # CONFIG_IP_VS_RR=m CONFIG_IP_VS_WRR=m CONFIG_IP_VS_LC=m CONFIG_IP_VS_WLC=m CONFIG_IP_VS_LBLC=m CONFIG_IP_VS_LBLCR=m CONFIG_IP_VS_DH=m CONFIG_IP_VS_SH=m CONFIG_IP_VS_SED=m CONFIG_IP_VS_NQ=m # # IPVS application helper # # # IP: Netfilter Configuration # # CONFIG_NF_DEFRAG_IPV4 is not set CONFIG_IP_NF_QUEUE=m CONFIG_IP_NF_IPTABLES=m CONFIG_IP_NF_MATCH_AH=m CONFIG_IP_NF_MATCH_ECN=m CONFIG_IP_NF_MATCH_TTL=m CONFIG_IP_NF_FILTER=m CONFIG_IP_NF_TARGET_REJECT=m CONFIG_IP_NF_TARGET_LOG=m CONFIG_IP_NF_TARGET_ULOG=m CONFIG_IP_NF_MANGLE=m CONFIG_IP_NF_TARGET_ECN=m CONFIG_IP_NF_TARGET_TTL=m CONFIG_IP_NF_RAW=m # CONFIG_IP_NF_SECURITY is not set CONFIG_IP_NF_ARPTABLES=m CONFIG_IP_NF_ARPFILTER=m CONFIG_IP_NF_ARP_MANGLE=m # # IPv6: Netfilter Configuration # # CONFIG_NF_DEFRAG_IPV6 is not set CONFIG_IP6_NF_QUEUE=m CONFIG_IP6_NF_IPTABLES=m CONFIG_IP6_NF_MATCH_AH=m CONFIG_IP6_NF_MATCH_EUI64=m CONFIG_IP6_NF_MATCH_FRAG=m CONFIG_IP6_NF_MATCH_OPTS=m CONFIG_IP6_NF_MATCH_HL=m CONFIG_IP6_NF_MATCH_IPV6HEADER=m # CONFIG_IP6_NF_MATCH_MH is not set CONFIG_IP6_NF_MATCH_RT=m CONFIG_IP6_NF_TARGET_HL=m CONFIG_IP6_NF_TARGET_LOG=m CONFIG_IP6_NF_FILTER=m CONFIG_IP6_NF_TARGET_REJECT=m CONFIG_IP6_NF_MANGLE=m CONFIG_IP6_NF_RAW=m # CONFIG_IP6_NF_SECURITY is not set # # DECnet: Netfilter Configuration # # CONFIG_DECNET_NF_GRABULATOR is not set CONFIG_BRIDGE_NF_EBTABLES=m CONFIG_BRIDGE_EBT_BROUTE=m CONFIG_BRIDGE_EBT_T_FILTER=m CONFIG_BRIDGE_EBT_T_NAT=m CONFIG_BRIDGE_EBT_802_3=m CONFIG_BRIDGE_EBT_AMONG=m CONFIG_BRIDGE_EBT_ARP=m CONFIG_BRIDGE_EBT_IP=m # CONFIG_BRIDGE_EBT_IP6 is not set CONFIG_BRIDGE_EBT_LIMIT=m CONFIG_BRIDGE_EBT_MARK=m CONFIG_BRIDGE_EBT_PKTTYPE=m CONFIG_BRIDGE_EBT_STP=m CONFIG_BRIDGE_EBT_VLAN=m CONFIG_BRIDGE_EBT_ARPREPLY=m CONFIG_BRIDGE_EBT_DNAT=m CONFIG_BRIDGE_EBT_MARK_T=m CONFIG_BRIDGE_EBT_REDIRECT=m CONFIG_BRIDGE_EBT_SNAT=m CONFIG_BRIDGE_EBT_LOG=m CONFIG_BRIDGE_EBT_ULOG=m # CONFIG_BRIDGE_EBT_NFLOG is not set CONFIG_IP_DCCP=m CONFIG_INET_DCCP_DIAG=m # # DCCP CCIDs Configuration (EXPERIMENTAL) # # CONFIG_IP_DCCP_CCID2_DEBUG is not set CONFIG_IP_DCCP_CCID3=y # CONFIG_IP_DCCP_CCID3_DEBUG is not set CONFIG_IP_DCCP_TFRC_LIB=y # # DCCP Kernel Hacking # # CONFIG_IP_DCCP_DEBUG is not set # CONFIG_NET_DCCPPROBE 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 is not set CONFIG_SCTP_HMAC_MD5=y # CONFIG_RDS is not set CONFIG_TIPC=m # CONFIG_TIPC_ADVANCED is not set # CONFIG_TIPC_DEBUG is not set CONFIG_ATM=m CONFIG_ATM_CLIP=m # CONFIG_ATM_CLIP_NO_ICMP is not set CONFIG_ATM_LANE=m # CONFIG_ATM_MPOA is not set CONFIG_ATM_BR2684=m # CONFIG_ATM_BR2684_IPFILTER is not set # CONFIG_L2TP is not set CONFIG_STP=m CONFIG_BRIDGE=m CONFIG_BRIDGE_IGMP_SNOOPING=y # CONFIG_NET_DSA is not set CONFIG_VLAN_8021Q=m # CONFIG_VLAN_8021Q_GVRP is not set CONFIG_DECNET=m CONFIG_DECNET_ROUTER=y CONFIG_LLC=y # CONFIG_LLC2 is not set CONFIG_IPX=m # CONFIG_IPX_INTERN is not set CONFIG_ATALK=m CONFIG_DEV_APPLETALK=m CONFIG_IPDDP=m CONFIG_IPDDP_ENCAP=y CONFIG_IPDDP_DECAP=y # CONFIG_X25 is not set # CONFIG_LAPB is not set # CONFIG_ECONET is not set CONFIG_WAN_ROUTER=m # CONFIG_PHONET is not set # CONFIG_IEEE802154 is not set CONFIG_NET_SCHED=y # # Queueing/Scheduling # CONFIG_NET_SCH_CBQ=m CONFIG_NET_SCH_HTB=m CONFIG_NET_SCH_HFSC=m CONFIG_NET_SCH_ATM=m CONFIG_NET_SCH_PRIO=m # CONFIG_NET_SCH_MULTIQ is not set CONFIG_NET_SCH_RED=m # CONFIG_NET_SCH_SFB is not set CONFIG_NET_SCH_SFQ=m CONFIG_NET_SCH_TEQL=m CONFIG_NET_SCH_TBF=m CONFIG_NET_SCH_GRED=m CONFIG_NET_SCH_DSMARK=m CONFIG_NET_SCH_NETEM=m # CONFIG_NET_SCH_DRR is not set # CONFIG_NET_SCH_MQPRIO is not set # CONFIG_NET_SCH_CHOKE is not set # CONFIG_NET_SCH_QFQ is not set CONFIG_NET_SCH_INGRESS=m # # Classification # CONFIG_NET_CLS=y CONFIG_NET_CLS_BASIC=m CONFIG_NET_CLS_TCINDEX=m CONFIG_NET_CLS_ROUTE4=m CONFIG_NET_CLS_FW=m CONFIG_NET_CLS_U32=m CONFIG_CLS_U32_PERF=y CONFIG_CLS_U32_MARK=y CONFIG_NET_CLS_RSVP=m CONFIG_NET_CLS_RSVP6=m # CONFIG_NET_CLS_FLOW is not set CONFIG_NET_EMATCH=y CONFIG_NET_EMATCH_STACK=32 CONFIG_NET_EMATCH_CMP=m CONFIG_NET_EMATCH_NBYTE=m CONFIG_NET_EMATCH_U32=m CONFIG_NET_EMATCH_META=m CONFIG_NET_EMATCH_TEXT=m CONFIG_NET_CLS_ACT=y CONFIG_NET_ACT_POLICE=m CONFIG_NET_ACT_GACT=m CONFIG_GACT_PROB=y CONFIG_NET_ACT_MIRRED=m CONFIG_NET_ACT_IPT=m # CONFIG_NET_ACT_NAT is not set CONFIG_NET_ACT_PEDIT=m CONFIG_NET_ACT_SIMP=m # CONFIG_NET_ACT_SKBEDIT is not set # CONFIG_NET_ACT_CSUM is not set CONFIG_NET_CLS_IND=y CONFIG_NET_SCH_FIFO=y # 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_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_HAMRADIO is not set # CONFIG_CAN is not set CONFIG_IRDA=m # # IrDA protocols # CONFIG_IRLAN=m CONFIG_IRNET=m CONFIG_IRCOMM=m # CONFIG_IRDA_ULTRA is not set # # IrDA options # CONFIG_IRDA_CACHE_LAST_LSAP=y CONFIG_IRDA_FAST_RR=y # CONFIG_IRDA_DEBUG is not set # # Infrared-port device drivers # # # SIR device drivers # CONFIG_IRTTY_SIR=m # # Dongle support # CONFIG_DONGLE=y CONFIG_ESI_DONGLE=m CONFIG_ACTISYS_DONGLE=m CONFIG_TEKRAM_DONGLE=m CONFIG_TOIM3232_DONGLE=m CONFIG_LITELINK_DONGLE=m CONFIG_MA600_DONGLE=m CONFIG_GIRBIL_DONGLE=m CONFIG_MCP2120_DONGLE=m CONFIG_OLD_BELKIN_DONGLE=m CONFIG_ACT200L_DONGLE=m # CONFIG_KINGSUN_DONGLE is not set # CONFIG_KSDAZZLE_DONGLE is not set # CONFIG_KS959_DONGLE is not set # # FIR device drivers # CONFIG_USB_IRDA=m CONFIG_SIGMATEL_FIR=m CONFIG_NSC_FIR=m CONFIG_WINBOND_FIR=m CONFIG_SMC_IRCC_FIR=m CONFIG_ALI_FIR=m CONFIG_VLSI_FIR=m CONFIG_VIA_FIR=m CONFIG_MCS_FIR=m CONFIG_BT=m # CONFIG_BT_RFCOMM is not set # CONFIG_BT_BNEP is not set # CONFIG_BT_HIDP is not set # # Bluetooth device drivers # # CONFIG_BT_HCIBTUSB is not set # CONFIG_BT_HCIBTSDIO is not set CONFIG_BT_HCIUART=m CONFIG_BT_HCIUART_H4=y CONFIG_BT_HCIUART_BCSP=y # CONFIG_BT_HCIUART_ATH3K is not set # CONFIG_BT_HCIUART_LL is not set CONFIG_BT_HCIBCM203X=m CONFIG_BT_HCIBPA10X=m CONFIG_BT_HCIBFUSB=m CONFIG_BT_HCIDTL1=m CONFIG_BT_HCIBT3C=m CONFIG_BT_HCIBLUECARD=m CONFIG_BT_HCIBTUART=m CONFIG_BT_HCIVHCI=m # CONFIG_BT_MRVL is not set # CONFIG_AF_RXRPC is not set CONFIG_FIB_RULES=y CONFIG_WIRELESS=y # CONFIG_CFG80211 is not set # CONFIG_LIB80211 is not set # # CFG80211 needs to be enabled for MAC80211 # # CONFIG_WIMAX is not set CONFIG_RFKILL=m CONFIG_RFKILL_LEDS=y CONFIG_RFKILL_INPUT=y # 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="/sbin/hotplug" # CONFIG_DEVTMPFS is not set CONFIG_STANDALONE=y CONFIG_PREVENT_FIRMWARE_BUILD=y CONFIG_FW_LOADER=y CONFIG_FIRMWARE_IN_KERNEL=y CONFIG_EXTRA_FIRMWARE="" # CONFIG_DEBUG_DRIVER is not set # CONFIG_DEBUG_DEVRES is not set # CONFIG_SYS_HYPERVISOR is not set CONFIG_CONNECTOR=y CONFIG_PROC_EVENTS=y CONFIG_MTD=m # CONFIG_MTD_TESTS is not set CONFIG_MTD_REDBOOT_PARTS=m CONFIG_MTD_REDBOOT_DIRECTORY_BLOCK=-1 # CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED is not set # CONFIG_MTD_REDBOOT_PARTS_READONLY is not set # CONFIG_MTD_AR7_PARTS is not set # # User Modules And Translation Layers # CONFIG_MTD_CHAR=m CONFIG_MTD_BLKDEVS=m CONFIG_MTD_BLOCK=m CONFIG_MTD_BLOCK_RO=m CONFIG_FTL=m CONFIG_NFTL=m CONFIG_NFTL_RW=y CONFIG_INFTL=m CONFIG_RFD_FTL=m # CONFIG_SSFDC is not set # CONFIG_SM_FTL is not set # CONFIG_MTD_OOPS is not set # CONFIG_MTD_SWAP is not set # # RAM/ROM/Flash chip drivers # CONFIG_MTD_CFI=m CONFIG_MTD_JEDECPROBE=m CONFIG_MTD_GEN_PROBE=m # CONFIG_MTD_CFI_ADV_OPTIONS is not set CONFIG_MTD_MAP_BANK_WIDTH_1=y CONFIG_MTD_MAP_BANK_WIDTH_2=y CONFIG_MTD_MAP_BANK_WIDTH_4=y # CONFIG_MTD_MAP_BANK_WIDTH_8 is not set # CONFIG_MTD_MAP_BANK_WIDTH_16 is not set # CONFIG_MTD_MAP_BANK_WIDTH_32 is not set CONFIG_MTD_CFI_I1=y CONFIG_MTD_CFI_I2=y # CONFIG_MTD_CFI_I4 is not set # CONFIG_MTD_CFI_I8 is not set CONFIG_MTD_CFI_INTELEXT=m CONFIG_MTD_CFI_AMDSTD=m CONFIG_MTD_CFI_STAA=m CONFIG_MTD_CFI_UTIL=m CONFIG_MTD_RAM=m CONFIG_MTD_ROM=m CONFIG_MTD_ABSENT=m # # Mapping drivers for chip access # CONFIG_MTD_COMPLEX_MAPPINGS=y # CONFIG_MTD_PHYSMAP is not set CONFIG_MTD_SC520CDP=m CONFIG_MTD_NETSC520=m CONFIG_MTD_TS5500=m # CONFIG_MTD_SBC_GXX is not set # CONFIG_MTD_AMD76XROM is not set # CONFIG_MTD_ICHXROM is not set # CONFIG_MTD_ESB2ROM is not set # CONFIG_MTD_CK804XROM is not set CONFIG_MTD_SCB2_FLASH=m # CONFIG_MTD_NETtel is not set # CONFIG_MTD_L440GX is not set CONFIG_MTD_PCI=m # CONFIG_MTD_PCMCIA is not set # CONFIG_MTD_INTEL_VR_NOR is not set # CONFIG_MTD_PLATRAM is not set # CONFIG_MTD_LATCH_ADDR is not set # # Self-contained MTD device drivers # CONFIG_MTD_PMC551=m # CONFIG_MTD_PMC551_BUGFIX is not set # CONFIG_MTD_PMC551_DEBUG is not set # CONFIG_MTD_SLRAM is not set # CONFIG_MTD_PHRAM is not set CONFIG_MTD_MTDRAM=m CONFIG_MTDRAM_TOTAL_SIZE=4096 CONFIG_MTDRAM_ERASE_SIZE=128 CONFIG_MTD_BLOCK2MTD=m # # Disk-On-Chip Device Drivers # # CONFIG_MTD_DOC2000 is not set # CONFIG_MTD_DOC2001 is not set # CONFIG_MTD_DOC2001PLUS is not set # CONFIG_MTD_DOCG3 is not set CONFIG_MTD_NAND_ECC=m CONFIG_MTD_NAND_ECC_SMC=y CONFIG_MTD_NAND=m # CONFIG_MTD_NAND_VERIFY_WRITE is not set # CONFIG_MTD_NAND_ECC_BCH is not set # CONFIG_MTD_SM_COMMON is not set # CONFIG_MTD_NAND_MUSEUM_IDS is not set # CONFIG_MTD_NAND_DENALI is not set CONFIG_MTD_NAND_IDS=m # CONFIG_MTD_NAND_RICOH is not set CONFIG_MTD_NAND_DISKONCHIP=m # CONFIG_MTD_NAND_DISKONCHIP_PROBE_ADVANCED is not set CONFIG_MTD_NAND_DISKONCHIP_PROBE_ADDRESS=0 # CONFIG_MTD_NAND_DISKONCHIP_BBTWRITE is not set # CONFIG_MTD_NAND_CAFE is not set CONFIG_MTD_NAND_NANDSIM=m # CONFIG_MTD_NAND_PLATFORM is not set # CONFIG_MTD_ALAUDA is not set # CONFIG_MTD_ONENAND is not set # # LPDDR flash memory drivers # # CONFIG_MTD_LPDDR is not set # CONFIG_MTD_UBI 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_PC_PCMCIA=m # CONFIG_PARPORT_GSC is not set # CONFIG_PARPORT_AX88796 is not set CONFIG_PARPORT_1284=y CONFIG_PARPORT_NOT_PC=y CONFIG_PNP=y CONFIG_PNP_DEBUG_MESSAGES=y # # Protocols # CONFIG_PNPACPI=y CONFIG_BLK_DEV=y CONFIG_BLK_DEV_FD=m CONFIG_PARIDE=m # # Parallel IDE high-level drivers # CONFIG_PARIDE_PD=m CONFIG_PARIDE_PCD=m CONFIG_PARIDE_PF=m CONFIG_PARIDE_PT=m CONFIG_PARIDE_PG=m # # Parallel IDE protocol modules # CONFIG_PARIDE_ATEN=m CONFIG_PARIDE_BPCK=m CONFIG_PARIDE_COMM=m CONFIG_PARIDE_DSTR=m CONFIG_PARIDE_FIT2=m CONFIG_PARIDE_FIT3=m CONFIG_PARIDE_EPAT=m CONFIG_PARIDE_EPATC8=y CONFIG_PARIDE_EPIA=m CONFIG_PARIDE_FRIQ=m CONFIG_PARIDE_FRPW=m CONFIG_PARIDE_KBIC=m CONFIG_PARIDE_KTTI=m CONFIG_PARIDE_ON20=m CONFIG_PARIDE_ON26=m # CONFIG_BLK_DEV_PCIESSD_MTIP32XX is not set CONFIG_BLK_CPQ_DA=m CONFIG_BLK_CPQ_CISS_DA=m CONFIG_CISS_SCSI_TAPE=y CONFIG_BLK_DEV_DAC960=m CONFIG_BLK_DEV_UMEM=m # CONFIG_BLK_DEV_COW_COMMON is not set CONFIG_BLK_DEV_LOOP=m 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_SX8=m CONFIG_BLK_DEV_UB=m 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=m # CONFIG_BLK_DEV_HD is not set # CONFIG_BLK_DEV_RBD is not set # CONFIG_SENSORS_LIS3LV02D is not set CONFIG_MISC_DEVICES=y # CONFIG_AD525X_DPOT is not set # CONFIG_IBM_ASM is not set # CONFIG_PHANTOM is not set # CONFIG_INTEL_MID_PTI is not set # CONFIG_SGI_IOC4 is not set # CONFIG_TIFM_CORE is not set # CONFIG_ICS932S401 is not set # CONFIG_ENCLOSURE_SERVICES is not set # CONFIG_HP_ILO is not set # CONFIG_APDS9802ALS is not set # CONFIG_ISL29003 is not set # CONFIG_ISL29020 is not set # CONFIG_SENSORS_TSL2550 is not set # CONFIG_SENSORS_BH1780 is not set # CONFIG_SENSORS_BH1770 is not set # CONFIG_SENSORS_APDS990X is not set # CONFIG_HMC6352 is not set # CONFIG_DS1682 is not set # CONFIG_VMWARE_BALLOON is not set # CONFIG_BMP085 is not set # CONFIG_PCH_PHUB is not set # CONFIG_USB_SWITCH_FSA9480 is not set # CONFIG_C2PORT is not set # # EEPROM support # # CONFIG_EEPROM_AT24 is not set # CONFIG_EEPROM_LEGACY is not set # CONFIG_EEPROM_MAX6875 is not set # CONFIG_EEPROM_93CX6 is not set # CONFIG_CB710_CORE is not set # CONFIG_IWMC3200TOP is not set # # Texas Instruments shared transport line discipline # # CONFIG_SENSORS_LIS3_I2C is not set # # Altera FPGA firmware download module # # CONFIG_ALTERA_STAPL is not set CONFIG_HAVE_IDE=y CONFIG_IDE=y # # Please see Documentation/ide/ide.txt for help/info on IDE drives # CONFIG_IDE_XFER_MODE=y CONFIG_IDE_TIMINGS=y CONFIG_IDE_ATAPI=y # CONFIG_BLK_DEV_IDE_SATA is not set CONFIG_IDE_GD=y CONFIG_IDE_GD_ATA=y # CONFIG_IDE_GD_ATAPI is not set CONFIG_BLK_DEV_IDECS=m # CONFIG_BLK_DEV_DELKIN is not set CONFIG_BLK_DEV_IDECD=m CONFIG_BLK_DEV_IDECD_VERBOSE_ERRORS=y # CONFIG_BLK_DEV_IDETAPE is not set # CONFIG_BLK_DEV_IDEACPI is not set CONFIG_IDE_TASK_IOCTL=y CONFIG_IDE_PROC_FS=y # # IDE chipset support/bugfixes # CONFIG_IDE_GENERIC=y # CONFIG_BLK_DEV_PLATFORM is not set # CONFIG_BLK_DEV_CMD640 is not set CONFIG_BLK_DEV_IDEPNP=y CONFIG_BLK_DEV_IDEDMA_SFF=y # # PCI IDE chipsets support # CONFIG_BLK_DEV_IDEPCI=y CONFIG_IDEPCI_PCIBUS_ORDER=y # CONFIG_BLK_DEV_OFFBOARD is not set CONFIG_BLK_DEV_GENERIC=y # CONFIG_BLK_DEV_OPTI621 is not set # CONFIG_BLK_DEV_RZ1000 is not set CONFIG_BLK_DEV_IDEDMA_PCI=y CONFIG_BLK_DEV_AEC62XX=y CONFIG_BLK_DEV_ALI15X3=y CONFIG_BLK_DEV_AMD74XX=y CONFIG_BLK_DEV_ATIIXP=y CONFIG_BLK_DEV_CMD64X=y # CONFIG_BLK_DEV_TRIFLEX is not set # CONFIG_BLK_DEV_CS5520 is not set # CONFIG_BLK_DEV_CS5530 is not set CONFIG_BLK_DEV_HPT366=y # CONFIG_BLK_DEV_JMICRON is not set # CONFIG_BLK_DEV_SC1200 is not set CONFIG_BLK_DEV_PIIX=y # CONFIG_BLK_DEV_IT8172 is not set # CONFIG_BLK_DEV_IT8213 is not set CONFIG_BLK_DEV_IT821X=y # CONFIG_BLK_DEV_NS87415 is not set CONFIG_BLK_DEV_PDC202XX_OLD=y CONFIG_BLK_DEV_PDC202XX_NEW=y CONFIG_BLK_DEV_SVWKS=y CONFIG_BLK_DEV_SIIMAGE=y CONFIG_BLK_DEV_SIS5513=y # CONFIG_BLK_DEV_SLC90E66 is not set # CONFIG_BLK_DEV_TRM290 is not set CONFIG_BLK_DEV_VIA82CXXX=y # CONFIG_BLK_DEV_TC86C001 is not set CONFIG_BLK_DEV_IDEDMA=y # # SCSI device support # CONFIG_SCSI_MOD=y CONFIG_RAID_ATTRS=m CONFIG_SCSI=y CONFIG_SCSI_DMA=y # CONFIG_SCSI_TGT is not set CONFIG_SCSI_NETLINK=y CONFIG_SCSI_PROC_FS=y # # SCSI support type (disk, tape, CD-ROM) # CONFIG_BLK_DEV_SD=y CONFIG_CHR_DEV_ST=m CONFIG_CHR_DEV_OSST=m CONFIG_BLK_DEV_SR=m CONFIG_BLK_DEV_SR_VENDOR=y CONFIG_CHR_DEV_SG=m CONFIG_CHR_DEV_SCH=m CONFIG_SCSI_MULTI_LUN=y CONFIG_SCSI_CONSTANTS=y CONFIG_SCSI_LOGGING=y # CONFIG_SCSI_SCAN_ASYNC is not set CONFIG_SCSI_WAIT_SCAN=m # # SCSI Transports # CONFIG_SCSI_SPI_ATTRS=m CONFIG_SCSI_FC_ATTRS=m CONFIG_SCSI_ISCSI_ATTRS=m CONFIG_SCSI_SAS_ATTRS=m CONFIG_SCSI_SAS_LIBSAS=m # CONFIG_SCSI_SAS_ATA is not set CONFIG_SCSI_SAS_HOST_SMP=y CONFIG_SCSI_SRP_ATTRS=m CONFIG_SCSI_LOWLEVEL=y CONFIG_ISCSI_TCP=m CONFIG_ISCSI_BOOT_SYSFS=m # 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=m # CONFIG_SCSI_HPSA is not set CONFIG_SCSI_3W_9XXX=m # CONFIG_SCSI_3W_SAS is not set CONFIG_SCSI_ACARD=m CONFIG_SCSI_AACRAID=m CONFIG_SCSI_AIC7XXX=m CONFIG_AIC7XXX_CMDS_PER_DEVICE=4 CONFIG_AIC7XXX_RESET_DELAY_MS=15000 # CONFIG_AIC7XXX_DEBUG_ENABLE is not set CONFIG_AIC7XXX_DEBUG_MASK=0 # CONFIG_AIC7XXX_REG_PRETTY_PRINT is not set CONFIG_SCSI_AIC7XXX_OLD=m CONFIG_SCSI_AIC79XX=m CONFIG_AIC79XX_CMDS_PER_DEVICE=4 CONFIG_AIC79XX_RESET_DELAY_MS=15000 # CONFIG_AIC79XX_DEBUG_ENABLE is not set CONFIG_AIC79XX_DEBUG_MASK=0 # CONFIG_AIC79XX_REG_PRETTY_PRINT is not set CONFIG_SCSI_AIC94XX=m # CONFIG_AIC94XX_DEBUG 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=y CONFIG_MEGARAID_MM=m CONFIG_MEGARAID_MAILBOX=m CONFIG_MEGARAID_LEGACY=m CONFIG_MEGARAID_SAS=m # CONFIG_SCSI_MPT2SAS is not set CONFIG_SCSI_HPTIOP=m CONFIG_SCSI_BUSLOGIC=m # CONFIG_VMWARE_PVSCSI is not set # 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=m # CONFIG_SCSI_ISCI is not set CONFIG_SCSI_IPS=m CONFIG_SCSI_INITIO=m CONFIG_SCSI_INIA100=m CONFIG_SCSI_PPA=m CONFIG_SCSI_IMM=m # CONFIG_SCSI_IZIP_EPP16 is not set # CONFIG_SCSI_IZIP_SLOW_CTR is not set # CONFIG_SCSI_STEX is not set CONFIG_SCSI_SYM53C8XX_2=m CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE=1 CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS=16 CONFIG_SCSI_SYM53C8XX_MAX_TAGS=64 CONFIG_SCSI_SYM53C8XX_MMIO=y # CONFIG_SCSI_IPR is not set CONFIG_SCSI_QLOGIC_1280=m CONFIG_SCSI_QLA_FC=m CONFIG_SCSI_QLA_ISCSI=m CONFIG_SCSI_LPFC=m # CONFIG_SCSI_LPFC_DEBUG_FS is not set CONFIG_SCSI_DC395x=m CONFIG_SCSI_DC390T=m # 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_LOWLEVEL_PCMCIA is not set # CONFIG_SCSI_DH is not set # CONFIG_SCSI_OSD_INITIATOR 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 is not set # 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_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 is not set # 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 is not set # 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 is not set # CONFIG_PATA_NS87410 is not set # CONFIG_PATA_OPTI is not set # CONFIG_PATA_PCMCIA is not set # CONFIG_PATA_RZ1000 is not set # # Generic fallback / legacy drivers # # CONFIG_PATA_ACPI is not set # CONFIG_ATA_GENERIC is not set # 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=m CONFIG_MD_FAULTY=m CONFIG_BLK_DEV_DM=m # CONFIG_DM_DEBUG is not set CONFIG_DM_CRYPT=m CONFIG_DM_SNAPSHOT=m # CONFIG_DM_THIN_PROVISIONING is not set CONFIG_DM_MIRROR=m # CONFIG_DM_RAID is not set # CONFIG_DM_LOG_USERSPACE is not set CONFIG_DM_ZERO=m CONFIG_DM_MULTIPATH=m # CONFIG_DM_MULTIPATH_QL is not set # CONFIG_DM_MULTIPATH_ST is not set # CONFIG_DM_DELAY is not set # CONFIG_DM_UEVENT is not set # CONFIG_DM_FLAKEY is not set # CONFIG_TARGET_CORE is not set CONFIG_FUSION=y CONFIG_FUSION_SPI=m CONFIG_FUSION_FC=m CONFIG_FUSION_SAS=m CONFIG_FUSION_MAX_SGE=40 CONFIG_FUSION_CTL=m CONFIG_FUSION_LAN=m # CONFIG_FUSION_LOGGING is not set # # IEEE 1394 (FireWire) support # # CONFIG_FIREWIRE is not set # CONFIG_FIREWIRE_NOSY is not set CONFIG_I2O=m # CONFIG_I2O_LCT_NOTIFY_ON_CHANGES is not set CONFIG_I2O_EXT_ADAPTEC=y CONFIG_I2O_EXT_ADAPTEC_DMA64=y CONFIG_I2O_CONFIG=m CONFIG_I2O_CONFIG_OLD_IOCTL=y CONFIG_I2O_BUS=m CONFIG_I2O_BLOCK=m CONFIG_I2O_SCSI=m CONFIG_I2O_PROC=m # CONFIG_MACINTOSH_DRIVERS is not set CONFIG_NETDEVICES=y CONFIG_NET_CORE=y CONFIG_BONDING=m CONFIG_DUMMY=m CONFIG_EQUALIZER=m CONFIG_NET_FC=y CONFIG_MII=m CONFIG_IFB=m # CONFIG_NET_TEAM is not set # CONFIG_MACVLAN is not set CONFIG_NETCONSOLE=y CONFIG_NETPOLL=y CONFIG_NETPOLL_TRAP=y CONFIG_NET_POLL_CONTROLLER=y CONFIG_TUN=m # CONFIG_VETH is not set # CONFIG_ARCNET is not set CONFIG_ATM_DRIVERS=y # CONFIG_ATM_DUMMY is not set CONFIG_ATM_TCP=m CONFIG_ATM_LANAI=m CONFIG_ATM_ENI=m # CONFIG_ATM_ENI_DEBUG is not set # CONFIG_ATM_ENI_TUNE_BURST is not set CONFIG_ATM_FIRESTREAM=m # CONFIG_ATM_ZATM is not set # CONFIG_ATM_NICSTAR is not set CONFIG_ATM_IDT77252=m # CONFIG_ATM_IDT77252_DEBUG is not set # CONFIG_ATM_IDT77252_RCV_ALL is not set CONFIG_ATM_IDT77252_USE_SUNI=y CONFIG_ATM_AMBASSADOR=m # CONFIG_ATM_AMBASSADOR_DEBUG is not set CONFIG_ATM_HORIZON=m # CONFIG_ATM_HORIZON_DEBUG is not set # CONFIG_ATM_IA is not set # CONFIG_ATM_FORE200E is not set CONFIG_ATM_HE=m # CONFIG_ATM_HE_USE_SUNI is not set # CONFIG_ATM_SOLOS is not set # # CAIF transport drivers # CONFIG_ETHERNET=y CONFIG_NET_VENDOR_3COM=y CONFIG_PCMCIA_3C574=m CONFIG_PCMCIA_3C589=m CONFIG_VORTEX=m CONFIG_TYPHOON=m # CONFIG_NET_VENDOR_ADAPTEC is not set # CONFIG_NET_VENDOR_ALTEON is not set # CONFIG_NET_VENDOR_AMD is not set # 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_FUJITSU is not set # CONFIG_NET_VENDOR_HP is not set CONFIG_NET_VENDOR_INTEL=y # CONFIG_E100 is not set CONFIG_E1000=y CONFIG_E1000E=y # 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 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=m # 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=y # CONFIG_SC92031 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_NET_VENDOR_XIRCOM 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=m # # MII PHY device drivers # CONFIG_MARVELL_PHY=m CONFIG_DAVICOM_PHY=m CONFIG_QSEMI_PHY=m CONFIG_LXT_PHY=m CONFIG_CICADA_PHY=m CONFIG_VITESSE_PHY=m CONFIG_SMSC_PHY=m # 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_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_PPPOATM=m 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=y # CONFIG_PCMCIA_IBMTR is not set CONFIG_IBMOL=m CONFIG_3C359=m # CONFIG_TMS380TR is not set # # USB Network Adapters # CONFIG_USB_CATC=m CONFIG_USB_KAWETH=m CONFIG_USB_PEGASUS=m CONFIG_USB_RTL8150=m CONFIG_USB_USBNET=m CONFIG_USB_NET_AX8817X=m CONFIG_USB_NET_CDCETHER=m # CONFIG_USB_NET_CDC_EEM is not set CONFIG_USB_NET_CDC_NCM=m # CONFIG_USB_NET_DM9601 is not set # CONFIG_USB_NET_SMSC75XX is not set # CONFIG_USB_NET_SMSC95XX is not set CONFIG_USB_NET_GL620A=m CONFIG_USB_NET_NET1080=m CONFIG_USB_NET_PLUSB=m # CONFIG_USB_NET_MCS7830 is not set CONFIG_USB_NET_RNDIS_HOST=m CONFIG_USB_NET_CDC_SUBSET=m CONFIG_USB_ALI_M5632=y CONFIG_USB_AN2720=y CONFIG_USB_BELKIN=y CONFIG_USB_ARMLINUX=y CONFIG_USB_EPSON2888=y # CONFIG_USB_KC2190 is not set CONFIG_USB_NET_ZAURUS=m # CONFIG_USB_NET_CX82310_ETH is not set # CONFIG_USB_NET_KALMIA is not set # CONFIG_USB_HSO is not set # CONFIG_USB_NET_INT51X1 is not set # CONFIG_USB_IPHETH is not set # CONFIG_USB_SIERRA_NET is not set # CONFIG_USB_VL600 is not set CONFIG_WLAN=y # CONFIG_PCMCIA_RAYCS is not set # CONFIG_AIRO is not set # CONFIG_ATMEL is not set # CONFIG_AIRO_CS is not set # CONFIG_PCMCIA_WL3501 is not set # CONFIG_PRISM54 is not set # CONFIG_USB_ZD1201 is not set # CONFIG_HOSTAP is not set # # Enable WiMAX (Networking options) to see the WiMAX drivers # # CONFIG_WAN is not set # CONFIG_VMXNET3 is not set # CONFIG_ISDN is not set # CONFIG_PHONE is not set # # Input device support # CONFIG_INPUT=y CONFIG_INPUT_FF_MEMLESS=y CONFIG_INPUT_POLLDEV=m CONFIG_INPUT_SPARSEKMAP=m # # 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=m 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_LM8323 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 is not set # 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 is not set # CONFIG_MOUSE_PS2_SENTELIC is not set # CONFIG_MOUSE_PS2_TOUCHKIT is not set CONFIG_MOUSE_SERIAL=m # CONFIG_MOUSE_APPLETOUCH is not set # CONFIG_MOUSE_BCM5974 is not set CONFIG_MOUSE_VSXXXAA=m # CONFIG_MOUSE_SYNAPTICS_I2C is not set CONFIG_INPUT_JOYSTICK=y CONFIG_JOYSTICK_ANALOG=m CONFIG_JOYSTICK_A3D=m CONFIG_JOYSTICK_ADI=m CONFIG_JOYSTICK_COBRA=m CONFIG_JOYSTICK_GF2K=m CONFIG_JOYSTICK_GRIP=m CONFIG_JOYSTICK_GRIP_MP=m CONFIG_JOYSTICK_GUILLEMOT=m CONFIG_JOYSTICK_INTERACT=m CONFIG_JOYSTICK_SIDEWINDER=m CONFIG_JOYSTICK_TMDC=m CONFIG_JOYSTICK_IFORCE=m CONFIG_JOYSTICK_IFORCE_USB=y CONFIG_JOYSTICK_IFORCE_232=y CONFIG_JOYSTICK_WARRIOR=m CONFIG_JOYSTICK_MAGELLAN=m CONFIG_JOYSTICK_SPACEORB=m CONFIG_JOYSTICK_SPACEBALL=m CONFIG_JOYSTICK_STINGER=m CONFIG_JOYSTICK_TWIDJOY=m # CONFIG_JOYSTICK_ZHENHUA is not set CONFIG_JOYSTICK_DB9=m CONFIG_JOYSTICK_GAMECON=m CONFIG_JOYSTICK_TURBOGRAFX=m # CONFIG_JOYSTICK_AS5011 is not set CONFIG_JOYSTICK_JOYDUMP=m # CONFIG_JOYSTICK_XPAD is not set # CONFIG_JOYSTICK_WALKERA0701 is not set # CONFIG_INPUT_TABLET is not set CONFIG_INPUT_TOUCHSCREEN=y # CONFIG_TOUCHSCREEN_AD7879 is not set # CONFIG_TOUCHSCREEN_ATMEL_MXT is not set # CONFIG_TOUCHSCREEN_BU21013 is not set # CONFIG_TOUCHSCREEN_DYNAPRO is not set # CONFIG_TOUCHSCREEN_HAMPSHIRE is not set # CONFIG_TOUCHSCREEN_EETI is not set # CONFIG_TOUCHSCREEN_EGALAX is not set # CONFIG_TOUCHSCREEN_FUJITSU is not set CONFIG_TOUCHSCREEN_GUNZE=m CONFIG_TOUCHSCREEN_ELO=m # CONFIG_TOUCHSCREEN_WACOM_W8001 is not set # CONFIG_TOUCHSCREEN_MAX11801 is not set # CONFIG_TOUCHSCREEN_MCS5000 is not set CONFIG_TOUCHSCREEN_MTOUCH=m # CONFIG_TOUCHSCREEN_INEXIO is not set CONFIG_TOUCHSCREEN_MK712=m # CONFIG_TOUCHSCREEN_PENMOUNT is not set # CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set # CONFIG_TOUCHSCREEN_TOUCHWIN is not set # CONFIG_TOUCHSCREEN_WM97XX is not set # CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set # CONFIG_TOUCHSCREEN_TSC_SERIO is not set # CONFIG_TOUCHSCREEN_TSC2007 is not set # CONFIG_TOUCHSCREEN_ST1232 is not set # CONFIG_TOUCHSCREEN_TPS6507X is not set CONFIG_INPUT_MISC=y # CONFIG_INPUT_AD714X is not set # CONFIG_INPUT_BMA150 is not set CONFIG_INPUT_PCSPKR=m # CONFIG_INPUT_MMA8450 is not set # CONFIG_INPUT_MPU3050 is not set # CONFIG_INPUT_APANEL is not set # CONFIG_INPUT_ATLAS_BTNS is not set # CONFIG_INPUT_ATI_REMOTE2 is not set # CONFIG_INPUT_KEYSPAN_REMOTE is not set # CONFIG_INPUT_KXTJ9 is not set # CONFIG_INPUT_POWERMATE is not set # CONFIG_INPUT_YEALINK is not set # CONFIG_INPUT_CM109 is not set CONFIG_INPUT_UINPUT=m # CONFIG_INPUT_PCF8574 is not set # CONFIG_INPUT_ADXL34X is not set # CONFIG_INPUT_CMA3000 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=m CONFIG_GAMEPORT_NS558=m CONFIG_GAMEPORT_L4=m CONFIG_GAMEPORT_EMU10K1=m CONFIG_GAMEPORT_FM801=m # # 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 is not set # CONFIG_LEGACY_PTYS is not set CONFIG_SERIAL_NONSTANDARD=y # CONFIG_ROCKETPORT is not set CONFIG_CYCLADES=m # CONFIG_CYZ_INTR is not set # CONFIG_MOXA_INTELLIO is not set # CONFIG_MOXA_SMARTIO is not set CONFIG_SYNCLINK=m CONFIG_SYNCLINKMP=m CONFIG_SYNCLINK_GT=m # CONFIG_NOZOMI is not set # CONFIG_ISI is not set CONFIG_N_HDLC=m # CONFIG_N_GSM is not set # CONFIG_TRACE_SINK is not set CONFIG_DEVKMEM=y # CONFIG_STALDRV 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_CS=m 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_SERIAL_JSM=m # 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=m # CONFIG_IPMI_PANIC_EVENT is not set CONFIG_IPMI_DEVICE_INTERFACE=m CONFIG_IPMI_SI=m CONFIG_IPMI_WATCHDOG=m CONFIG_IPMI_POWEROFF=m CONFIG_HW_RANDOM=y # CONFIG_HW_RANDOM_TIMERIOMEM is not set CONFIG_HW_RANDOM_INTEL=m CONFIG_HW_RANDOM_AMD=m CONFIG_HW_RANDOM_VIA=y CONFIG_NVRAM=y # CONFIG_RTC is not set # CONFIG_GEN_RTC is not set CONFIG_R3964=m # CONFIG_APPLICOM is not set # # PCMCIA character devices # # CONFIG_SYNCLINK_CS is not set CONFIG_CARDMAN_4000=m CONFIG_CARDMAN_4040=m # CONFIG_IPWIRELESS is not set CONFIG_MWAVE=m # CONFIG_RAW_DRIVER is not set CONFIG_HPET=y # CONFIG_HPET_MMAP is not set CONFIG_HANGCHECK_TIMER=m CONFIG_TCG_TPM=m CONFIG_TCG_TIS=m CONFIG_TCG_NSC=m CONFIG_TCG_ATMEL=m CONFIG_TCG_INFINEON=m # 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 # # 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=m CONFIG_I2C_AMD756_S4882=m CONFIG_I2C_AMD8111=m CONFIG_I2C_I801=m # CONFIG_I2C_ISCH is not set # CONFIG_I2C_PIIX4 is not set CONFIG_I2C_NFORCE2=m # CONFIG_I2C_NFORCE2_S4985 is not set # CONFIG_I2C_SIS5595 is not set # CONFIG_I2C_SIS630 is not set CONFIG_I2C_SIS96X=m CONFIG_I2C_VIA=m CONFIG_I2C_VIAPRO=m # # ACPI drivers # # CONFIG_I2C_SCMI is not set # # 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 is not set # CONFIG_I2C_PXA_PCI is not set # CONFIG_I2C_SIMTEC is not set # 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 is not set # # 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 # CONFIG_HSI 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=m CONFIG_W1_CON=y # # 1-wire Bus Masters # CONFIG_W1_MASTER_MATROX=m CONFIG_W1_MASTER_DS2490=m CONFIG_W1_MASTER_DS2482=m # CONFIG_W1_MASTER_DS1WM is not set # # 1-wire Slaves # CONFIG_W1_SLAVE_THERM=m CONFIG_W1_SLAVE_SMEM=m # CONFIG_W1_SLAVE_DS2408 is not set # CONFIG_W1_SLAVE_DS2423 is not set # CONFIG_W1_SLAVE_DS2431 is not set CONFIG_W1_SLAVE_DS2433=m CONFIG_W1_SLAVE_DS2433_CRC=y # CONFIG_W1_SLAVE_DS2760 is not set # CONFIG_W1_SLAVE_DS2780 is not set # CONFIG_W1_SLAVE_BQ27000 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_BQ20Z75 is not set # CONFIG_BATTERY_BQ27x00 is not set # CONFIG_BATTERY_MAX17040 is not set # CONFIG_BATTERY_MAX17042 is not set # CONFIG_CHARGER_MAX8903 is not set CONFIG_HWMON=m CONFIG_HWMON_VID=m # CONFIG_HWMON_DEBUG_CHIP is not set # # Native drivers # CONFIG_SENSORS_ABITUGURU=m # CONFIG_SENSORS_ABITUGURU3 is not set # CONFIG_SENSORS_AD7414 is not set # CONFIG_SENSORS_AD7418 is not set CONFIG_SENSORS_ADM1021=m CONFIG_SENSORS_ADM1025=m CONFIG_SENSORS_ADM1026=m # CONFIG_SENSORS_ADM1029 is not set CONFIG_SENSORS_ADM1031=m CONFIG_SENSORS_ADM9240=m # CONFIG_SENSORS_ADT7411 is not set # CONFIG_SENSORS_ADT7462 is not set # CONFIG_SENSORS_ADT7470 is not set # CONFIG_SENSORS_ADT7475 is not set # CONFIG_SENSORS_ASC7621 is not set # CONFIG_SENSORS_K8TEMP is not set # CONFIG_SENSORS_K10TEMP is not set # CONFIG_SENSORS_FAM15H_POWER is not set CONFIG_SENSORS_ASB100=m CONFIG_SENSORS_ATXP1=m # CONFIG_SENSORS_DS620 is not set CONFIG_SENSORS_DS1621=m # CONFIG_SENSORS_I5K_AMB is not set CONFIG_SENSORS_F71805F=m # CONFIG_SENSORS_F71882FG is not set # CONFIG_SENSORS_F75375S is not set # CONFIG_SENSORS_FSCHMD is not set # CONFIG_SENSORS_G760A is not set CONFIG_SENSORS_GL518SM=m CONFIG_SENSORS_GL520SM=m # CONFIG_SENSORS_CORETEMP is not set # CONFIG_SENSORS_IBMAEM is not set # CONFIG_SENSORS_IBMPEX is not set CONFIG_SENSORS_IT87=m # CONFIG_SENSORS_JC42 is not set # CONFIG_SENSORS_LINEAGE is not set CONFIG_SENSORS_LM63=m # CONFIG_SENSORS_LM73 is not set CONFIG_SENSORS_LM75=m CONFIG_SENSORS_LM77=m CONFIG_SENSORS_LM78=m CONFIG_SENSORS_LM80=m CONFIG_SENSORS_LM83=m CONFIG_SENSORS_LM85=m CONFIG_SENSORS_LM87=m CONFIG_SENSORS_LM90=m CONFIG_SENSORS_LM92=m # CONFIG_SENSORS_LM93 is not set # CONFIG_SENSORS_LTC4151 is not set # CONFIG_SENSORS_LTC4215 is not set # CONFIG_SENSORS_LTC4245 is not set # CONFIG_SENSORS_LTC4261 is not set # CONFIG_SENSORS_LM95241 is not set # CONFIG_SENSORS_LM95245 is not set # CONFIG_SENSORS_MAX16065 is not set CONFIG_SENSORS_MAX1619=m # CONFIG_SENSORS_MAX1668 is not set # CONFIG_SENSORS_MAX6639 is not set # CONFIG_SENSORS_MAX6642 is not set # CONFIG_SENSORS_MAX6650 is not set # CONFIG_SENSORS_NTC_THERMISTOR is not set CONFIG_SENSORS_PC87360=m # CONFIG_SENSORS_PC87427 is not set CONFIG_SENSORS_PCF8591=m # CONFIG_PMBUS is not set # CONFIG_SENSORS_SHT21 is not set CONFIG_SENSORS_SIS5595=m # CONFIG_SENSORS_SMM665 is not set # CONFIG_SENSORS_DME1737 is not set # CONFIG_SENSORS_EMC1403 is not set # CONFIG_SENSORS_EMC2103 is not set # CONFIG_SENSORS_EMC6W201 is not set CONFIG_SENSORS_SMSC47M1=m CONFIG_SENSORS_SMSC47M192=m CONFIG_SENSORS_SMSC47B397=m # CONFIG_SENSORS_SCH56XX_COMMON is not set # CONFIG_SENSORS_SCH5627 is not set # CONFIG_SENSORS_SCH5636 is not set # CONFIG_SENSORS_ADS1015 is not set # CONFIG_SENSORS_ADS7828 is not set # CONFIG_SENSORS_AMC6821 is not set # CONFIG_SENSORS_THMC50 is not set # CONFIG_SENSORS_TMP102 is not set # CONFIG_SENSORS_TMP401 is not set # CONFIG_SENSORS_TMP421 is not set # CONFIG_SENSORS_VIA_CPUTEMP is not set CONFIG_SENSORS_VIA686A=m # CONFIG_SENSORS_VT1211 is not set CONFIG_SENSORS_VT8231=m CONFIG_SENSORS_W83781D=m CONFIG_SENSORS_W83791D=m CONFIG_SENSORS_W83792D=m # CONFIG_SENSORS_W83793 is not set # CONFIG_SENSORS_W83795 is not set CONFIG_SENSORS_W83L785TS=m # CONFIG_SENSORS_W83L786NG is not set CONFIG_SENSORS_W83627HF=m CONFIG_SENSORS_W83627EHF=m # CONFIG_SENSORS_APPLESMC is not set # # ACPI drivers # # CONFIG_SENSORS_ACPI_POWER is not set # CONFIG_SENSORS_ATK0110 is not set CONFIG_THERMAL=y CONFIG_WATCHDOG=y # CONFIG_WATCHDOG_CORE is not set # CONFIG_WATCHDOG_NOWAYOUT is not set # # Watchdog Device Drivers # CONFIG_SOFT_WATCHDOG=m # CONFIG_ACQUIRE_WDT is not set # CONFIG_ADVANTECH_WDT is not set CONFIG_ALIM1535_WDT=m CONFIG_ALIM7101_WDT=m # CONFIG_F71808E_WDT is not set # CONFIG_SP5100_TCO is not set # CONFIG_SC520_WDT is not set # CONFIG_SBC_FITPC2_WATCHDOG is not set # CONFIG_EUROTECH_WDT is not set # CONFIG_IB700_WDT is not set CONFIG_IBMASR=m # CONFIG_WAFER_WDT is not set CONFIG_I6300ESB_WDT=m # CONFIG_ITCO_WDT is not set # CONFIG_IT8712F_WDT is not set # CONFIG_IT87_WDT is not set # CONFIG_HP_WATCHDOG is not set # CONFIG_SC1200_WDT is not set # CONFIG_PC87413_WDT is not set # CONFIG_NV_TCO is not set # CONFIG_60XX_WDT is not set # CONFIG_SBC8360_WDT is not set # CONFIG_CPU5_WDT is not set # CONFIG_SMSC_SCH311X_WDT is not set # CONFIG_SMSC37B787_WDT is not set CONFIG_W83627HF_WDT=m # CONFIG_W83697HF_WDT is not set # CONFIG_W83697UG_WDT is not set CONFIG_W83877F_WDT=m CONFIG_W83977F_WDT=m CONFIG_MACHZ_WDT=m # CONFIG_SBC_EPX_C3_WATCHDOG is not set # # PCI-based Watchdog Cards # CONFIG_PCIPCWATCHDOG=m CONFIG_WDTPCI=m # # USB-based Watchdog Cards # CONFIG_USBPCWATCHDOG=m CONFIG_SSB_POSSIBLE=y # # Sonics Silicon Backplane # CONFIG_SSB=m CONFIG_SSB_SPROM=y CONFIG_SSB_PCIHOST_POSSIBLE=y CONFIG_SSB_PCIHOST=y # CONFIG_SSB_B43_PCI_BRIDGE is not set CONFIG_SSB_PCMCIAHOST_POSSIBLE=y # CONFIG_SSB_PCMCIAHOST is not set CONFIG_SSB_SDIOHOST_POSSIBLE=y # CONFIG_SSB_SDIOHOST is not set # CONFIG_SSB_DEBUG is not set CONFIG_SSB_DRIVER_PCICORE_POSSIBLE=y CONFIG_SSB_DRIVER_PCICORE=y 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=y CONFIG_AGP_INTEL=y CONFIG_AGP_SIS=y CONFIG_AGP_VIA=y CONFIG_VGA_ARB=y CONFIG_VGA_ARB_MAX_GPUS=16 # CONFIG_VGA_SWITCHEROO is not set CONFIG_DRM=m CONFIG_DRM_KMS_HELPER=m CONFIG_DRM_TTM=m CONFIG_DRM_TDFX=m CONFIG_DRM_R128=m CONFIG_DRM_RADEON=m # CONFIG_DRM_RADEON_KMS is not set CONFIG_DRM_I810=m CONFIG_DRM_I915=m # CONFIG_DRM_I915_KMS is not set CONFIG_DRM_MGA=m CONFIG_DRM_SIS=m CONFIG_DRM_VIA=m CONFIG_DRM_SAVAGE=m # CONFIG_DRM_VMWGFX is not set # CONFIG_DRM_GMA500 is not set # CONFIG_STUB_POULSBO is not set CONFIG_VGASTATE=m CONFIG_VIDEO_OUTPUT_CONTROL=m CONFIG_FB=y # CONFIG_FIRMWARE_EDID is not set CONFIG_FB_DDC=m 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=y CONFIG_FB_BOTH_ENDIAN=y # CONFIG_FB_BIG_ENDIAN is not set # CONFIG_FB_LITTLE_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=y CONFIG_FB_MODE_HELPERS=y CONFIG_FB_TILEBLITTING=y # # Frame buffer hardware drivers # CONFIG_FB_CIRRUS=m # 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=m # CONFIG_FB_UVESA is not set CONFIG_FB_VESA=y # CONFIG_FB_N411 is not set # CONFIG_FB_HGA is not set # CONFIG_FB_S1D13XXX is not set CONFIG_FB_NVIDIA=m CONFIG_FB_NVIDIA_I2C=y # CONFIG_FB_NVIDIA_DEBUG is not set CONFIG_FB_NVIDIA_BACKLIGHT=y CONFIG_FB_RIVA=m # CONFIG_FB_RIVA_I2C is not set # CONFIG_FB_RIVA_DEBUG is not set CONFIG_FB_RIVA_BACKLIGHT=y # CONFIG_FB_LE80578 is not set CONFIG_FB_MATROX=m CONFIG_FB_MATROX_MILLENIUM=y CONFIG_FB_MATROX_MYSTIQUE=y CONFIG_FB_MATROX_G=y CONFIG_FB_MATROX_I2C=m CONFIG_FB_MATROX_MAVEN=m CONFIG_FB_RADEON=m CONFIG_FB_RADEON_I2C=y CONFIG_FB_RADEON_BACKLIGHT=y # CONFIG_FB_RADEON_DEBUG is not set CONFIG_FB_ATY128=m CONFIG_FB_ATY128_BACKLIGHT=y CONFIG_FB_ATY=m CONFIG_FB_ATY_CT=y CONFIG_FB_ATY_GENERIC_LCD=y CONFIG_FB_ATY_GX=y CONFIG_FB_ATY_BACKLIGHT=y # CONFIG_FB_S3 is not set CONFIG_FB_SAVAGE=m CONFIG_FB_SAVAGE_I2C=y CONFIG_FB_SAVAGE_ACCEL=y # CONFIG_FB_SIS is not set # CONFIG_FB_VIA is not set CONFIG_FB_NEOMAGIC=m CONFIG_FB_KYRO=m CONFIG_FB_3DFX=m CONFIG_FB_3DFX_ACCEL=y CONFIG_FB_3DFX_I2C=y CONFIG_FB_VOODOO1=m # CONFIG_FB_VT8623 is not set CONFIG_FB_TRIDENT=m # 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=y CONFIG_LCD_CLASS_DEVICE=m # CONFIG_LCD_PLATFORM is not set CONFIG_BACKLIGHT_CLASS_DEVICE=y CONFIG_BACKLIGHT_GENERIC=y # CONFIG_BACKLIGHT_PROGEAR is not set # CONFIG_BACKLIGHT_APPLE is not set # CONFIG_BACKLIGHT_SAHARA is not set # CONFIG_BACKLIGHT_ADP8860 is not set # CONFIG_BACKLIGHT_ADP8870 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=m CONFIG_SOUND_OSS_CORE=y CONFIG_SOUND_OSS_CORE_PRECLAIM=y CONFIG_SND=m CONFIG_SND_TIMER=m CONFIG_SND_PCM=m CONFIG_SND_HWDEP=m CONFIG_SND_RAWMIDI=m CONFIG_SND_SEQUENCER=m CONFIG_SND_SEQ_DUMMY=m CONFIG_SND_OSSEMUL=y CONFIG_SND_MIXER_OSS=m CONFIG_SND_PCM_OSS=m CONFIG_SND_PCM_OSS_PLUGINS=y CONFIG_SND_SEQUENCER_OSS=y # CONFIG_SND_HRTIMER is not set CONFIG_SND_DYNAMIC_MINORS=y # CONFIG_SND_SUPPORT_OLD_API is not set CONFIG_SND_VERBOSE_PROCFS=y # CONFIG_SND_VERBOSE_PRINTK is not set # CONFIG_SND_DEBUG is not set CONFIG_SND_VMASTER=y CONFIG_SND_KCTL_JACK=y CONFIG_SND_DMA_SGBUF=y CONFIG_SND_RAWMIDI_SEQ=m CONFIG_SND_OPL3_LIB_SEQ=m # CONFIG_SND_OPL4_LIB_SEQ is not set # CONFIG_SND_SBAWE_SEQ is not set CONFIG_SND_EMU10K1_SEQ=m CONFIG_SND_MPU401_UART=m CONFIG_SND_OPL3_LIB=m CONFIG_SND_VX_LIB=m CONFIG_SND_AC97_CODEC=m CONFIG_SND_DRIVERS=y # CONFIG_SND_PCSP is not set CONFIG_SND_DUMMY=m # CONFIG_SND_ALOOP is not set CONFIG_SND_VIRMIDI=m CONFIG_SND_MTPAV=m # CONFIG_SND_MTS64 is not set # CONFIG_SND_SERIAL_U16550 is not set CONFIG_SND_MPU401=m # CONFIG_SND_PORTMAN2X4 is not set # CONFIG_SND_AC97_POWER_SAVE is not set CONFIG_SND_SB_COMMON=m CONFIG_SND_PCI=y CONFIG_SND_AD1889=m CONFIG_SND_ALS300=m CONFIG_SND_ALS4000=m CONFIG_SND_ALI5451=m # CONFIG_SND_ASIHPI is not set CONFIG_SND_ATIIXP=m CONFIG_SND_ATIIXP_MODEM=m CONFIG_SND_AU8810=m CONFIG_SND_AU8820=m CONFIG_SND_AU8830=m # CONFIG_SND_AW2 is not set CONFIG_SND_AZT3328=m CONFIG_SND_BT87X=m # CONFIG_SND_BT87X_OVERCLOCK is not set CONFIG_SND_CA0106=m CONFIG_SND_CMIPCI=m # CONFIG_SND_OXYGEN is not set CONFIG_SND_CS4281=m CONFIG_SND_CS46XX=m CONFIG_SND_CS46XX_NEW_DSP=y # CONFIG_SND_CS5530 is not set # CONFIG_SND_CS5535AUDIO is not set # CONFIG_SND_CTXFI is not set CONFIG_SND_DARLA20=m CONFIG_SND_GINA20=m CONFIG_SND_LAYLA20=m CONFIG_SND_DARLA24=m CONFIG_SND_GINA24=m CONFIG_SND_LAYLA24=m CONFIG_SND_MONA=m CONFIG_SND_MIA=m CONFIG_SND_ECHO3G=m CONFIG_SND_INDIGO=m CONFIG_SND_INDIGOIO=m CONFIG_SND_INDIGODJ=m # CONFIG_SND_INDIGOIOX is not set # CONFIG_SND_INDIGODJX is not set CONFIG_SND_EMU10K1=m CONFIG_SND_EMU10K1X=m CONFIG_SND_ENS1370=m CONFIG_SND_ENS1371=m CONFIG_SND_ES1938=m CONFIG_SND_ES1968=m # CONFIG_SND_ES1968_INPUT is not set CONFIG_SND_FM801=m CONFIG_SND_HDA_INTEL=m CONFIG_SND_HDA_PREALLOC_SIZE=64 # CONFIG_SND_HDA_HWDEP is not set # CONFIG_SND_HDA_INPUT_BEEP is not set # CONFIG_SND_HDA_INPUT_JACK is not set # CONFIG_SND_HDA_PATCH_LOADER is not set CONFIG_SND_HDA_CODEC_REALTEK=y CONFIG_SND_HDA_ENABLE_REALTEK_QUIRKS=y CONFIG_SND_HDA_CODEC_ANALOG=y CONFIG_SND_HDA_CODEC_SIGMATEL=y CONFIG_SND_HDA_CODEC_VIA=y CONFIG_SND_HDA_CODEC_HDMI=y CONFIG_SND_HDA_CODEC_CIRRUS=y CONFIG_SND_HDA_CODEC_CONEXANT=y CONFIG_SND_HDA_CODEC_CA0110=y CONFIG_SND_HDA_CODEC_CA0132=y CONFIG_SND_HDA_CODEC_CMEDIA=y CONFIG_SND_HDA_CODEC_SI3054=y CONFIG_SND_HDA_GENERIC=y # CONFIG_SND_HDA_POWER_SAVE is not set CONFIG_SND_HDSP=m CONFIG_SND_HDSPM=m CONFIG_SND_ICE1712=m CONFIG_SND_ICE1724=m CONFIG_SND_INTEL8X0=m CONFIG_SND_INTEL8X0M=m CONFIG_SND_KORG1212=m # CONFIG_SND_LOLA is not set # CONFIG_SND_LX6464ES is not set CONFIG_SND_MAESTRO3=m # CONFIG_SND_MAESTRO3_INPUT is not set CONFIG_SND_MIXART=m CONFIG_SND_NM256=m CONFIG_SND_PCXHR=m CONFIG_SND_RIPTIDE=m CONFIG_SND_RME32=m CONFIG_SND_RME96=m CONFIG_SND_RME9652=m CONFIG_SND_SONICVIBES=m CONFIG_SND_TRIDENT=m CONFIG_SND_VIA82XX=m CONFIG_SND_VIA82XX_MODEM=m # CONFIG_SND_VIRTUOSO is not set CONFIG_SND_VX222=m CONFIG_SND_YMFPCI=m CONFIG_SND_USB=y CONFIG_SND_USB_AUDIO=m # CONFIG_SND_USB_UA101 is not set CONFIG_SND_USB_USX2Y=m # CONFIG_SND_USB_CAIAQ is not set # CONFIG_SND_USB_US122L is not set # CONFIG_SND_USB_6FIRE is not set CONFIG_SND_PCMCIA=y # CONFIG_SND_VXPOCKET is not set # CONFIG_SND_PDAUDIOCF is not set # CONFIG_SND_SOC is not set # CONFIG_SOUND_PRIME is not set CONFIG_AC97_BUS=m CONFIG_HID_SUPPORT=y CONFIG_HID=y CONFIG_HID_BATTERY_STRENGTH=y # CONFIG_HIDRAW is not set # # USB Input Devices # CONFIG_USB_HID=y CONFIG_HID_PID=y CONFIG_USB_HIDDEV=y # # Special HID drivers # CONFIG_HID_A4TECH=y # CONFIG_HID_ACRUX is not set CONFIG_HID_APPLE=y CONFIG_HID_BELKIN=y CONFIG_HID_CHERRY=y CONFIG_HID_CHICONY=y # CONFIG_HID_PRODIKEYS is not set CONFIG_HID_CYPRESS=y CONFIG_HID_DRAGONRISE=y # CONFIG_DRAGONRISE_FF is not set # CONFIG_HID_EMS_FF is not set CONFIG_HID_EZKEY=y # CONFIG_HID_HOLTEK is not set # CONFIG_HID_KEYTOUCH is not set CONFIG_HID_KYE=y # CONFIG_HID_UCLOGIC is not set # CONFIG_HID_WALTOP is not set CONFIG_HID_GYRATION=y CONFIG_HID_TWINHAN=y CONFIG_HID_KENSINGTON=y # CONFIG_HID_LCPOWER is not set CONFIG_HID_LOGITECH=y CONFIG_HID_LOGITECH_DJ=m CONFIG_LOGITECH_FF=y # CONFIG_LOGIRUMBLEPAD2_FF is not set # CONFIG_LOGIG940_FF is not set CONFIG_LOGIWHEELS_FF=y CONFIG_HID_MICROSOFT=y CONFIG_HID_MONTEREY=y # CONFIG_HID_MULTITOUCH is not set CONFIG_HID_NTRIG=y # CONFIG_HID_ORTEK is not set CONFIG_HID_PANTHERLORD=y # CONFIG_PANTHERLORD_FF is not set CONFIG_HID_PETALYNX=y # CONFIG_HID_PICOLCD is not set # CONFIG_HID_PRIMAX is not set # CONFIG_HID_ROCCAT is not set CONFIG_HID_SAMSUNG=y CONFIG_HID_SONY=y # CONFIG_HID_SPEEDLINK is not set CONFIG_HID_SUNPLUS=y CONFIG_HID_GREENASIA=y # CONFIG_GREENASIA_FF is not set CONFIG_HID_SMARTJOYPLUS=y # CONFIG_SMARTJOYPLUS_FF is not set CONFIG_HID_TOPSEED=y CONFIG_HID_THRUSTMASTER=y CONFIG_THRUSTMASTER_FF=y CONFIG_HID_ZEROPLUS=y # CONFIG_ZEROPLUS_FF is not set # CONFIG_HID_ZYDACRON 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 is not set # # Miscellaneous USB options # CONFIG_USB_DEVICEFS=y CONFIG_USB_DEVICE_CLASS=y # CONFIG_USB_DYNAMIC_MINORS is not set CONFIG_USB_MON=y # CONFIG_USB_WUSB is not set # CONFIG_USB_WUSB_CBAF is not set # # USB Host Controller Drivers # # CONFIG_USB_C67X00_HCD is not set # CONFIG_USB_XHCI_HCD is not set CONFIG_USB_EHCI_HCD=m CONFIG_USB_EHCI_ROOT_HUB_TT=y CONFIG_USB_EHCI_TT_NEWSCHED=y # CONFIG_USB_OXU210HP_HCD is not set CONFIG_USB_ISP116X_HCD=m # CONFIG_USB_ISP1760_HCD is not set # CONFIG_USB_ISP1362_HCD is not set CONFIG_USB_OHCI_HCD=m # CONFIG_USB_OHCI_HCD_SSB is not set # 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=m CONFIG_USB_SL811_HCD=m # CONFIG_USB_SL811_HCD_ISO is not set CONFIG_USB_SL811_CS=m # 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=m CONFIG_USB_PRINTER=m # 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=m CONFIG_USB_STORAGE_FREECOM=m CONFIG_USB_STORAGE_ISD200=m CONFIG_USB_STORAGE_USBAT=m CONFIG_USB_STORAGE_SDDR09=m CONFIG_USB_STORAGE_SDDR55=m CONFIG_USB_STORAGE_JUMPSHOT=m CONFIG_USB_STORAGE_ALAUDA=m # 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=y # # USB Imaging devices # CONFIG_USB_MDC800=m CONFIG_USB_MICROTEK=m # # USB port drivers # CONFIG_USB_USS720=m CONFIG_USB_SERIAL=m CONFIG_USB_EZUSB=y CONFIG_USB_SERIAL_GENERIC=y # CONFIG_USB_SERIAL_AIRCABLE is not set CONFIG_USB_SERIAL_ARK3116=m CONFIG_USB_SERIAL_BELKIN=m # CONFIG_USB_SERIAL_CH341 is not set CONFIG_USB_SERIAL_WHITEHEAT=m CONFIG_USB_SERIAL_DIGI_ACCELEPORT=m # CONFIG_USB_SERIAL_CP210X is not set CONFIG_USB_SERIAL_CYPRESS_M8=m CONFIG_USB_SERIAL_EMPEG=m CONFIG_USB_SERIAL_FTDI_SIO=m CONFIG_USB_SERIAL_FUNSOFT=m CONFIG_USB_SERIAL_VISOR=m CONFIG_USB_SERIAL_IPAQ=m CONFIG_USB_SERIAL_IR=m CONFIG_USB_SERIAL_EDGEPORT=m CONFIG_USB_SERIAL_EDGEPORT_TI=m CONFIG_USB_SERIAL_GARMIN=m CONFIG_USB_SERIAL_IPW=m # CONFIG_USB_SERIAL_IUU is not set CONFIG_USB_SERIAL_KEYSPAN_PDA=m CONFIG_USB_SERIAL_KEYSPAN=m CONFIG_USB_SERIAL_KEYSPAN_MPR=y CONFIG_USB_SERIAL_KEYSPAN_USA28=y CONFIG_USB_SERIAL_KEYSPAN_USA28X=y CONFIG_USB_SERIAL_KEYSPAN_USA28XA=y CONFIG_USB_SERIAL_KEYSPAN_USA28XB=y CONFIG_USB_SERIAL_KEYSPAN_USA19=y CONFIG_USB_SERIAL_KEYSPAN_USA18X=y CONFIG_USB_SERIAL_KEYSPAN_USA19W=y CONFIG_USB_SERIAL_KEYSPAN_USA19QW=y CONFIG_USB_SERIAL_KEYSPAN_USA19QI=y CONFIG_USB_SERIAL_KEYSPAN_USA49W=y CONFIG_USB_SERIAL_KEYSPAN_USA49WLC=y CONFIG_USB_SERIAL_KLSI=m CONFIG_USB_SERIAL_KOBIL_SCT=m CONFIG_USB_SERIAL_MCT_U232=m # CONFIG_USB_SERIAL_MOS7720 is not set # CONFIG_USB_SERIAL_MOS7840 is not set # CONFIG_USB_SERIAL_MOTOROLA is not set CONFIG_USB_SERIAL_NAVMAN=m CONFIG_USB_SERIAL_PL2303=m # CONFIG_USB_SERIAL_OTI6858 is not set # CONFIG_USB_SERIAL_QCAUX is not set # CONFIG_USB_SERIAL_QUALCOMM is not set # CONFIG_USB_SERIAL_SPCP8X5 is not set CONFIG_USB_SERIAL_HP4X=m CONFIG_USB_SERIAL_SAFE=m CONFIG_USB_SERIAL_SAFE_PADDED=y # CONFIG_USB_SERIAL_SIEMENS_MPI is not set CONFIG_USB_SERIAL_SIERRAWIRELESS=m # CONFIG_USB_SERIAL_SYMBOL is not set CONFIG_USB_SERIAL_TI=m CONFIG_USB_SERIAL_CYBERJACK=m CONFIG_USB_SERIAL_XIRCOM=m CONFIG_USB_SERIAL_WWAN=m CONFIG_USB_SERIAL_OPTION=m CONFIG_USB_SERIAL_OMNINET=m # CONFIG_USB_SERIAL_OPTICON is not set # CONFIG_USB_SERIAL_VIVOPAY_SERIAL is not set # CONFIG_USB_SERIAL_ZIO is not set # CONFIG_USB_SERIAL_SSU100 is not set # CONFIG_USB_SERIAL_DEBUG is not set # # USB Miscellaneous drivers # CONFIG_USB_EMI62=m CONFIG_USB_EMI26=m # CONFIG_USB_ADUTUX is not set # CONFIG_USB_SEVSEG is not set CONFIG_USB_RIO500=m CONFIG_USB_LEGOTOWER=m CONFIG_USB_LCD=m CONFIG_USB_LED=m # CONFIG_USB_CYPRESS_CY7C63 is not set # CONFIG_USB_CYTHERM is not set CONFIG_USB_IDMOUSE=m # CONFIG_USB_FTDI_ELAN is not set CONFIG_USB_APPLEDISPLAY=m CONFIG_USB_SISUSBVGA=m CONFIG_USB_SISUSBVGA_CON=y CONFIG_USB_LD=m # CONFIG_USB_TRANCEVIBRATOR is not set # CONFIG_USB_IOWARRIOR is not set CONFIG_USB_TEST=m # CONFIG_USB_ISIGHTFW is not set # CONFIG_USB_YUREX is not set CONFIG_USB_ATM=m CONFIG_USB_SPEEDTOUCH=m CONFIG_USB_CXACRU=m CONFIG_USB_UEAGLEATM=m CONFIG_USB_XUSBATM=m # CONFIG_USB_GADGET is not set # # OTG and related infrastructure # # CONFIG_NOP_USB_XCEIV is not set # CONFIG_UWB is not set CONFIG_MMC=m # CONFIG_MMC_DEBUG is not set # CONFIG_MMC_UNSAFE_RESUME is not set # CONFIG_MMC_CLKGATE is not set # # MMC/SD/SDIO Card Drivers # CONFIG_MMC_BLOCK=m CONFIG_MMC_BLOCK_MINORS=8 CONFIG_MMC_BLOCK_BOUNCE=y # CONFIG_SDIO_UART is not set # CONFIG_MMC_TEST is not set # # MMC/SD/SDIO Host Controller Drivers # CONFIG_MMC_SDHCI=m # CONFIG_MMC_SDHCI_PCI is not set # CONFIG_MMC_SDHCI_PLTFM is not set CONFIG_MMC_WBSD=m # CONFIG_MMC_TIFM_SD is not set # CONFIG_MMC_SDRICOH_CS is not set # CONFIG_MMC_CB710 is not set # CONFIG_MMC_VIA_SDMMC is not set # CONFIG_MMC_VUB300 is not set # CONFIG_MMC_USHC is not set # CONFIG_MEMSTICK is not set CONFIG_NEW_LEDS=y CONFIG_LEDS_CLASS=y # # LED drivers # # CONFIG_LEDS_LM3530 is not set # CONFIG_LEDS_PCA9532 is not set # CONFIG_LEDS_LP3944 is not set # CONFIG_LEDS_LP5521 is not set # CONFIG_LEDS_LP5523 is not set # CONFIG_LEDS_CLEVO_MAIL is not set # CONFIG_LEDS_PCA955X is not set # CONFIG_LEDS_BD2802 is not set # CONFIG_LEDS_INTEL_SS4200 is not set CONFIG_LEDS_TRIGGERS=y # # LED Triggers # CONFIG_LEDS_TRIGGER_TIMER=m CONFIG_LEDS_TRIGGER_IDE_DISK=y CONFIG_LEDS_TRIGGER_HEARTBEAT=m # CONFIG_LEDS_TRIGGER_BACKLIGHT is not set # CONFIG_LEDS_TRIGGER_DEFAULT_ON is not set # # iptables trigger is under Netfilter config (LED target) # # CONFIG_ACCESSIBILITY is not set CONFIG_INFINIBAND=m CONFIG_INFINIBAND_USER_MAD=m CONFIG_INFINIBAND_USER_ACCESS=m CONFIG_INFINIBAND_USER_MEM=y CONFIG_INFINIBAND_ADDR_TRANS=y CONFIG_INFINIBAND_MTHCA=m CONFIG_INFINIBAND_MTHCA_DEBUG=y CONFIG_INFINIBAND_IPATH=m # CONFIG_INFINIBAND_QIB is not set # CONFIG_INFINIBAND_AMSO1100 is not set # CONFIG_MLX4_INFINIBAND is not set # CONFIG_INFINIBAND_NES is not set CONFIG_INFINIBAND_IPOIB=m # CONFIG_INFINIBAND_IPOIB_CM is not set CONFIG_INFINIBAND_IPOIB_DEBUG=y CONFIG_INFINIBAND_IPOIB_DEBUG_DATA=y CONFIG_INFINIBAND_SRP=m CONFIG_INFINIBAND_ISER=m CONFIG_EDAC=y # # Reporting subsystems # # CONFIG_EDAC_DEBUG is not set CONFIG_EDAC_DECODE_MCE=y # CONFIG_EDAC_MCE_INJ is not set CONFIG_EDAC_MM_EDAC=m # CONFIG_EDAC_AMD64 is not set CONFIG_EDAC_E752X=m # CONFIG_EDAC_I82975X is not set # CONFIG_EDAC_I3000 is not set # CONFIG_EDAC_I3200 is not set # CONFIG_EDAC_X38 is not set # CONFIG_EDAC_I5400 is not set # CONFIG_EDAC_I7CORE is not set # CONFIG_EDAC_I5000 is not set # CONFIG_EDAC_I5100 is not set # CONFIG_EDAC_I7300 is not set # CONFIG_EDAC_SBRIDGE is not set # CONFIG_RTC_CLASS is not set # CONFIG_DMADEVICES is not set # 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=y # CONFIG_ACERHDF is not set # CONFIG_ASUS_LAPTOP is not set # CONFIG_DELL_LAPTOP is not set # CONFIG_FUJITSU_LAPTOP is not set # CONFIG_HP_ACCEL is not set # CONFIG_MSI_LAPTOP is not set # CONFIG_PANASONIC_LAPTOP is not set # CONFIG_COMPAL_LAPTOP is not set # CONFIG_SONY_LAPTOP is not set # CONFIG_IDEAPAD_LAPTOP is not set # CONFIG_THINKPAD_ACPI is not set CONFIG_SENSORS_HDAPS=m # CONFIG_INTEL_MENLOW is not set # CONFIG_EEEPC_LAPTOP is not set # CONFIG_ACPI_WMI is not set CONFIG_ACPI_ASUS=m # CONFIG_TOPSTAR_LAPTOP is not set CONFIG_ACPI_TOSHIBA=m # CONFIG_TOSHIBA_BT_RFKILL is not set # CONFIG_ACPI_CMPC is not set # CONFIG_INTEL_IPS is not set # CONFIG_IBM_RTL is not set # CONFIG_XO15_EBOOK is not set # CONFIG_SAMSUNG_LAPTOP is not set # CONFIG_INTEL_OAKTRAIL is not set # CONFIG_SAMSUNG_Q10 is not set # # Hardware Spinlock drivers # CONFIG_CLKEVT_I8253=y CONFIG_I8253_LOCK=y CONFIG_CLKBLD_I8253=y CONFIG_IOMMU_SUPPORT=y # CONFIG_AMD_IOMMU is not set # CONFIG_INTEL_IOMMU is not set # CONFIG_IRQ_REMAP is not set # # Remoteproc drivers # # # Rpmsg drivers # # CONFIG_VIRT_DRIVERS is not set # CONFIG_PM_DEVFREQ is not set # CONFIG_XSHM is not set # # Firmware Drivers # CONFIG_EDD=m # CONFIG_EDD_OFF is not set CONFIG_FIRMWARE_MEMMAP=y CONFIG_DELL_RBU=m CONFIG_DCDBAS=m CONFIG_DMIID=y # CONFIG_DMI_SYSFS is not set # CONFIG_ISCSI_IBFT_FIND is not set # CONFIG_GOOGLE_FIRMWARE is not set # # File systems # CONFIG_EXT2_FS=y 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 is not set CONFIG_EXT3_FS_XATTR=y CONFIG_EXT3_FS_POSIX_ACL=y CONFIG_EXT3_FS_SECURITY=y # CONFIG_EXT4_FS is not set CONFIG_FS_XIP=y CONFIG_JBD=y # CONFIG_JBD_DEBUG is not set CONFIG_JBD2=m # CONFIG_JBD2_DEBUG is not set CONFIG_FS_MBCACHE=y # CONFIG_REISERFS_FS is not set CONFIG_JFS_FS=m CONFIG_JFS_POSIX_ACL=y CONFIG_JFS_SECURITY=y # CONFIG_JFS_DEBUG is not set # CONFIG_JFS_STATISTICS is not set CONFIG_XFS_FS=m CONFIG_XFS_QUOTA=y CONFIG_XFS_POSIX_ACL=y # CONFIG_XFS_RT is not set # CONFIG_XFS_DEBUG is not set CONFIG_GFS2_FS=m # CONFIG_GFS2_FS_LOCKING_DLM is not set CONFIG_OCFS2_FS=m CONFIG_OCFS2_FS_O2CB=m CONFIG_OCFS2_FS_USERSPACE_CLUSTER=m CONFIG_OCFS2_FS_STATS=y # CONFIG_OCFS2_DEBUG_MASKLOG is not set # CONFIG_OCFS2_DEBUG_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=y # CONFIG_FANOTIFY_ACCESS_PERMISSIONS is not set CONFIG_QUOTA=y # CONFIG_QUOTA_NETLINK_INTERFACE is not set CONFIG_PRINT_QUOTA_WARNING=y # 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 is not set # # Caches # # CONFIG_FSCACHE 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_SYSCTL=y CONFIG_PROC_PAGE_MONITOR=y CONFIG_SYSFS=y CONFIG_TMPFS=y # CONFIG_TMPFS_POSIX_ACL is not set # CONFIG_TMPFS_XATTR is not set CONFIG_HUGETLBFS=y CONFIG_HUGETLB_PAGE=y CONFIG_CONFIGFS_FS=m CONFIG_MISC_FILESYSTEMS=y # CONFIG_ADFS_FS is not set CONFIG_AFFS_FS=m # CONFIG_ECRYPT_FS is not set CONFIG_HFS_FS=m CONFIG_HFSPLUS_FS=m CONFIG_BEFS_FS=m # CONFIG_BEFS_DEBUG is not set CONFIG_BFS_FS=m CONFIG_EFS_FS=m CONFIG_JFFS2_FS=m CONFIG_JFFS2_FS_DEBUG=0 CONFIG_JFFS2_FS_WRITEBUFFER=y # CONFIG_JFFS2_FS_WBUF_VERIFY is not set CONFIG_JFFS2_SUMMARY=y # CONFIG_JFFS2_FS_XATTR is not set # CONFIG_JFFS2_COMPRESSION_OPTIONS is not set CONFIG_JFFS2_ZLIB=y # CONFIG_JFFS2_LZO is not set CONFIG_JFFS2_RTIME=y # CONFIG_JFFS2_RUBIN is not set # CONFIG_LOGFS is not set CONFIG_CRAMFS=m # CONFIG_SQUASHFS is not set CONFIG_VXFS_FS=m CONFIG_MINIX_FS=y # CONFIG_OMFS_FS is not set # CONFIG_HPFS_FS is not set CONFIG_QNX4FS_FS=m CONFIG_ROMFS_FS=m CONFIG_ROMFS_BACKED_BY_BLOCK=y # CONFIG_ROMFS_BACKED_BY_MTD is not set # CONFIG_ROMFS_BACKED_BY_BOTH is not set CONFIG_ROMFS_ON_BLOCK=y # CONFIG_PSTORE is not set CONFIG_SYSV_FS=m CONFIG_UFS_FS=m # CONFIG_UFS_FS_WRITE is not set # CONFIG_UFS_DEBUG is not set 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 is not set # CONFIG_NFS_USE_LEGACY_DNS is not set CONFIG_NFS_USE_KERNEL_DNS=y # CONFIG_NFS_USE_NEW_IDMAPPER is not set 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_XPRT_RDMA=m # CONFIG_CEPH_FS is not set # CONFIG_CIFS is not set # CONFIG_NCP_FS is not set CONFIG_CODA_FS=m # CONFIG_AFS_FS is not set # # Partition Types # CONFIG_PARTITION_ADVANCED=y # CONFIG_ACORN_PARTITION is not set CONFIG_OSF_PARTITION=y CONFIG_AMIGA_PARTITION=y # 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=y # CONFIG_ULTRIX_PARTITION is not set CONFIG_SUN_PARTITION=y CONFIG_KARMA_PARTITION=y CONFIG_EFI_PARTITION=y # CONFIG_SYSV68_PARTITION is not set CONFIG_NLS=y CONFIG_NLS_DEFAULT="utf8" CONFIG_NLS_CODEPAGE_437=y CONFIG_NLS_CODEPAGE_737=m CONFIG_NLS_CODEPAGE_775=m CONFIG_NLS_CODEPAGE_850=m CONFIG_NLS_CODEPAGE_852=m CONFIG_NLS_CODEPAGE_855=m CONFIG_NLS_CODEPAGE_857=m CONFIG_NLS_CODEPAGE_860=m CONFIG_NLS_CODEPAGE_861=m CONFIG_NLS_CODEPAGE_862=m CONFIG_NLS_CODEPAGE_863=m CONFIG_NLS_CODEPAGE_864=m CONFIG_NLS_CODEPAGE_865=m CONFIG_NLS_CODEPAGE_866=m CONFIG_NLS_CODEPAGE_869=m CONFIG_NLS_CODEPAGE_936=m CONFIG_NLS_CODEPAGE_950=m CONFIG_NLS_CODEPAGE_932=m CONFIG_NLS_CODEPAGE_949=m CONFIG_NLS_CODEPAGE_874=m CONFIG_NLS_ISO8859_8=m CONFIG_NLS_CODEPAGE_1250=m CONFIG_NLS_CODEPAGE_1251=m 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=m CONFIG_NLS_ISO8859_6=m CONFIG_NLS_ISO8859_7=m CONFIG_NLS_ISO8859_9=m CONFIG_NLS_ISO8859_13=m CONFIG_NLS_ISO8859_14=m CONFIG_NLS_ISO8859_15=m CONFIG_NLS_KOI8_R=m CONFIG_NLS_KOI8_U=m 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=y CONFIG_ENABLE_MUST_CHECK=y CONFIG_FRAME_WARN=2048 CONFIG_MAGIC_SYSRQ=y # CONFIG_STRIP_ASM_SYMS is not set # CONFIG_UNUSED_SYMBOLS is not set CONFIG_DEBUG_FS=y # CONFIG_HEADERS_CHECK is not set # CONFIG_DEBUG_SECTION_MISMATCH is not set CONFIG_DEBUG_KERNEL=y # CONFIG_DEBUG_SHIRQ is not set # CONFIG_LOCKUP_DETECTOR is not set # CONFIG_HARDLOCKUP_DETECTOR is not set 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 is not set # CONFIG_DEBUG_OBJECTS is not set # CONFIG_DEBUG_SLAB is not set # CONFIG_DEBUG_KMEMLEAK is not set # CONFIG_DEBUG_RT_MUTEXES is not set # 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=y CONFIG_PROVE_RCU_REPEATEDLY=y # CONFIG_SPARSE_RCU_POINTER is not set CONFIG_LOCKDEP=y CONFIG_LOCK_STAT=y CONFIG_DEBUG_LOCKDEP=y CONFIG_TRACE_IRQFLAGS=y # CONFIG_DEBUG_ATOMIC_SLEEP is not set # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set CONFIG_STACKTRACE=y # CONFIG_DEBUG_STACK_USAGE is not set # CONFIG_DEBUG_KOBJECT is not set CONFIG_DEBUG_BUGVERBOSE=y CONFIG_DEBUG_INFO=y # CONFIG_DEBUG_INFO_REDUCED is not set # CONFIG_DEBUG_VM is not set # 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 is not set # CONFIG_DEBUG_CREDENTIALS is not set CONFIG_ARCH_WANT_FRAME_POINTERS=y CONFIG_FRAME_POINTER=y # CONFIG_BOOT_PRINTK_DELAY is not set # 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 is not set CONFIG_SYSCTL_SYSCALL_CHECK=y # CONFIG_DEBUG_PAGEALLOC is not set CONFIG_USER_STACKTRACE_SUPPORT=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_RING_BUFFER=y CONFIG_RING_BUFFER_ALLOW_SWAP=y CONFIG_TRACING_SUPPORT=y # CONFIG_FTRACE is not set # CONFIG_PROVIDE_OHCI1394_DMA_INIT is not set # CONFIG_DYNAMIC_DEBUG is not set # 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 is not set CONFIG_HAVE_ARCH_KMEMCHECK=y # CONFIG_TEST_KSTRTOX is not set # CONFIG_STRICT_DEVMEM is not set CONFIG_X86_VERBOSE_BOOTUP=y CONFIG_EARLY_PRINTK=y # CONFIG_EARLY_PRINTK_DBGP is not set CONFIG_DEBUG_STACKOVERFLOW=y # CONFIG_X86_PTDUMP is not set CONFIG_DEBUG_RODATA=y # CONFIG_DEBUG_RODATA_TEST is not set # CONFIG_DEBUG_SET_MODULE_RONX is not set # CONFIG_DEBUG_NX_TEST is not set # 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 is not set # CONFIG_CPA_DEBUG is not set # CONFIG_OPTIMIZE_INLINING is not set # 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 is not set # CONFIG_SECURITY_PATH is not set CONFIG_LSM_MMAP_MIN_ADDR=65536 CONFIG_SECURITY_SELINUX=y CONFIG_SECURITY_SELINUX_BOOTPARAM=y CONFIG_SECURITY_SELINUX_BOOTPARAM_VALUE=1 CONFIG_SECURITY_SELINUX_DISABLE=y CONFIG_SECURITY_SELINUX_DEVELOP=y CONFIG_SECURITY_SELINUX_AVC_STATS=y CONFIG_SECURITY_SELINUX_CHECKREQPROT_VALUE=1 # CONFIG_SECURITY_SELINUX_POLICYDB_VERSION_MAX is not set # CONFIG_SECURITY_SMACK is not set # CONFIG_SECURITY_TOMOYO is not set # CONFIG_SECURITY_APPARMOR is not set # CONFIG_IMA is not set # CONFIG_EVM is not set CONFIG_DEFAULT_SECURITY_SELINUX=y # CONFIG_DEFAULT_SECURITY_DAC is not set CONFIG_DEFAULT_SECURITY="selinux" 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_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=m CONFIG_CRYPTO_BLKCIPHER2=y CONFIG_CRYPTO_HASH=y CONFIG_CRYPTO_HASH2=y CONFIG_CRYPTO_RNG2=y 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 is not set CONFIG_CRYPTO_NULL=m # CONFIG_CRYPTO_PCRYPT is not set CONFIG_CRYPTO_WORKQUEUE=y # CONFIG_CRYPTO_CRYPTD is not set CONFIG_CRYPTO_AUTHENC=m # CONFIG_CRYPTO_TEST is not set # # Authenticated Encryption with Associated Data # # CONFIG_CRYPTO_CCM is not set # CONFIG_CRYPTO_GCM is not set # CONFIG_CRYPTO_SEQIV is not set # # Block modes # CONFIG_CRYPTO_CBC=m # CONFIG_CRYPTO_CTR is not set # 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 is not set # # Digest # CONFIG_CRYPTO_CRC32C=y # CONFIG_CRYPTO_CRC32C_INTEL is not set # CONFIG_CRYPTO_GHASH is not set CONFIG_CRYPTO_MD4=m CONFIG_CRYPTO_MD5=m CONFIG_CRYPTO_MICHAEL_MIC=m # 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=m CONFIG_CRYPTO_WP512=m # 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 is not set CONFIG_CRYPTO_ANUBIS=m CONFIG_CRYPTO_ARC4=m CONFIG_CRYPTO_BLOWFISH=m CONFIG_CRYPTO_BLOWFISH_COMMON=m # CONFIG_CRYPTO_BLOWFISH_X86_64 is not set # CONFIG_CRYPTO_CAMELLIA is not set CONFIG_CRYPTO_CAST5=m CONFIG_CRYPTO_CAST6=m CONFIG_CRYPTO_DES=m # CONFIG_CRYPTO_FCRYPT is not set CONFIG_CRYPTO_KHAZAD=m # CONFIG_CRYPTO_SALSA20 is not set # CONFIG_CRYPTO_SALSA20_X86_64 is not set # CONFIG_CRYPTO_SEED is not set CONFIG_CRYPTO_SERPENT=m # CONFIG_CRYPTO_SERPENT_SSE2_X86_64 is not set CONFIG_CRYPTO_TEA=m CONFIG_CRYPTO_TWOFISH=m CONFIG_CRYPTO_TWOFISH_COMMON=m # 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 is not set # CONFIG_CRYPTO_LZO is not set # # Random Number Generation # # CONFIG_CRYPTO_ANSI_CPRNG is not set # CONFIG_CRYPTO_USER_API_HASH is not set # CONFIG_CRYPTO_USER_API_SKCIPHER is not set CONFIG_CRYPTO_HW=y # CONFIG_CRYPTO_DEV_PADLOCK is not set CONFIG_HAVE_KVM=y CONFIG_VIRTUALIZATION=y # CONFIG_KVM is not set # CONFIG_VHOST_NET is not set # CONFIG_BINARY_PRINTF is not set # # 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=m # CONFIG_CRC_T10DIF is not set CONFIG_CRC_ITU_T=m CONFIG_CRC32=y # CONFIG_CRC7 is not set CONFIG_LIBCRC32C=y # CONFIG_CRC8 is not set CONFIG_ZLIB_INFLATE=y CONFIG_ZLIB_DEFLATE=m 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_REED_SOLOMON=m CONFIG_REED_SOLOMON_DEC16=y CONFIG_TEXTSEARCH=y CONFIG_TEXTSEARCH_KMP=m CONFIG_TEXTSEARCH_BM=m CONFIG_TEXTSEARCH_FSM=m CONFIG_HAS_IOMEM=y CONFIG_HAS_IOPORT=y CONFIG_HAS_DMA=y CONFIG_CHECK_SIGNATURE=y CONFIG_CPU_RMAP=y CONFIG_DQL=y CONFIG_NLATTR=y # CONFIG_AVERAGE is not set # CONFIG_CORDIC is not set # CONFIG_MPILIB is not set # CONFIG_DIGSIG is not set ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:44 ` Andrew Morton @ 2011-12-22 23:46 ` Tejun Heo 2011-12-23 0:42 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-22 23:46 UTC (permalink / raw) To: Andrew Morton Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 Hello, On Thu, Dec 22, 2011 at 03:44:27PM -0800, Andrew Morton wrote: > > Weird, I can't reproduce the problem on block/for-3.3/core. Trying > > linux-next... hmmm, it works there too. > > This machine is next to my desk, about 50 yards from your cube ;) Heh, physical access feels like such distant concept. :) I'll test with the config and if I still can't reproduce it, play with your machine. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-22 23:46 ` Tejun Heo @ 2011-12-23 0:42 ` Tejun Heo 2011-12-24 5:13 ` Hugh Dickins 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-23 0:42 UTC (permalink / raw) To: Andrew Morton Cc: Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Thu, Dec 22, 2011 at 03:46:39PM -0800, Tejun Heo wrote: > On Thu, Dec 22, 2011 at 03:44:27PM -0800, Andrew Morton wrote: > > > Weird, I can't reproduce the problem on block/for-3.3/core. Trying > > > linux-next... hmmm, it works there too. > > > > This machine is next to my desk, about 50 yards from your cube ;) > > Heh, physical access feels like such distant concept. :) > > I'll test with the config and if I still can't reproduce it, play with > your machine. Couldn't reproduce it on block/for-3.3 or next & you were already gone. Is anyone else seeing this? Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: linux-next: Tree for Dec 21 2011-12-23 0:42 ` Tejun Heo @ 2011-12-24 5:13 ` Hugh Dickins 2011-12-25 1:02 ` [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Hugh Dickins @ 2011-12-24 5:13 UTC (permalink / raw) To: Tejun Heo Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, Jens Axboe, linux-ide, x86 On Thu, 22 Dec 2011, Tejun Heo wrote: > On Thu, Dec 22, 2011 at 03:46:39PM -0800, Tejun Heo wrote: > > On Thu, Dec 22, 2011 at 03:44:27PM -0800, Andrew Morton wrote: > > > > Weird, I can't reproduce the problem on block/for-3.3/core. Trying > > > > linux-next... hmmm, it works there too. > > > > > > This machine is next to my desk, about 50 yards from your cube ;) > > > > Heh, physical access feels like such distant concept. :) > > > > I'll test with the config and if I still can't reproduce it, play with > > your machine. > > Couldn't reproduce it on block/for-3.3 or next & you were already > gone. Is anyone else seeing this? Twice today, on ThinkPad T420s running 3.2.0-rc6-next-20111222. I haven't seen it at all under heavy load, but twice when simply rebuilding the kernel - I think both times it hung with "LD whatever/built-in.o" the last line on screen. I had (a variant of) kdb in, here's the stack it gave me, but I think I've got a bug in there which has missed out a number of stackframes: so don't waste time puzzling over any anomalies in it, but there's enough to suggest it's the same as Andrew was seeing. ffff880013ac2100 28524 28522 1* D ffff880013ac2538 sh RSP RIP Function (args) ffff88004165f820 ffffffff814e559a _raw_spin_unlock_irq+0x31 ffff88004165f858 ffffffff811d2867 get_request_wait+0xab ffff88004165f8b8 ffffffff811cfb75 elv_merge+0xa0 ffff88004165fd18 ffffffff810ca90c do_writepages+0x1f ffff88004165fd28 ffffffff810c2671 __filemap_fdatawrite_range+0x4e ffff88004165fd68 ffffffff810c2e92 filemap_flush+0x17 ffff88004165fd78 ffffffff8116533e ext4_alloc_da_blocks+0x28 ffff88004165fd88 ffffffff81160f6a ext4_release_file+0x2e ffff88004165fdb8 ffffffff811077d4 __fput+0x107 ffff88004165fe08 ffffffff81107899 fput+0x15 ffff88004165fe18 ffffffff81104037 filp_close+0x6b ffff88004165fe48 ffffffff81056b47 close_files+0x16a ffff88004165fea8 ffffffff81057f31 put_files_struct+0x21 ffff88004165fed8 ffffffff81058107 exit_files+0x46 ffff88004165ff08 ffffffff81058648 do_exit+0x20e ffff88004165ff48 ffffffff810588d1 do_group_exit+0x7d ffff88004165ff78 ffffffff8105890e sys_exit_group+0x12 I interrupted a few more times, yes, once or twice I caught it in some cfq io_context business: didn't take much notice because I thought I'd saved the stack to log, but it hasn't appeared in my /var/log/messages after reboot. Once or twice there was another sh running on another cpu, showing a very similar stack. Hugh ^ permalink raw reply [flat|nested] 41+ messages in thread
* [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-24 5:13 ` Hugh Dickins @ 2011-12-25 1:02 ` Tejun Heo 2011-12-25 13:29 ` Jens Axboe 2011-12-28 8:33 ` Hugh Dickins 0 siblings, 2 replies; 41+ messages in thread From: Tejun Heo @ 2011-12-25 1:02 UTC (permalink / raw) To: Jens Axboe Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, Hugh Dickins, x86 While fixing io_context creation / task exit race condition, 6e736be7f2 "block: make ioc get/put interface more conventional and fix race on alloction" also prevented an exiting (%PF_EXITING) task from creating its own io_context. This is incorrect as exit path may issue IOs, e.g. from exit_files(), and if those IOs are the first ones issued by the task, io_context needs to be created to process the IOs. Combined with the existing problem of io_context / io_cq creation failure having the possibility of stalling IO, this problem results in deterministic full IO lockup with certain workloads. Fix it by allowing io_context creation regardless of %PF_EXITING for %current. Signed-off-by: Tejun Heo <tj@kernel.org> Reported-by: Andrew Morton <akpm@linux-foundation.org> Reported-by: Hugh Dickins <hughd@google.com> --- Thanks a lot for the hint, Hugh. My testing stuff (fio, dd and some adhoc rawio testing programs) was issuing IOs before exiting, so I didn't hit the problem and I suspect the reason why I didn't see the boot failure Andrew was seeing was because of systemd - boot process used to be dominated by lots of short-lived programs, many of which touching/modifying files, and thus it triggered the first IO on exit paths with Andrew's old userland. With systemd, most of those are gone, so... Thanks. block/blk-ioc.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/block/blk-ioc.c b/block/blk-ioc.c index ce9b35a..33fae7d 100644 --- a/block/blk-ioc.c +++ b/block/blk-ioc.c @@ -281,9 +281,16 @@ void create_io_context_slowpath(struct task_struct *task, gfp_t gfp_flags, INIT_HLIST_HEAD(&ioc->icq_list); INIT_WORK(&ioc->release_work, ioc_release_fn); - /* try to install, somebody might already have beaten us to it */ + /* + * Try to install. ioc shouldn't be installed if someone else + * already did or @task, which isn't %current, is exiting. Note + * that we need to allow ioc creation on exiting %current as exit + * path may issue IOs from e.g. exit_files(). The exit path is + * responsible for not issuing IO after exit_io_context(). + */ task_lock(task); - if (!task->io_context && !(task->flags & PF_EXITING)) + if (!task->io_context && + (task == current || !(task->flags & PF_EXITING))) task->io_context = ioc; else kmem_cache_free(iocontext_cachep, ioc); ^ permalink raw reply related [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-25 1:02 ` [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context Tejun Heo @ 2011-12-25 13:29 ` Jens Axboe 2011-12-27 22:07 ` Andrew Morton 2011-12-28 8:33 ` Hugh Dickins 1 sibling, 1 reply; 41+ messages in thread From: Jens Axboe @ 2011-12-25 13:29 UTC (permalink / raw) To: Tejun Heo Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, Hugh Dickins, x86 On 2011-12-25 02:02, Tejun Heo wrote: > While fixing io_context creation / task exit race condition, > 6e736be7f2 "block: make ioc get/put interface more conventional and > fix race on alloction" also prevented an exiting (%PF_EXITING) task > from creating its own io_context. This is incorrect as exit path may > issue IOs, e.g. from exit_files(), and if those IOs are the first ones > issued by the task, io_context needs to be created to process the IOs. > > Combined with the existing problem of io_context / io_cq creation > failure having the possibility of stalling IO, this problem results in > deterministic full IO lockup with certain workloads. > > Fix it by allowing io_context creation regardless of %PF_EXITING for > %current. Thanks, applied. -- Jens Axboe ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-25 13:29 ` Jens Axboe @ 2011-12-27 22:07 ` Andrew Morton 0 siblings, 0 replies; 41+ messages in thread From: Andrew Morton @ 2011-12-27 22:07 UTC (permalink / raw) To: Jens Axboe Cc: Tejun Heo, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, Hugh Dickins, x86 On Sun, 25 Dec 2011 14:29:34 +0100 Jens Axboe <axboe@kernel.dk> wrote: > On 2011-12-25 02:02, Tejun Heo wrote: > > While fixing io_context creation / task exit race condition, > > 6e736be7f2 "block: make ioc get/put interface more conventional and > > fix race on alloction" also prevented an exiting (%PF_EXITING) task > > from creating its own io_context. This is incorrect as exit path may > > issue IOs, e.g. from exit_files(), and if those IOs are the first ones > > issued by the task, io_context needs to be created to process the IOs. > > > > Combined with the existing problem of io_context / io_cq creation > > failure having the possibility of stalling IO, this problem results in > > deterministic full IO lockup with certain workloads. > > > > Fix it by allowing io_context creation regardless of %PF_EXITING for > > %current. The patch works for me. > Thanks, applied. So we get another great big bisection hole in mainline. I feel duty bound to rewhine about this :( ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-25 1:02 ` [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context Tejun Heo 2011-12-25 13:29 ` Jens Axboe @ 2011-12-28 8:33 ` Hugh Dickins 2011-12-28 16:48 ` Tejun Heo 1 sibling, 1 reply; 41+ messages in thread From: Hugh Dickins @ 2011-12-28 8:33 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Sat, 24 Dec 2011, Tejun Heo wrote: > While fixing io_context creation / task exit race condition, > 6e736be7f2 "block: make ioc get/put interface more conventional and > fix race on alloction" also prevented an exiting (%PF_EXITING) task > from creating its own io_context. This is incorrect as exit path may > issue IOs, e.g. from exit_files(), and if those IOs are the first ones > issued by the task, io_context needs to be created to process the IOs. > > Combined with the existing problem of io_context / io_cq creation > failure having the possibility of stalling IO, this problem results in > deterministic full IO lockup with certain workloads. > > Fix it by allowing io_context creation regardless of %PF_EXITING for > %current. > > Signed-off-by: Tejun Heo <tj@kernel.org> > Reported-by: Andrew Morton <akpm@linux-foundation.org> > Reported-by: Hugh Dickins <hughd@google.com> Thanks, I think I've now built enough kernels on -next plus your patch to say that it does indeed solve that problem. However, there are a couple of other unhealthy symptoms I've noticed under load in -next's block/cfq layer, both with and without your patch. One is kernel BUG at block/cfq-iosched.c:2585! BUG_ON(RB_EMPTY_ROOT(&cfqq->sort_list)); cfq_dispatch_request+0x1a cfq_dispatch_requests+0x5c blk_peek_request+0x195 scsi_request_fn+0x6a __blk_run_queue+0x16 scsi_run_queue+0x18a scsi_next_command+0x36 scsi_io_completion+0x426 scsi_finish_command+0xaf scsi_softirq_done+0xdd blk_done_softirq+0x6c __do_softirq+0x80 call_softirq+0x1c do_softirq+0x33 irq_exit+0x3f do_IRQ+0x97 ret_from_intr I've had that one four times now on different machines; but quicker to reproduce are these warnings from CONFIG_DEBUG_LIST=y: ------------[ cut here ]------------ WARNING: at lib/list_debug.c:53 __list_del_entry+0x8d/0x98() Hardware name: 4174AY9 list_del corruption. prev->next should be ffff880005aa1380, but was 6b6b6b6b6b6b6b6b Modules linked in: snd_pcm_oss snd_mixer_oss snd_seq snd_seq_device Pid: 29241, comm: cc1 Tainted: G W 3.2.0-rc6-next-20111222 #18 Call Trace: <IRQ> [<ffffffff810544b4>] warn_slowpath_common+0x80/0x98 [<ffffffff81054560>] warn_slowpath_fmt+0x41/0x43 [<ffffffff811fc1a1>] __list_del_entry+0x8d/0x98 [<ffffffff811df8ab>] cfq_remove_request+0x3b/0xdf [<ffffffff811df989>] cfq_dispatch_insert+0x3a/0x87 [<ffffffff811dfb3b>] cfq_dispatch_request+0x65/0x92 [<ffffffff811dfbc4>] cfq_dispatch_requests+0x5c/0x133 [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 [<ffffffff811d3069>] blk_peek_request+0x195/0x1a6 [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 [<ffffffff812e0cf5>] scsi_request_fn+0x6d/0x3d3 [<ffffffff811d0730>] __blk_run_queue+0x19/0x1b [<ffffffff811d0bfd>] blk_run_queue+0x21/0x35 [<ffffffff812e08c4>] scsi_run_queue+0x11f/0x1b9 [<ffffffff812e205c>] scsi_next_command+0x36/0x46 [<ffffffff812e24dc>] scsi_io_completion+0x426/0x4a9 [<ffffffff812dc0b2>] scsi_finish_command+0xaf/0xb8 [<ffffffff812e200c>] scsi_softirq_done+0xdd/0xe5 [<ffffffff811d79c6>] blk_done_softirq+0x76/0x8a [<ffffffff8105a28d>] __do_softirq+0x98/0x136 [<ffffffff814e649c>] call_softirq+0x1c/0x30 [<ffffffff8102f187>] do_softirq+0x38/0x81 [<ffffffff8105a596>] irq_exit+0x4e/0xb6 [<ffffffff8102ee9e>] do_IRQ+0x97/0xae [<ffffffff814e49f0>] common_interrupt+0x70/0x70 <EOI> [<ffffffff814e4a8e>] ? retint_swapgs+0xe/0x13 ---[ end trace 61fdaa1b260613d1 ]--- Hugh ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-28 8:33 ` Hugh Dickins @ 2011-12-28 16:48 ` Tejun Heo 2011-12-28 17:50 ` Hugh Dickins 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-28 16:48 UTC (permalink / raw) To: Hugh Dickins Cc: Jens Axboe, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, Hugh. On Wed, Dec 28, 2011 at 12:33:01AM -0800, Hugh Dickins wrote: > Thanks, I think I've now built enough kernels on -next plus your patch > to say that it does indeed solve that problem. Awesome, thanks for verifying the fix. > However, there are a couple of other unhealthy symptoms I've noticed > under load in -next's block/cfq layer, both with and without your patch. > > One is kernel BUG at block/cfq-iosched.c:2585! > BUG_ON(RB_EMPTY_ROOT(&cfqq->sort_list)); > > cfq_dispatch_request+0x1a > cfq_dispatch_requests+0x5c > blk_peek_request+0x195 > scsi_request_fn+0x6a > __blk_run_queue+0x16 > scsi_run_queue+0x18a > scsi_next_command+0x36 > scsi_io_completion+0x426 > scsi_finish_command+0xaf > scsi_softirq_done+0xdd > blk_done_softirq+0x6c > __do_softirq+0x80 > call_softirq+0x1c > do_softirq+0x33 > irq_exit+0x3f > do_IRQ+0x97 > ret_from_intr > > I've had that one four times now on different machines; but quicker > to reproduce are these warnings from CONFIG_DEBUG_LIST=y: > > ------------[ cut here ]------------ > WARNING: at lib/list_debug.c:53 __list_del_entry+0x8d/0x98() > Hardware name: 4174AY9 > list_del corruption. prev->next should be ffff880005aa1380, but was 6b6b6b6b6b6b6b6b > Modules linked in: snd_pcm_oss snd_mixer_oss snd_seq snd_seq_device > Pid: 29241, comm: cc1 Tainted: G W 3.2.0-rc6-next-20111222 #18 > Call Trace: > <IRQ> [<ffffffff810544b4>] warn_slowpath_common+0x80/0x98 > [<ffffffff81054560>] warn_slowpath_fmt+0x41/0x43 > [<ffffffff811fc1a1>] __list_del_entry+0x8d/0x98 > [<ffffffff811df8ab>] cfq_remove_request+0x3b/0xdf > [<ffffffff811df989>] cfq_dispatch_insert+0x3a/0x87 > [<ffffffff811dfb3b>] cfq_dispatch_request+0x65/0x92 > [<ffffffff811dfbc4>] cfq_dispatch_requests+0x5c/0x133 > [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 > [<ffffffff811d3069>] blk_peek_request+0x195/0x1a6 > [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 > [<ffffffff812e0cf5>] scsi_request_fn+0x6d/0x3d3 > [<ffffffff811d0730>] __blk_run_queue+0x19/0x1b > [<ffffffff811d0bfd>] blk_run_queue+0x21/0x35 > [<ffffffff812e08c4>] scsi_run_queue+0x11f/0x1b9 > [<ffffffff812e205c>] scsi_next_command+0x36/0x46 > [<ffffffff812e24dc>] scsi_io_completion+0x426/0x4a9 > [<ffffffff812dc0b2>] scsi_finish_command+0xaf/0xb8 > [<ffffffff812e200c>] scsi_softirq_done+0xdd/0xe5 > [<ffffffff811d79c6>] blk_done_softirq+0x76/0x8a > [<ffffffff8105a28d>] __do_softirq+0x98/0x136 > [<ffffffff814e649c>] call_softirq+0x1c/0x30 > [<ffffffff8102f187>] do_softirq+0x38/0x81 > [<ffffffff8105a596>] irq_exit+0x4e/0xb6 > [<ffffffff8102ee9e>] do_IRQ+0x97/0xae > [<ffffffff814e49f0>] common_interrupt+0x70/0x70 > <EOI> [<ffffffff814e4a8e>] ? retint_swapgs+0xe/0x13 > ---[ end trace 61fdaa1b260613d1 ]--- Hmm... that looks like cfqq being freed before unlinked. I'll try to reproduce it. Is there any particular workload you were running? Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-28 16:48 ` Tejun Heo @ 2011-12-28 17:50 ` Hugh Dickins 2011-12-28 17:55 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Hugh Dickins @ 2011-12-28 17:50 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Wed, 28 Dec 2011, Tejun Heo wrote: > On Wed, Dec 28, 2011 at 12:33:01AM -0800, Hugh Dickins wrote: > > > However, there are a couple of other unhealthy symptoms I've noticed > > under load in -next's block/cfq layer, both with and without your patch. > > > > One is kernel BUG at block/cfq-iosched.c:2585! > > BUG_ON(RB_EMPTY_ROOT(&cfqq->sort_list)); > > > > cfq_dispatch_request+0x1a > > cfq_dispatch_requests+0x5c > > blk_peek_request+0x195 > > scsi_request_fn+0x6a > > __blk_run_queue+0x16 > > scsi_run_queue+0x18a > > scsi_next_command+0x36 > > scsi_io_completion+0x426 > > scsi_finish_command+0xaf > > scsi_softirq_done+0xdd > > blk_done_softirq+0x6c > > __do_softirq+0x80 > > call_softirq+0x1c > > do_softirq+0x33 > > irq_exit+0x3f > > do_IRQ+0x97 > > ret_from_intr > > > > I've had that one four times now on different machines; but quicker > > to reproduce are these warnings from CONFIG_DEBUG_LIST=y: > > > > ------------[ cut here ]------------ > > WARNING: at lib/list_debug.c:53 __list_del_entry+0x8d/0x98() > > Hardware name: 4174AY9 > > list_del corruption. prev->next should be ffff880005aa1380, but was 6b6b6b6b6b6b6b6b > > Modules linked in: snd_pcm_oss snd_mixer_oss snd_seq snd_seq_device > > Pid: 29241, comm: cc1 Tainted: G W 3.2.0-rc6-next-20111222 #18 > > Call Trace: > > <IRQ> [<ffffffff810544b4>] warn_slowpath_common+0x80/0x98 > > [<ffffffff81054560>] warn_slowpath_fmt+0x41/0x43 > > [<ffffffff811fc1a1>] __list_del_entry+0x8d/0x98 > > [<ffffffff811df8ab>] cfq_remove_request+0x3b/0xdf > > [<ffffffff811df989>] cfq_dispatch_insert+0x3a/0x87 > > [<ffffffff811dfb3b>] cfq_dispatch_request+0x65/0x92 > > [<ffffffff811dfbc4>] cfq_dispatch_requests+0x5c/0x133 > > [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 > > [<ffffffff811d3069>] blk_peek_request+0x195/0x1a6 > > [<ffffffff812e103e>] ? scsi_request_fn+0x3b6/0x3d3 > > [<ffffffff812e0cf5>] scsi_request_fn+0x6d/0x3d3 > > [<ffffffff811d0730>] __blk_run_queue+0x19/0x1b > > [<ffffffff811d0bfd>] blk_run_queue+0x21/0x35 > > [<ffffffff812e08c4>] scsi_run_queue+0x11f/0x1b9 > > [<ffffffff812e205c>] scsi_next_command+0x36/0x46 > > [<ffffffff812e24dc>] scsi_io_completion+0x426/0x4a9 > > [<ffffffff812dc0b2>] scsi_finish_command+0xaf/0xb8 > > [<ffffffff812e200c>] scsi_softirq_done+0xdd/0xe5 > > [<ffffffff811d79c6>] blk_done_softirq+0x76/0x8a > > [<ffffffff8105a28d>] __do_softirq+0x98/0x136 > > [<ffffffff814e649c>] call_softirq+0x1c/0x30 > > [<ffffffff8102f187>] do_softirq+0x38/0x81 > > [<ffffffff8105a596>] irq_exit+0x4e/0xb6 > > [<ffffffff8102ee9e>] do_IRQ+0x97/0xae > > [<ffffffff814e49f0>] common_interrupt+0x70/0x70 > > <EOI> [<ffffffff814e4a8e>] ? retint_swapgs+0xe/0x13 > > ---[ end trace 61fdaa1b260613d1 ]--- > > Hmm... that looks like cfqq being freed before unlinked. I'll try to > reproduce it. Is there any particular workload you were running? "It's the tmpfs swapping test that I've been running, with variations, for years. System booted with mem=700M and 1.5G swap, two repetitious make -j20 kernel builds (of a 2.6.24 kernel: I stuck with that because the balance of built to unbuilt source grows smaller with later kernels), one directly in a tmpfs, the other in a 1k-block ext2 (that I drive with ext4's CONFIG_EXT4_USE_FOR_EXT23) on /dev/loop0 on a 450MB tmpfs file." I doubt much of that (quoted from an older mail to someone else about one of the many other bugs it's found) is relevant: maybe just plenty of file I/O and swapping. Hugh ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-28 17:50 ` Hugh Dickins @ 2011-12-28 17:55 ` Tejun Heo 2011-12-28 21:19 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-28 17:55 UTC (permalink / raw) To: Hugh Dickins Cc: Jens Axboe, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, On Wed, Dec 28, 2011 at 9:50 AM, Hugh Dickins <hughd@google.com> wrote: > "It's the tmpfs swapping test that I've been running, with variations, > for years. System booted with mem=700M and 1.5G swap, two repetitious > make -j20 kernel builds (of a 2.6.24 kernel: I stuck with that because > the balance of built to unbuilt source grows smaller with later kernels), > one directly in a tmpfs, the other in a 1k-block ext2 (that I drive with > ext4's CONFIG_EXT4_USE_FOR_EXT23) on /dev/loop0 on a 450MB tmpfs file." > > I doubt much of that (quoted from an older mail to someone else about > one of the many other bugs it's found) is relevant: maybe just plenty > of file I/O and swapping. Plain -j4 build isn't triggering anything. I'll try to replicate the condition. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-28 17:55 ` Tejun Heo @ 2011-12-28 21:19 ` Tejun Heo 2012-01-03 17:35 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2011-12-28 21:19 UTC (permalink / raw) To: Hugh Dickins Cc: Jens Axboe, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Wed, Dec 28, 2011 at 09:55:12AM -0800, Tejun Heo wrote: > Hello, > > On Wed, Dec 28, 2011 at 9:50 AM, Hugh Dickins <hughd@google.com> wrote: > > "It's the tmpfs swapping test that I've been running, with variations, > > for years. System booted with mem=700M and 1.5G swap, two repetitious > > make -j20 kernel builds (of a 2.6.24 kernel: I stuck with that because > > the balance of built to unbuilt source grows smaller with later kernels), > > one directly in a tmpfs, the other in a 1k-block ext2 (that I drive with > > ext4's CONFIG_EXT4_USE_FOR_EXT23) on /dev/loop0 on a 450MB tmpfs file." > > > > I doubt much of that (quoted from an older mail to someone else about > > one of the many other bugs it's found) is relevant: maybe just plenty > > of file I/O and swapping. > > Plain -j4 build isn't triggering anything. I'll try to replicate the condition. It's not too reliable but I can reproduce it with -j 22 allmodconfig build inside qemu w/ 512M of memory. I'll try to find out what's going on. Thanks. -- tejun -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2011-12-28 21:19 ` Tejun Heo @ 2012-01-03 17:35 ` Tejun Heo 2012-01-03 17:59 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-03 17:35 UTC (permalink / raw) To: Hugh Dickins, Jens Axboe Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Happy new year, guys. On Wed, Dec 28, 2011 at 01:19:18PM -0800, Tejun Heo wrote: > > On Wed, Dec 28, 2011 at 9:50 AM, Hugh Dickins <hughd@google.com> wrote: > > > "It's the tmpfs swapping test that I've been running, with variations, > > > for years. System booted with mem=700M and 1.5G swap, two repetitious > > > make -j20 kernel builds (of a 2.6.24 kernel: I stuck with that because > > > the balance of built to unbuilt source grows smaller with later kernels), > > > one directly in a tmpfs, the other in a 1k-block ext2 (that I drive with > > > ext4's CONFIG_EXT4_USE_FOR_EXT23) on /dev/loop0 on a 450MB tmpfs file." > > > > > > I doubt much of that (quoted from an older mail to someone else about > > > one of the many other bugs it's found) is relevant: maybe just plenty > > > of file I/O and swapping. > > > > Plain -j4 build isn't triggering anything. I'll try to replicate the condition. > > It's not too reliable but I can reproduce it with -j 22 allmodconfig > build inside qemu w/ 512M of memory. I'll try to find out what's > going on. I misread the code, the problem is empty cfqq on the cfq prio tree. I don't think this is caused by recent io_context changes. It looks like somebody is forgetting to remove cfqq from the dispatch prio tree after emptying a cfqq by removing a request from it. Jens, any ideas? Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 17:35 ` Tejun Heo @ 2012-01-03 17:59 ` Tejun Heo 2012-01-03 20:09 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-03 17:59 UTC (permalink / raw) To: Hugh Dickins, Jens Axboe, Shaohua Li Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, again. Adding Shaohua Li as he fixed a similar issue in 4a0b75c7d0 "block, cfq: fix empty queue crash caused by request merge". The original thread can be read from http://thread.gmane.org/gmane.linux.kernel.next/20064/focus=20159 On Tue, Jan 03, 2012 at 09:35:00AM -0800, Tejun Heo wrote: > Happy new year, guys. > > On Wed, Dec 28, 2011 at 01:19:18PM -0800, Tejun Heo wrote: > > > On Wed, Dec 28, 2011 at 9:50 AM, Hugh Dickins <hughd@google.com> wrote: > > > > "It's the tmpfs swapping test that I've been running, with variations, > > > > for years. System booted with mem=700M and 1.5G swap, two repetitious > > > > make -j20 kernel builds (of a 2.6.24 kernel: I stuck with that because > > > > the balance of built to unbuilt source grows smaller with later kernels), > > > > one directly in a tmpfs, the other in a 1k-block ext2 (that I drive with > > > > ext4's CONFIG_EXT4_USE_FOR_EXT23) on /dev/loop0 on a 450MB tmpfs file." > > > > > > > > I doubt much of that (quoted from an older mail to someone else about > > > > one of the many other bugs it's found) is relevant: maybe just plenty > > > > of file I/O and swapping. > > > > > > Plain -j4 build isn't triggering anything. I'll try to replicate the condition. > > > > It's not too reliable but I can reproduce it with -j 22 allmodconfig > > build inside qemu w/ 512M of memory. I'll try to find out what's > > going on. > > I misread the code, the problem is empty cfqq on the cfq prio tree. I > don't think this is caused by recent io_context changes. It looks > like somebody is forgetting to remove cfqq from the dispatch prio tree > after emptying a cfqq by removing a request from it. Jens, any ideas? That should have been service tree. I couldn't find more missing removals other than the one Shaohua's patch already fixed. Close cooperator selection in cfq_select_queue() seems suspicious tho. I can't see what prevents it from returning an empty coopeator cfqq. I'm trying to verify whether that's the case. Will update when I know more. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 17:59 ` Tejun Heo @ 2012-01-03 20:09 ` Tejun Heo 2012-01-03 20:20 ` Jens Axboe 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-03 20:09 UTC (permalink / raw) To: Hugh Dickins, Jens Axboe, Shaohua Li Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Tue, Jan 03, 2012 at 09:59:22AM -0800, Tejun Heo wrote: > That should have been service tree. I couldn't find more missing > removals other than the one Shaohua's patch already fixed. Close > cooperator selection in cfq_select_queue() seems suspicious tho. I > can't see what prevents it from returning an empty coopeator cfqq. > I'm trying to verify whether that's the case. Will update when I know > more. While testing, found another bug. Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) 070: e8 32 ab 1d 00 88 ff ff e8 32 ab 1d 00 88 ff ff .2.......2...... Prev obj: start=ffff88001dab3178, len=232 Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) 000: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk 010: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk Next obj: start=ffff88001dab3378, len=232 Redzone: 0xd84156c5635688c0/0xd84156c5635688c0. Last user: [<ffffffff813a8e53>](cfq_get_queue+0x153/0x670) 000: 02 00 00 00 21 01 00 00 e0 c9 b1 1d 00 88 ff ff ....!........... 010: 89 96 ae 18 00 88 ff ff 00 00 00 00 00 00 00 00 ................ The field at 0x70 which is being updated after being freed is cfqq->fifo. Interestingly, it didn't lead to any visible failure. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 20:09 ` Tejun Heo @ 2012-01-03 20:20 ` Jens Axboe 2012-01-03 22:13 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Jens Axboe @ 2012-01-03 20:20 UTC (permalink / raw) To: Tejun Heo Cc: Hugh Dickins, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On 2012-01-03 21:09, Tejun Heo wrote: > On Tue, Jan 03, 2012 at 09:59:22AM -0800, Tejun Heo wrote: >> That should have been service tree. I couldn't find more missing >> removals other than the one Shaohua's patch already fixed. Close >> cooperator selection in cfq_select_queue() seems suspicious tho. I >> can't see what prevents it from returning an empty coopeator cfqq. >> I'm trying to verify whether that's the case. Will update when I know >> more. > > While testing, found another bug. > > Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. > Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) > 070: e8 32 ab 1d 00 88 ff ff e8 32 ab 1d 00 88 ff ff .2.......2...... > Prev obj: start=ffff88001dab3178, len=232 > Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. > Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) > 000: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk > 010: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk > Next obj: start=ffff88001dab3378, len=232 > Redzone: 0xd84156c5635688c0/0xd84156c5635688c0. > Last user: [<ffffffff813a8e53>](cfq_get_queue+0x153/0x670) > 000: 02 00 00 00 21 01 00 00 e0 c9 b1 1d 00 88 ff ff ....!........... > 010: 89 96 ae 18 00 88 ff ff 00 00 00 00 00 00 00 00 ................ > > The field at 0x70 which is being updated after being freed is > cfqq->fifo. Interestingly, it didn't lead to any visible failure. That's pretty odd. Given Hughs report as well, it sure does sound like we now have some life time issues with cfqq's. -- Jens Axboe ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 20:20 ` Jens Axboe @ 2012-01-03 22:13 ` Tejun Heo 2012-01-03 22:35 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-03 22:13 UTC (permalink / raw) To: Jens Axboe Cc: Hugh Dickins, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Tue, Jan 03, 2012 at 09:20:44PM +0100, Jens Axboe wrote: > On 2012-01-03 21:09, Tejun Heo wrote: > > On Tue, Jan 03, 2012 at 09:59:22AM -0800, Tejun Heo wrote: > >> That should have been service tree. I couldn't find more missing > >> removals other than the one Shaohua's patch already fixed. Close > >> cooperator selection in cfq_select_queue() seems suspicious tho. I > >> can't see what prevents it from returning an empty coopeator cfqq. > >> I'm trying to verify whether that's the case. Will update when I know > >> more. > > > > While testing, found another bug. > > > > Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. > > Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) > > 070: e8 32 ab 1d 00 88 ff ff e8 32 ab 1d 00 88 ff ff .2.......2...... > > Prev obj: start=ffff88001dab3178, len=232 > > Redzone: 0x9f911029d74e35b/0x9f911029d74e35b. > > Last user: [<ffffffff813a82ee>](cfq_put_queue+0x7e/0xd0) > > 000: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk > > 010: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk > > Next obj: start=ffff88001dab3378, len=232 > > Redzone: 0xd84156c5635688c0/0xd84156c5635688c0. > > Last user: [<ffffffff813a8e53>](cfq_get_queue+0x153/0x670) > > 000: 02 00 00 00 21 01 00 00 e0 c9 b1 1d 00 88 ff ff ....!........... > > 010: 89 96 ae 18 00 88 ff ff 00 00 00 00 00 00 00 00 ................ > > > > The field at 0x70 which is being updated after being freed is > > cfqq->fifo. Interestingly, it didn't lead to any visible failure. > > That's pretty odd. Given Hughs report as well, it sure does sound like > we now have some life time issues with cfqq's. Hmmm... I disabled cfqq merge logic (commented out cfq_close_cooperator() and the following cfq_setup_merge() calls) in cfq_select_queue() and neither is triggering for quite a while now. Maybe cfqq refcnt is getting borked over cfqq merging / splitting? It would also explain the low frequency of the issue too. I'll try to further isolate it but It would be awesome if someone more familiar with the logic can go over that part. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 22:13 ` Tejun Heo @ 2012-01-03 22:35 ` Tejun Heo 2012-01-05 1:24 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-03 22:35 UTC (permalink / raw) To: Jens Axboe Cc: Hugh Dickins, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Tue, Jan 03, 2012 at 02:13:01PM -0800, Tejun Heo wrote: > > That's pretty odd. Given Hughs report as well, it sure does sound like > > we now have some life time issues with cfqq's. > > Hmmm... I disabled cfqq merge logic (commented out > cfq_close_cooperator() and the following cfq_setup_merge() calls) in > cfq_select_queue() and neither is triggering for quite a while now. > Maybe cfqq refcnt is getting borked over cfqq merging / splitting? It > would also explain the low frequency of the issue too. I'll try to > further isolate it but It would be awesome if someone more familiar > with the logic can go over that part. Scrap that. It triggered and yeah cfq_get_next_queue() is retrieving empty cfqq from the service tree. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-03 22:35 ` Tejun Heo @ 2012-01-05 1:24 ` Tejun Heo 2012-01-05 18:36 ` Hugh Dickins 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-05 1:24 UTC (permalink / raw) To: Jens Axboe Cc: Hugh Dickins, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, again. On Tue, Jan 03, 2012 at 02:35:05PM -0800, Tejun Heo wrote: > > Hmmm... I disabled cfqq merge logic (commented out > > cfq_close_cooperator() and the following cfq_setup_merge() calls) in > > cfq_select_queue() and neither is triggering for quite a while now. > > Maybe cfqq refcnt is getting borked over cfqq merging / splitting? It > > would also explain the low frequency of the issue too. I'll try to > > further isolate it but It would be awesome if someone more familiar > > with the logic can go over that part. > > Scrap that. It triggered and yeah cfq_get_next_queue() is retrieving > empty cfqq from the service tree. Update: I've been running with ELEVATOR_INSERT_SORT_MERGE disabled and none of the issues triggered for about three hours now. It usually triggers under an hour. Hugh, can you please verify whether the patch appended at the end makes the problem go away? Thanks. diff --git a/block/elevator.c b/block/elevator.c index 99838f4..2e172d2 100644 --- a/block/elevator.c +++ b/block/elevator.c @@ -644,6 +644,9 @@ void __elv_add_request(struct request_queue *q, struct request *rq, int where) rq->q = q; + if (where == ELEVATOR_INSERT_SORT_MERGE) + where = ELEVATOR_INSERT_SORT; + if (rq->cmd_flags & REQ_SOFTBARRIER) { /* barriers are scheduling boundary, update end_sector */ if (rq->cmd_type == REQ_TYPE_FS || ^ permalink raw reply related [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-05 1:24 ` Tejun Heo @ 2012-01-05 18:36 ` Hugh Dickins 2012-01-05 18:38 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Hugh Dickins @ 2012-01-05 18:36 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Wed, 4 Jan 2012, Tejun Heo wrote: > On Tue, Jan 03, 2012 at 02:35:05PM -0800, Tejun Heo wrote: > > > Hmmm... I disabled cfqq merge logic (commented out > > > cfq_close_cooperator() and the following cfq_setup_merge() calls) in > > > cfq_select_queue() and neither is triggering for quite a while now. > > > Maybe cfqq refcnt is getting borked over cfqq merging / splitting? It > > > would also explain the low frequency of the issue too. I'll try to > > > further isolate it but It would be awesome if someone more familiar > > > with the logic can go over that part. > > > > Scrap that. It triggered and yeah cfq_get_next_queue() is retrieving > > empty cfqq from the service tree. > > Update: I've been running with ELEVATOR_INSERT_SORT_MERGE disabled and > none of the issues triggered for about three hours now. It usually > triggers under an hour. > > Hugh, can you please verify whether the patch appended at the end > makes the problem go away? I can vouch that it makes the list_debug.c:53 warnings go away: they used to come in half an hour, but I've run on two machines for 10 hours so far without seeing any. And I've not yet seen a cfq-iosched.c:2585 with that patch in; but those were more elusive - we'll have to run until tomorrow night before concluding that it makes those go away too. Or if you understand the connection between these, and would prefer to assume that it fixes them both, and want me to try another patch instead (I assume the one I'm running with is a workaround to narrow down the issue, rather than an intended fix?), let me know and I'll switch over. Hugh > > Thanks. > > diff --git a/block/elevator.c b/block/elevator.c > index 99838f4..2e172d2 100644 > --- a/block/elevator.c > +++ b/block/elevator.c > @@ -644,6 +644,9 @@ void __elv_add_request(struct request_queue *q, struct request *rq, int where) > > rq->q = q; > > + if (where == ELEVATOR_INSERT_SORT_MERGE) > + where = ELEVATOR_INSERT_SORT; > + > if (rq->cmd_flags & REQ_SOFTBARRIER) { > /* barriers are scheduling boundary, update end_sector */ > if (rq->cmd_type == REQ_TYPE_FS || > ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context 2012-01-05 18:36 ` Hugh Dickins @ 2012-01-05 18:38 ` Tejun Heo 2012-01-06 2:17 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-05 18:38 UTC (permalink / raw) To: Hugh Dickins Cc: Jens Axboe, Shaohua Li, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, Hugh. On Thu, Jan 05, 2012 at 10:36:21AM -0800, Hugh Dickins wrote: > I can vouch that it makes the list_debug.c:53 warnings go away: they > used to come in half an hour, but I've run on two machines for 10 > hours so far without seeing any. Yeah, my overnight test is pretty conclusive too. I can usually hit the bug under 30mins without the patch. > And I've not yet seen a cfq-iosched.c:2585 with that patch in; but > those were more elusive - we'll have to run until tomorrow night > before concluding that it makes those go away too. > > Or if you understand the connection between these, and would prefer > to assume that it fixes them both, and want me to try another patch > instead (I assume the one I'm running with is a workaround to narrow > down the issue, rather than an intended fix?), let me know and I'll > switch over. Yeap, I can see the connections now and think I know where the bug is too. I'll, hopefully, be able to post fix soon. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-05 18:38 ` Tejun Heo @ 2012-01-06 2:17 ` Tejun Heo 2012-01-06 2:36 ` Tejun Heo 2012-01-06 2:47 ` Shaohua Li 0 siblings, 2 replies; 41+ messages in thread From: Tejun Heo @ 2012-01-06 2:17 UTC (permalink / raw) To: Jens Axboe, Shaohua Li, Hugh Dickins Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 When two requests are merged, if the absorbed request is older than the absorbing one, cfq_merged_requests() tries to reposition it in the cfqq->fifo list by list_move()'ing the absorbing request to the absorbed one before removing it. This works if both requests are on the same cfqq but nothing guarantees that and the code ends up moving the merged request to a different cfqq's fifo list without adjusting the rest. This leads to the following failures. * A request may be on the fifo list of a cfqq without holding reference to it and the cfqq can be freed before requst is finished. Among other things, this triggers list debug warning and slab debug use-after-free warning. * As a request can be on the wrong fifo queue, it may be issued and completed before its cfqq is scheduled. If the cfqq didn't have other requests on it, it would be empty by the time it's dispatched triggering BUG_ON() in cfq_dispatch_request(). Fix it by making cfq_merged_requests() scan the absorbing request's fifo list for the correct slot and move there instead. Signed-off-by: Tejun Heo <tj@kernel.org> Reported-by: Hugh Dickins <hughd@google.com> Cc: stable@vger.kernel.org --- It survived my testing long enough and I'm relatively confident this should fix the crash but I might have gotten the scanning wrong, so please pay extra attention there. I suspect we just didn't have enough backward request-request merges before the recent plug merge updates to trigger this bug. Thanks. block/cfq-iosched.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 163263d..a235cf3 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c @@ -1663,8 +1663,15 @@ cfq_merged_requests(struct request_queue *q, struct request *rq, */ if (!list_empty(&rq->queuelist) && !list_empty(&next->queuelist) && time_before(rq_fifo_time(next), rq_fifo_time(rq))) { - list_move(&rq->queuelist, &next->queuelist); + struct request *pos = rq; + rq_set_fifo_time(rq, rq_fifo_time(next)); + + list_for_each_entry_continue_reverse(pos, &cfqq->fifo, queuelist) + if (time_before_eq(rq_fifo_time(pos), rq_fifo_time(rq))) + break; + if (rq != pos) + list_move(&rq->queuelist, &pos->queuelist); } if (cfqq->next_rq == next) ^ permalink raw reply related [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 2:17 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Tejun Heo @ 2012-01-06 2:36 ` Tejun Heo 2012-01-06 3:14 ` Shaohua Li 2012-01-06 2:47 ` Shaohua Li 1 sibling, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-06 2:36 UTC (permalink / raw) To: Jens Axboe, Shaohua Li, Hugh Dickins Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, again. On Thu, Jan 05, 2012 at 06:17:07PM -0800, Tejun Heo wrote: > When two requests are merged, if the absorbed request is older than > the absorbing one, cfq_merged_requests() tries to reposition it in the > cfqq->fifo list by list_move()'ing the absorbing request to the > absorbed one before removing it. > > This works if both requests are on the same cfqq but nothing > guarantees that and the code ends up moving the merged request to a > different cfqq's fifo list without adjusting the rest. This leads to > the following failures. > > * A request may be on the fifo list of a cfqq without holding > reference to it and the cfqq can be freed before requst is finished. > Among other things, this triggers list debug warning and slab debug > use-after-free warning. > > * As a request can be on the wrong fifo queue, it may be issued and > completed before its cfqq is scheduled. If the cfqq didn't have > other requests on it, it would be empty by the time it's dispatched > triggering BUG_ON() in cfq_dispatch_request(). > > Fix it by making cfq_merged_requests() scan the absorbing request's > fifo list for the correct slot and move there instead. Hmmm... while the patch would fix the problem. It isn't entirely correct. The root cause is, 1. q->last_merge and rqhash used to be used only for merging bios into requests and that queries elevator whether the merge should be allowed. cfq disallows merging if they belong to different cfqqs. 2. request-request merging didn't use to use q->last_merge or rqhash to find request candidates. It used elv_former/latter_request() and cfq never returned request from a different cfqq. 3. Plug merging started using q->last_merge and rqhash and now elevator can't prevent cross cfqq merges. So, yeah, the right fix would be using elv_former/latter_request() instead. Maybe we should strip out rqhash altogether and change elevator handle everything? I don't know. I'll prepare a different fix patch soon. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 2:36 ` Tejun Heo @ 2012-01-06 3:14 ` Shaohua Li 2012-01-06 3:04 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Shaohua Li @ 2012-01-06 3:14 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 18:36 -0800, Tejun Heo wrote: > Hello, again. > > On Thu, Jan 05, 2012 at 06:17:07PM -0800, Tejun Heo wrote: > > When two requests are merged, if the absorbed request is older than > > the absorbing one, cfq_merged_requests() tries to reposition it in the > > cfqq->fifo list by list_move()'ing the absorbing request to the > > absorbed one before removing it. > > > > This works if both requests are on the same cfqq but nothing > > guarantees that and the code ends up moving the merged request to a > > different cfqq's fifo list without adjusting the rest. This leads to > > the following failures. > > > > * A request may be on the fifo list of a cfqq without holding > > reference to it and the cfqq can be freed before requst is finished. > > Among other things, this triggers list debug warning and slab debug > > use-after-free warning. > > > > * As a request can be on the wrong fifo queue, it may be issued and > > completed before its cfqq is scheduled. If the cfqq didn't have > > other requests on it, it would be empty by the time it's dispatched > > triggering BUG_ON() in cfq_dispatch_request(). > > > > Fix it by making cfq_merged_requests() scan the absorbing request's > > fifo list for the correct slot and move there instead. > > Hmmm... while the patch would fix the problem. It isn't entirely > correct. The root cause is, > > 1. q->last_merge and rqhash used to be used only for merging bios into > requests and that queries elevator whether the merge should be > allowed. cfq disallows merging if they belong to different cfqqs. > > 2. request-request merging didn't use to use q->last_merge or rqhash to > find request candidates. It used elv_former/latter_request() and > cfq never returned request from a different cfqq. > > 3. Plug merging started using q->last_merge and rqhash and now > elevator can't prevent cross cfqq merges. > > So, yeah, the right fix would be using elv_former/latter_request() > instead. Maybe we should strip out rqhash altogether and change > elevator handle everything? I don't know. I'll prepare a different > fix patch soon. So not allow merge from two cfq queues strictly? This will impact performance. I don't know how important the strict isolation is. we even allow two cfq queues merge to improve performance. ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 3:14 ` Shaohua Li @ 2012-01-06 3:04 ` Tejun Heo 2012-01-06 3:30 ` Tejun Heo 2012-01-06 3:34 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Shaohua Li 0 siblings, 2 replies; 41+ messages in thread From: Tejun Heo @ 2012-01-06 3:04 UTC (permalink / raw) To: Shaohua Li Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, On Fri, Jan 06, 2012 at 11:14:15AM +0800, Shaohua Li wrote: > > So, yeah, the right fix would be using elv_former/latter_request() > > instead. Maybe we should strip out rqhash altogether and change > > elevator handle everything? I don't know. I'll prepare a different > > fix patch soon. > > So not allow merge from two cfq queues strictly? This will impact > performance. I don't know how important the strict isolation is. we even > allow two cfq queues merge to improve performance. That's how cfq has behaved before this recent plug merge breakage and IIRC why the cooperating queue thing is there. If you want to change the behavior, that should be an explicit separate patch. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 3:04 ` Tejun Heo @ 2012-01-06 3:30 ` Tejun Heo 2012-01-06 3:52 ` [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE Tejun Heo 2012-01-06 3:34 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Shaohua Li 1 sibling, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-06 3:30 UTC (permalink / raw) To: Jens Axboe, Hugh Dickins, Shaohua Li Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Ummmm... I've been looking at the code and currently I think the best option is yank out plug merging for this merge window. Bypassing rqhash for request merging doesn't seem like a good idea. rqhash itself is, at this point, redundant and the limitation that it can only find requests by the ending sectors lead to weird designs. The single ->last_merge was okay but the recursive back merging is just ugly. What it should be doing is trying back merge and then front merge once for each request insertion as the usual merge path does. We can't do attempt_back/front_merge() for INSERT_MERGE at this point because elv_latter/former_request() only works for requests which are already on elevator and, unfortunately, putting a request onto cfq may kick the queue directly and the request might already be gone by the time we try to merge it. For this merge window, I think we better just disable INSERT_MERGE. A mid-term solution could be changing elevator interface such that elevator_add_req_fn() doesn't kick the queue directly but notify elevator core that the queue needs kicking via return value, so that merging can happen before kicking the queue. Note that there's a caveat here. Merging might make kicking unnecessary or wrong. Better solution would be changing elevator merge logic so that it has "give me request closest to this offset" interface and then use prev/next from there to find out merge candidates for both bio-rq and rq-rq merges and just kill rqhash. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE 2012-01-06 3:30 ` Tejun Heo @ 2012-01-06 3:52 ` Tejun Heo 2012-01-06 4:19 ` Shaohua Li 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-06 3:52 UTC (permalink / raw) To: Jens Axboe, Hugh Dickins, Shaohua Li Cc: Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 5e84ea3a9c "block: attempt to merge with existing requests on plug flush" added support for merging requests on plug flush and 274193224c "block: recursive merge requests" added recursive merging. Because these mergings happen before the request is inserted on the elevator, the usual elv_latter/former_request() can't be used to locate merge candidates. It instead used bio merging mechanism - last_merge hint and rqhash; unfortunately, this means that the elevator doesn't have a say in which are allowed to merge and which aren't. For cfq, this resulted in merges across different cfqq's which led to crashes as requests jump between different cfqq's unexpectedly. Proper solution would be improving merge mechanism such that we can always query elevator to find out merge candidates and remove rqhash; however, the merge window is already upon us. Disable INSERT_SORT_MERGE for now. For detailed discussion of the bug: http://thread.gmane.org/gmane.linux.kernel.next/20064/focus=20159 Signed-off-by: Tejun Heo <tj@kernel.org> Reported-by: Hugh Dickins <hughd@google.com> Cc: stable@vger.kernel.org --- block/blk-core.c | 5 ++++- block/elevator.c | 5 +++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/block/blk-core.c b/block/blk-core.c index 8fbdac7..7db6afa 100644 --- a/block/blk-core.c +++ b/block/blk-core.c @@ -2859,11 +2859,14 @@ void blk_flush_plug_list(struct blk_plug *plug, bool from_schedule) /* * rq is already accounted, so use raw insert + * + * FIXME: We want INSERT_SORT_MERGE for non-FLUSH/FUA + * requests but it's currently broken. */ if (rq->cmd_flags & (REQ_FLUSH | REQ_FUA)) __elv_add_request(q, rq, ELEVATOR_INSERT_FLUSH); else - __elv_add_request(q, rq, ELEVATOR_INSERT_SORT_MERGE); + __elv_add_request(q, rq, ELEVATOR_INSERT_SORT); depth++; } diff --git a/block/elevator.c b/block/elevator.c index 99838f4..c32f5bc 100644 --- a/block/elevator.c +++ b/block/elevator.c @@ -644,6 +644,11 @@ void __elv_add_request(struct request_queue *q, struct request *rq, int where) rq->q = q; + /* + * FIXME: INSERT_SORT_MERGE is broken and blk_flush_plug_list(), + * the only user, is updated to use INSERT_SORT for now. + */ + if (rq->cmd_flags & REQ_SOFTBARRIER) { /* barriers are scheduling boundary, update end_sector */ if (rq->cmd_type == REQ_TYPE_FS || ^ permalink raw reply related [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE 2012-01-06 3:52 ` [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE Tejun Heo @ 2012-01-06 4:19 ` Shaohua Li 2012-01-06 4:38 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Shaohua Li @ 2012-01-06 4:19 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 19:52 -0800, Tejun Heo wrote: > 5e84ea3a9c "block: attempt to merge with existing requests on plug > flush" added support for merging requests on plug flush and 274193224c > "block: recursive merge requests" added recursive merging. > > Because these mergings happen before the request is inserted on the > elevator, the usual elv_latter/former_request() can't be used to > locate merge candidates. It instead used bio merging mechanism - > last_merge hint and rqhash; unfortunately, this means that the > elevator doesn't have a say in which are allowed to merge and which > aren't. > > For cfq, this resulted in merges across different cfqq's which led to > crashes as requests jump between different cfqq's unexpectedly. > > Proper solution would be improving merge mechanism such that we can > always query elevator to find out merge candidates and remove rqhash; > however, the merge window is already upon us. Disable > INSERT_SORT_MERGE for now. > > For detailed discussion of the bug: > > http://thread.gmane.org/gmane.linux.kernel.next/20064/focus=20159 > this is overkill. when plug is added, we found huge performance regression, that's why we add INSERT_SORT_MERGE. Thanks, Shaohua ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE 2012-01-06 4:19 ` Shaohua Li @ 2012-01-06 4:38 ` Tejun Heo 2012-01-06 8:15 ` Shaohua Li 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-06 4:38 UTC (permalink / raw) To: Shaohua Li Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, On Thu, Jan 5, 2012 at 8:19 PM, Shaohua Li <shaohua.li@intel.com> wrote: >> For detailed discussion of the bug: >> >> http://thread.gmane.org/gmane.linux.kernel.next/20064/focus=20159 >> > this is overkill. when plug is added, we found huge performance > regression, that's why we add INSERT_SORT_MERGE. With what workload? I suspect most of the improvements is from merging across different cfqqs, no? The whole recursive thing can't be very useful if cross-cfqq merging isn't allowed. Maybe there are specific cases where last_merge hint merging can be specially effective. I don't know. Regardless, this is an apparent bug and the block tree will be pushed mainline pretty soon. If necessary, fix it better later. Doing complex things inside merge window usually isn't a good idea. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE 2012-01-06 4:38 ` Tejun Heo @ 2012-01-06 8:15 ` Shaohua Li 2012-01-06 15:34 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Shaohua Li @ 2012-01-06 8:15 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 20:38 -0800, Tejun Heo wrote: > Hello, > > On Thu, Jan 5, 2012 at 8:19 PM, Shaohua Li <shaohua.li@intel.com> wrote: > >> For detailed discussion of the bug: > >> > >> http://thread.gmane.org/gmane.linux.kernel.next/20064/focus=20159 > >> > > this is overkill. when plug is added, we found huge performance > > regression, that's why we add INSERT_SORT_MERGE. > > With what workload? I suspect most of the improvements is from merging > across different cfqqs, no? The whole recursive thing can't be very > useful if cross-cfqq merging isn't allowed. Maybe there are specific > cases where last_merge hint merging can be specially effective. I > don't know. Regardless, this is an apparent bug and the block tree > will be pushed mainline pretty soon. If necessary, fix it better > later. Doing complex things inside merge window usually isn't a good > idea. it's not related to the recursive merge. I forgot the detail of the workload why we add INSERT_SORT_MERGE, it's added several months ago anyway. Obviously we shouldn't do complex things inside the merge window. I just didn't agree to disable INSERT_SORT_MERGE, which will bring performance regression for sure. Can we just change CFQ like your first path? Thanks, Shaohua ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE 2012-01-06 8:15 ` Shaohua Li @ 2012-01-06 15:34 ` Tejun Heo 0 siblings, 0 replies; 41+ messages in thread From: Tejun Heo @ 2012-01-06 15:34 UTC (permalink / raw) To: Shaohua Li Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, Shaohua. On Fri, Jan 06, 2012 at 04:15:57PM +0800, Shaohua Li wrote: > it's not related to the recursive merge. I forgot the detail of the > workload why we add INSERT_SORT_MERGE, it's added several months ago > anyway. > Obviously we shouldn't do complex things inside the merge window. I just > didn't agree to disable INSERT_SORT_MERGE, which will bring performance > regression for sure. Can we just change CFQ like your first path? But that is exactly what was broken and papering it over is exactly the thing we shouldn't do, for now or for ever. Think about it. Your commit f1f8cc94651 "block, cfq: fix empty queue crash caused by request merge" fixed one symptom caused by cross cfqq merging happening behind cfq's back without properly root-causing it. I'm not saying it was your fault but in the end all it did was obscuring the root cause of the problem further, making the next more subtle failure much more difficult to diagnose. So, if you think cross-cfqq merging is a good idea, please go ahead and do it properly. It shouldn't happen as a side effect of two bugs folded together. As for quicker fix than revamping merge infrastructure, adding another callback to explicitly ask elevator whether two requests chosen by block core can be merged. I didn't go that route because I wasn't sure about the benefit of doing so - I still can't see how that would make a lot of difference without cross cfqq merging, and wanted to stay on the safer side given the intricacy of the problem. So, if you wanna do that and have workload which is benefited enough to justify the extra step, let's do it after the merge window, merge as fixes and send it back via -stable. But we shouldn't be doing that inside merge window when all other trees are getting pushed upstream and we don't have much time for testing ourselves or in linux-next. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 3:04 ` Tejun Heo 2012-01-06 3:30 ` Tejun Heo @ 2012-01-06 3:34 ` Shaohua Li 2012-01-06 3:22 ` Tejun Heo 1 sibling, 1 reply; 41+ messages in thread From: Shaohua Li @ 2012-01-06 3:34 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 19:04 -0800, Tejun Heo wrote: > Hello, > > On Fri, Jan 06, 2012 at 11:14:15AM +0800, Shaohua Li wrote: > > > So, yeah, the right fix would be using elv_former/latter_request() > > > instead. Maybe we should strip out rqhash altogether and change > > > elevator handle everything? I don't know. I'll prepare a different > > > fix patch soon. > > > > So not allow merge from two cfq queues strictly? This will impact > > performance. I don't know how important the strict isolation is. we even > > allow two cfq queues merge to improve performance. > > That's how cfq has behaved before this recent plug merge breakage and > IIRC why the cooperating queue thing is there. If you want to change > the behavior, that should be an explicit separate patch. My point is both cooperating merge and the plug merge of different cfq are merge, no reason we allow one but disallow the other. plug merge isn't a breakage to me. Thanks, Shaohua ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 3:34 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Shaohua Li @ 2012-01-06 3:22 ` Tejun Heo 2012-01-06 4:15 ` Shaohua Li 0 siblings, 1 reply; 41+ messages in thread From: Tejun Heo @ 2012-01-06 3:22 UTC (permalink / raw) To: Shaohua Li Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, Jan 5, 2012 at 7:34 PM, Shaohua Li <shaohua.li@intel.com> wrote: >> That's how cfq has behaved before this recent plug merge breakage and >> IIRC why the cooperating queue thing is there. If you want to change >> the behavior, that should be an explicit separate patch. > My point is both cooperating merge and the plug merge of different cfq > are merge, no reason we allow one but disallow the other. plug merge > isn't a breakage to me. Isolation is pretty big deal for cfq and cross cfqq merging happening without cfq noticing it isn't gonna be helpful to the cause. Why don't we merge bio's across different cfqq's then? -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 3:22 ` Tejun Heo @ 2012-01-06 4:15 ` Shaohua Li 2012-01-06 4:40 ` Tejun Heo 0 siblings, 1 reply; 41+ messages in thread From: Shaohua Li @ 2012-01-06 4:15 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 19:22 -0800, Tejun Heo wrote: > On Thu, Jan 5, 2012 at 7:34 PM, Shaohua Li <shaohua.li@intel.com> wrote: > >> That's how cfq has behaved before this recent plug merge breakage and > >> IIRC why the cooperating queue thing is there. If you want to change > >> the behavior, that should be an explicit separate patch. > > My point is both cooperating merge and the plug merge of different cfq > > are merge, no reason we allow one but disallow the other. plug merge > > isn't a breakage to me. > > Isolation is pretty big deal for cfq and cross cfqq merging happening > without cfq noticing it isn't gonna be helpful to the cause. Why > don't we merge bio's across different cfqq's then? don't know. I don't think a tweak for merge impacts isolation so much. For rotate disk, request size hasn't impact to request cost, so this doesn't impact isolation. Even for ssd, big size request is more efficient to dispatch. And we already have breakage of fairness for SSD, such as no idle. ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 4:15 ` Shaohua Li @ 2012-01-06 4:40 ` Tejun Heo 0 siblings, 0 replies; 41+ messages in thread From: Tejun Heo @ 2012-01-06 4:40 UTC (permalink / raw) To: Shaohua Li Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 Hello, On Thu, Jan 5, 2012 at 8:15 PM, Shaohua Li <shaohua.li@intel.com> wrote: > don't know. I don't think a tweak for merge impacts isolation so much. > For rotate disk, request size hasn't impact to request cost, so this > doesn't impact isolation. Even for ssd, big size request is more > efficient to dispatch. And we already have breakage of fairness for SSD, > such as no idle. I'm not saying they shouldn't be merged but the decision should be elevator's. Block core shouldn't decide it for the elevator. So, whether cross cfqq merge is a good idea or not is mostly irrelevant in this thread. Thanks. -- tejun ^ permalink raw reply [flat|nested] 41+ messages in thread
* Re: [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq 2012-01-06 2:17 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Tejun Heo 2012-01-06 2:36 ` Tejun Heo @ 2012-01-06 2:47 ` Shaohua Li 1 sibling, 0 replies; 41+ messages in thread From: Shaohua Li @ 2012-01-06 2:47 UTC (permalink / raw) To: Tejun Heo Cc: Jens Axboe, Hugh Dickins, Andrew Morton, Stephen Rothwell, linux-next, LKML, linux-scsi, linux-ide, x86 On Thu, 2012-01-05 at 18:17 -0800, Tejun Heo wrote: > When two requests are merged, if the absorbed request is older than > the absorbing one, cfq_merged_requests() tries to reposition it in the > cfqq->fifo list by list_move()'ing the absorbing request to the > absorbed one before removing it. > > This works if both requests are on the same cfqq but nothing > guarantees that and the code ends up moving the merged request to a > different cfqq's fifo list without adjusting the rest. This leads to > the following failures. > > * A request may be on the fifo list of a cfqq without holding > reference to it and the cfqq can be freed before requst is finished. > Among other things, this triggers list debug warning and slab debug > use-after-free warning. > > * As a request can be on the wrong fifo queue, it may be issued and > completed before its cfqq is scheduled. If the cfqq didn't have > other requests on it, it would be empty by the time it's dispatched > triggering BUG_ON() in cfq_dispatch_request(). > > Fix it by making cfq_merged_requests() scan the absorbing request's > fifo list for the correct slot and move there instead. > > Signed-off-by: Tejun Heo <tj@kernel.org> > Reported-by: Hugh Dickins <hughd@google.com> > Cc: stable@vger.kernel.org > --- > It survived my testing long enough and I'm relatively confident this > should fix the crash but I might have gotten the scanning wrong, so > please pay extra attention there. > > I suspect we just didn't have enough backward request-request merges > before the recent plug merge updates to trigger this bug. The patch itself looks good to me, but I'm wondering if we really need do reposition of the fifo list for merged request. it's rare case and not worthy such complexity to me. Thanks, Shaohua ^ permalink raw reply [flat|nested] 41+ messages in thread
end of thread, other threads:[~2012-01-06 15:34 UTC | newest]
Thread overview: 41+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20111221174733.9ba0861e762e8d96844b060b@canb.auug.org.au>
2011-12-21 23:15 ` linux-next: Tree for Dec 21 Andrew Morton
2011-12-22 23:08 ` Andrew Morton
2011-12-22 23:20 ` Tejun Heo
2011-12-22 23:24 ` Andrew Morton
2011-12-22 23:38 ` Tejun Heo
2011-12-22 23:44 ` Andrew Morton
2011-12-22 23:46 ` Tejun Heo
2011-12-23 0:42 ` Tejun Heo
2011-12-24 5:13 ` Hugh Dickins
2011-12-25 1:02 ` [PATCH block/for-3.3/core] block: an exiting task should be allowed to create io_context Tejun Heo
2011-12-25 13:29 ` Jens Axboe
2011-12-27 22:07 ` Andrew Morton
2011-12-28 8:33 ` Hugh Dickins
2011-12-28 16:48 ` Tejun Heo
2011-12-28 17:50 ` Hugh Dickins
2011-12-28 17:55 ` Tejun Heo
2011-12-28 21:19 ` Tejun Heo
2012-01-03 17:35 ` Tejun Heo
2012-01-03 17:59 ` Tejun Heo
2012-01-03 20:09 ` Tejun Heo
2012-01-03 20:20 ` Jens Axboe
2012-01-03 22:13 ` Tejun Heo
2012-01-03 22:35 ` Tejun Heo
2012-01-05 1:24 ` Tejun Heo
2012-01-05 18:36 ` Hugh Dickins
2012-01-05 18:38 ` Tejun Heo
2012-01-06 2:17 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Tejun Heo
2012-01-06 2:36 ` Tejun Heo
2012-01-06 3:14 ` Shaohua Li
2012-01-06 3:04 ` Tejun Heo
2012-01-06 3:30 ` Tejun Heo
2012-01-06 3:52 ` [PATCH block:for-3.3/core] block: disable ELEVATOR_INSERT_SORT_MERGE Tejun Heo
2012-01-06 4:19 ` Shaohua Li
2012-01-06 4:38 ` Tejun Heo
2012-01-06 8:15 ` Shaohua Li
2012-01-06 15:34 ` Tejun Heo
2012-01-06 3:34 ` [PATCH block:for-3.3/core] cfq: merged request shouldn't jump to a different cfqq Shaohua Li
2012-01-06 3:22 ` Tejun Heo
2012-01-06 4:15 ` Shaohua Li
2012-01-06 4:40 ` Tejun Heo
2012-01-06 2:47 ` Shaohua Li
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).