Should have been part of r35023: Introduction of the vm_page::modified flag.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@35024 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
829f302836
commit
3b8c056da0
@ -94,11 +94,12 @@ struct vm_page {
|
|||||||
vint32 accessing_thread;
|
vint32 accessing_thread;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint8 is_dummy : 1;
|
|
||||||
uint8 state : 3;
|
uint8 state : 3;
|
||||||
uint8 busy_writing : 1;
|
bool is_dummy : 1;
|
||||||
|
bool busy_writing : 1;
|
||||||
// used in VMAnonymousCache::Merge()
|
// used in VMAnonymousCache::Merge()
|
||||||
uint8 unused : 3;
|
bool modified : 1;
|
||||||
|
uint8 unused : 2;
|
||||||
|
|
||||||
int8 usage_count;
|
int8 usage_count;
|
||||||
uint16 wired_count;
|
uint16 wired_count;
|
||||||
|
@ -1974,6 +1974,9 @@ virtual_page_address(VMArea* area, vm_page* page)
|
|||||||
bool
|
bool
|
||||||
vm_test_map_modification(vm_page* page)
|
vm_test_map_modification(vm_page* page)
|
||||||
{
|
{
|
||||||
|
if (page->modified)
|
||||||
|
return true;
|
||||||
|
|
||||||
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
||||||
vm_page_mapping* mapping;
|
vm_page_mapping* mapping;
|
||||||
while ((mapping = iterator.Next()) != NULL) {
|
while ((mapping = iterator.Next()) != NULL) {
|
||||||
@ -2001,7 +2004,7 @@ int32
|
|||||||
vm_test_map_activation(vm_page* page, bool* _modified)
|
vm_test_map_activation(vm_page* page, bool* _modified)
|
||||||
{
|
{
|
||||||
int32 activation = 0;
|
int32 activation = 0;
|
||||||
bool modified = false;
|
bool modified = page->modified;
|
||||||
|
|
||||||
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
||||||
vm_page_mapping* mapping;
|
vm_page_mapping* mapping;
|
||||||
@ -2034,6 +2037,9 @@ vm_test_map_activation(vm_page* page, bool* _modified)
|
|||||||
void
|
void
|
||||||
vm_clear_map_flags(vm_page* page, uint32 flags)
|
vm_clear_map_flags(vm_page* page, uint32 flags)
|
||||||
{
|
{
|
||||||
|
if ((flags & PAGE_MODIFIED) != 0)
|
||||||
|
page->modified = false;
|
||||||
|
|
||||||
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
vm_page_mappings::Iterator iterator = page->mappings.GetIterator();
|
||||||
vm_page_mapping* mapping;
|
vm_page_mapping* mapping;
|
||||||
while ((mapping = iterator.Next()) != NULL) {
|
while ((mapping = iterator.Next()) != NULL) {
|
||||||
@ -2056,6 +2062,8 @@ void
|
|||||||
vm_remove_all_page_mappings(vm_page* page, uint32* _flags)
|
vm_remove_all_page_mappings(vm_page* page, uint32* _flags)
|
||||||
{
|
{
|
||||||
uint32 accumulatedFlags = 0;
|
uint32 accumulatedFlags = 0;
|
||||||
|
if (page->modified)
|
||||||
|
accumulatedFlags |= PAGE_MODIFIED;
|
||||||
|
|
||||||
vm_page_mappings queue;
|
vm_page_mappings queue;
|
||||||
queue.MoveFrom(&page->mappings);
|
queue.MoveFrom(&page->mappings);
|
||||||
@ -2095,7 +2103,7 @@ vm_remove_all_page_mappings(vm_page* page, uint32* _flags)
|
|||||||
|
|
||||||
|
|
||||||
/*! If \a preserveModified is \c true, the caller must hold the lock of the
|
/*! If \a preserveModified is \c true, the caller must hold the lock of the
|
||||||
page's cache and the page must not be busy.
|
page's cache.
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
vm_unmap_page(VMArea* area, addr_t virtualAddress, bool preserveModified)
|
vm_unmap_page(VMArea* area, addr_t virtualAddress, bool preserveModified)
|
||||||
@ -2127,8 +2135,8 @@ vm_unmap_page(VMArea* area, addr_t virtualAddress, bool preserveModified)
|
|||||||
map->ops->flush(map);
|
map->ops->flush(map);
|
||||||
|
|
||||||
status = map->ops->query(map, virtualAddress, &physicalAddress, &flags);
|
status = map->ops->query(map, virtualAddress, &physicalAddress, &flags);
|
||||||
if ((flags & PAGE_MODIFIED) != 0 && page->state != PAGE_STATE_MODIFIED)
|
if ((flags & PAGE_MODIFIED) != 0)
|
||||||
vm_page_set_state(page, PAGE_STATE_MODIFIED);
|
page->modified = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
vm_page_mapping* mapping = NULL;
|
vm_page_mapping* mapping = NULL;
|
||||||
@ -2162,9 +2170,7 @@ vm_unmap_page(VMArea* area, addr_t virtualAddress, bool preserveModified)
|
|||||||
|
|
||||||
|
|
||||||
/*! If \a preserveModified is \c true, the caller must hold the lock of all
|
/*! If \a preserveModified is \c true, the caller must hold the lock of all
|
||||||
mapped pages' caches and none of the pages must be busy.
|
mapped pages' caches.
|
||||||
TODO: Particularly the latter is very inconvenient. See the TODOs below for
|
|
||||||
reasons for this requirement.
|
|
||||||
*/
|
*/
|
||||||
status_t
|
status_t
|
||||||
vm_unmap_pages(VMArea* area, addr_t base, size_t size, bool preserveModified)
|
vm_unmap_pages(VMArea* area, addr_t base, size_t size, bool preserveModified)
|
||||||
@ -2214,18 +2220,8 @@ vm_unmap_pages(VMArea* area, addr_t base, size_t size, bool preserveModified)
|
|||||||
physicalAddress);
|
physicalAddress);
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_PAGE_ACCESS_START(page);
|
if ((flags & PAGE_MODIFIED) != 0)
|
||||||
// TODO: No guarantee for that. See below.
|
page->modified = true;
|
||||||
|
|
||||||
if ((flags & PAGE_MODIFIED) != 0
|
|
||||||
&& page->state != PAGE_STATE_MODIFIED) {
|
|
||||||
vm_page_set_state(page, PAGE_STATE_MODIFIED);
|
|
||||||
// TODO: We are only allowed to do this, if (a) we have also
|
|
||||||
// locked the cache and (b) the page is not busy! Not doing
|
|
||||||
// it is problematic, too, since we'd lose information.
|
|
||||||
}
|
|
||||||
|
|
||||||
DEBUG_PAGE_ACCESS_END(page);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user