echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=2 count=2 seek=$(($addr/8)) conv=notrunc 2>/dev/null和echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=8 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null和echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=4 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null和echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=2 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null以上几句代码分别可以把01010101101010100101010110101010输出为什么?
时间: 2023-09-28 16:04:05 浏览: 34
这些代码无法将一个二进制字符串直接转换为其他的内容。它们是用于将一个二进制数据写入到系统内存中指定的地址位置的命令。具体来说,这些命令使用echo命令产生一个二进制数据流,然后使用dd命令将其写入到/dev/mem设备中指定的地址位置。不同的命令使用不同的字节大小(bs)写入数据,因此写入的内容可能会有所不同。
相关问题
echo -ne "\x55\xaa\x55\xaa" | dd of=/dev/mem bs=2 count=2 seek=$(($addr/2)) conv=notrunc 2>/dev/null与echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=8 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null 区别是什么
这两个命令的区别在于写入的数据大小和数量。
第一个命令 `echo -ne "\x55\xaa\x55\xaa" | dd of=/dev/mem bs=2 count=2 seek=$(($addr/2)) conv=notrunc 2>/dev/null` 写入了两个字节(16位)的数据,写入的数量为2,每个数据占用2个字节。其中 `bs=2` 表示每次操作的块大小为2个字节,`count=2` 表示写入2个块,即总共写入4个字节。`seek=$(($addr/2))` 表示从偏移地址处开始写入数据,偏移地址需要除以2,因为每个数据占用2个字节。
第二个命令 `echo -ne "\x55\xaa\x55\xaa\x55\xaa\x55\xaa" | dd of=/dev/mem bs=8 count=1 seek=$(($addr/8)) conv=notrunc 2>/dev/null` 写入了一个八个字节(64位)的数据,写入的数量为1,每个数据占用8个字节。其中 `bs=8` 表示每次操作的块大小为8个字节,`count=1` 表示写入1个块,即总共写入8个字节。`seek=$(($addr/8))` 表示从偏移地址处开始写入数据,偏移地址需要除以8,因为每个数据占用8个字节。
因此,这两个命令的区别在于写入数据的大小和数量不同,需要根据实际情况选择合适的命令。
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 "addr: $addr" 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如何能让这段代码输出addr时输出0x30000000、0x30000001、0x30000002和0x30000003而不是805306368、805306369、805306370和805306371
可以使用printf命令来控制输出格式,将addr以16进制的形式输出。修改代码如下:
```
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
printf "addr: 0x%x\n" $addr
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
```
这样输出的addr就会以16进制的形式显示。