classic memory layout & flexible memory layout

本文阐述了 经典的虚拟内存布局 和 易变虚拟内存布局;

                                                     -------Gustavo Duarte 他的blog很好看
上图,有图一切都明白了。
flexible memory layout:
classic memory layout:
 
易变虚拟内存布局就是在各个虚拟内存区中引用随机的偏移量。从而使Hacker很难猜测出函数库,映射文件等等的位置。从而一定程度上使程序得到保护,但是32位系统用户空间的狭小,削弱了这种效果。
我们也可以从这个patch的原作者的mail中得到一些有用的信息:
the goal of the patch is to change the way virtual memory is allocated,
from:
//传统虚拟内存布局
  0x08000000 ... binary image
  0x08xxxxxx ... brk area, grows upwards
  0x40000000 ... start of mmap, new mmaps go after old ones//从1G开始 向上增长,这导致了一个问题,无法完全利用虚拟内存空间。
  0xbfxxxxxx ... stack

to a more flexible top-down mmap() method:
//易变虚拟内存布局
  0x08000000 ... binary image
  0x08xxxxxx ... brk area, grows upwards
  0xbfxxxxxx ... _end_ of all mmaps, new mmaps go below old ones//从stack+random offset开始 向下增长,可以用满虚拟内存空间
  0xbfyyyyyy ... stack

the new layout has a couple of advantages:

- primarily this layout enables both malloc(), mmap()/shmat() users to
  utilize the full address space: 3GB on stock x86, 4GB on x86 4:4 or
  x86-64 running x86 apps.

- the new layout is also in essence 'self-tuning' the mmap() and
  malloc() limits: no hacks like /proc/PID/mmap_base are needed - both
  malloc() and mmap() can grow until all the address space is full.
  With the old layout, malloc() space was limited to 900MB, mmap() space
  to ~2GB.

- The new layout also allows very large continuous mmap()s because the
  'free space' is always a continuous hole (statistically).

- there's also a ~4K pagetable saved per typical process, because we
  dont allocate at 1GB anymore and dont fragment the VM that much -
  there are only 2 main chunks, the binary image + brk(), and the mmap()
  area + stack.
  1. [root@localhost study]# pmap -x 1
  2. 1: init [3]
  3. Address Kbytes RSS Dirty Mode Mapping
  4. 002e7000 4 4 0 r-x-- [ anon ]
  5. 00469000 104 84 0 r-x-- ld-2.5.so
  6. 00483000 4 4 4 r-x-- ld-2.5.so
  7. 00484000 4 4 4 rwx-- ld-2.5.so
  8. 00487000 1276 356 0 r-x-- libc-2.5.so
  9. 005c6000 4 0 0 --x-- libc-2.5.so
  10. 005c7000 8 8 4 r-x-- libc-2.5.so
  11. 005c9000 4 4 4 rwx-- libc-2.5.so
  12. 005ca000 12 12 12 rwx-- [ anon ]
  13. 005f8000 8 8 0 r-x-- libdl-2.5.so
  14. 005fa000 4 4 4 r-x-- libdl-2.5.so
  15. 005fb000 4 4 4 rwx-- libdl-2.5.so
  16. 00638000 88 40 0 r-x-- libselinux.so.1
  17. 0064e000 8 8 8 rwx-- libselinux.so.1
  18. 00652000 236 16 0 r-x-- libsepol.so.1
  19. 0068d000 4 4 4 rwx-- libsepol.so.1
  20. 0068e000 40 0 0 rwx-- [ anon ]
  21. 08048000 32 32 0 r-x-- init
  22. 08050000 4 4 4 rw--- init
  23. 098db000 132 16 16 rw--- [ anon ]
  24. b7f32000 8 8 8 rw--- [ anon ]
  25. bfc07000 84 16 16 rw--- [ stack ]
  26. -------- ------- ------- ------- -------
  27. total kB 2072 - - -
  28. [root@localhost study]# cat /proc/1/maps
  29. 002e7000-002e8000 r-xp 002e7000 00:00 0 [vdso]
  30. 00469000-00483000 r-xp 00000000 08:03 1182164 /lib/ld-2.5.so
  31. 00483000-00484000 r-xp 00019000 08:03 1182164 /lib/ld-2.5.so
  32. 00484000-00485000 rwxp 0001a000 08:03 1182164 /lib/ld-2.5.so
  33. 00487000-005c6000 r-xp 00000000 08:03 1182165 /lib/libc-2.5.so
  34. 005c6000-005c7000 --xp 0013f000 08:03 1182165 /lib/libc-2.5.so
  35. 005c7000-005c9000 r-xp 0013f000 08:03 1182165 /lib/libc-2.5.so
  36. 005c9000-005ca000 rwxp 00141000 08:03 1182165 /lib/libc-2.5.so
  37. 005ca000-005cd000 rwxp 005ca000 00:00 0
  38. 005f8000-005fa000 r-xp 00000000 08:03 1182169 /lib/libdl-2.5.so
  39. 005fa000-005fb000 r-xp 00001000 08:03 1182169 /lib/libdl-2.5.so
  40. 005fb000-005fc000 rwxp 00002000 08:03 1182169 /lib/libdl-2.5.so
  41. 00638000-0064e000 r-xp 00000000 08:03 1182183 /lib/libselinux.so.1
  42. 0064e000-00650000 rwxp 00015000 08:03 1182183 /lib/libselinux.so.1
  43. 00652000-0068d000 r-xp 00000000 08:03 1182182 /lib/libsepol.so.1
  44. 0068d000-0068e000 rwxp 0003b000 08:03 1182182 /lib/libsepol.so.1
  45. 0068e000-00698000 rwxp 0068e000 00:00 0
  46. 08048000-08050000 r-xp 00000000 08:03 884969 /sbin/init
  47. 08050000-08051000 rw-p 00008000 08:03 884969 /sbin/init
  48. 098db000-098fc000 rw-p 098db000 00:00 0 [heap]
  49. b7f32000-b7f34000 rw-p b7f32000 00:00 0
  50. bfc07000-bfc1c000 rw-p bffea000 00:00 0 [stack]
以上为flexible memroy layout 输出结果。可以与上图对比着看一下
内核的/proc文件系统也提供了相应的控制接口,来确定使用哪种虚拟内存布局
echo 1 > /proc/sys/vm/legacy_va_layout
1 使用传统虚拟内存布局
0 使用易变虚拟内存布局
weixin151云匹面粉直供微信小程序+springboot后端毕业源码案例设计 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
PICC(Proximity Integrated Circuit Card)命令是用于操作MIFARE经典记忆标签的一系列指令。 MIFARE经典记忆标签是一种RFID(Radio-frequency Identification)标签,用于存储数据和与读卡器进行通信。以下是一些常见的PICC命令: 1. PICC防冲突命令:用于解决多个标签同时进入操作范围时的冲突问题,确保每个标签能够被正确识别和操作。 2. PICC选择命令:用于从多个标签中选择特定的标签进行进一步的操作。通过发送标签的序列号命令,读卡器可以选择指定的标签进行数据读取或写入操作。 3. PICC鉴权命令:用于验证读卡器是否具有对特定存储区域进行读取或写入操作的权限。读卡器需要提供正确的密钥才能通过鉴权。 4. PICC读取块数据命令:用于从标签的特定存储区域中读取数据。通过发送块地址和密钥,读卡器可以获取标签存储区域中的数据。 5. PICC写入块数据命令:用于向标签的特定存储区域中写入数据。通过发送块地址、密钥和待写入的数据,读卡器可以将数据写入标签存储区域中。 6. PICC值块操作命令:用于对标签存储区域中的值块进行增减操作。通过发送块地址、密钥和指定的增减值,读卡器可以修改值块的值。 这些PICC命令为读卡器与MIFARE经典记忆标签之间的通信提供了基本的操作指令。读卡器可以使用这些命令来读取标签中的数据、写入新的数据、验证权限以及进行其他操作。同时,读卡器还可以根据标签的响应进行错误处理和数据处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值