diff options
author | Vijay Kumar <vijay.ac.kumar@oracle.com> | 2017-10-11 14:50:06 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-11-15 00:26:46 -0500 |
commit | 46ad8d2d22c17e2b577adec55ae87161666a3267 (patch) | |
tree | dac0c0d3b741e169a4269c59ee1ef152c8ba9583 /arch/sparc/lib | |
parent | 2b41ce5df20b698436526fcd8478094140b91706 (diff) |
sparc64: Use sparc optimized fls and __fls for T4 and above
For T4 and above, patch fls and __fls functions
at the boot time to use lzcnt instruction.
Signed-off-by: Vijay Kumar <vijay.ac.kumar@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/lib')
-rw-r--r-- | arch/sparc/lib/NG4patch.S | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/arch/sparc/lib/NG4patch.S b/arch/sparc/lib/NG4patch.S index 3cc0f8cc95df..da65a3ebb7cc 100644 --- a/arch/sparc/lib/NG4patch.S +++ b/arch/sparc/lib/NG4patch.S | |||
@@ -3,6 +3,8 @@ | |||
3 | * Copyright (C) 2012 David S. Miller <davem@davemloft.net> | 3 | * Copyright (C) 2012 David S. Miller <davem@davemloft.net> |
4 | */ | 4 | */ |
5 | 5 | ||
6 | #include <linux/linkage.h> | ||
7 | |||
6 | #define BRANCH_ALWAYS 0x10680000 | 8 | #define BRANCH_ALWAYS 0x10680000 |
7 | #define NOP 0x01000000 | 9 | #define NOP 0x01000000 |
8 | #define NG_DO_PATCH(OLD, NEW) \ | 10 | #define NG_DO_PATCH(OLD, NEW) \ |
@@ -52,3 +54,10 @@ niagara4_patch_pageops: | |||
52 | retl | 54 | retl |
53 | nop | 55 | nop |
54 | .size niagara4_patch_pageops,.-niagara4_patch_pageops | 56 | .size niagara4_patch_pageops,.-niagara4_patch_pageops |
57 | |||
58 | ENTRY(niagara4_patch_fls) | ||
59 | NG_DO_PATCH(fls, NG4fls) | ||
60 | NG_DO_PATCH(__fls, __NG4fls) | ||
61 | retl | ||
62 | nop | ||
63 | ENDPROC(niagara4_patch_fls) | ||