On 08/22/2011 21:36, Matthew Dillon wrote:
     The limitation was ONLY due to a *minor* 32-bit integer overflow in one
     or two *intermediate* calculations in the radix tree code, which I
     long ago fixed in DragonFly.

     Just find the changes in the DFly codebase and determine if they need
     to be applied.

     The swap space radix code (which I wrote long ago) is in page-sized
     blocks, so you actually probably want to keep using a 32-bit integer for
     the block number there to keep the physical memory reservation required
     for the radix tree low.  If you just pop the base block id up to 64 bits
     without adjusting the radix code to overlay a 64 bit bitmap on it you
     waste a lot of physical memory for the same amount of swap reservation.

Unfortunately, in FreeBSD, when daddr_t was increased to 64 bits a few years ago, the bitmap size was not increased. So, we have been wasting about half the space used by the blist structure for some time now. I expect that we'll fix this after the current code freeze ends.

However, as Alexander observed, the primary reason for the 32GB limit on the size of a swap partition was artificial. The limit was being implemented in the wrong place. It was being performed before the conversion from 512 byte blocks to 4KB pages. Since a blist is managing swap space at the granularity of pages and the limit is imposed by the blist code, the check should come after the conversion. Just by moving the check to its proper place, the effective limit can be increased from 32GB to 256GB. Kostik committed such a change earlier today.

Alan


_______________________________________________
freebsd-stable@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-stable
To unsubscribe, send any mail to "freebsd-stable-unsubscr...@freebsd.org"

Reply via email to