|
@@ -19,6 +19,8 @@
|
|
#include <linux/bio.h>
|
|
#include <linux/bio.h>
|
|
#include <linux/prefetch.h>
|
|
#include <linux/prefetch.h>
|
|
#include <linux/uio.h>
|
|
#include <linux/uio.h>
|
|
|
|
+#include <linux/mm.h>
|
|
|
|
+#include <linux/memcontrol.h>
|
|
#include <linux/cleancache.h>
|
|
#include <linux/cleancache.h>
|
|
|
|
|
|
#include "f2fs.h"
|
|
#include "f2fs.h"
|
|
@@ -1775,6 +1777,35 @@ int f2fs_release_page(struct page *page, gfp_t wait)
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ * This was copied from __set_page_dirty_buffers which gives higher performance
|
|
|
|
+ * in very high speed storages. (e.g., pmem)
|
|
|
|
+ */
|
|
|
|
+void f2fs_set_page_dirty_nobuffers(struct page *page)
|
|
|
|
+{
|
|
|
|
+ struct address_space *mapping = page->mapping;
|
|
|
|
+ unsigned long flags;
|
|
|
|
+
|
|
|
|
+ if (unlikely(!mapping))
|
|
|
|
+ return;
|
|
|
|
+
|
|
|
|
+ spin_lock(&mapping->private_lock);
|
|
|
|
+ lock_page_memcg(page);
|
|
|
|
+ SetPageDirty(page);
|
|
|
|
+ spin_unlock(&mapping->private_lock);
|
|
|
|
+
|
|
|
|
+ spin_lock_irqsave(&mapping->tree_lock, flags);
|
|
|
|
+ WARN_ON_ONCE(!PageUptodate(page));
|
|
|
|
+ account_page_dirtied(page, mapping);
|
|
|
|
+ radix_tree_tag_set(&mapping->page_tree,
|
|
|
|
+ page_index(page), PAGECACHE_TAG_DIRTY);
|
|
|
|
+ spin_unlock_irqrestore(&mapping->tree_lock, flags);
|
|
|
|
+ unlock_page_memcg(page);
|
|
|
|
+
|
|
|
|
+ __mark_inode_dirty(mapping->host, I_DIRTY_PAGES);
|
|
|
|
+ return;
|
|
|
|
+}
|
|
|
|
+
|
|
static int f2fs_set_data_page_dirty(struct page *page)
|
|
static int f2fs_set_data_page_dirty(struct page *page)
|
|
{
|
|
{
|
|
struct address_space *mapping = page->mapping;
|
|
struct address_space *mapping = page->mapping;
|
|
@@ -1797,7 +1828,7 @@ static int f2fs_set_data_page_dirty(struct page *page)
|
|
}
|
|
}
|
|
|
|
|
|
if (!PageDirty(page)) {
|
|
if (!PageDirty(page)) {
|
|
- __set_page_dirty_nobuffers(page);
|
|
|
|
|
|
+ f2fs_set_page_dirty_nobuffers(page);
|
|
update_dirty_page(inode, page);
|
|
update_dirty_page(inode, page);
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|