Re: Reiser4 GIT and Kernel 3.11 patchs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Cool, thanks!
I'll concentrate then on fixing problem with non-removable files..

Edward.


19.09.2013 20:09, Mathieu Belanger пишет:

I have ported the code to the new shrinker API (kernel 3.12-rc1) and removed the support for the old API a have added earlier.

It compile but did not test yet.

Here the diff to apply on the current Ivan patch (for Edward or other who don't use git):


@@ -31,9 +31,11 @@
* Shrinks d_cursor_cache. Scan LRU list of unused cursors, freeing requested
  * number. Return number of still freeable cursors.
  */
-static int d_cursor_shrink(struct shrinker *shrink, struct shrink_control *sc) +static unsigned long d_cursor_shrink_scan(struct shrinker *shrink, struct shrink_control *sc)
 {
-  if (sc->nr_to_scan != 0) {
+  unsigned long freed = 0;
+  unsigned long remain = sc->nr_to_scan;
+  if (remain != 0) {
     dir_cursor *scan;

     spin_lock(&d_c_lock);
@@ -41,12 +43,18 @@ static int d_cursor_shrink(struct shrinker *shrink, struct shrink_control *sc)
       scan = list_entry(cursor_cache.next, dir_cursor, alist);
       assert("nikita-3567", scan->ref == 0);
       kill_cursor(scan);
-      --sc->nr_to_scan;
-      if (sc->nr_to_scan == 0)
+      --remain;
+      freed++;
+      if (remain == 0)
         break;
     }
     spin_unlock(&d_c_lock);
   }
+  return freed;
+}
+
+static unsigned long d_cursor_shrink_count (struct shrinker *shrink, struct shrink_control *sc)
+{
   return d_cursor_unused;
 }

@@ -58,7 +66,8 @@ static int d_cursor_shrink(struct shrinker *shrink, struct shrink_control *sc)
  * shrunk only if system is really tight on memory.
  */
 static struct shrinker d_cursor_shrinker = {
-  .shrink = d_cursor_shrink,
+  .count_objects = d_cursor_shrink_count,
+  .scan_objects = d_cursor_shrink_scan,
   .seeks = DEFAULT_SEEKS << 3,
 };

--
To unsubscribe from this list: send the line "unsubscribe reiserfs-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

--
To unsubscribe from this list: send the line "unsubscribe reiserfs-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux File System Development]     [Linux BTRFS]     [Linux NFS]     [Linux Filesystems]     [Ext4 Filesystem]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite Forum]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Device Mapper]     [Linux Resources]

  Powered by Linux