start_addr=0x30000000 end_addr=0x30000003 data_write=0x55AA55AA count=0 match_count=0 for ((addr=$start_addr; addr<$end_addr; addr=addr+4)); do echo -ne "\x55\xAA\x55\xAA" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/nul data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') done for ((addr=$start_addr; addr<$end_addr; addr+=4)); do data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') if [ "$data_write" == "$data" ]; then match_count=$((match_count+1)) fi count=$((count+1)) done echo $data echo $data_read echo $match_count echo $count if [ $match_count -eq $count ]; then echo "PASS" else echo "FAIL" fi这段代码有错误吗?
时间: 2024-04-28 09:20:31 浏览: 172
这段代码可能存在一些错误。具体地说,以下是我发现的一些问题:
1. 在第 3 行 `2>/dev/nul` 应该是 `2>/dev/null`,即应该是 `null` 而不是 `nul`。
2. 在第 5 行 `done` 后应该加上一个分号,即应该是 `done;`。
3. 在第 6 行 `data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"')` 中,应该将 `/dev/mem` 替换为 `/dev/mem0`。这是因为 `/dev/mem` 已经被默认禁用,需要手动启用,而 `/dev/mem0` 则不需要。
除了这些小问题以外,这段代码的逻辑上看起来是正确的,可以用来对指定地址范围的内存进行读写测试。
相关问题
start_addr=0x30000000 end_addr=0x30000003 data_write=0x55AA55AA count=0 match_count=0 for ((addr=$start_addr; addr<$end_addr; addr=addr+4)); do echo -ne "\x55\xAA\x55\xAA" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') done for ((addr=$start_addr; addr<$end_addr; addr+=4)); do data_read=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') if [ "$data_write" == "$data" ]; then match_count=$((match_count+1)) fi count=$((count+1)) done echo $data echo $data_read echo $match_count echo $count if [ $match_count -eq $count ]; then echo "PASS" else echo "FAIL" fi这段代码为什么match_count和count输出的是1,我的设想是从起始地址到终止地址一共四个地址,不应该是比较4次吗?
这段代码中,`match_count` 和 `count` 都输出的是 1,而不是 4,是因为在第二个循环中,变量 `data` 没有被正确赋值。
在第一个循环中,变量 `data` 被赋值了 4 次,但每次循环结束后,`data` 的值被覆盖了,最终只保存了最后一次循环的结果。所以,在第二个循环中,无论比较哪个地址的数据,`data` 的值都是最后一次循环的结果,而不是当前地址的数据值,因此 `match_count` 的值只能是 0 或 1。
为了解决这个问题,我们需要在第二个循环中,将从 `/dev/mem` 中读取的数据存入一个变量中,再与 `data_write` 进行比较。修改后的代码如下:
```
#!/bin/bash
start_addr=0x30000000
end_addr=0x30000003
data_write=0x55AA55AA
count=0
match_count=0
for ((addr=$start_addr; addr<$end_addr; addr=addr+4)); do
echo -ne "\x55\xAA\x55\xAA" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null
data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"')
done
for ((addr=$start_addr; addr<$end_addr; addr+=4)); do
data_read=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"')
if [ "$data_write" == "$data_read" ]; then
match_count=$((match_count+1))
fi
count=$((count+1))
done
echo $data
echo $data_read
echo $match_count
echo $count
if [ $match_count -eq $count ]; then
echo "PASS"
else
echo "FAIL"
fi
```
在这个修改后的代码中,我们将从 `/dev/mem` 中读取的数据存入变量 `data_read` 中,并与 `data_write` 进行比较。这样就可以正确地统计 `match_count` 和 `count` 的值了。
start_addr=0x05877000 #end_addr=0x3ffff000 end_addr=0x05877002 data_write=0x55AA55AA data_read=$(printf "%08x" $data_write) count=0 match_count=0 for ((addr=$start_addr; addr<$end_addr; addr=addr+4)); do echo $data_write | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/nul done for ((addr=$start_addr; addr<$end_addr; addr+=4)); do data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"') if [ "$data_read" == "$data" ]; then match_count=$((match_count+1)) fi count=$((count+1)) done echo $data echo $data_read那么该如何修改程序才能让程序输出PASS
为了让程序输出 PASS,我们需要在循环结束后,判断 match_count 是否等于 count,如果等于,即所有数据都成功读取并且与写入的数据一致,就输出 PASS。
修改后的代码如下:
```
start_addr=0x05877000
end_addr=0x3ffff000
data_write=0x55AA55AA
data_read=$(printf "%08x" $data_write)
count=0
match_count=0
for ((addr=$start_addr; addr<$end_addr; addr=addr+4)); do
echo $data_write | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/nul
done
for ((addr=$start_addr; addr<$end_addr; addr+=4)); do
data=$(dd if=/dev/mem bs=4 count=1 skip=$(($addr/4)) 2>/dev/null | hexdump -e '/4 "%08x\n"')
if [ "$data_read" == "$data" ]; then
match_count=$((match_count+1))
fi
count=$((count+1))
done
if [ $match_count -eq $count ]; then
echo "PASS"
else
echo "FAIL"
fi
echo $data
echo $data_read
```
这样,当所有数据都成功读取并且与写入的数据一致时,程序就会输出 PASS。
阅读全文
相关推荐











