当前位置: 技术问答>linux和unix
问一个内存分配的问题
来源: 互联网 发布时间:2017-03-23
本文导语: 请问 __alloc_pages 一次性申请到最大的内存是多少? 是2^10个页面吗? 然后就是 slub在向buddy系统申请页面的时候.每次都会申请到2^order个页面。在slub中最大的order为11。能申请到这么大的页面吗? ...
请问 __alloc_pages 一次性申请到最大的内存是多少? 是2^10个页面吗?
然后就是 slub在向buddy系统申请页面的时候.每次都会申请到2^order个页面。在slub中最大的order为11。能申请到这么大的页面吗?
然后就是 slub在向buddy系统申请页面的时候.每次都会申请到2^order个页面。在slub中最大的order为11。能申请到这么大的页面吗?
|
__alloc_pages里面有一个参数是分配策略order, 也就是分配2^order个页面。而且是连续的页面。
linux系统启动时会建立页面的链表。
有一个数组pages[1..order],数组的成分是链表,pages[order]就是有2^order个页面的链表头,
分配的策略是找order的链表头,有就分出,没有就找比order大的,找一个出来分拆。
2^11页面很大吗,一个页面算2K,2^9才1M, 2^11才4M。
linux系统启动时会建立页面的链表。
有一个数组pages[1..order],数组的成分是链表,pages[order]就是有2^order个页面的链表头,
分配的策略是找order的链表头,有就分出,没有就找比order大的,找一个出来分拆。
2^11页面很大吗,一个页面算2K,2^9才1M, 2^11才4M。
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。