summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README.HG130
-rw-r--r--v4l/ChangeLog7
2 files changed, 80 insertions, 57 deletions
diff --git a/README.HG b/README.HG
index 0f114b340..a01b395c3 100644
--- a/README.HG
+++ b/README.HG
@@ -1,78 +1,83 @@
Mauro Carvalho Chehab 2006 Jan 28
- This file describes general procedures used by v4l-dvb
+ This file describes general procedures used by v4l-dvb
maintainers. Some of these also applies to patch submitters.
- We've moved from cvs to a modern SCM system that fits better
+ We've moved from cvs to a modern SCM system that fits better
into kernel development model, called Mercurial (aka hg).
- hg 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.
+ At http://selenic.com/mercurial you'll find quick-start info, a
+tutorial and FAQs.
- It is strongly recommended that every developer use a local copy
-of the repository to make their own tests and use one or more tags for his
-own needs.
+ 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.
- Mercurial is a developer database, It means that it might be
-broken from time to time, although all efforts should be done to avoid this.
-There are more "stable" snapshots at http://www.linuxtv.org/downloads/snapshot
-page.
+ 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.
+
+ The v4l-dvb mercurial repository is meant for development. It
+means that it might be broken from time to time, although all efforts
+should be done to avoid this. There are more "stable" snapshots at
+http://www.linuxtv.org/downloads/snapshot page.
This file postulates some simple rules for maintaing hg tree,
as stated bellow:
- 1) It is strongly recommended that hg maintainers be active at
+ 1) 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;
- 2) Minor changes, like simple card additions (for example a new card
-row at a card struct) can be applied directly by the hg maintainer;
+ 2) Minor changes, like simple card additions (for example a
+new card row at a card struct) can be applied directly by each
+developer;
3) Medium changes that needs modification on card coding or
creating a new card type should be discussed first at the Mailing Lists
-video4linux-list .at. redhat .dot. com (analog/common parts) and/or
-linux-dvb .at. linuxtv .dot. org to allow other contributors to discuss
-about the way it will be included.
+video4linux-list@redhat.com (analog/common parts) and/or
+linux-dvb@linuxtv.org to allow other contributors to discuss about the
+way it will be included.
- 4) Major changes that implies changing some core structs should
-be widely discussed on IRC, posted to the list, created a snapshot THEN
-committed to the tip branch. It is strongly recommended to use a branch
-or v4l_experimental area for such changes.
+ 4) Major changes that implies changing some core structs
+should be widely discussed on IRC, posted to the list, created a
+snapshot THEN committed to the tip branch. It is strongly recommended
+to use a branch or v4l_experimental area for such changes.
- 5) The v4l-dvb maintainer should be warned to create a snapshot
-if the changes could generate impacts on other cards BEFORE commiting
-the change to the tip tag;
+ 5) Every CVS maintainer should follow the "rules of thumb" of
+kernel development stated at Linux source code, especially:
- 6) Every CVS maintainer should follow the "rules of thumb" of kernel
-development stated at Linux source code, especially:
Documenation/SubmittingPatches
Documentation/SubmittingDrivers
Documentation/CodingStyle
- 7) Non active CVS maintainers or that ones who doesn't like to follow
-these rules may be dropped.
+ 6) Every commit should update ChangeLog describing who did,
+what changed and in what files, by using the command:
- 8) Every commit should update ChangeLog describing who did, what
-changed and in what files, by using the command:
make changes
- 9) The latest changelog line will be automatically used as a prototype
-to the commit message at the local repository by using:
+ 7) The latest changelog line will be automatically used as a
+prototype to the commit message at the local repository by using:
+
make commit
- 10) if commit go wrong, hg allows you to undo the last commit, by using
-the command:
+ 8) if commit go wrong, hg allows you to undo the last commit,
+by using the command:
+
hg undo
- This command will preserve the changes at the files. So, a new hg commit
-will redo the desired commit.
+ This command will preserve the changes at the files. So, a new
+hg commit will redo the desired commit.
+
+ 9) To update master repository, it is needed to do:
- 11) To update master repository, it is needed to do:
make pull
- 12) For hg to work properly, these vars should be defined (replacing the
-names at the left):
+ 10) For hg to work properly, these vars should be defined
+(replacing the names at the left):
CHANGE_LOG_NAME="Maintainer Name"
CHANGE_LOG_EMAIL_ADDRESS=maintainer-email@cvsmaintainersite.com
@@ -83,8 +88,10 @@ export CHANGE_LOG_NAME CHANGE_LOG_EMAIL_ADDRESS CHANGE_LOG_LOGIN HGUSER
It is recommended to have these lines at .bashrc or .profile.
- 13) All commit messages shall have a Developers Certificate of Origin
-version 1.1 at Changelog and cvs commit log, as postulated at kernel's source at:
+ 11) All commit messages shall have a Developers Certificate of
+Origin version 1.1 at Changelog and cvs commit log, as postulated at
+kernel's source at:
+
Documentation/SubmittingPatches
This is done by using Signed-off-by: fields at hg commit message.
@@ -106,9 +113,11 @@ version 1.1 at Changelog and cvs commit log, as postulated at kernel's source at
Obs.: Timestamp should be in GMT.
- 14) Commit messages are very rellevant, since they will be used
+ 12) Commit messages are very rellevant, since they will be used
when generating the patches for v4l-dvb.git and to mainstream.
+
The format of commit message shall be:
+
patch subject
From: Patch Developer <patchdeveloper@patchdevelopersite.com>
@@ -117,24 +126,28 @@ patch descriptions
Signed-off-by: Patch Developer <patchdeveloper@patchdevelopersite.com>
Signed-off-by: Cvs Maintainer <cvsmaintainer@cvsmaintainersite.com>
- 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.
+ 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.
+
From: shouldn't be suppressed
+
You may add other signers, if the patch were tested by somebody
-else and he also wants to sign. The commiter signed-off-by should be the last one.
+else and he also wants to sign. The commiter signed-off-by should be
+the last one.
- 15) If the patch also affects other parts of kernel (like alsa
+ 13) If the patch also affects other parts of kernel (like alsa
or i2c), it is required that, at upstream submiting, the patch also go
-to the maintainers of that subsystem. To do this, CVS maintainer shall add
-one or more cc: fields at commit message, after the subject:
+to the maintainers of that subsystem. To do this, CVS maintainer shall
+add one or more cc: fields at 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.
+ Please notice that this is manually handled by the -git
+maintainer, so unnecessary usage should be avoided.
- 16) Sometimes, mainstream changes do affect v4l-dvb tree, and
+ 14) 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:
@@ -142,20 +155,23 @@ kernel-sync
Patches with such lines will not be submited upstream.
- 17) sometimes, it is necessary to introduce some testing code
+ 15) sometimes, it is necessary to introduce some testing code
inside a module or remove parts that are not yet finished. Also,
compatibility tests maybe 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 shuld be used:
+
#if 0 /* keep */
or
#if 1 /* keep */
- 18) Nested #ifs are allowed, but #elsif 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.
+ 16) Nested #ifs are allowed, but #elsif 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.
Cheers,
Mauro
diff --git a/v4l/ChangeLog b/v4l/ChangeLog
index 8b3c7dc56..68c8c888d 100644
--- a/v4l/ChangeLog
+++ b/v4l/ChangeLog
@@ -1,3 +1,10 @@
+2006-01-29 01:48 mchehab
+
+ * README.HG:
+ - Some review, thanks to Johannes Stezenbach.
+
+ Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
+
2006-01-29 01:07 mchehab
* Makefile: