39 lines
1.7 KiB
ReStructuredText
39 lines
1.7 KiB
ReStructuredText
|
.. include:: ../disclaimer-zh_CN.rst
|
|||
|
|
|||
|
:Original: Documentation/mm/free_page_reporting.rst
|
|||
|
|
|||
|
:翻译:
|
|||
|
|
|||
|
司延腾 Yanteng Si <siyanteng@loongson.cn>
|
|||
|
|
|||
|
:校译:
|
|||
|
|
|||
|
==========
|
|||
|
空闲页报告
|
|||
|
==========
|
|||
|
|
|||
|
空闲页报告是一个API,设备可以通过它来注册接收系统当前未使用的页面列表。这在虚拟
|
|||
|
化的情况下是很有用的,客户机能够使用这些数据来通知管理器它不再使用内存中的某些页
|
|||
|
面。
|
|||
|
|
|||
|
对于驱动,通常是气球驱动要使用这个功能,它将分配和初始化一个page_reporting_dev_info
|
|||
|
结构体。它要填充的结构体中的字段是用于处理散点列表的 "report" 函数指针。它还必
|
|||
|
须保证每次调用该函数时能处理至少相当于PAGE_REPORTING_CAPACITY的散点列表条目。
|
|||
|
假设没有其他页面报告设备已经注册, 对page_reporting_register的调用将向报告框
|
|||
|
架注册页面报告接口。
|
|||
|
|
|||
|
一旦注册,页面报告API将开始向驱动报告成批的页面。API将在接口被注册后2秒开始报告
|
|||
|
页面,并在任何足够高的页面被释放之后2秒继续报告。
|
|||
|
|
|||
|
报告的页面将被存储在传递给报告函数的散列表中,最后一个条目的结束位被设置在条目
|
|||
|
nent-1中。 当页面被报告函数处理时,分配器将无法访问它们。一旦报告函数完成,这些
|
|||
|
页将被返回到它们所获得的自由区域。
|
|||
|
|
|||
|
在移除使用空闲页报告的驱动之前,有必要调用page_reporting_unregister,以移除
|
|||
|
目前被空闲页报告使用的page_reporting_dev_info结构体。这样做将阻止进一步的报
|
|||
|
告通过该接口发出。如果另一个驱动或同一驱动被注册,它就有可能恢复前一个驱动在报告
|
|||
|
空闲页方面的工作。
|
|||
|
|
|||
|
|
|||
|
Alexander Duyck, 2019年12月04日
|