Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751725AbdFIK0A (ORCPT ); Fri, 9 Jun 2017 06:26:00 -0400 Received: from mout.kundenserver.de ([212.227.126.134]:53239 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751563AbdFIKZ7 (ORCPT ); Fri, 9 Jun 2017 06:25:59 -0400 From: Arnd Bergmann To: Andrew Morton Cc: Arnd Bergmann , Naoya Horiguchi , "Aneesh Kumar K.V" , Punit Agrawal , Anshuman Khandual , linux-kernel@vger.kernel.org Subject: [PATCH] mm: hugetlb: replace some macros with inline functions Date: Fri, 9 Jun 2017 12:25:05 +0200 Message-Id: <20170609102544.2947326-1-arnd@arndb.de> X-Mailer: git-send-email 2.9.0 X-Provags-ID: V03:K0:QOTkz2f8hFZKf4gYGmQ6ABFeKGfqKWmxHNny9nAg0Mvj+IHOrWM lELHP7FfDfgVIEvn/OLQIoL6gbGEtAs8bhJjibrmH/LZ1O04I2bclRuOZqJDbRNaA59U2qI GUhonU/DHa2Jpi7pM1uFfcT2Vy+ZYliRyW1GYTxK+pnODcD5YFMr7RYZICFAmc/t4y9wh+8 BSZUiB91+3OAkmb0Rq6/g== X-UI-Out-Filterresults: notjunk:1;V01:K0:amC/Tej7YmQ=:ttsYJtTahU6DoH+td72ePc B0xWaHEE1vRH3V6YtmFSZtgLwh6fTfoItnpVlBM9u8mSasj5Aymm/6RINm6pqDVhUFpVfLBC/ eEuXoYKpSeX3mjMh/jiWV2+VdgXm11tAxM/ZZy+BQYZ7YWU8nNXQRxEK6lVJY1KTB86lMRQpa HzCra4M2m1da+18r15Ii0m2avy0CvYKrXS/otBEtEWTtc88CpGjbBs4cdVEKUxFWUeEaM9XdO LX2SjOVGI3dHgQ3Ud5SEt+Ld1sE81Kw74BVJf/SjCLH59Zhg51Tr2NGJiDnc1oMXWBjvXOsUe T9/UCYUgrjgBF+U6yLp8DA5jxylCxbI8FPmaO9wxXt6c6ttRN3+cxCRLrisY/ecU2uoJzULDJ dJTjzo3UL9htDWIRRV+EzvPssY8uA040zEsvP/04qKUIZ17Q3pI8yqBG6u/623ua/XqkKQZJW d0TMTz73ELYy1B5gVUxryQlhqlI5QcM+PI1qxzkExTEuSIFmF4608f4dmHXIxLexRjXQsWNM2 Cyo+s6C+IiBC7659prTA1KP3vpPWEbdGVIAt6Zwtwbo8IkrS3fBEr59Qw3piwwnxFwlkzP763 8PYY2ajK3MscwS1k1iyaz6jzN3YjhjLwkjN/9Z2N4MwzlTtVdbwhy6TeZGdRY+fcF7FB5JPWJ eC1upg5AVmiQiPv5qnXOm8i6gL+KFM5OgZQyNWEa6hrpa0OSY8X23HkiKeHVTUcKJQf0= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1800 Lines: 65 All users of dissolve_free_huge_page() that ignore the result cause a warning when CONFIG_HUGETLB_PAGE is disabled: mm/memory-failure.c: In function 'me_huge_page': include/linux/hugetlb.h:556:36: error: statement with no effect [-Werror=unused-value] #define dissolve_free_huge_page(p) 0 We can avoid this by using an inline function instead of the macro, and I decided to do the same change for the related helpers as well. Fixes: mmotm ("mm: hugetlb: soft-offline: dissolve source hugepage after successful migration") Signed-off-by: Arnd Bergmann --- include/linux/hugetlb.h | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/include/linux/hugetlb.h b/include/linux/hugetlb.h index dbb118c566cd..57f700ac127e 100644 --- a/include/linux/hugetlb.h +++ b/include/linux/hugetlb.h @@ -546,16 +546,37 @@ static inline unsigned int pages_per_huge_page(struct hstate *h) { return 1; } -#define hstate_index_to_shift(index) 0 -#define hstate_index(h) 0 + +static inline unsigned hstate_index_to_shift(unsigned index) +{ + return 0; +} + +static inline int hstate_index(struct hstate *h) +{ + return 0; +} static inline pgoff_t basepage_index(struct page *page) { return page->index; } -#define dissolve_free_huge_page(p) 0 -#define dissolve_free_huge_pages(s, e) 0 -#define hugepage_migration_supported(h) false + +static inline int dissolve_free_huge_page(struct page *page) +{ + return 0; +} + +static inline int dissolve_free_huge_pages(unsigned long start_pfn, + unsigned long end_pfn) +{ + return 0; +} + +static inline bool hugepage_migration_supported(struct hstate *h) +{ + return false; +} static inline spinlock_t *huge_pte_lockptr(struct hstate *h, struct mm_struct *mm, pte_t *pte) -- 2.9.0