DragonFlyBSD/src 2cc1fb6sys/gnu/vfs/ext2fs ext2_lookup.c

ext2fs - Clear CNP_PDIRUNLOCK flag after a lookup.

vop_compat_nresolve() unlocks the vnode when flag CNP_PDIRUNLOCK
is set, so either we clear the flag or avoid unlocking the vnode
after an ext2_lookup().

DragonFly-bug: http://bugs.dragonflybsd.org/issues/2454

Reported by: Skylar Hawk
DeltaFile
+3-1sys/gnu/vfs/ext2fs/ext2_lookup.c
+3-11 files

DragonFlyBSD/src 3da47b3share/zoneinfo northamerica asia

Sync zoneinfo database with tzdata2012i from ftp://ftp.iana.org/tz/releases

* asia: Comment typo fix.

* northamerica: Cuba switched back to standard time on 2012-11-04, 01:00.
DeltaFile
+8-1share/zoneinfo/northamerica
+1-1share/zoneinfo/asia
+9-22 files

DragonFlyBSD/src 1a54018share/zoneinfo asia southamerica

Sync zoneinfo database with tzdata2012h from ftp://ftp.iana.org/tz/releases

* asia:
    Israel has new DST rules next year (thanks to Ephraim Silverberg).
    Jordan stays on DST this winter (thanks to Steffen Thorsen).

* southamerica:
    Bahia no longer has DST (thanks to Kelley Cook).
    Tocantins has DST (thanks to Rodrigo Severo).
DeltaFile
+45-37share/zoneinfo/asia
+13-2share/zoneinfo/southamerica
+58-392 files

DragonFlyBSD/src 873a592share/zoneinfo australasia asia

Sync zoneinfo database with tzdata2012g from ftp://ftp.iana.org/tz/releases

* asia (Asia/Gaza, Asia/Hebron): Fall transition was Sep 21, not Sep 28.
    Thanks to Steffen Thorsen for this.

* australasia (Pacific/Apia): New DST rules for Western Samoa.
    Thanks to Nicholas Pereira for the heads-up and to Robert Elz
    for coding up the rules.
DeltaFile
+19-2share/zoneinfo/australasia
+4-2share/zoneinfo/asia
+23-42 files

DragonFlyBSD/src ec2a337sys/dev/netif/msk if_msk.c, sys/netgraph7/atm ngatmbase.c

kernel: Fix a few more mbuf MB_* vs. kmalloc M_* flag misuses.
DeltaFile
+3-3sys/netinet/sctp_output.c
+1-3sys/netgraph7/atm/ngatmbase.c
+1-1sys/dev/netif/msk/if_msk.c
+5-73 files

DragonFlyBSD/src 9439a25share/zoneinfo australasia Theory

Sync zoneinfo database with tzdata2012f from ftp://ftp.iana.org/tz/releases

* australasia (Pacific/Fiji): Fiji DST is October 21 through January 20
    this year.  (Thanks to Steffen Thorsen.)

* Theory: Correct a typo.
DeltaFile
+11-3share/zoneinfo/australasia
+1-1share/zoneinfo/Theory
+12-42 files

DragonFlyBSD/src b9a4a0asbin/hammer cmd_mirror.c

Fix buildworld.
DeltaFile
+1-1sbin/hammer/cmd_mirror.c
+1-11 files

DragonFlyBSD/src bb8e632sbin/hammer cmd_mirror.c

hammer - Fix core dump during remote termination of mirror-stream

* Fix issue where remote-end hammer can core trying to fprintf() an error
  message if a mirror-stream connection is lost unexpectedly.
DeltaFile
+2-1sbin/hammer/cmd_mirror.c
+2-11 files

DragonFlyBSD/src 39b8be9sys/sys param.h

<sys/param.h>: Fix wrongly merged comments on the release branch.
DeltaFile
+0-4sys/sys/param.h
+0-41 files

DragonFlyBSD/src c0cbd31sys/dev/netif/bce if_bce.c

kernel/bce: Fix an impossible && that should really be a ||.

Reviewed-by: sephe
DeltaFile
+1-1sys/dev/netif/bce/if_bce.c
+1-11 files

DragonFlyBSD/src 3845431sys/dev/raid/hptmv entry.c

kernel/hptmv: Fix the completion of a write.

What is intended here is to perform BUS_DMASYNC_POSTWRITE when a write
is completed, but the 'else if' had the wrong check.
DeltaFile
+1-1sys/dev/raid/hptmv/entry.c
+1-11 files

DragonFlyBSD/src 92f46d0sys/netproto/ipx ipx_usrreq.c

kernel/ipx: Add a missing 'goto set_head;'.
DeltaFile
+1-1sys/netproto/ipx/ipx_usrreq.c
+1-11 files

DragonFlyBSD/src 2c98716sys/sys param.h

Tag for 3.0.3.
DeltaFile
+2-1sys/sys/param.h
+2-11 files

DragonFlyBSD/src e10bce1sys/emulation/linux/i386/linprocfs linprocfs_subr.c linprocfs_vnops.c

Merge remote branch 'crater/DragonFly_RELEASE_3_0' into rel3_0
DeltaFile
+30-6sys/emulation/linux/i386/linprocfs/linprocfs_subr.c
+11-11sys/emulation/linux/i386/linprocfs/linprocfs_vnops.c
+4-2sys/emulation/linux/i386/linprocfs/linprocfs_misc.c
+1-0sys/emulation/linux/i386/linprocfs/linprocfs.h
+46-194 files

DragonFlyBSD/src 1710f27sys/emulation/linux/i386/linprocfs linprocfs_vnops.c

kernel/linprocfs: Add a missing header for spin_{,un}lock().
DeltaFile
+1-0sys/emulation/linux/i386/linprocfs/linprocfs_vnops.c
+1-01 files

DragonFlyBSD/src 4876e2asys/emulation/linux/i386/linprocfs linprocfs_subr.c linprocfs_vnops.c

kernel/linprocfs: Fix accessing files in /proc (such as /proc/meminfo).

It is the same fix that was applied to procfs with 198c0ff2.
DeltaFile
+30-6sys/emulation/linux/i386/linprocfs/linprocfs_subr.c
+11-11sys/emulation/linux/i386/linprocfs/linprocfs_vnops.c
+1-0sys/emulation/linux/i386/linprocfs/linprocfs.h
+42-173 files

DragonFlyBSD/src f8183e2sys/emulation/linux/i386/linprocfs linprocfs_misc.c

kernel/linprocfs: Fix a panic when accessing /proc/<pid>/maps.

Analogous to procfs.
DeltaFile
+4-2sys/emulation/linux/i386/linprocfs/linprocfs_misc.c
+4-21 files

DragonFlyBSD/src 42ad053sys/kern kern_condvar.c

kernel - Fix condvar races

* Interlocked sleep was not using the PINTERLOCKED flag.

* Misc other adjustments.
DeltaFile
+19-14sys/kern/kern_condvar.c
+19-141 files

DragonFlyBSD/src 68cdd77sys/kern kern_subr.c, sys/vfs/hammer hammer_vnops.c

kernel - Adjust UFS and HAMMER to use uiomovebp()

* Add uiomovebp(), a version of uiomove() which is aware of a locked bp
  representing the to or from buffer and can work-around issues related
  to VM faults causing recursions and deadlocks on the user buffer.

  uiomovebp() does not yet detect or handle deadlocks.  Implementing
  deadlock handling will require a certain degree of finess related to
  the vnode and bp locks and we don't want to have to do it unless we
  actually deadlock.  TODO.

* Adjust UFS, HAMMER, TMPFS, MSDOSFS, NFS, NTFS to use uiomovebp().
DeltaFile
+33-0sys/kern/kern_subr.c
+3-3sys/vfs/nfs/nfs_bio.c
+2-4sys/vfs/hammer/hammer_vnops.c
+2-2sys/vfs/ntfs/ntfs_subr.c
+2-2sys/vfs/msdosfs/msdosfs_vnops.c
+2-2sys/vfs/tmpfs/tmpfs_vnops.c
+44-133 files not shown
+50-169 files

DragonFlyBSD/src 9ca0255sys/kern kern_lock.c, sys/vfs/ufs ffs_rawread.c

kernel - Change lockmgr LK_SHARED behavior to fix improper recursion return

* When obtaining a LK_SHARED lock in a situation where you already own the
  lock LK_EXCLUSIVE, lockmgr would downgrade the lock to shared.

  This creates a very serious problem when large procedural recursions get
  a lock that is already being held exclusively but request a shared lock.
  When these recursions return the original top level will find its lock is
  no longer exclusive.

* This problem occured with vnode locks when a VOP_WRITE operation on a mmap'd
  space causes a VM fault which then turns around and issues a read().
  When the fault returns the vnode wound up locked shared instead of
  exclusive.

* Fix the problem by NOT downgrading an exclusive lock to shared when
  recursing on LK_SHARED.  Simply add another count to the exclusive
  lock.
DeltaFile
+27-2sys/kern/kern_lock.c
+0-14sys/vfs/ufs/ffs_rawread.c
+27-162 files

DragonFlyBSD/src 4d289d9sys/vm vm_object.c

kernel - Fix incorrect dirty/reprotect code in pageout

* vm_object_page_collect_flush() was trying to re-protect VM pages that
  were still marked dirty after pageout I/O was initiated without owning
  the BUSY bit on the page.  This operation could race whatever I/O was
  going on and multiple issues.  Remove the re-protect.

  Just don't do it.  It's an unnecessary operation.  We still re-set
  PG_CLEANCHK on the page and that should be fine insofar as the pageout
  daemon goes.

* Note that the pageout_flush code protects the VM pages properly (to
  read-only) prior to initiating I/O .

* Should fix bug #2350

* Might be related to the wire-count bug considering that we were messing
  with the page's pmap without owning the BUSY bit.  Small chance.
DeltaFile
+10-4sys/vm/vm_object.c
+10-41 files

DragonFlyBSD/src c4ad22esys/vm vm_map.c

kernel - Fix long-standing vm_map token panic

* Bug turned out to be an error path in vm_map_find().

* This bug ate a lot of hours from several people, but Antonio was able
  to instrument the token path in a way that allowed us to narrow down
  and locate the problem.

Submitted-by: tuxillo, vsrinivas
Debugging-by: tuxillo
DeltaFile
+2-0sys/vm/vm_map.c
+2-01 files

DragonFlyBSD/src 1ecd457sys/kern kern_ktr.c

kernel - Stop KTR logging during panic

* Stop all KTR logging when a panic occurs so the KTR buffer doesn't
  get wiped out by events during the panic & core dump.  This gives
  us a KTR buf snapshot as of the panic entry.
DeltaFile
+3-1sys/kern/kern_ktr.c
+3-11 files

DragonFlyBSD/src f5e3dacsys/vfs/procfs procfs_vnops.c

kernel - Fix numerous procfs/ptrace issues (3)

* Add a safety spin-lock around adjustments to p_stops so it hopefully
  interacts better with the event processing side of things.
DeltaFile
+4-0sys/vfs/procfs/procfs_vnops.c
+4-01 files

DragonFlyBSD/src 1a3fa08sys/kern kern_proc.c kern_exit.c, sys/sys proc.h

kernel - Fix exit races which can lead to a corrupt p_children list

* There are a few races when getting multiple tokens where a threaded
  process is wait*()ing for exiting children from multiple threads
  at once.

  Fix the problem by serializing the operation on a per-child basis,
  and by using PHOLD/PRELE prior to acquiring the child's p_token.
  Then re-check the conditions before accepting the child.

* There is a small chance this will also reduce or fix VM on-exit races
  in i386, as this bug could result in an already-destroyed process
  being pulled off by the racing wait*().  Maybe 25% chance.
DeltaFile
+91-11sys/kern/kern_proc.c
+66-3sys/kern/kern_exit.c
+4-0sys/sys/proc.h
+161-143 files

DragonFlyBSD/src 2fe8ae7sys/kern kern_proc.c

Kernel - Fix numerous procfs/ptrace issues (2)

* The last fix wasn't quite right.  Fix it for real.
DeltaFile
+13-8sys/kern/kern_proc.c
+13-81 files

DragonFlyBSD/src 7c37ea0sys/emulation/linux/i386/linprocfs linprocfs_vnops.c, sys/kern kern_exec.c kern_proc.c

Kernel - Fix numerous procfs/ptrace issues

* Fix interactions during exec and exit.  This should fix truss
  (bug 2313).

* Reset p_* fields related to tracing on last procfs close for the
  process.
DeltaFile
+29-1sys/vfs/procfs/procfs_subr.c
+20-2sys/emulation/linux/i386/linprocfs/linprocfs_vnops.c
+17-3sys/vfs/procfs/procfs_vnops.c
+13-1sys/kern/kern_exec.c
+13-0sys/kern/kern_proc.c
+1-1sys/kern/kern_exit.c
+93-82 files not shown
+95-98 files

DragonFlyBSD/src cd920besys/vfs/ufs ffs_softdep.c

kernel -- ffs: Compile fix for ffs_softdep.c
DeltaFile
+1-1sys/vfs/ufs/ffs_softdep.c
+1-11 files

DragonFlyBSD/src e4a7deesys/vfs/ufs ffs_softdep.c

kernel - Fix two UFS+softupdates bugs

* The softdep sema_*() functions (the ones in ffs_softdep.c, not the sysv
  functions) were not MPSAFE for the case where the passed interlock is
  NULL.  Use a spinlock for that case.

* getdirtybuf()'s semantics were broken and could return success even
  after having released &lk with the bp still unlocked.

  Fixing this should fix most of the reported softdep panics.
DeltaFile
+109-56sys/vfs/ufs/ffs_softdep.c
+109-561 files

DragonFlyBSD/src 091cd5fsys/vfs/ufs ffs_softdep.c

kernel -- ffs: Softdep lock and assorted fixes

* Remove interlocked_sleep; we can just use lksleep directly

* sema_get no longer eats the interlock passed in; all of its
  callers were retaking the lock eventually or immediately.

* softdep was setting up a callout to wake itself in request_cleanup.
  Switch to directly using timeout in lksleep for this purpose.

* Do not access inodedep structure outside of softdep lock in
  softdep_update_inodeblock for buffer field.

* Remove prio field from semaphores; they were unused and the DFly
  tsleep routines do not respect priority anyway.

* Do not release softdep lock before panic()ing
DeltaFile
+25-115sys/vfs/ufs/ffs_softdep.c
+25-1151 files