~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/powerpc/xmon/spr_access.S

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #include <asm/ppc_asm.h>
  3 #include <asm/asm-compat.h>
  4 
  5 /* unsigned long xmon_mfspr(sprn, default_value) */
  6 _GLOBAL(xmon_mfspr)
  7         LOAD_REG_ADDR(r5, .Lmfspr_table)
  8         b       xmon_mxspr
  9 
 10 /* void xmon_mtspr(sprn, new_value) */
 11 _GLOBAL(xmon_mtspr)
 12         LOAD_REG_ADDR(r5, .Lmtspr_table)
 13         b       xmon_mxspr
 14 
 15 /*
 16  * r3 = sprn
 17  * r4 = default or new value
 18  * r5 = table base
 19  */
 20 xmon_mxspr:
 21         /*
 22          * To index into the table of mxsprs we need:
 23          *  i = (sprn & 0x3ff) * 8
 24          * or using rwlinm:
 25          *  i = (sprn << 3) & (0x3ff << 3)
 26          */
 27         rlwinm  r3, r3, 3, 0x3ff << 3
 28         add     r5, r5, r3
 29         mtctr   r5
 30         mr      r3, r4 /* put default_value in r3 for mfspr */
 31         bctr
 32 
 33 .Lmfspr_table:
 34         spr = 0
 35         .rept   1024
 36         mfspr   r3, spr
 37         blr
 38         spr = spr + 1
 39         .endr
 40 
 41 .Lmtspr_table:
 42         spr = 0
 43         .rept   1024
 44         mtspr   spr, r4
 45         blr
 46         spr = spr + 1
 47         .endr

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php