This patch set is trying to simplify the select_task_rq_fair() with
schedule balance map.

After get rid of the complex code and reorganize the logical, pgbench show
the improvement.

        Prev:
                | db_size | clients |  tps  |
                +---------+---------+-------+
                | 22 MB   |       1 |  4437 |
                | 22 MB   |      16 | 51351 |
                | 22 MB   |      32 | 49959 |
                | 7484 MB |       1 |  4078 |
                | 7484 MB |      16 | 44681 |
                | 7484 MB |      32 | 42463 |
                | 15 GB   |       1 |  3992 |
                | 15 GB   |      16 | 44107 |
                | 15 GB   |      32 | 41797 |

        Post:
                | db_size | clients |  tps  |
                +---------+---------+-------+
                | 22 MB   |       1 | 11053 |           +149.11%
                | 22 MB   |      16 | 55671 |           +8.41%
                | 22 MB   |      32 | 52596 |           +5.28%
                | 7483 MB |       1 |  8180 |           +100.59%
                | 7483 MB |      16 | 48392 |           +8.31%
                | 7483 MB |      32 | 44185 |           +0.18%
                | 15 GB   |       1 |  8127 |           +103.58%
                | 15 GB   |      16 | 48156 |           +9.18%
                | 15 GB   |      32 | 43387 |           +3.8%

Please check the patch for more details about schedule balance map, they
currently based on linux-next 3.7.0-rc6, will rebase them to tip tree in
follow version.

Comments are very welcomed.

Test with:
        12 cpu X86 server and linux-next 3.7.0-rc6.

Michael Wang (2):
        [PATCH 1/2] sched: schedule balance map foundation
        [PATCH 2/2] sched: simplify select_task_rq_fair() with schedule balance 
map

Signed-off-by: Michael Wang <wang...@linux.vnet.ibm.com>
---
 core.c  |   61 +++++++++++++++++++++++++++++
 fair.c  |  133 +++++++++++++++++++++++++++++++++-------------------------------
 sched.h |   28 +++++++++++++
 3 files changed, 159 insertions(+), 63 deletions(-)

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to