start_addr=0x30000000 end_addr=0x30000003 data_write=0x55AA55AA count=0 match_count=0 # 写入数据 for ((addr=$start_addr; addr<$end_addr+1; addr=addr+1)); do echo -ne "\x55\xAA\x55\xAA" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null data=$(echo -ne "\x55\xAA\x55\xAA" | hexdump -e '/4 "%08x\n"') data_text=$(echo -ne "\x55\xAA\x55\xAA" | hexdump -e '/4 "%08x\n"' | sed 's/../& /g') echo "data_text: $data_text" #echo "data: $data" data_read=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') data_read_text=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"' | sed 's/../& /g') echo "data_read_text: $data_read_text" # echo "data_read: $data_read" if [ "$data_read" == "$data" ]; then match_count=$((match_count+1)) echo "match_count: $match_count" fi count=$((count+1)) echo "count: $count" done # 输出结果 # 判断结果 if [ $match_count -eq $count ]; then echo "PASS" else echo "FAIL" fi 这段代码为什么data与data_read全部相等并输出PASS.可是为什么data_text可以正常输出但data_read_text输出的是空白?如何能让data_text_read可以输出可视的文本结果?
时间: 2024-03-01 07:52:31 浏览: 28
这段代码中,data_write的值为0x55AA55AA,所以在写入数据时,使用echo -ne命令将其转换成16进制格式并写入/dev/mem设备。接着,使用hexdump命令将写入的数据转换成可读的16进制格式,并使用sed命令将其转换成可视的文本格式,即data_text。但是,在读取数据时,只是使用dd命令将数据读取到data_read中,并没有对其进行转换,所以输出的是16进制格式的data_read。由于data_write中的数据是没有对应的ASCII字符的,所以在将其转换成可视的文本格式时,会输出空白。
如果要让data_read_text输出可视的文本结果,可以使用xxd命令来进行转换。在读取数据时,将其读取到一个临时文件中,然后使用xxd命令将其转换成可视的文本格式,最后将结果输出即可。以下是修改后的代码:
```
start_addr=0x30000000
end_addr=0x30000003
data_write=0x55AA55AA
count=0
match_count=0
# 写入数据
for ((addr=$start_addr; addr<$end_addr+1; addr=addr+1)); do
echo -ne "\x55\xAA\x55\xAA" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null
data=$(echo -ne "\x55\xAA\x55\xAA" | hexdump -e '/4 "%08x\n"')
data_text=$(echo -ne "\x55\xAA\x55\xAA" | hexdump -e '/4 "%08x\n"' | sed 's/../& /g')
echo "data_text: $data_text"
#echo "data: $data"
dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | xxd -p | tr -d '\n' | xxd -r -p > temp.txt
data_read=$(cat temp.txt)
data_read_text=$(cat temp.txt | xxd -p -r)
echo "data_read_text: $data_read_text"
#echo "data_read: $data_read"
if [ "$data_read" == "$data" ]; then
match_count=$((match_count+1))
echo "match_count: $match_count"
fi
count=$((count+1))
echo "count: $count"
done
# 输出结果
# 判断结果
if [ $match_count -eq $count ]; then
echo "PASS"
else
echo "FAIL"
fi
# 删除临时文件
rm temp.txt
```
在这个修改后的代码中,使用了xxd命令将读取的数据转换成可视的文本格式,并将结果存储在temp.txt文件中。然后使用cat命令将temp.txt文件中的内容读取出来,并再次使用xxd命令将其转换成可视的文本格式,最后将结果输出。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)