Merge git://git.kernel.org/pub/scm/linux/kernel/git/arjan/linux-2.6-async-for-30
authorLinus Torvalds <torvalds@linux-foundation.org>
Sat, 28 Mar 2009 21:00:33 +0000 (14:00 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Sat, 28 Mar 2009 21:00:33 +0000 (14:00 -0700)
* git://git.kernel.org/pub/scm/linux/kernel/git/arjan/linux-2.6-async-for-30:
  fastboot: remove duplicate unpack_to_rootfs()
  ide/net: flip the order of SATA and network init
  async: remove the temporary (2.6.29) "async is off by default" code

Fix up conflicts in init/initramfs.c manually

1  2 
init/initramfs.c

diff --combined init/initramfs.c
@@@ -5,6 -5,7 +5,7 @@@
  #include <linux/fcntl.h>
  #include <linux/delay.h>
  #include <linux/string.h>
+ #include <linux/dirent.h>
  #include <linux/syscalls.h>
  #include <linux/utime.h>
  
@@@ -166,8 -167,6 +167,6 @@@ static __initdata char *victim
  static __initdata unsigned count;
  static __initdata loff_t this_header, next_header;
  
- static __initdata int dry_run;
  static inline void __init eat(unsigned n)
  {
        victim += n;
@@@ -229,10 -228,6 +228,6 @@@ static int __init do_header(void
        parse_header(collected);
        next_header = this_header + N_ALIGN(name_len) + body_len;
        next_header = (next_header + 3) & ~3;
-       if (dry_run) {
-               read_into(name_buf, N_ALIGN(name_len), GotName);
-               return 0;
-       }
        state = SkipIt;
        if (name_len <= 0 || name_len > PATH_MAX)
                return 0;
@@@ -303,8 -298,6 +298,6 @@@ static int __init do_name(void
                free_hash();
                return 0;
        }
-       if (dry_run)
-               return 0;
        clean_path(collected, mode);
        if (S_ISREG(mode)) {
                int ml = maybe_link();
@@@ -390,13 -383,11 +383,13 @@@ static int __init write_buffer(char *bu
        return len - count;
  }
  
 -static void __init flush_buffer(char *buf, unsigned len)
 +static int __init flush_buffer(void *bufv, unsigned len)
  {
 +      char *buf = (char *) bufv;
        int written;
 +      int origLen = len;
        if (message)
 -              return;
 +              return -1;
        while ((written = write_buffer(buf, len)) < len && !message) {
                char c = buf[written];
                if (c == '0') {
                } else
                        error("junk in compressed archive");
        }
 +      return origLen;
  }
  
 -/*
 - * gzip declarations
 - */
 -
 -#define OF(args)  args
 -
 -#ifndef memzero
 -#define memzero(s, n)     memset ((s), 0, (n))
 -#endif
 -
 -typedef unsigned char  uch;
 -typedef unsigned short ush;
 -typedef unsigned long  ulg;
 -
 -#define WSIZE 0x8000    /* window size--must be a power of two, and */
 -                      /*  at least 32K for zip's deflate method */
 -
 -static uch *inbuf;
 -static uch *window;
 -
 -static unsigned insize;  /* valid bytes in inbuf */
 -static unsigned inptr;   /* index of next byte to be processed in inbuf */
 -static unsigned outcnt;  /* bytes in output buffer */
 -static long bytes_out;
 -
 -#define get_byte()  (inptr < insize ? inbuf[inptr++] : -1)
 -              
 -/* Diagnostic functions (stubbed out) */
 -#define Assert(cond,msg)
 -#define Trace(x)
 -#define Tracev(x)
 -#define Tracevv(x)
 -#define Tracec(c,x)
 -#define Tracecv(c,x)
 -
 -#define STATIC static
 -#define INIT __init
 -
 -static void __init flush_window(void);
 -static void __init error(char *m);
 -
 -#define NO_INFLATE_MALLOC
 +static unsigned my_inptr;   /* index of next byte to be processed in inbuf */
  
 -#include "../lib/inflate.c"
 -
 -/* ===========================================================================
 - * Write the output window window[0..outcnt-1] and update crc and bytes_out.
 - * (Used for the decompressed data only.)
 - */
 -static void __init flush_window(void)
 -{
 -      ulg c = crc;         /* temporary variable */
 -      unsigned n;
 -      uch *in, ch;
 -
 -      flush_buffer(window, outcnt);
 -      in = window;
 -      for (n = 0; n < outcnt; n++) {
 -              ch = *in++;
 -              c = crc_32_tab[((int)c ^ ch) & 0xff] ^ (c >> 8);
 -      }
 -      crc = c;
 -      bytes_out += (ulg)outcnt;
 -      outcnt = 0;
 -}
 +#include <linux/decompress/generic.h>
  
- static char * __init unpack_to_rootfs(char *buf, unsigned len, int check_only)
+ static char * __init unpack_to_rootfs(char *buf, unsigned len)
  {
        int written;
 +      decompress_fn decompress;
 +      const char *compress_name;
 +      static __initdata char msg_buf[64];
 +
        header_buf = kmalloc(110, GFP_KERNEL);
        symlink_buf = kmalloc(PATH_MAX + N_ALIGN(PATH_MAX) + 1, GFP_KERNEL);
        name_buf = kmalloc(N_ALIGN(PATH_MAX), GFP_KERNEL);
 -      window = kmalloc(WSIZE, GFP_KERNEL);
 -      if (!window || !header_buf || !symlink_buf || !name_buf)
 +
 +      if (!header_buf || !symlink_buf || !name_buf)
                panic("can't allocate buffers");
 +
        state = Start;
        this_header = 0;
        message = NULL;
                        continue;
                }
                this_header = 0;
 -              insize = len;
 -              inbuf = buf;
 -              inptr = 0;
 -              outcnt = 0;             /* bytes in output buffer */
 -              bytes_out = 0;
 -              crc = (ulg)0xffffffffL; /* shift register contents */
 -              makecrc();
 -              gunzip();
 +              decompress = decompress_method(buf, len, &compress_name);
 +              if (decompress)
 +                      decompress(buf, len, NULL, flush_buffer, NULL,
 +                                 &my_inptr, error);
 +              else if (compress_name) {
 +                      if (!message) {
 +                              snprintf(msg_buf, sizeof msg_buf,
 +                                       "compression method %s not configured",
 +                                       compress_name);
 +                              message = msg_buf;
 +                      }
 +              }
                if (state != Reset)
 -                      error("junk in gzipped archive");
 -              this_header = saved_offset + inptr;
 -              buf += inptr;
 -              len -= inptr;
 +                      error("junk in compressed archive");
 +              this_header = saved_offset + my_inptr;
 +              buf += my_inptr;
 +              len -= my_inptr;
        }
        dir_utime();
 -      kfree(window);
        kfree(name_buf);
        kfree(symlink_buf);
        kfree(header_buf);
@@@ -523,24 -566,73 +515,73 @@@ skip
        initrd_end = 0;
  }
  
+ #define BUF_SIZE 1024
+ static void __init clean_rootfs(void)
+ {
+       int fd;
+       void *buf;
+       struct linux_dirent64 *dirp;
+       int count;
+       fd = sys_open("/", O_RDONLY, 0);
+       WARN_ON(fd < 0);
+       if (fd < 0)
+               return;
+       buf = kzalloc(BUF_SIZE, GFP_KERNEL);
+       WARN_ON(!buf);
+       if (!buf) {
+               sys_close(fd);
+               return;
+       }
+       dirp = buf;
+       count = sys_getdents64(fd, dirp, BUF_SIZE);
+       while (count > 0) {
+               while (count > 0) {
+                       struct stat st;
+                       int ret;
+                       ret = sys_newlstat(dirp->d_name, &st);
+                       WARN_ON_ONCE(ret);
+                       if (!ret) {
+                               if (S_ISDIR(st.st_mode))
+                                       sys_rmdir(dirp->d_name);
+                               else
+                                       sys_unlink(dirp->d_name);
+                       }
+                       count -= dirp->d_reclen;
+                       dirp = (void *)dirp + dirp->d_reclen;
+               }
+               dirp = buf;
+               memset(buf, 0, BUF_SIZE);
+               count = sys_getdents64(fd, dirp, BUF_SIZE);
+       }
+       sys_close(fd);
+       kfree(buf);
+ }
  static int __init populate_rootfs(void)
  {
        char *err = unpack_to_rootfs(__initramfs_start,
-                        __initramfs_end - __initramfs_start, 0);
+                        __initramfs_end - __initramfs_start);
        if (err)
 -              panic(err);
 +              panic(err);     /* Failed to decompress INTERNAL initramfs */
        if (initrd_start) {
  #ifdef CONFIG_BLK_DEV_RAM
                int fd;
                printk(KERN_INFO "checking if image is initramfs...");
                err = unpack_to_rootfs((char *)initrd_start,
-                       initrd_end - initrd_start, 1);
+                       initrd_end - initrd_start);
                if (!err) {
                        printk(" it is\n");
-                       unpack_to_rootfs((char *)initrd_start,
-                               initrd_end - initrd_start, 0);
                        free_initrd();
                        return 0;
+               } else {
+                       clean_rootfs();
+                       unpack_to_rootfs(__initramfs_start,
+                                __initramfs_end - __initramfs_start);
                }
                printk("it isn't (%s); looks like an initrd\n", err);
                fd = sys_open("/initrd.image", O_WRONLY|O_CREAT, 0700);
  #else
                printk(KERN_INFO "Unpacking initramfs...");
                err = unpack_to_rootfs((char *)initrd_start,
-                       initrd_end - initrd_start, 0);
+                       initrd_end - initrd_start);
 -              if (err)
 -                      panic(err);
 -              printk(" done\n");
 +              if (err) {
 +                      printk(" failed!\n");
 +                      printk(KERN_EMERG "%s\n", err);
 +              } else {
 +                      printk(" done\n");
 +              }
                free_initrd();
  #endif
        }