On Wed, May 30, 2012 at 09:33:38PM -0700, Philip Guenther wrote:
> The problem was in the handling of munlock(addr, 0).  The zero length case 
> wasn't detected, resulting in an iterator being started after its end 
> point.  :-/
> 
> The diff below fixes the code to have munlock() return success when len==0 
> and adds an assertion to catch the iterators getting screwed up by other 
> means.  With this, I was unable to get bitcoind to crash my system.

Weird case... okay by me.

> 
> 
> Philip
> 
> Index: uvm/uvm_map.c
> ===================================================================
> RCS file: /cvs/src/sys/uvm/uvm_map.c,v
> retrieving revision 1.153
> diff -u -p -r1.153 uvm_map.c
> --- uvm/uvm_map.c     19 Apr 2012 12:42:03 -0000      1.153
> +++ uvm/uvm_map.c     31 May 2012 04:30:19 -0000
> @@ -2054,6 +2054,8 @@ uvm_map_pageable(struct vm_map *map, vad
>  
>       if (start > end)
>               return EINVAL;
> +     if (start == end)
> +             return 0;       /* nothing to do */
>       if (start < map->min_offset)
>               return EFAULT; /* why? see first XXX below */
>       if (end > map->max_offset)
> @@ -2106,8 +2108,10 @@ uvm_map_pageable(struct vm_map *map, vad
>                       error = EINVAL;
>                       goto out;
>               }
> -     } else
> +     } else {
> +             KASSERT(last != first);
>               last = RB_PREV(uvm_map_addr, &map->addr, last);
> +     }
>  
>       /*
>        * Wire/unwire pages here.

Reply via email to