1*92b3de3fSJonathan Corbet.. include:: ../../disclaimer-zh_CN.rst 2*92b3de3fSJonathan Corbet 3*92b3de3fSJonathan Corbet:Original: Documentation/arch/parisc/registers.rst 4*92b3de3fSJonathan Corbet 5*92b3de3fSJonathan Corbet:翻译: 6*92b3de3fSJonathan Corbet 7*92b3de3fSJonathan Corbet 司延腾 Yanteng Si <siyanteng@loongson.cn> 8*92b3de3fSJonathan Corbet 9*92b3de3fSJonathan Corbet.. _cn_parisc_registers: 10*92b3de3fSJonathan Corbet 11*92b3de3fSJonathan Corbet========================= 12*92b3de3fSJonathan CorbetLinux/PA-RISC的寄存器用法 13*92b3de3fSJonathan Corbet========================= 14*92b3de3fSJonathan Corbet 15*92b3de3fSJonathan Corbet[ 用星号表示目前尚未实现的计划用途。 ] 16*92b3de3fSJonathan Corbet 17*92b3de3fSJonathan CorbetABI约定的通用寄存器 18*92b3de3fSJonathan Corbet=================== 19*92b3de3fSJonathan Corbet 20*92b3de3fSJonathan Corbet控制寄存器 21*92b3de3fSJonathan Corbet---------- 22*92b3de3fSJonathan Corbet 23*92b3de3fSJonathan Corbet============================ ================================= 24*92b3de3fSJonathan CorbetCR 0 (恢复计数器) 用于ptrace 25*92b3de3fSJonathan CorbetCR 1-CR 7(无定义) 未使用 26*92b3de3fSJonathan CorbetCR 8 (Protection ID) 每进程值* 27*92b3de3fSJonathan CorbetCR 9, 12, 13 (PIDS) 未使用 28*92b3de3fSJonathan CorbetCR10 (CCR) FPU延迟保存* 29*92b3de3fSJonathan CorbetCR11 按照ABI的规定(SAR) 30*92b3de3fSJonathan CorbetCR14 (中断向量) 初始化为 fault_vector 31*92b3de3fSJonathan CorbetCR15 (EIEM) 所有位初始化为1* 32*92b3de3fSJonathan CorbetCR16 (间隔计时器) 读取周期数/写入开始时间间隔计时器 33*92b3de3fSJonathan CorbetCR17-CR22 中断参数 34*92b3de3fSJonathan CorbetCR19 中断指令寄存器 35*92b3de3fSJonathan CorbetCR20 中断空间寄存器 36*92b3de3fSJonathan CorbetCR21 中断偏移量寄存器 37*92b3de3fSJonathan CorbetCR22 中断 PSW 38*92b3de3fSJonathan CorbetCR23 (EIRR) 读取未决中断/写入清除位 39*92b3de3fSJonathan CorbetCR24 (TR 0) 内核空间页目录指针 40*92b3de3fSJonathan CorbetCR25 (TR 1) 用户空间页目录指针 41*92b3de3fSJonathan CorbetCR26 (TR 2) 不使用 42*92b3de3fSJonathan CorbetCR27 (TR 3) 线程描述符指针 43*92b3de3fSJonathan CorbetCR28 (TR 4) 不使用 44*92b3de3fSJonathan CorbetCR29 (TR 5) 不使用 45*92b3de3fSJonathan CorbetCR30 (TR 6) 当前 / 0 46*92b3de3fSJonathan CorbetCR31 (TR 7) 临时寄存器,在不同地方使用 47*92b3de3fSJonathan Corbet============================ ================================= 48*92b3de3fSJonathan Corbet 49*92b3de3fSJonathan Corbet空间寄存器(内核模式) 50*92b3de3fSJonathan Corbet---------------------- 51*92b3de3fSJonathan Corbet 52*92b3de3fSJonathan Corbet======== ============================== 53*92b3de3fSJonathan CorbetSR0 临时空间寄存器 54*92b3de3fSJonathan CorbetSR4-SR7 设置为0 55*92b3de3fSJonathan CorbetSR1 临时空间寄存器 56*92b3de3fSJonathan CorbetSR2 内核不应该破坏它 57*92b3de3fSJonathan CorbetSR3 用于用户空间访问(当前进程) 58*92b3de3fSJonathan Corbet======== ============================== 59*92b3de3fSJonathan Corbet 60*92b3de3fSJonathan Corbet空间寄存器(用户模式) 61*92b3de3fSJonathan Corbet---------------------- 62*92b3de3fSJonathan Corbet 63*92b3de3fSJonathan Corbet======== ============================ 64*92b3de3fSJonathan CorbetSR0 临时空间寄存器 65*92b3de3fSJonathan CorbetSR1 临时空间寄存器 66*92b3de3fSJonathan CorbetSR2 保存Linux gateway page的空间 67*92b3de3fSJonathan CorbetSR3 在内核中保存用户地址空间的值 68*92b3de3fSJonathan CorbetSR4-SR7 定义了用户/内核的短地址空间 69*92b3de3fSJonathan Corbet======== ============================ 70*92b3de3fSJonathan Corbet 71*92b3de3fSJonathan Corbet 72*92b3de3fSJonathan Corbet处理器状态字 73*92b3de3fSJonathan Corbet------------ 74*92b3de3fSJonathan Corbet 75*92b3de3fSJonathan Corbet====================== ================================================ 76*92b3de3fSJonathan CorbetW (64位地址) 0 77*92b3de3fSJonathan CorbetE (小尾端) 0 78*92b3de3fSJonathan CorbetS (安全间隔计时器) 0 79*92b3de3fSJonathan CorbetT (产生分支陷阱) 0 80*92b3de3fSJonathan CorbetH (高特权级陷阱) 0 81*92b3de3fSJonathan CorbetL (低特权级陷阱) 0 82*92b3de3fSJonathan CorbetN (撤销下一条指令) 被C代码使用 83*92b3de3fSJonathan CorbetX (数据存储中断禁用) 0 84*92b3de3fSJonathan CorbetB (产生分支) 被C代码使用 85*92b3de3fSJonathan CorbetC (代码地址转译) 1, 在执行实模式代码时为0 86*92b3de3fSJonathan CorbetV (除法步长校正) 被C代码使用 87*92b3de3fSJonathan CorbetM (HPMC 掩码) 0, 在执行HPMC操作*时为1 88*92b3de3fSJonathan CorbetC/B (进/借 位) 被C代码使用 89*92b3de3fSJonathan CorbetO (有序引用) 1* 90*92b3de3fSJonathan CorbetF (性能监视器) 0 91*92b3de3fSJonathan CorbetR (回收计数器陷阱) 0 92*92b3de3fSJonathan CorbetQ (收集中断状态) 1 (在rfi之前的代码中为0) 93*92b3de3fSJonathan CorbetP (保护标识符) 1* 94*92b3de3fSJonathan CorbetD (数据地址转译) 1, 在执行实模式代码时为0 95*92b3de3fSJonathan CorbetI (外部中断掩码) 由cli()/sti()宏使用。 96*92b3de3fSJonathan Corbet====================== ================================================ 97*92b3de3fSJonathan Corbet 98*92b3de3fSJonathan Corbet“隐形”寄存器(影子寄存器) 99*92b3de3fSJonathan Corbet--------------------------- 100*92b3de3fSJonathan Corbet 101*92b3de3fSJonathan Corbet============= =================== 102*92b3de3fSJonathan CorbetPSW W 默认值 0 103*92b3de3fSJonathan CorbetPSW E 默认值 0 104*92b3de3fSJonathan Corbet影子寄存器 被中断处理代码使用 105*92b3de3fSJonathan CorbetTOC启用位 1 106*92b3de3fSJonathan Corbet============= =================== 107*92b3de3fSJonathan Corbet 108*92b3de3fSJonathan Corbet---------------------------------------------------------- 109*92b3de3fSJonathan Corbet 110*92b3de3fSJonathan CorbetPA-RISC架构定义了7个寄存器作为“影子寄存器”。这些寄存器在 111*92b3de3fSJonathan CorbetRETURN FROM INTERRUPTION AND RESTORE指令中使用,通过消 112*92b3de3fSJonathan Corbet除中断处理程序中对一般寄存器(GR)的保存和恢复的需要来减 113*92b3de3fSJonathan Corbet少状态保存和恢复时间。影子寄存器是GRs 1, 8, 9, 16, 17, 114*92b3de3fSJonathan Corbet24和25。 115*92b3de3fSJonathan Corbet 116*92b3de3fSJonathan Corbet------------------------------------------------------------------------- 117*92b3de3fSJonathan Corbet 118*92b3de3fSJonathan Corbet寄存器使用说明,最初由John Marvin提供,并由Randolph Chung提供一些补充说明。 119*92b3de3fSJonathan Corbet 120*92b3de3fSJonathan Corbet对于通用寄存器: 121*92b3de3fSJonathan Corbet 122*92b3de3fSJonathan Corbetr1,r2,r19-r26,r28,r29 & r31可以在不保存它们的情况下被使用。当然,如果你 123*92b3de3fSJonathan Corbet关心它们,在调用另一个程序之前,你也需要保存它们。上面的一些寄存器确实 124*92b3de3fSJonathan Corbet有特殊的含义,你应该注意一下: 125*92b3de3fSJonathan Corbet 126*92b3de3fSJonathan Corbet r1: 127*92b3de3fSJonathan Corbet addil指令是硬性规定将其结果放在r1中,所以如果你使用这条指令要 128*92b3de3fSJonathan Corbet 注意这点。 129*92b3de3fSJonathan Corbet 130*92b3de3fSJonathan Corbet r2: 131*92b3de3fSJonathan Corbet 这就是返回指针。一般来说,你不想使用它,因为你需要这个指针来返 132*92b3de3fSJonathan Corbet 回给你的调用者。然而,它与这组寄存器组合在一起,因为调用者不能 133*92b3de3fSJonathan Corbet 依赖你返回时的值是相同的,也就是说,你可以将r2复制到另一个寄存 134*92b3de3fSJonathan Corbet 器,并在作废r2后通过该寄存器返回,这应该不会给调用程序带来问题。 135*92b3de3fSJonathan Corbet 136*92b3de3fSJonathan Corbet r19-r22: 137*92b3de3fSJonathan Corbet 这些通常被认为是临时寄存器。 138*92b3de3fSJonathan Corbet 请注意,在64位中它们是arg7-arg4。 139*92b3de3fSJonathan Corbet 140*92b3de3fSJonathan Corbet r23-r26: 141*92b3de3fSJonathan Corbet 这些是arg3-arg0,也就是说,如果你不再关心传入的值,你可以使用 142*92b3de3fSJonathan Corbet 它们。 143*92b3de3fSJonathan Corbet 144*92b3de3fSJonathan Corbet r28,r29: 145*92b3de3fSJonathan Corbet 这俩是ret0和ret1。它们是你传入返回值的地方。r28是主返回值。当返回 146*92b3de3fSJonathan Corbet 小结构体时,r29也可以用来将数据传回给调用程序。 147*92b3de3fSJonathan Corbet 148*92b3de3fSJonathan Corbet r30: 149*92b3de3fSJonathan Corbet 栈指针 150*92b3de3fSJonathan Corbet 151*92b3de3fSJonathan Corbet r31: 152*92b3de3fSJonathan Corbet ble指令将返回指针放在这里。 153*92b3de3fSJonathan Corbet 154*92b3de3fSJonathan Corbet 155*92b3de3fSJonathan Corbet r3-r18,r27,r30需要被保存和恢复。r3-r18只是一般用途的寄存器。 156*92b3de3fSJonathan Corbet r27是数据指针,用来使对全局变量的引用更容易。r30是栈指针。 157