Stable tag will be slipped Sunday and release engineering will begin Monday

Matthew Dillon dillon at apollo.backplane.com
Sat Apr 2 18:29:14 PST 2005


:Okay, I am proud to claim the role of the least educated and the most amateurish
:of all DFly groupies, so I will ask the painfully stupid questions :o)
:
:I've been following the long and confusing thread about what the various tags
:should be named (and why) and I am hereby declaring my total confusion.
:
:I've been following FreeBSD-CURRENT for about ten years, and yet I still don't
:understand the meaning of their tag names -- so, should I be surprised that I
:don't understand the DFly names either?
:...

    Basically it comes down to the problem of identifying what kernel and 
    world someone is running.   In FreeBSD's case they run parallel releases
    of both their 'stable' and 'current' series.  The two major series 
    (stable and current) have their own CVS branches (current is just on the
    CVS HEAD).  Each release made within the series also has its own branch.
    To make things more confusing, the -RELEASE designation only applies to
    the actual release while the -STABLE designation applies to continued 
    development on the stable branch.

    DragonFly just has one series.  i.e. no parallel development is occuring.
    When we release (starting with this upcoming release) we create a branch
    for the release.   Only bug fixes are allowed to be committed to a
    release branch... no new features. 

    As of this upcoming release, our tags are going to be named based on
    the scheme Chris Pressey came up with (the one that got a lot of positive
    responses on the lists).  We will have three tag names:

    DEVELOPMENT

	This represents the absolute bleeding edge head of the CVS tree.
	When Max commits yet another rearrangement of the Make variable
	handling module, or Joerg rearranges the sound drivers, this 
	is where it goes :-)

    PREVIEW

	This is a slip tag (not a branch) that we synchronize with the head
	of the tree from time to time (just like I did a few days ago).  It
	represents near-bleeding-edge but likely-to-not-blow-up-in-your-face
	work.

    RELEASE+subversions

	This will be a branch tag.  e.g. representing an official release.
	So, for example, the upcoming release will be called
	DragonFly 1.2.0-RELEASE (the tag name itself will be something more
	compressed).

	Commits made to a release branch will automatically bump a 
	subversion, e.g. 1.2.0, 1.2.1, ... 1.2.75.  Again, only bug fixes
	would be committed to a release branch.  So someone running a
	release who reports a bug might tell us that is is running 1.2.25,
	which gives us a darn good idea exactly what the state of his
	system is.

	Dave Sharnoff came up with a great idea to prevent commits on the
	release branch from getting out-of-synch with the subversions
	(which is only incremented once a day at most, if something had
	been committed), and that is to have a slip tag within the release 
	branch that is kept synchronized with the automated subversion
	change.  This will be what people tracking a RELEASE branch will
	be using to keep up to date, rather then tracking the branch tag
	itself.  That gets into the nitty-gritty and will be mostly 
	invisible to end-users, but I thought I'd mention it anyway.

    We do not regard releases as being production-ready.  At some point in
    the future we will put together a testing regimen and require a certain
    amount of in-the-field-time for a release branch before we start
    calling it PRODUCTION.  So, e.g.  lets say that by the time we get to
    1.2.75 there's enough feedback and testing to be able to call it 
    production, the nomenclature in the boot message would change
    from RELEASE to PRODUCTION.  Some release branches might never make it
    to that exhaulted status.

    Unlike FreeBSD subversions of old, our subversions automatically track
    commits made to a release branch, so it is expected that the subversion
    might grow to a fairly large number.

					-Matt
					Matthew Dillon 
					<dillon at xxxxxxxxxxxxx>





More information about the Kernel mailing list