type
status
date
slug
summary
tags
category
icon
password
PA2.2学习日志
AM相关
data:image/s3,"s3://crabby-images/6ac21/6ac2131ae59270cc1393a58df2741885ec24bec3" alt="notion image"
分析应该是通过改make file来将 CONFIG_TARGET_AM的选项打开,但在AM的makefile中添加如下代码并不行,留到后面再思考吧。
尝试,但未成功
data:image/s3,"s3://crabby-images/b022e/b022e36fc38e19facc6503baff62a64c54f2c106" alt="notion image"
直接修改默认值了
data:image/s3,"s3://crabby-images/71a27/71a275de462fdfa35b1cc69deb97a8d7bcc6ac91" alt="notion image"
使用 riscv-test-am测试的结果
data:image/s3,"s3://crabby-images/3acb0/3acb00a463fb57f1c16bb77438e42806d5201fd6" alt="notion image"
实现库函数中 srtcmp和memcmp借鉴了网上的代码,其他库函数似乎可以通过;
可以通过string的test,但是其他库函数有可能会出错。
data:image/s3,"s3://crabby-images/178c3/178c3a16e6c30b6d8c4c6e790739c5df67437a54" alt="notion image"
现存问题,riscv-test中的div等,执行时会报出异常。导致结果不过。
疑惑:在am-kernal中执行make是怎么导致nemu也重新编译的???
找到了,在下面的链接中,直接批处理的方式也找到了 —09.08
09.08看了一天只看懂了itrace 是怎么实现的。
下面准备实现iring buf;
09.09-09.22 个人变动加中秋节,项目短暂停滞。不能隔太久,太久就都忘记了。
12.15 重启
基础设施部分,开始。
在cpu/ 下创建了trace.c文件,同时创建了trace.h文件。
在cpu/cpu-exec.c中进行调用。
如果在sdb中故意触发Assert错误,可以大体验证该功能正确
专门设置 输入 si 199时触发Assert错误,此时除了打印寄存器值之外,还打印了环形缓冲器的值。该设置在提交时被注释。
data:image/s3,"s3://crabby-images/cd313/cd31324c6ffab59265e82af570f94e0bf98d2f6f" alt="notion image"
data:image/s3,"s3://crabby-images/86201/86201b7b9ece8c49fce5653432176cac7017a94a" alt="notion image"
经过参考完成mtrace 功能,扫描内容时,会打印读取的动作。
目前还没有实现写内存的动作,因此没有验证写入时的mtrace。
data:image/s3,"s3://crabby-images/66ace/66ace6d370b49818297675a385b0d33bd0b18093" alt="notion image"
2025.1.7 尝试进行ftrace的开发,首先学习如何生成.elf文件。
gcc -o xxx.elf xxx.c 可以生成elf文件
readelf xxx.elf 将结果显示成文本
data:image/s3,"s3://crabby-images/26821/26821b742150c4b7156e199512284400bd92b774" alt="notion image"
data:image/s3,"s3://crabby-images/7cfd8/7cfd8f415704c249bc640371ef28d4121756b167" alt="notion image"
以下是16进制显示的elf内容
data:image/s3,"s3://crabby-images/47c78/47c781f0646d2b326436eac0e1f9bd4f8e442a8d" alt="notion image"
以下是readelf读出的内容
data:image/s3,"s3://crabby-images/10834/108341e65d45544663b52c7274daf628d93c1169" alt="notion image"
通过上述两个文件,字符串应该在rodata中。
为什么会这样?
data:image/s3,"s3://crabby-images/8f435/8f43543af044c2ed4a60286f8e49e481d1a1132d" alt="notion image"
ftrace开发时的bug,定义的符号表是全局变量
在monitor.c文件中采用结构体动态定义:
Symbol *symbol = NULL;
那么在trace.c中引用时,就要采用同样的方式定义:
extern Symbol *symbol;
一开始写成了extern Symbol[];就不能输出正确结果;
总结:结构体全局定义时需要格式对应:
如果初次定义采用动态定义,那其他文件引用时就需要采用相应形式:extern Symbol *symbol;
如果初次定义采用静态定义:Symbol symbol[10]; ,那其他文件引用时就需要采用相应形式:extern Symbol symbol[];
以上两种方式都可以。
完成ftrace接入
data:image/s3,"s3://crabby-images/f7732/f773280dde31292dab585ae58cb4d8ae677da4e7" alt="notion image"
data:image/s3,"s3://crabby-images/81921/8192182fd1169905f438e1b7ab3b2b99066a542f" alt="notion image"
似乎是因为函数一直在递归,但是函数内调用函数并不会用jalr指令,但是第一个完整执行的晚点函数并调用ret指令返回的有可能在其他函数内。
冗余的符号表
data:image/s3,"s3://crabby-images/7bc40/7bc406e6d1771cc86d9aaeafc75990b5fc9675c5" alt="notion image"
左图为丢弃符号表后解析出的elf信息,右图为原信息。strtab被丢弃
data:image/s3,"s3://crabby-images/4118a/4118a0e34186dda64d68ba87ad899040957a253a" alt="notion image"
丢弃符号表后仍然能运行。
data:image/s3,"s3://crabby-images/f34c0/f34c01fdbe366b29412eb251eb58174caed2ef66" alt="notion image"
如果将hello.o中的符号表丢弃,然后再链接,则链接报错
data:image/s3,"s3://crabby-images/61900/61900f57b5d1d92351d9cbf8bb279338a4876495" alt="notion image"
链接报错,无法运行。
data:image/s3,"s3://crabby-images/97ca7/97ca776c0b36877694fc2f1270ff9b326d5be251" alt="notion image"
似乎是在链接过程中需要使用符号表进行符号解析并重定向,没有符号表就不能完成重定向功能。
而链接完成后丢弃符号表并不影响程序执行。
如何生成native的可执行文件
data:image/s3,"s3://crabby-images/b4da7/b4da79ee6f1a5ad72e341f1685857ff4a11f4cf7" alt="notion image"
首先解析ARCH的名称,将其存入$(ARCH)变量中
data:image/s3,"s3://crabby-images/420ad/420ada14daa0dbeedeb5395606fc350230aa25a8" alt="notion image"
然后根据$(ARCH)分析是否需要交叉编译.
data:image/s3,"s3://crabby-images/a54c7/a54c74440fb97e96a177fe72a48c3f2685add28f" alt="notion image"
如果ARCH选择的是riscv32-nemu
则会包含riscv32-nemu的文件
data:image/s3,"s3://crabby-images/048ae/048ae40dc5a008c63a4ce7d2cd93c5a141ae1f9c" alt="notion image"
并包含riscv32编译所需的文件
data:image/s3,"s3://crabby-images/3c723/3c723ba8ba79b83ecfee44acccf33001d2719dd9" alt="notion image"
在之后的编译和链接过程中,就会使用前缀为 riscv64-linux-gnu- 相关的指令。
如果ARCH选择是native,则使用默认的编译和链接等命令,就会将可执行程序编译到linux平台下。
这是如何实现的?
data:image/s3,"s3://crabby-images/8bb56/8bb569798b933cf410295ddcd082c399e3756e74" alt="notion image"
在klib下的strxx.c中有条件编译选项:
data:image/s3,"s3://crabby-images/88f61/88f614a01100785f72b0f424ad384785308d0636" alt="notion image"
如果有宏定义 __NATIVE__USE__KLIB__,则会编译klib中的字符处理函数,如果没有宏定义,则会寻找glibc中的字符处理函数。
编写更多的测试
data:image/s3,"s3://crabby-images/e63e3/e63e39efdfdc2788f754a8905db1e807146b060e" alt="notion image"
data:image/s3,"s3://crabby-images/92219/922192a9c7e21733bd3fdc231702b2055901e85b" alt="notion image"
编写makefile和验证文件,运行如下命令,无报错证明验证通过。
data:image/s3,"s3://crabby-images/c7a9b/c7a9b0dd32ec634506a8f488b1858b2197fd9d77" alt="notion image"
测试strcpy函数。
data:image/s3,"s3://crabby-images/41c23/41c23531e9aed56a30c735cce04bbd0da0e56827" alt="notion image"
data:image/s3,"s3://crabby-images/2b23d/2b23d6cbb5cbeddad4d1f3873c4e6736c129f3c9" alt="notion image"
memcpy_test简单测试通过
data:image/s3,"s3://crabby-images/f1d1b/f1d1b4afa6c16a9374fc886c47678260a0253527" alt="notion image"
memmove_test简单测试通过,使用了三层循环,输出巨多。
data:image/s3,"s3://crabby-images/1c27a/1c27aa738fa67914396bf15652073a6f4bfe548a" alt="notion image"
data:image/s3,"s3://crabby-images/39c78/39c78e73146cffcd2e59abec8b4c90a218c18d7a" alt="notion image"
memcmp可以借助memcpy来进行测试,判断的区间同样分成三段,第一段和第三段未复制,cmp结果应该小于0,第二段复制,cmp结果应该等于0。
完成memcmp验证
data:image/s3,"s3://crabby-images/39e29/39e2900dcbc55f624c1a4c91e9ff12845f5a7f31" alt="notion image"
完成strlen验证
data:image/s3,"s3://crabby-images/bcb60/bcb60d312b312de4ccae8faacea42e9d939a68ca" alt="notion image"
data:image/s3,"s3://crabby-images/381e2/381e23e7982fc1cb9f087e8eb39f57a5cebcbdbf" alt="notion image"
native打印的数值如下,将下面数值整理至test程序中。
data:image/s3,"s3://crabby-images/36c78/36c785e59766bc020a45d7fb4f1eafe296d23d67" alt="notion image"
记录一个调试过程
make ALL=sprintf_test ARCH=native gdb 时原框架并不能进入调试状态,需要在am的makefile中加入-g选项。
同时要make clean 或着 换一个程序编译之后,再换回来。否则由于可能存在的增量编译使得新加的选项并不能生效。
需进行以下修改,否则可能无法全部生效。
data:image/s3,"s3://crabby-images/002f9/002f92b60612f23459c1084ea76d766f87aee56e" alt="notion image"
data:image/s3,"s3://crabby-images/cc7fd/cc7fd33540cc5e23eb94646c361ac0b6af77bf80" alt="notion image"
data:image/s3,"s3://crabby-images/1b128/1b12823a95703da04d79cd59e967e498fb6bbfd1" alt="notion image"
通过sprintf测试
data:image/s3,"s3://crabby-images/93b59/93b59c950af0a47257fab662ee2dc624adc778c9" alt="notion image"
验证时还是找到了bug,起初itoa函数中并未对value起初等于0进行处理,导致sprintf只打印一个0时,不会将0写入到目的buffer中,导致错误。单独增加处理0的代码,测试既能通过。
data:image/s3,"s3://crabby-images/a3d6c/a3d6c3d428a9e6b6c59807c7cf3823832ede2fff" alt="notion image"
Differential Testing
终于开始差分测试了,又到了曾经熟悉的内容,加油。