1
1
mirror of https://github.com/foxsen/archbase.git synced 2026-02-03 02:14:40 +08:00

<<会被latex特殊解释,改为\<\<

This commit is contained in:
Zhang Fuxin
2021-11-02 23:10:16 +08:00
parent ae64014380
commit d4ebd3cd6e

View File

@@ -439,7 +439,7 @@ autofit()
```
这里的if \~ else实现采用了BEQZ指令当\$t0寄存器的值等于0时进行跳转跳转到标号.L1执行“else”分支中的操作当\$t0寄存器的值不等于0时则顺序执行“then”分支中的操作并在完成后无条件跳转到标号.L2处绕开“else”分支。
switch \~ case语句的结构更为复杂由于可能的分支数较多通常会被映射为跳转表的形式如表\@ref(tab:switch-case)所示。如果在编译选项中加入-fno-jump-tables的选项那么switch \~ case语句还可以被映射为跳转级联的形式如表\@ref(tab:switch-case-chain)所示。表中"alsl.d rd, rj, rk, sa"所进行的操作是GR[rd] = (GR[rj] << sa) + GR[rk]。即将rj号通用寄存器中的值先左移sa位再与rk号通用寄存器中的值相加结果写入rd号通用寄存器中。
switch \~ case语句的结构更为复杂由于可能的分支数较多通常会被映射为跳转表的形式如表\@ref(tab:switch-case)所示。如果在编译选项中加入-fno-jump-tables的选项那么switch \~ case语句还可以被映射为跳转级联的形式如表\@ref(tab:switch-case-chain)所示。表中"alsl.d rd, rj, rk, sa"所进行的操作是GR[rd] = (GR[rj] \<\< sa) + GR[rk]。即将rj号通用寄存器中的值先左移sa位再与rk号通用寄存器中的值相加结果写入rd号通用寄存器中。
```{r switch-case, echo = FALSE, message=FALSE, tab.cap='switch~case语句及其跳转表形式的LoongArch机器表示', tab.id='switch-case'}
autonum <- run_autonum(seq_id = "tab", bkm = "switch-case", bkm_all = TRUE)