aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc/lib
diff options
context:
space:
mode:
authorVijay Kumar <vijay.ac.kumar@oracle.com>2017-10-11 14:50:06 -0400
committerDavid S. Miller <davem@davemloft.net>2017-11-15 00:26:46 -0500
commit46ad8d2d22c17e2b577adec55ae87161666a3267 (patch)
treedac0c0d3b741e169a4269c59ee1ef152c8ba9583 /arch/sparc/lib
parent2b41ce5df20b698436526fcd8478094140b91706 (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.S9
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
58ENTRY(niagara4_patch_fls)
59 NG_DO_PATCH(fls, NG4fls)
60 NG_DO_PATCH(__fls, __NG4fls)
61 retl
62 nop
63ENDPROC(niagara4_patch_fls)