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