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

TOMOYO Linux Cross Reference
Linux/arch/powerpc/kernel/idle_64e.S

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ 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-or-later */
  2 /*
  3  * Copyright 2010 IBM Corp, Benjamin Herrenschmidt <benh@kernel.crashing.org>
  4  *
  5  * Generic idle routine for 64 bits e500 processors
  6  */
  7 
  8 #include <linux/threads.h>
  9 #include <asm/reg.h>
 10 #include <asm/ppc_asm.h>
 11 #include <asm/asm-offsets.h>
 12 #include <asm/ppc-opcode.h>
 13 #include <asm/processor.h>
 14 #include <asm/thread_info.h>
 15 #include <asm/epapr_hcalls.h>
 16 #include <asm/hw_irq.h>
 17 
 18 /* 64-bit version only for now */
 19 .macro BOOK3E_IDLE name loop
 20 _GLOBAL(\name)
 21         /* Save LR for later */
 22         mflr    r0
 23         std     r0,16(r1)
 24 
 25         /* Hard disable interrupts */
 26         wrteei  0
 27 
 28         /* Now check if an interrupt came in while we were soft disabled
 29          * since we may otherwise lose it (doorbells etc...).
 30          */
 31         lbz     r3,PACAIRQHAPPENED(r13)
 32         cmpwi   cr0,r3,0
 33         bne     2f
 34 
 35         /* Now we are going to mark ourselves as soft and hard enabled in
 36          * order to be able to take interrupts while asleep. We inform lockdep
 37          * of that. We don't actually turn interrupts on just yet tho.
 38          */
 39 #ifdef CONFIG_TRACE_IRQFLAGS
 40         stdu    r1,-128(r1)
 41         bl      trace_hardirqs_on
 42         addi    r1,r1,128
 43 #endif
 44         li      r0,IRQS_ENABLED
 45         stb     r0,PACAIRQSOFTMASK(r13)
 46         
 47         /* Interrupts will make use return to LR, so get something we want
 48          * in there
 49          */
 50         bl      1f
 51 
 52         /* And return (interrupts are on) */
 53         ld      r0,16(r1)
 54         mtlr    r0
 55         blr
 56 
 57 1:      /* Let's set the _TLF_NAPPING flag so interrupts make us return
 58          * to the right spot
 59         */
 60         ld      r11, PACACURRENT(r13)
 61         ld      r10,TI_LOCAL_FLAGS(r11)
 62         ori     r10,r10,_TLF_NAPPING
 63         std     r10,TI_LOCAL_FLAGS(r11)
 64 
 65         /* We can now re-enable hard interrupts and go to sleep */
 66         wrteei  1
 67         \loop
 68 
 69 2:
 70         lbz     r10,PACAIRQHAPPENED(r13)
 71         ori     r10,r10,PACA_IRQ_HARD_DIS
 72         stb     r10,PACAIRQHAPPENED(r13)
 73         blr
 74 .endm
 75 
 76 .macro BOOK3E_IDLE_LOOP
 77 1:
 78         PPC_WAIT_v203
 79         b       1b
 80 .endm
 81 
 82 /* epapr_ev_idle_start below is patched with the proper hcall
 83    opcodes during kernel initialization */
 84 .macro EPAPR_EV_IDLE_LOOP
 85 idle_loop:
 86         LOAD_REG_IMMEDIATE(r11, EV_HCALL_TOKEN(EV_IDLE))
 87 
 88 .global epapr_ev_idle_start
 89 epapr_ev_idle_start:
 90         li      r3, -1
 91         nop
 92         nop
 93         nop
 94         b       idle_loop
 95 .endm
 96 
 97 BOOK3E_IDLE epapr_ev_idle EPAPR_EV_IDLE_LOOP
 98 
 99 BOOK3E_IDLE e500_idle BOOK3E_IDLE_LOOP

~ [ 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