I have a dual ppro 200MHZ W6LI motherboard.  I put 2.4.4-ac5 on last
night, and the machine hung at Freeing unused Kernel memory.  I
selectively backed off what I thought were relevant patches.  I got to
aic7xxx, and ac5 without it worked. I attached /proc/scsi/aic7xxx/0.

Andy Carlson                           |\      _,,,---,,_
[EMAIL PROTECTED]                ZZZzz /,`.-'`'    -.  ;-;;,_
BJC Health System                     |,4-  ) )-,_. ,\ (  `'-'
St. Louis, Missouri                  '---''(_/--'  `-'\_)
Cat Pics: http://andyc.dyndns.org

On Mon, 7 May 2001, Christoph Rohland wrote:

> Hi,
> 
> The appended patch does it's own accounting of shmem pages and adjust
> the page cache size to take these into account. So now again you will
> see shmem pages as used in top/vmstat etc. This confused a lot of
> people.
> 
> There is a uncertainty in the calculations since the vm may drop pages
> behind shmem and the number of shmem pages is estimated too high. This
> especially happens on truncate because first the page cache is reduced
> and later the shmem readjusts it's count.
> 
> To prevent negative cache sizes the adjustment is only done if
> shmem_nrpages > page_cache_size.
> 
> The latter part of the patch (all the init.c files) also exports the
> shmem page number to the shared memory field in meminfo. This means a
> change in semantics of this field but apparently a lot of people
> interpret this field exactly this way and it was not used any more
> 
> The patches are on top of my encapsulation patch.
> 
> Greetings
>               Christoph
> 
> diff -uNr 2.4.4-mSsu/fs/proc/proc_misc.c 2.4.4-mSsua/fs/proc/proc_misc.c
> --- 2.4.4-mSsu/fs/proc/proc_misc.c    Sun Apr 29 20:32:52 2001
> +++ 2.4.4-mSsua/fs/proc/proc_misc.c   Mon May  7 13:38:53 2001
> @@ -140,6 +140,17 @@
>  {
>       struct sysinfo i;
>       int len;
> +     unsigned int cached, shmem;
> +
> +     /*
> +      * There may be some inconsistency because shmem_nrpages
> +      * update is delayed to page_cache_size
> +      * We make sure the cached value does not get below zero 
> +      */
> +     cached = atomic_read(&page_cache_size);
> +     shmem  = atomic_read(&shmem_nrpages);
> +     if (shmem < cached)
> +             cached -= shmem;
>  
>  /*
>   * display in kilobytes.
> @@ -153,8 +164,8 @@
>                  "Swap: %8lu %8lu %8lu\n",
>                  B(i.totalram), B(i.totalram-i.freeram), B(i.freeram),
>                  B(i.sharedram), B(i.bufferram),
> -                B(atomic_read(&page_cache_size)), B(i.totalswap),
> -                B(i.totalswap-i.freeswap), B(i.freeswap));
> +             B(cached), B(i.totalswap),
> +             B(i.totalswap-i.freeswap), B(i.freeswap));
>          /*
>           * Tagged format, for easy grepping and expansion.
>           * The above will go away eventually, once the tools
> @@ -180,7 +191,7 @@
>                  K(i.freeram),
>                  K(i.sharedram),
>                  K(i.bufferram),
> -                K(atomic_read(&page_cache_size)),
> +             K(cached),
>               K(nr_active_pages),
>               K(nr_inactive_dirty_pages),
>               K(nr_inactive_clean_pages()),
> diff -uNr 2.4.4-mSsu/include/linux/shmem_fs.h 2.4.4-mSsua/include/linux/shmem_fs.h
> --- 2.4.4-mSsu/include/linux/shmem_fs.h       Wed May  2 18:36:05 2001
> +++ 2.4.4-mSsua/include/linux/shmem_fs.h      Mon May  7 12:52:00 2001
> @@ -17,6 +17,8 @@
>       unsigned long val;
>  } swp_entry_t;
>  
> +extern atomic_t shmem_nrpages;
> +
>  struct shmem_inode_info {
>       spinlock_t              lock;
>       struct semaphore        sem;
> diff -uNr 2.4.4-mSsu/mm/mmap.c 2.4.4-mSsua/mm/mmap.c
> --- 2.4.4-mSsu/mm/mmap.c      Sun Apr 29 20:33:01 2001
> +++ 2.4.4-mSsua/mm/mmap.c     Mon May  7 13:42:03 2001
> @@ -55,13 +55,24 @@
>        */
>  
>       long free;
> -     
> +     unsigned long cached, shmem;
> +
> +     /*
> +      * There may be some inconsistency because shmem_nrpages
> +      * update is delayed to the page_cache_size
> +      * We make sure the cached value does not get below zero 
> +      */
> +     cached = atomic_read(&page_cache_size);
> +     shmem  = atomic_read(&shmem_nrpages);
> +     if (cached > shmem)
> +             cached -= shmem;
> +
>          /* Sometimes we want to use more memory than we have. */
>       if (sysctl_overcommit_memory)
>           return 1;
>  
>       free = atomic_read(&buffermem_pages);
> -     free += atomic_read(&page_cache_size);
> +     free += cached;
>       free += nr_free_pages();
>       free += nr_swap_pages;
>  
> diff -uNr 2.4.4-mSsu/mm/shmem.c 2.4.4-mSsua/mm/shmem.c
> --- 2.4.4-mSsu/mm/shmem.c     Fri May  4 21:37:34 2001
> +++ 2.4.4-mSsua/mm/shmem.c    Mon May  7 11:13:27 2001
> @@ -3,7 +3,8 @@
>   *
>   * Copyright (C) 2000 Linus Torvalds.
>   *            2000 Transmeta Corp.
> - *            2000 Christoph Rohland
> + *            2000-2001 Christoph Rohland
> + *            2000-2001 SAP AG
>   * 
>   * This file is released under the GPL.
>   */
> @@ -45,6 +46,7 @@
>  
>  LIST_HEAD (shmem_inodes);
>  static spinlock_t shmem_ilock = SPIN_LOCK_UNLOCKED;
> +atomic_t shmem_nrpages = ATOMIC_INIT(0);
>  
>  #define BLOCKS_PER_PAGE (PAGE_SIZE/512)
>  
> @@ -52,6 +54,7 @@
>   * shmem_recalc_inode - recalculate the size of an inode
>   *
>   * @inode: inode to recalc
> + * @swap:  additional swap pages freed externally
>   *
>   * We have to calculate the free blocks since the mm can drop pages
>   * behind our back
> @@ -62,12 +65,14 @@
>   *
>   * So the mm freed 
>   * inodes->i_blocks/BLOCKS_PER_PAGE - 
> - *                   (inode->i_mapping->nrpages + info->swapped)
> + *                   (inode->i_mapping->nrpages + info->swapped)
>   *
>   * It has to be called with the spinlock held.
> + *
> + * The swap parameter is a performance hack for truncate.
>   */
>  
> -static void shmem_recalc_inode(struct inode * inode)
> +static void shmem_recalc_inode(struct inode * inode, unsigned long swap)
>  {
>       unsigned long freed;
>  
> @@ -79,6 +84,7 @@
>               spin_lock (&info->stat_lock);
>               info->free_blocks += freed;
>               spin_unlock (&info->stat_lock);
> +             atomic_sub(freed-swap, &shmem_nrpages);
>       }
>  }
>  
> @@ -195,7 +201,7 @@
>  out:
>       info->max_index = index;
>       info->swapped -= freed;
> -     shmem_recalc_inode(inode);
> +     shmem_recalc_inode(inode, freed);
>       spin_unlock (&info->lock);
>       up(&info->sem);
>  }
> @@ -250,14 +256,15 @@
>       entry = shmem_swp_entry(info, page->index);
>       if (IS_ERR(entry))      /* this had been allocted on page allocation */
>               BUG();
> -     shmem_recalc_inode(page->mapping->host);
> +     shmem_recalc_inode(page->mapping->host, 0);
>       error = -EAGAIN;
>       if (entry->val)
>               BUG();
>  
>       *entry = swap;
>       error = 0;
> -     /* Remove the from the page cache */
> +     /* Remove the page from the page cache */
> +     atomic_dec(&shmem_nrpages);
>       lru_cache_del(page);
>       remove_inode_page(page);
>  
> @@ -376,6 +383,7 @@
>       }
>  
>       /* We have the page */
> +     atomic_inc(&shmem_nrpages);
>       SetPageUptodate(page);
>       if (info->locked)
>               page_cache_get(page);
> @@ -1275,6 +1283,7 @@
>       return 0;
>  found:
>       add_to_page_cache(page, info->inode->i_mapping, offset + idx);
> +     atomic_inc(&shmem_nrpages);
>       set_page_dirty(page);
>       SetPageUptodate(page);
>       UnlockPage(page);
> diff -uNr 2.4.4-mSsu/arch/alpha/mm/init.c c/arch/alpha/mm/init.c
> --- 2.4.4-mSsu/arch/alpha/mm/init.c   Sun Apr 29 20:31:56 2001
> +++ c/arch/alpha/mm/init.c    Sun May  6 21:47:25 2001
> @@ -402,7 +402,7 @@
>  si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/arm/mm/init.c c/arch/arm/mm/init.c
> --- 2.4.4-mSsu/arch/arm/mm/init.c     Sun Apr 29 20:31:56 2001
> +++ c/arch/arm/mm/init.c      Sun May  6 21:47:01 2001
> @@ -647,7 +647,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram  = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram   = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/cris/mm/init.c c/arch/cris/mm/init.c
> --- 2.4.4-mSsu/arch/cris/mm/init.c    Sun Apr 29 20:31:57 2001
> +++ c/arch/cris/mm/init.c     Sun May  6 21:47:03 2001
> @@ -503,7 +503,7 @@
>  
>       i = max_mapnr;
>       val->totalram = 0;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       while (i-- > 0)  {
> diff -uNr 2.4.4-mSsu/arch/i386/mm/init.c c/arch/i386/mm/init.c
> --- 2.4.4-mSsu/arch/i386/mm/init.c    Sun Apr 29 20:32:08 2001
> +++ c/arch/i386/mm/init.c     Sun May  6 20:24:21 2001
> @@ -570,7 +570,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = totalhigh_pages;
> diff -uNr 2.4.4-mSsu/arch/ia64/mm/init.c c/arch/ia64/mm/init.c
> --- 2.4.4-mSsu/arch/ia64/mm/init.c    Sun Apr 29 20:32:11 2001
> +++ c/arch/ia64/mm/init.c     Sun May  6 21:47:05 2001
> @@ -151,7 +151,7 @@
>  si_meminfo (struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/m68k/mm/init.c c/arch/m68k/mm/init.c
> --- 2.4.4-mSsu/arch/m68k/mm/init.c    Sat Nov  4 18:11:22 2000
> +++ c/arch/m68k/mm/init.c     Sun May  6 21:47:45 2001
> @@ -217,7 +217,7 @@
>  
>      i = max_mapnr;
>      val->totalram = totalram_pages;
> -    val->sharedram = 0;
> +    val->sharedram = atomic_read(&shmem_nrpages);
>      val->freeram = nr_free_pages();
>      val->bufferram = atomic_read(&buffermem_pages);
>      while (i-- > 0) {
> diff -uNr 2.4.4-mSsu/arch/mips/mm/init.c c/arch/mips/mm/init.c
> --- 2.4.4-mSsu/arch/mips/mm/init.c    Sat Nov  4 18:11:22 2000
> +++ c/arch/mips/mm/init.c     Sun May  6 21:47:01 2001
> @@ -343,7 +343,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/mips64/mm/init.c c/arch/mips64/mm/init.c
> --- 2.4.4-mSsu/arch/mips64/mm/init.c  Sat Nov  4 18:11:22 2000
> +++ c/arch/mips64/mm/init.c   Sun May  6 21:47:04 2001
> @@ -411,7 +411,7 @@
>  si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/parisc/mm/init.c c/arch/parisc/mm/init.c
> --- 2.4.4-mSsu/arch/parisc/mm/init.c  Sun Dec 17 12:53:55 2000
> +++ c/arch/parisc/mm/init.c   Sun May  6 21:47:02 2001
> @@ -458,7 +458,7 @@
>  
>       i = max_mapnr;
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>  #if 0
> diff -uNr 2.4.4-mSsu/arch/ppc/mm/init.c c/arch/ppc/mm/init.c
> --- 2.4.4-mSsu/arch/ppc/mm/init.c     Wed Apr 11 12:36:13 2001
> +++ c/arch/ppc/mm/init.c      Sun May  6 21:47:05 2001
> @@ -336,7 +336,7 @@
>  
>       i = max_mapnr;
>       val->totalram = 0;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       while (i-- > 0)  {
> diff -uNr 2.4.4-mSsu/arch/s390/mm/init.c c/arch/s390/mm/init.c
> --- 2.4.4-mSsu/arch/s390/mm/init.c    Sun Apr 29 20:32:21 2001
> +++ c/arch/s390/mm/init.c     Sun May  6 21:47:03 2001
> @@ -271,7 +271,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/s390x/mm/init.c c/arch/s390x/mm/init.c
> --- 2.4.4-mSsu/arch/s390x/mm/init.c   Sun Apr 29 20:32:22 2001
> +++ c/arch/s390x/mm/init.c    Sun May  6 21:47:18 2001
> @@ -284,7 +284,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>          val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = 0;
> diff -uNr 2.4.4-mSsu/arch/sh/mm/init.c c/arch/sh/mm/init.c
> --- 2.4.4-mSsu/arch/sh/mm/init.c      Sun Apr 29 20:32:23 2001
> +++ c/arch/sh/mm/init.c       Sun May  6 21:47:26 2001
> @@ -215,7 +215,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = totalhigh_pages;
> diff -uNr 2.4.4-mSsu/arch/sparc/mm/init.c c/arch/sparc/mm/init.c
> --- 2.4.4-mSsu/arch/sparc/mm/init.c   Sun Apr 29 20:32:23 2001
> +++ c/arch/sparc/mm/init.c    Sun May  6 21:47:04 2001
> @@ -534,7 +534,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = totalram_pages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>       val->totalhigh = totalhigh_pages;
> diff -uNr 2.4.4-mSsu/arch/sparc64/mm/init.c c/arch/sparc64/mm/init.c
> --- 2.4.4-mSsu/arch/sparc64/mm/init.c Sun Apr 29 20:32:25 2001
> +++ c/arch/sparc64/mm/init.c  Sun May  6 21:47:02 2001
> @@ -1512,7 +1512,7 @@
>  void si_meminfo(struct sysinfo *val)
>  {
>       val->totalram = num_physpages;
> -     val->sharedram = 0;
> +     val->sharedram = atomic_read(&shmem_nrpages);
>       val->freeram = nr_free_pages();
>       val->bufferram = atomic_read(&buffermem_pages);
>  
> 
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to [EMAIL PROTECTED]
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 
Adaptec AIC7xxx driver version: 6.1.11
aic7880: Wide Channel A, SCSI Id=7, 16/255 SCBs
Channel A Target 0 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
        Goal: 10.000MB/s transfers (10.000MHz, offset 15)
        Curr: 10.000MB/s transfers (10.000MHz, offset 15)
        Channel A Target 0 Lun 0 Settings
                Commands Queued 3
                Commands Active 0
                Command Openings 1
                Max Tagged Openings 0
                Device Queue Frozen Count 0
Channel A Target 1 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
        Goal: 20.000MB/s transfers (10.000MHz, offset 8, 16bit)
        Curr: 20.000MB/s transfers (10.000MHz, offset 8, 16bit)
        Channel A Target 1 Lun 0 Settings
                Commands Queued 153
                Commands Active 0
                Command Openings 253
                Max Tagged Openings 253
                Device Queue Frozen Count 0
Channel A Target 2 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
        Goal: 20.000MB/s transfers (10.000MHz, offset 8, 16bit)
        Curr: 20.000MB/s transfers (10.000MHz, offset 8, 16bit)
        Channel A Target 2 Lun 0 Settings
                Commands Queued 1486
                Commands Active 0
                Command Openings 253
                Max Tagged Openings 253
                Device Queue Frozen Count 0
Channel A Target 3 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 4 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 5 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 6 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 7 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 8 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 9 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 10 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 11 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 12 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 13 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 14 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)
Channel A Target 15 Negotiation Settings
        User: 40.000MB/s transfers (20.000MHz, offset 255, 16bit)

Reply via email to