1 .. include:: ../../disclaimer-zh_CN.rst
3 :Original: Documentation/arch/parisc/registers.rst
7 司延腾 Yanteng Si <siyanteng@loongson.cn>
9 .. _cn_parisc_registers:
11 =========================
13 =========================
23 ============================ =================================
26 CR 8 (Protection ID) 每进程值*
27 CR 9, 12, 13 (PIDS) 未使用
30 CR14 (中断向量) 初始化为 fault_vector
32 CR16 (间隔计时器) 读取周期数/写入开始时间间隔计时器
38 CR23 (EIRR) 读取未决中断/写入清除位
46 CR31 (TR 7) 临时寄存器,在不同地方使用
47 ============================ =================================
50 ----------------------
52 ======== ==============================
58 ======== ==============================
61 ----------------------
63 ======== ============================
66 SR2 保存Linux gateway page的空间
68 SR4-SR7 定义了用户/内核的短地址空间
69 ======== ============================
75 ====================== ================================================
85 C (代码地址转译) 1, 在执行实模式代码时为0
87 M (HPMC 掩码) 0, 在执行HPMC操作*时为1
92 Q (收集中断状态) 1 (在rfi之前的代码中为0)
94 D (数据地址转译) 1, 在执行实模式代码时为0
95 I (外部中断掩码) 由cli()/sti()宏使用。
96 ====================== ================================================
99 ---------------------------
101 ============= ===================
106 ============= ===================
108 ----------------------------------------------------------
110 PA-RISC架构定义了7个寄存器作为“影子寄存器”。这些寄存器在
111 RETURN FROM INTERRUPTION AND RESTORE指令中使用,通过消
112 除中断处理程序中对一般寄存器(GR)的保存和恢复的需要来减
113 少状态保存和恢复时间。影子寄存器是GRs 1, 8, 9, 16, 17,
116 -------------------------------------------------------------------------
118 寄存器使用说明,最初由John Marvin提供,并由Randolph Chung提供一些补充说明。
122 r1,r2,r19-r26,r28,r29 & r31可以在不保存它们的情况下被使用。当然,如果你
123 关心它们,在调用另一个程序之前,你也需要保存它们。上面的一些寄存器确实
127 addil指令是硬性规定将其结果放在r1中,所以如果你使用这条指令要
131 这就是返回指针。一般来说,你不想使用它,因为你需要这个指针来返
132 回给你的调用者。然而,它与这组寄存器组合在一起,因为调用者不能
133 依赖你返回时的值是相同的,也就是说,你可以将r2复制到另一个寄存
134 器,并在作废r2后通过该寄存器返回,这应该不会给调用程序带来问题。
138 请注意,在64位中它们是arg7-arg4。
141 这些是arg3-arg0,也就是说,如果你不再关心传入的值,你可以使用
145 这俩是ret0和ret1。它们是你传入返回值的地方。r28是主返回值。当返回
146 小结构体时,r29也可以用来将数据传回给调用程序。
155 r3-r18,r27,r30需要被保存和恢复。r3-r18只是一般用途的寄存器。
156 r27是数据指针,用来使对全局变量的引用更容易。r30是栈指针。