Starting on 2010-01-23, the main tree is maintained via git SCM, being available at Linuxtv git trees, following the procedures adopted on the other Linux Kernel drivers. The patches on git are backported to the mercurial tree.

Mercurial is a distributed SCM, which means every developer gets his
own full copy of the repository (including the complete revision
history), and can work and commit locally without network connection.
The resulting changesets can then be exchanged between repositories and
finally published to the master repository in linuxtv.org. A list of
current available repositories is available at: http://linuxtv.org/hg

Mercurial is organized with a master tag, called tip. This tag contains
the master repository that will be used by normal users and to generate
patches to kernel.

This file postulates some simple rules for maintaing hg trees, as stated below:

It is strongly recommended that each developer be active at IRC channels (irc://irc.freenode.net) #v4l (for analog) and/or #linuxtv (for digital). It helps to have more discussions at major changes;

Each developer may have one or more development trees, for his daily work. It is recommended to have a tree called 'v4l-dvb' for each developer with their stable patches.

After the patches are ready, developer should send an email to v4l-dvb-maintainer list asking the maintainer to pull it from developer repository, pushing it at master. The maintainer will analyse the patch and publish at master hg if everything looks ok.

Medium or major changes that needs modification on card coding, creating a new card type or requiring changes at core structs should be discussed first at the Mailing Lists video4linux-list@redhat.com (analog/common parts) and/or linux-dvb@linuxtv.org and at IRC to allow other contributors to discuss about the way it will be included.

Every developer should follow the "rules of thumb" of kernel development stated at Linux source code, especially:

Documentation/SubmittingPatches

Documentation/SubmittingDrivers

Documentation/CodingStyle

All commits should have a consistent message. On v4l-dvb, this is done by using:

make commit

This will run some scripts that will check changed files, generating a ChangeLog like comment (that will be removed from the commit) and prepare the last Signed-off-by field, as described bellow.

Files can be added, removed or renamed at hg repository. This should be done by using:

All lines starting with # will be removed by make commit stripts. Subject should be a brief description of the patch. Please notice that, with hg, there's no need (and not desired) to define a Subject: tag. The *first* msg line will be used as subject, just like git. *WARNING* Be careful not to leave the first line blank, otherwise hg will leave subject in blank.

From: line shouldn't be suppressed, since it will be used when
converting to -git as patch author.

You may add other signers, if the patch were tested /co-developed by somebody else and he also wants to sign. The committer signed-off-by should be the last one.

If the patch also affects other parts of kernel (like alsa or i2c), it is required that, at upstream submitting, the patch also goes to the maintainers of that subsystem. To do this, CVS maintainer shall add one or more cc: fields to the commit message, after the subject:

CC: someotherkerneldeveloper@someplace

Please notice that this is manually handled by the -git maintainer, so unnecessary usage should be avoided.

Sometimes, mainstream changes do affect v4l-dvb tree, and requires to apply some kernel patches at the tree. This kind of commit should follow the rules above and should also have a line like:

kernel-sync

Patches with such lines will not be submitted upstream.

sometimes it is necessary to introduce some testing code inside a module or remove parts that are not yet finished. Also, compatibility tests may be required to provide backporting. To allow compatibility tests, "compat.h" should be included first. It does include also linux/version.h.

To include testing code, #if 0 or #if 1 may be used. If this code is meant to go also to kernel, this struct should be used:

#if 0 /* keep */

or

#if 1 /* keep */

Nested #ifs are allowed, but the #elif macro shouldn't be used, since the macro preprocessing script used to prepare kernel upstream patches (v4l/scripts/gentree.pl) is not able to handle it.

To import contributed stuff, a script is provided at tree and allows easy import of a mbox-based patch emails. This is done with: ./mailimport <mbox file> For it to work properly, git tools need to be installed at local machine, since git have a gitimport script that is used by mailimport. Also, hg have a feature, called mqueue, that allows having several patches that can be applied/unapplied for testing. mailimport trusts on it to work, so, this extension should be enabled for mailimport script to work.

Some quotations about development

"The most difficult problem isn't fixing bugs, but fixing bugs
without breaking other configurations. There are many: different
cards, different TV norms, whereas most of the developers can test
only one TV norm." - Gerd Knorr

"Anyone who has never made a mistake has never tried anything new." - Albert Einstein