From owner-freebsd-hackers Mon Jun 24 13:30:49 2002 Delivered-To: freebsd-hackers@freebsd.org Received: from pintail.mail.pas.earthlink.net (pintail.mail.pas.earthlink.net [207.217.120.122]) by hub.freebsd.org (Postfix) with ESMTP id B815937B400 for ; Mon, 24 Jun 2002 13:30:30 -0700 (PDT) Received: from pool0352.cvx22-bradley.dialup.earthlink.net ([209.179.199.97] helo=mindspring.com) by pintail.mail.pas.earthlink.net with esmtp (Exim 3.33 #2) id 17MaTM-00059C-00; Mon, 24 Jun 2002 13:30:05 -0700 Message-ID: <3D178124.192785D1@mindspring.com> Date: Mon, 24 Jun 2002 13:29:24 -0700 From: Terry Lambert X-Mailer: Mozilla 4.7 [en]C-CCK-MCD {Sony} (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: "Matthew D. Fuller" Cc: Paul Herman , "Geoffrey C. Speicher" , freebsd-hackers@FreeBSD.ORG Subject: Re: bug in pw, -STABLE [patch] References: <20020623111412.V38509-100000@mammoth.eat.frenchfries.net> <3D1662CC.FE6F6D49@mindspring.com> <20020624124039.GB59373@over-yonder.net> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG "Matthew D. Fuller" wrote: > Terry Lambert, and lo! it spake thus: > > > > The problem with your proposed patch is that it breaks the > > ability to allow authentication against the database while > > it is undergoing modification, which may be a prolonged period. > > Would it? > > For starters, this locks master.passwd, not spwd.db, so any well-behaved > program that used getpw*() like a good little monkey wouldn't even notice > it. In fact, with Paul's change and the rename() alteration, it'd be > BETTER for programs that tried to parse master.passwd, because as it > currently stands, there are times when it's incomplete (because of the > line-by-line copy, which caused us both a few moments of illness when we > noticed it). Whatever locking protocol you come up with needs to be partcipated in by everyone. Historically, passwd file manipulations have used link count locking. The real issue here is that there are a number of incremental file update utilities for managmenet of very large installations, and a large number of historical programs from places like comp.unix.sources that use file locks, rather than advisory range locks. Any locking protocol using advisory locking must lock out readers while there are writers. What you are really locking (or should be) is directory entries here, which means using the same exclusion space for the locking as you use for the update operation, which is a lock on the parent directory (e.g. as is used internally to the FS rename operation). --- Terry To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message