当前位置:  技术问答>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。能申请到这么大的页面吗?

|
__alloc_pages里面有一个参数是分配策略order, 也就是分配2^order个页面。而且是连续的页面。
linux系统启动时会建立页面的链表。
有一个数组pages[1..order],数组的成分是链表,pages[order]就是有2^order个页面的链表头,
分配的策略是找order的链表头,有就分出,没有就找比order大的,找一个出来分拆。

2^11页面很大吗,一个页面算2K,2^9才1M, 2^11才4M。

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。














站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3