Get more from commits into the release notes
[ikiwiki.git] / release32 / index.mdwn
1 # DragonFly Release 3.2
2
3 ## 22 October 2012 (3.2.1 release)
4
5
6 The DragonFly 3.0 release is here!  
7
8 ## Big-ticket items
9
10 ### Performance improvements under database load
11
12 Significant work has gone into the scheduler to improve performance, using postgres benchmarking as a measure.  See 
13 [the PDF of graphed results](http://lists.dragonflybsd.org/pipermail/users/attachments/20121010/7996ff88/attachment-0002.pdf) to see the improvements.  DragonFly should be now one of the best selections for Postgres and other databases.
14
15 ### New USB stack
16
17 [USB4BSD](http://www.selasky.org/hans_petter/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](http://lists.dragonflybsd.org/pipermail/users/2012-October/017542.html) for how to do so.
18
19 ## Availability
20
21 Four 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.
22
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.
28
29 The 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](http://www.dragonflybsd.org/docs/supportedhardware/) or boot a Live CD to check for compatibility.  
30
31 The 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.
32
33 ### MD5 sums
34
35 MD5 sums for the compressed images:
36
37 * MD5 (dfly-i386-3.0.1_REL.img.bz2) = 8f812dbcb9c0ca28a61f5a0ae1e35a9e
38 foo
39 foo
40
41 MD5 sums for the uncompressed images:
42
43 * MD5 (dfly-i386-3.0.1_REL.img) = a7cc87b26c04a179476f9c3f20f8ce9d
44 foo
45 foo
46
47
48 ### pkgsrc packages
49
50 We offer roughly 10,000 pre-built [pkgsrc](http://www.pkgsrc.org) packages for this release. The [pkg_radd(1)](http://leaf.dragonflybsd.org/cgi/web-man?command=pkg_radd&section=ANY) utility may be used to download pre-built binary packages.  The path can be overridden by setting BINPKG_BASE in `/etc/pkg_radd.conf`.
51
52 To get a list of all packages, let [pkg_search(1)](http://leaf.dragonflybsd.org/cgi/web-man?command=pkg_search&section=ANY) download the summary file for that release:
53
54     # pkg_search -d
55
56 We supply a Makefile in `/usr` to track the pkgsrc tree and we supply a Git mirror of the NetBSD pkgsrc CVS repo at `git://git.dragonflybsd.org/pkgsrcv2.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.
57
58 ## DragonFly 3.0 Special Installation and Upgrade Notes
59
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.
61
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.)
63
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.
65
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.
67
68 **Remaining issues** - 
69
70
71 ## DragonFly 3.2.1 Release Notes
72
73 > ### Kernel changes
74
75 * Many bug fixes, greatly improving stability.  More robust pcb_onfault handling, fixed issues in the namecache module, VM system, etc.
76 * Removed several arbitrary bounds on kernel caches (such as the buffer cache) for x86-64.
77 * Improved control over BREAK_TO_DEBUGGER by adding run-time sysctls.
78 * Removed sio console baud switching when console & getty/login is running on the same serial port.
79 * mmap() now segment-aligns mappings when reasonable to do so.
80 * KTR logging is now frozen on entry to panic.
81 * Removed size cap for tmpfs.  This created problems when mounting tmpfs partitions from fstab prior to swap being turned on.
82 * Numerous buffer cache clustering performance improvements.
83 * Numerous vkernel related fixes.
84 * Implicit 64KB I/O request size limitations have been removed. All block devices can now cluster I/O requests up to MAXPHYS (currently 128KB) if they support it. 
85 * A new filesystem-independent quota subsystem has been added. See vquota(8)
86 * Fixed floating point rounding for long double in x86_64 platform
87 * Implemented RFC1405 and SACK rescue retransmission 
88 * Several Google Summer of Code projects added for PUFFS support, scheduler changes.
89 * tmpfs filesystems can be exported over NFS
90
91 > ### Hardware changes
92
93 * A driver for the new Ivy Bridge random number generator has been added
94 * Our ACPI reference implementation has been updated
95 * Smart Battery System support has been added
96 * Many ACPI and interrupt routing improvements, as well as bug fixes and workarounds for broken hardware
97 * Watchdog drivers for Intel and AMD chipsets have been imported from FreeBSD. See ichwd(4) and amdsbwd(4).
98 * Many ethernet drivers have been updated and reworked to fix bugs and increase performance, including MSI support
99 * A ixgbe(4) driver for Intel 10Gb/s ethernet adapters has been added.
100 * Many drivers for hardware RAID adapters have been updated
101 * A hpt27xx(4) driver for HighPoint RocketRAID 27xx SAS controllers has been added
102 * A hptrr(4) driver for HighPoint RocketRAID 17xx, 22xx, 23xx and 25xx has been added
103  
104 > ### New Multiprocessor-safe Work
105
106 * 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.
107 * Greatly reduced SMP bottlenecks in the unix domain socket code.
108 * Implemented shared tokens to reduce unnecessary bottlenecks in the VM system, particularly for forked and threaded processes.
109 * 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.
110 * Removed bottlenecks from the SYSV semaphore module and fixed numerous timing races.
111 * Added ability to bypass hardware timer read for gettimeofday(), added additional CLOCK_* defines for clock_gettime() and friends.
112  
113 > ### Userland changes
114
115 * 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.
116 * Added support for DT_GNU_HASH elf sections (RTLD).
117 Essentially DT_GNU_HASH is a GNU extension to the ELF
118 format that allows symbol searches much faster than the System V ABI
119 standard hash does.  
120 For 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.
121 Base 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.
122 * Dynamic linker (RTLD)  Added support for preinit, init, and fini arrays, DT_RUNPATH, -z nodefaultlib flag, and dflopen.  Updated ELF filter implementation and added two new directives to libmap.conf, along with general bug fixes from FreeBSD
123 * Support exception handling on statically linked binaries
124 * Imported terminfo and deprecated termcap.  DragonFly is the only BSD using terminfo for its terminal database.  Termcap is still installed, but terminfo has a higher priority and is accessed first.
125 * LDVER support added
126 If the environment variable LDVER is set as "ld.gold" then the gold linker will be used over the default ld.bfd linker, similar to compiler-focused CCVER.  Invalid values are ignored.
127 * cut - synced with FreeBSD
128 * realpath - missing posix functionality added (From FreeBSD)
129 * TUI mode added to kgdb, fixed on gdb
130 * boot2 loader reworked for more efficient code so gcc4.6, gcc4.7, and clang will be able to build it within the size limit
131 * dragonfly.pool.ntp.org now exists and is used by default for network time
132 * LVM stripe support in rconfig
133 * New, much faster scheduler, usched_dfly, added and made default.
134
135
136 > ### Removals
137
138 * kzip
139
140 > ### Contributed Software
141 * Shipping with pkgsrc-2012Q3 built packages.
142 * Removed gcc 4.1
143 * Added libedit 2012-03-11 from NetBSD
144 * Added libmpc 1.0.1
145 * Added gcc 4.7.2
146 * gcc 4.4 updated to 4.4.7
147 * grep updated to 2.12
148 * gdb updated to 7.4.1
149 * zlib updated to 1.2.7
150 * ncurses updated to 5.9
151 * libgmp updated to 5.0.5
152 * gcc 4.4 updated to final release 4.4.7
153 * OpenSSL updated to 1.01c
154 * tzdata updated to tzdata2012f
155 * sh updated from FreeBSD
156 * libpcap updated to 1.3.0
157 * dhclient updated from OpenBSD
158 * OpenPAM updated to 'Micrampelis'
159 * xz updated to 5.0.4
160 * tnftp updated to newest NetBSD version
161 * libarchive updated to 3.0.4
162 * tcpdump updated to 4.3.0
163 * file updated to 5.11
164
165 >### Security related