Jiri Kosina
4a6cc4bd32
sched: move rq_weight data array out of .percpu
Commit 34d76c41 introduced percpu array update_shares_data, size of which
being proportional to NR_CPUS. Unfortunately this blows up ia64 for large
NR_CPUS configuration, as ia64 allows only 64k for .percpu section.
Fix this by allocating this array dynamically and keep only pointer to it
percpu.
The per-cpu handling doesn't impose significant performance penalty on
potentially contented path in tg_shares_up().
...
ffffffff8104337c: 65 48 8b 14 25 20 cd mov %gs:0xcd20,%rdx
ffffffff81043383: 00 00
ffffffff81043385: 48 c7 c0 00 e1 00 00 mov $0xe100,%rax
ffffffff8104338c: 48 c7 45 a0 00 00 00 movq $0x0,-0x60(%rbp)
ffffffff81043393: 00
ffffffff81043394: 48 c7 45 a8 00 00 00 movq $0x0,-0x58(%rbp)
ffffffff8104339b: 00
ffffffff8104339c: 48 01 d0 add %rdx,%rax
ffffffff8104339f: 49 8d 94 24 08 01 00 lea 0x108(%r12),%rdx
ffffffff810433a6: 00
ffffffff810433a7: b9 ff ff ff ff mov $0xffffffff,%ecx
ffffffff810433ac: 48 89 45 b0 mov %rax,-0x50(%rbp)
ffffffff810433b0: bb 00 04 00 00 mov $0x400,%ebx
ffffffff810433b5: 48 89 55 c0 mov %rdx,-0x40(%rbp)
...
After:
...
ffffffff8104337c: 65 8b 04 25 28 cd 00 mov %gs:0xcd28,%eax
ffffffff81043383: 00
ffffffff81043384: 48 98 cltq
ffffffff81043386: 49 8d bc 24 08 01 00 lea 0x108(%r12),%rdi
ffffffff8104338d: 00
ffffffff8104338e: 48 8b 15 d3 7f 76 00 mov 0x767fd3(%rip),%rdx # ffffffff817ab368 <update_shares_data>
ffffffff81043395: 48 8b 34 c5 00 ee 6d mov -0x7e921200(,%rax,8),%rsi
ffffffff8104339c: 81
ffffffff8104339d: 48 c7 45 a0 00 00 00 movq $0x0,-0x60(%rbp)
ffffffff810433a4: 00
ffffffff810433a5: b9 ff ff ff ff mov $0xffffffff,%ecx
ffffffff810433aa: 48 89 7d c0 mov %rdi,-0x40(%rbp)
ffffffff810433ae: 48 c7 45 a8 00 00 00 movq $0x0,-0x58(%rbp)
ffffffff810433b5: 00
ffffffff810433b6: bb 00 04 00 00 mov $0x400,%ebx
ffffffff810433bb: 48 01 f2 add %rsi,%rdx
ffffffff810433be: 48 89 55 b0 mov %rdx,-0x50(%rbp)
...
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Acked-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Tejun Heo <tj@kernel.org>
2009-10-29 00:26:00 +09:00
..
2009-09-21 14:29:21 +02:00
2009-09-11 13:21:31 -07:00
2009-09-23 18:13:10 -07:00
2009-09-26 10:14:41 -07:00
2009-09-26 10:13:54 -07:00
2009-08-24 11:33:40 +10:00
2009-09-24 03:50:25 -04:00
2009-09-24 03:50:26 -04:00
2009-09-24 03:50:26 -04:00
2009-09-24 07:20:58 -07:00
2009-09-24 07:20:58 -07:00
2009-09-15 09:19:38 -07:00
2009-09-24 07:20:58 -07:00
2009-09-23 11:02:26 -07:00
2009-09-18 09:48:52 -07:00
2009-09-24 07:21:05 -07:00
2009-09-24 07:21:05 -07:00
2009-08-10 15:41:12 +02:00
2009-09-24 22:30:10 +02:00
2009-09-27 10:39:04 -07:00
2009-09-24 07:21:04 -07:00
2009-08-29 14:10:07 +02:00
2009-09-23 07:39:30 -07:00
2009-07-29 19:10:34 -07:00
2009-09-19 13:13:17 -07:00
2009-09-23 18:12:10 -07:00
2009-09-23 07:39:29 -07:00
2009-09-09 17:30:06 +02:00
2009-07-24 10:53:29 +02:00
2009-09-23 07:39:29 -07:00
2009-09-23 07:39:30 -07:00
2009-09-24 07:20:57 -07:00
2009-09-26 10:13:54 -07:00
2009-09-24 07:20:58 -07:00
2009-09-21 15:14:53 +02:00
2009-09-25 00:32:58 +09:30
2009-09-27 11:39:25 -07:00
2009-09-24 07:21:04 -07:00
2009-09-22 07:17:38 -07:00
2009-08-29 14:10:07 +02:00
2009-08-21 21:43:46 +02:00
2009-09-23 07:39:28 -07:00
2009-09-20 20:15:40 +02:00
2009-09-24 07:20:59 -07:00
2009-09-19 08:53:22 +02:00
2009-09-19 08:53:22 +02:00
2009-09-19 08:53:22 +02:00
2009-09-19 08:53:22 +02:00
2009-09-19 08:53:22 +02:00
2009-09-19 08:53:22 +02:00
2009-09-27 11:39:25 -07:00
2009-09-24 07:20:59 -07:00
2009-09-23 07:39:41 -07:00
2009-08-06 05:50:21 +02:00
2009-09-18 20:47:30 +02:00
2009-08-02 14:26:09 +02:00
2009-09-17 10:17:25 +02:00
2009-09-24 07:21:04 -07:00
2009-09-17 10:17:25 +02:00
2009-09-21 09:53:55 +02:00
2009-09-21 09:53:55 +02:00
2009-10-29 00:26:00 +09:00
2009-09-24 07:21:01 -07:00
2009-09-24 07:21:04 -07:00
2009-09-24 09:34:47 +09:30
2009-09-17 15:53:44 -04:00
2009-09-24 07:21:04 -07:00
2009-08-31 18:08:50 +02:00
2009-09-24 15:13:11 -07:00
2009-09-24 07:53:22 -07:00
2009-09-24 07:53:22 -07:00
2009-09-15 10:17:30 +02:00
2009-09-23 09:46:15 -07:00
2009-09-21 15:14:55 +02:00
2009-09-23 18:13:10 -07:00
2009-09-24 07:21:04 -07:00
2009-08-10 14:43:09 +02:00
2009-09-11 13:23:18 -07:00