big-ticket items added
[ikiwiki.git] / release32 / index.mdwn
da4e7f03 1# DragonFly Release 3.2
3## 22 October 2012 (3.2.1 release)
6The DragonFly 3.0 release is here!
8## Big-ticket items
fa7ea09f 10### Performance improvements under database load
da4e7f03 11
fa7ea09f 12Significant work has gone into the scheduler to improve performance, using postgres benchmarking as a measure. See
13[the PDF of graphed results]( to see the improvments. DragonFly should be now one of the best selections for Postgres and other databases.
d7de0cab 14
fa7ea09f 15### New USB stack
da4e7f03 16
fa7ea09f 17[USB4BSD]( has been incorporated into this release. More USB devices are compatible with DragonFly, and xhci (USB 3.0) users may be able to take full advantage of their newer hardware. Since this is a new feature, it is available in 3.2 but *not* built by default. See the [original announcement]( for how to do so.
da4e7f03 18
19## Availability
21Four release options are now available for 32-bit as well as for 64-bit. 64-bit installations are recommended if you do not need the linux emulation layer.
23* An ISO, to be burned to a physical CD or used as an image to install a virtual machine.
24* A bootable USB disk-key image. (minimum 2G USB stick needed)
25* A GUI bootable ISO image with a full X environment. DVD disc required.
26* A GUI bootable USB disk-key image with a full X environment. (minimum 4G USB stick needed)
27* The GUI images also include a snapshot of our git repos in /usr/src/.git and /usr/pkgsrc/.git which can be incrementally updated after the installation.
29The release ISO images should be available on most of the [[mirrors|mirrors]]. If the ISO is not available on a certain mirror, please try another one or download it from the DragonFly master site. Each image is in the "Live CD" format, meaning that it boots into a running and fully functional DragonFly system, which can be used for testing or system recovery tasks as well as installation. Check the [hardware page]( or boot a Live CD to check for compatibility.
31The GUI bootable USB image also contains the DragonFly git repo in /usr/src and the pkgsrc git repo in /usr/pkgsrc. The code can be trivially checked out using these repos and can be incrementally updated from master sites, post-install.
33### MD5 sums
35MD5 sums for the compressed images:
37* MD5 (dfly-i386-3.0.1_REL.img.bz2) = 8f812dbcb9c0ca28a61f5a0ae1e35a9e
41MD5 sums for the uncompressed images:
43* MD5 (dfly-i386-3.0.1_REL.img) = a7cc87b26c04a179476f9c3f20f8ce9d
48### pkgsrc packages
50We offer roughly 10,000 pre-built [pkgsrc]( packages for this release. The [pkg_radd(1)]( utility may be used to download pre-built binary packages. The path can be overridden by setting BINPKG_BASE in `/etc/pkg_radd.conf`.
52To get a list of all packages, let [pkg_search(1)]( download the summary file for that release:
54 # pkg_search -d
56We supply a Makefile in `/usr` to track the pkgsrc tree and we supply a Git mirror of the NetBSD pkgsrc CVS repo at `git://`. We recommend that users use it, instead of pulling from NetBSD with CVS. Our Git mirror is updated several times a day. Type 'make' in /usr to see the available commands for performing these actions.
58## DragonFly 3.0 Special Installation and Upgrade Notes
60**Disk size warning** - Unless your hard disk is 50G or larger, we recommend doing a UFS install and not the default HAMMER install. We also recommend installing from the CD ISO, not the GUI .img, for smaller drives. A more serious installation should use HAMMER with at least 50G of disk space and can install from the GUI .img. HAMMER on smaller disk drives is possible but requires careful pruning to keep from filling the disk with file history.
62**Virtual PC users** - Virtual PC does not supply serial numbers for the virtual disks. The system may need to be manually directed in the boot loader if the disk identifier changes. (Hit ? in the boot loader for a list of available volumes.)
64**Qemu users** - If you see a large number of error messages on the console when booting, you may need to boot DragonFly with ACPI disabled. This can be done in the menu presented at initial boot. If that doesn't help, try placing hw.ioapic_enable=0 in /boot/loader.conf.
66**Installer Crypt Options** - The installer can encrypt the root volume and the swap volume. It will not work properly for other volumes despite any additional check-boxes you might see. Installer and boot-time support works but is still a bit rough around the edges. Performance will be relatively high on multi-core machines.
68**Remaining issues** -
71## DragonFly 3.2.1 Release Notes
73> ### Kernel changes
33410790 75* Many bug fixes, greatly improving stability. More robust pcb_onfault handling, fixed issues in the namecache module, VM system, etc.
77* Removed several arbitrary bounds on kernel caches (such as the buffer cache) for x86-64.
79* Improved control over BREAK_TO_DEBUGGER by adding run-time sysctls.
81* Removed sio console baud switching when console & getty/login is running on the same serial port.
83* mmap() now segment-aligns mappings when reasonable to do so.
85* KTR logging is now frozen on entry to panic.
da4e7f03 86
96930242 87* Removed size cap for tmpfs. This created problems when mounting tmpfs partitions from fstab prior to swap being turned on.
89* Numerous buffer cache clustering performance improvements.
91* Numerous vkernel related fixes.
a4c07330 93* Implicit 64KB I/O request size limitations have been removed. All block devices can now cluster I/O requests up to MAXPHYS (128KB) if they support it.
95* A new filesystem-independent quota subsystem has been added. See vquota(8)
9d63f830 97* Fixed floating point rounding for long double in x86_64 platform
a4c07330 99> ### Hardware changes
101* Watchdog drivers for Intel and AMD chipsets have been imported from FreeBSD. See ichwd(4) and amdsbwd(4).
103* A ixgbe(4) driver for Intel 10Gb/s ethernet adapters has been added.
da4e7f03 104
105> ### New Multiprocessor-safe Work
81b597c4 106
107* Introduced a new cpu topology aware scheduler, usched_dfly, and made it the default. This scheduler implements several weighted algorithms and will first try to schedule threads to different sockets (to make best use of on-chip caches). As the load increases threads are then scheduled to real cores, and finally will be scheduled to hyper-threads. Threads with similar load characteristics tend to get spread out more. The scheduler also implements wait/wakeup pairing detection and tries to move related threads closer together to reduce inter-socket cache coherency bandwidth and share L3 caches.
109* Greatly reduced SMP bottlenecks in the unix domain socket code.
111* Implemented shared tokens to reduce unnecessary bottlenecks in the VM system, particularly for forked and threaded processes.
113* Introduced a major pmap optimization for x86-64 which allows page table pages to be shared between UNRELATED processes (so it works for process's separately exec'd or forked), in situations where those processes are mmap()ing the same thing. This feature works extremely well for both sysv shared memory and mmap()-based shared memory. In tests with postgres and a 6GB shared memory block the prior memory consumption from forking is now gone. This page table sharing works even better than the original shm_use_phys sysctl. Also observed significantly faster X application startup.
33410790 114
115* Removed bottlenecks from the SYSV semaphore module and fixed numerous timing races.
117* Added ability to bypass hardware timer read for gettimeofday(), added additional CLOCK_* defines for clock_gettime() and friends.
da4e7f03 119> ### Userland changes
33410790 120
121* mount now sniffs the label for hints on what type of filesystem is being mounted, when not otherwise specified. UFS is only assumed if no information can be garnered from the sniffing.
5a2fc42a 123* Added support for DT_GNU_HASH elf sections (RTLD).
ecfe9d07 124Essentially DT_GNU_HASH is a GNU extension to the ELF
125format that allows symbol searches much faster than the System V ABI
126standard hash does.
127For very large programs written in languages such as c++ that tend to link in many libraries with many symbols, the reduction in start-time can be dramatic.
5a2fc42a 128Base compilers were updated to generate both SysV and GNU hashes for every dynamic binary and the GNU hash will be used preferentially by the dynamic linker.
1af8e122 130* Dynamic linker (RTLD)
131Added support for preinit, init, and fini arrays
132Added support for DT_RUNPATH
133Added support for -z nodefaultlib flag
134Updated ELF filter implementation
135Added support for dflopen
136Added two new directives to libmap.conf
dee6b11d 137Synced general bug fixes from FreeBSD
139* Support exception handling on statically linked binaries
da4e7f03 140
9d63f830 141* Imported terminfo and deprecated termcap
142DragonFly is the only BSD using terminfo for its terminal database. Termcap is still installed but terminfo has a higher priority and is accessed first.
15a54c90 144* LDVER support added
145If the environment variable LDVER is set as "" then the gold linker will be used over the default ld.bfd linker, similar to compiler-focused CCVER. Invalid values are ignored.
147* cut - synced with FreeBSD
bcbb21ce 149* realpath - missing posix functionality added (From FreeBSD)
151* TUI mode added to kgdb, fixed on gdb
b370399d 153* boot2 loader reworked for more efficient code so gcc4.6, gcc4.7, and clang will be able to build it within the size limit
da4e7f03 155> ### Removals
158> ### Contributed Software
159* Shipping with pkgsrc-2012Q3 built packages.
1af8e122 160* removed gcc 4.1
161* added libedit 2012-03-11 from NetBSD
162* added libmpc 1.0.1
163* added gcc 4.7.2
164* grep 2.9 replaced with grep 2.12
165* gdb 7.3 replaced with gdb 7.4.1
166* zlib 1.2.5 replaced with zlib 1.2.7
167* ncurses 5.7 replaced with ncurses 5.9
168* libgmp 5.0.2 replaced with libgmp 5.0.5
dee6b11d 169* gcc 4.4 updated to final release 4.4.7
da4e7f03 170
171>### Security related