forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
mm/gup: Remove the macro overload API migration helpers from the get_…
…user*() APIs The pkeys changes brought about a truly hideous set of macros in: cde7014 ("mm/gup: Overload get_user_pages() functions") ... which macros are (ab-)using the fact that __VA_ARGS__ can be used to shift parameter positions in macro arguments without breaking the build and so can be used to call separate C functions depending on the number of arguments of the macro. This allowed easy migration of these 3 GUP APIs, as both these variants worked at the C level: old: ret = get_user_pages(current, current->mm, address, 1, 1, 0, &page, NULL); new: ret = get_user_pages(address, 1, 1, 0, &page, NULL); ... while we also generated a (functionally harmless but noticeable) build time warning if the old API was used. As there are over 300 uses of these APIs, this trick eased the migration of the API and avoided excessive migration pain in linux-next. Now, with its work done, get rid of all of that complication and ugliness: 3 files changed, 16 insertions(+), 140 deletions(-) ... where the linecount of the migration hack was further inflated by the fact that there are NOMMU variants of these GUP APIs as well. Much of the conversion was done in linux-next over the past couple of months, and Linus recently removed all remaining old API uses from the upstream tree in the following upstrea commit: cb10716 ("Convert straggling drivers to new six-argument get_user_pages()") There was one more old-API usage in mm/gup.c, in the CONFIG_HAVE_GENERIC_RCU_GUP code path that ARM, ARM64 and PowerPC uses. After this commit any old API usage will break the build. [ Also fixed a PowerPC/HAVE_GENERIC_RCU_GUP warning reported by Stephen Rothwell. ] Cc: Andrew Morton <[email protected]> Cc: Dave Hansen <[email protected]> Cc: Dave Hansen <[email protected]> Cc: Linus Torvalds <[email protected]> Cc: Peter Zijlstra <[email protected]> Cc: Stephen Rothwell <[email protected]> Cc: Thomas Gleixner <[email protected]> Cc: [email protected] Cc: [email protected] Signed-off-by: Ingo Molnar <[email protected]>
- Loading branch information
Ingo Molnar
committed
Apr 7, 2016
1 parent
9735a22
commit c12d2da
Showing
3 changed files
with
17 additions
and
143 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1250,78 +1250,20 @@ long get_user_pages_remote(struct task_struct *tsk, struct mm_struct *mm, | |
unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, | ||
struct vm_area_struct **vmas); | ||
long get_user_pages6(unsigned long start, unsigned long nr_pages, | ||
long get_user_pages(unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, | ||
struct vm_area_struct **vmas); | ||
long get_user_pages_locked6(unsigned long start, unsigned long nr_pages, | ||
long get_user_pages_locked(unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, int *locked); | ||
long __get_user_pages_unlocked(struct task_struct *tsk, struct mm_struct *mm, | ||
unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, | ||
unsigned int gup_flags); | ||
long get_user_pages_unlocked5(unsigned long start, unsigned long nr_pages, | ||
long get_user_pages_unlocked(unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages); | ||
int get_user_pages_fast(unsigned long start, int nr_pages, int write, | ||
struct page **pages); | ||
|
||
/* suppress warnings from use in EXPORT_SYMBOL() */ | ||
#ifndef __DISABLE_GUP_DEPRECATED | ||
#define __gup_deprecated __deprecated | ||
#else | ||
#define __gup_deprecated | ||
#endif | ||
/* | ||
* These macros provide backward-compatibility with the old | ||
* get_user_pages() variants which took tsk/mm. These | ||
* functions/macros provide both compile-time __deprecated so we | ||
* can catch old-style use and not break the build. The actual | ||
* functions also have WARN_ON()s to let us know at runtime if | ||
* the get_user_pages() should have been the "remote" variant. | ||
* | ||
* These are hideous, but temporary. | ||
* | ||
* If you run into one of these __deprecated warnings, look | ||
* at how you are calling get_user_pages(). If you are calling | ||
* it with current/current->mm as the first two arguments, | ||
* simply remove those arguments. The behavior will be the same | ||
* as it is now. If you are calling it on another task, use | ||
* get_user_pages_remote() instead. | ||
* | ||
* Any questions? Ask Dave Hansen <[email protected]> | ||
*/ | ||
long | ||
__gup_deprecated | ||
get_user_pages8(struct task_struct *tsk, struct mm_struct *mm, | ||
unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, | ||
struct vm_area_struct **vmas); | ||
#define GUP_MACRO(_1, _2, _3, _4, _5, _6, _7, _8, get_user_pages, ...) \ | ||
get_user_pages | ||
#define get_user_pages(...) GUP_MACRO(__VA_ARGS__, \ | ||
get_user_pages8, x, \ | ||
get_user_pages6, x, x, x, x, x)(__VA_ARGS__) | ||
|
||
__gup_deprecated | ||
long get_user_pages_locked8(struct task_struct *tsk, struct mm_struct *mm, | ||
unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages, | ||
int *locked); | ||
#define GUPL_MACRO(_1, _2, _3, _4, _5, _6, _7, _8, get_user_pages_locked, ...) \ | ||
get_user_pages_locked | ||
#define get_user_pages_locked(...) GUPL_MACRO(__VA_ARGS__, \ | ||
get_user_pages_locked8, x, \ | ||
get_user_pages_locked6, x, x, x, x)(__VA_ARGS__) | ||
|
||
__gup_deprecated | ||
long get_user_pages_unlocked7(struct task_struct *tsk, struct mm_struct *mm, | ||
unsigned long start, unsigned long nr_pages, | ||
int write, int force, struct page **pages); | ||
#define GUPU_MACRO(_1, _2, _3, _4, _5, _6, _7, get_user_pages_unlocked, ...) \ | ||
get_user_pages_unlocked | ||
#define get_user_pages_unlocked(...) GUPU_MACRO(__VA_ARGS__, \ | ||
get_user_pages_unlocked7, x, \ | ||
get_user_pages_unlocked5, x, x, x, x)(__VA_ARGS__) | ||
|
||
/* Container for pinned pfns / pages */ | ||
struct frame_vector { | ||
unsigned int nr_allocated; /* Number of frames we have space for */ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters