The patch titled Subject: mm-swap-add-cluster-lock-v5 has been added to the -mm tree. Its filename is mm-swap-add-cluster-lock-v5.patch This patch should soon appear at http://ozlabs.org/~akpm/mmots/broken-out/mm-swap-add-cluster-lock-v5.patch and later at http://ozlabs.org/~akpm/mmotm/broken-out/mm-swap-add-cluster-lock-v5.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** The -mm tree is included into linux-next and is updated there every 3-4 working days ------------------------------------------------------ From: "Huang\, Ying" <ying.huang@xxxxxxxxx> Subject: mm-swap-add-cluster-lock-v5 Link: http://lkml.kernel.org/r/878tqeuuic.fsf_-_@xxxxxxxxxxxxxxxxxxxx Signed-off-by: "Huang, Ying" <ying.huang@xxxxxxxxx> Cc: Tim Chen <tim.c.chen@xxxxxxxxxxxxxxx> Cc: Aaron Lu <aaron.lu@xxxxxxxxx> Cc: Andi Kleen <ak@xxxxxxxxxxxxxxx> Cc: Andrea Arcangeli <aarcange@xxxxxxxxxx> Cc: Christian Borntraeger <borntraeger@xxxxxxxxxx> Cc: Dave Hansen <dave.hansen@xxxxxxxxx> Cc: Hillf Danton <hillf.zj@xxxxxxxxxxxxxxx> Cc: Huang Ying <ying.huang@xxxxxxxxx> Cc: Hugh Dickins <hughd@xxxxxxxxxx> Cc: Johannes Weiner <hannes@xxxxxxxxxxx> Cc: Jonathan Corbet <corbet@xxxxxxx> escreveu: Cc: Kirill A. Shutemov <kirill.shutemov@xxxxxxxxxxxxxxx> Cc: Michal Hocko <mhocko@xxxxxxxxxx> Cc: Minchan Kim <minchan@xxxxxxxxxx> Cc: Rik van Riel <riel@xxxxxxxxxx> Cc: Shaohua Li <shli@xxxxxxxxxx> Cc: Vladimir Davydov <vdavydov.dev@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- include/linux/swap.h | 19 ++++++++++--------- mm/swapfile.c | 32 ++++++++++++++++---------------- 2 files changed, 26 insertions(+), 25 deletions(-) diff -puN include/linux/swap.h~mm-swap-add-cluster-lock-v5 include/linux/swap.h --- a/include/linux/swap.h~mm-swap-add-cluster-lock-v5 +++ a/include/linux/swap.h @@ -176,16 +176,17 @@ enum { * protected by swap_info_struct.lock. */ struct swap_cluster_info { - unsigned long data; + spinlock_t lock; /* + * Protect swap_cluster_info fields + * and swap_info_struct->swap_map + * elements correspond to the swap + * cluster + */ + unsigned int data:24; + unsigned int flags:8; }; -#define CLUSTER_COUNT_SHIFT 8 -#define CLUSTER_FLAG_MASK ((1UL << CLUSTER_COUNT_SHIFT) - 1) -#define CLUSTER_COUNT_MASK (~CLUSTER_FLAG_MASK) -#define CLUSTER_FLAG_FREE 1 /* This cluster is free */ -#define CLUSTER_FLAG_NEXT_NULL 2 /* This cluster has no next cluster */ -/* cluster lock, protect cluster_info contents and sis->swap_map */ -#define CLUSTER_FLAG_LOCK_BIT 2 -#define CLUSTER_FLAG_LOCK (1 << CLUSTER_FLAG_LOCK_BIT) +#define CLUSTER_FLAG_FREE 1 /* This cluster is free */ +#define CLUSTER_FLAG_NEXT_NULL 2 /* This cluster has no next cluster */ /* * We assign a cluster to each CPU, so each CPU can allocate swap entry from diff -puN mm/swapfile.c~mm-swap-add-cluster-lock-v5 mm/swapfile.c --- a/mm/swapfile.c~mm-swap-add-cluster-lock-v5 +++ a/mm/swapfile.c @@ -200,66 +200,66 @@ static void discard_swap_cluster(struct #define LATENCY_LIMIT 256 static inline void cluster_set_flag(struct swap_cluster_info *info, - unsigned int flag) + unsigned int flag) { - info->data = (info->data & (CLUSTER_COUNT_MASK | CLUSTER_FLAG_LOCK)) | - (flag & ~CLUSTER_FLAG_LOCK); + info->flags = flag; } static inline unsigned int cluster_count(struct swap_cluster_info *info) { - return info->data >> CLUSTER_COUNT_SHIFT; + return info->data; } static inline void cluster_set_count(struct swap_cluster_info *info, unsigned int c) { - info->data = (c << CLUSTER_COUNT_SHIFT) | (info->data & CLUSTER_FLAG_MASK); + info->data = c; } static inline void cluster_set_count_flag(struct swap_cluster_info *info, unsigned int c, unsigned int f) { - info->data = (info->data & CLUSTER_FLAG_LOCK) | - (c << CLUSTER_COUNT_SHIFT) | (f & ~CLUSTER_FLAG_LOCK); + info->flags = f; + info->data = c; } static inline unsigned int cluster_next(struct swap_cluster_info *info) { - return cluster_count(info); + return info->data; } static inline void cluster_set_next(struct swap_cluster_info *info, unsigned int n) { - cluster_set_count(info, n); + info->data = n; } static inline void cluster_set_next_flag(struct swap_cluster_info *info, unsigned int n, unsigned int f) { - cluster_set_count_flag(info, n, f); + info->flags = f; + info->data = n; } static inline bool cluster_is_free(struct swap_cluster_info *info) { - return info->data & CLUSTER_FLAG_FREE; + return info->flags & CLUSTER_FLAG_FREE; } static inline bool cluster_is_null(struct swap_cluster_info *info) { - return info->data & CLUSTER_FLAG_NEXT_NULL; + return info->flags & CLUSTER_FLAG_NEXT_NULL; } static inline void cluster_set_null(struct swap_cluster_info *info) { - cluster_set_next_flag(info, 0, CLUSTER_FLAG_NEXT_NULL); + info->flags = CLUSTER_FLAG_NEXT_NULL; + info->data = 0; } -/* Protect swap_cluster_info fields and si->swap_map */ static inline void __lock_cluster(struct swap_cluster_info *ci) { - bit_spin_lock(CLUSTER_FLAG_LOCK_BIT, &ci->data); + spin_lock(&ci->lock); } static inline struct swap_cluster_info *lock_cluster(struct swap_info_struct *si, @@ -278,7 +278,7 @@ static inline struct swap_cluster_info * static inline void unlock_cluster(struct swap_cluster_info *ci) { if (ci) - bit_spin_unlock(CLUSTER_FLAG_LOCK_BIT, &ci->data); + spin_unlock(&ci->lock); } static inline struct swap_cluster_info *lock_cluster_or_swap_info( _ Patches currently in -mm which might be from ying.huang@xxxxxxxxx are mm-swap-fix-kernel-message-in-swap_info_get.patch mm-swap-add-cluster-lock.patch mm-swap-add-cluster-lock-v5.patch mm-swap-split-swap-cache-into-64mb-trunks.patch mm-swap-add-cache-for-swap-slots-allocation-fix.patch mm-swap-skip-readahead-only-when-swap-slot-cache-is-enabled.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html