milis/talimatname/temel-ek/kernel-lts-e1/vfs-ino.patch

23 lines
556 B
Diff

diff --git a/fs/inode.c b/fs/inode.c
index 1be5f90..b6678aa 100644
--- a/fs/inode.c
+++ b/fs/inode.c
@@ -844,6 +844,8 @@ unsigned int get_next_ino(void)
unsigned int *p = &get_cpu_var(last_ino);
unsigned int res = *p;
+start:
+
#ifdef CONFIG_SMP
if (unlikely((res & (LAST_INO_BATCH-1)) == 0)) {
static atomic_t shared_last_ino;
@@ -856,7 +858,7 @@ unsigned int get_next_ino(void)
res++;
/* get_next_ino should not provide a 0 inode number */
if (unlikely(!res))
- res++;
+ goto start;
*p = res;
put_cpu_var(last_ino);
return res;