Date: Sat, 30 Dec 2006 16:03:44 +0000 (UTC) From: Robert Watson <rwatson@FreeBSD.org> To: src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org Subject: cvs commit: src/sys/netinet tcp_subr.c Message-ID: <200612301603.kBUG3iRp078184@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
rwatson     2006-12-30 16:03:44 UTC
  FreeBSD src repository
  Modified files:        (Branch: RELENG_6)
    sys/netinet          tcp_subr.c 
  Log:
  Merge tcp_subr.c:1.251 from HEAD to RELENG_6:
  
    Fix race conditions on enumerating pcb lists by moving the initialization
    (and where appropriate the destruction) of the pcb mutex to the
    init/finit functions of the pcb zones.  This allows locking of the pcb
    entries and race condition free comparison of the generation count.
    Rearrange locking a bit to avoid extra locking operation to update the
    generation count in in_pcballoc().  (in_pcballoc now returns the pcb
    locked)
  
    I am planning to convert pcb list handling from a type safe to a
    reference count model soon.  (As this allows really freeing the PCBs)
  
    Reviewed by:    rwatson, mohans
  
  This was missed in jhb's earlier MFC, and lead to a panic when creating
  TCP sockets.
  
  Reported by:    Larry Rosenman <ler at lerctr dot org>
                  Henrik Brix Andersen <henrik at brixandersen dot dk>
                  Karol Kwiatkowski <freebsd at orchid dot homeunix dot org>
                  Danny Braniss <danny at cs dot huji dot ac dot il>
                  Torfinn Ingolfsen <torfinn dot ingolfsen at broadpark dot no>
  
  Revision    Changes    Path
  1.228.2.13  +14 -2     src/sys/netinet/tcp_subr.c
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200612301603.kBUG3iRp078184>
