-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathNOTES
121 lines (102 loc) · 5.58 KB
/
NOTES
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
Back in 2007, I wrote some scripts to create a git repo with every single
ancient Linux version up to 2.4 before we had an SCM tracking commits.
(Yes, complete history, from 0.01, up to 2.4.0, including
every -pre,-test and -rc along the way as a separate commit).
And now for the really crazy part:
... with actual changelogs for as many commits as possible.
This seemed like a fun idea at first, then about a third the way through
I began to think this was nuts. At halfway, I'd decided I'd gone too far
to not finish it, and this is the result.
About halfway through, in September of 2007, someone called
'Gonsolo' did something similar to all this. [http://lwn.net/Articles/250699/]
Though his version lacked the changelogs, and missed a ton of prepatches.
It was also around this time, I found that I'm not the only person loony
enough to attempt this, and stumbled across
git://git.kernel.org/pub/scm/linux/kernel/git/nico/archive.git
Nico's archive had some bits I missed, and there were some bits
in his that I had got, so where possible, I stole some of his changelogs.
I think my variant is as complete as we're going to get.
(modulo new arrivals of missing changelogs: read below)
The whole process unpacks 27G of compressed kernel trees, creates interdiffs
between them all, and then imports them into a git tree.
It's recommended to run this process on an SSD, as this whole thing
is very IO bound.
Some other stats:
- commits: 1040
- commits with changelogs: 420
- final repo size: 68M
The repository can be found at
https://archive.org/details/git-history-of-linux
Each time a new development tree was forked, I created
a branch for the stable series to continue on.
Recreating a complete history of the Linux kernel is something
of a challenge.
* Some versions are missing, presumed lost forever.
- Riley Williams (RIP) kept a log of these at
http://ftp.cdut.edu.cn/pub/linux/kernel/history/lka-001.html
- Several missing versions that weren't on kernel.org were found at
http://www.linuxgrill.com/anonymous/kernel/Archive/historic/
http://www.filewatcher.com/b/ftp/ftp.lublin.pl/vol/1/alan/Software/Obsolete/Old-Kernel/
Some pre-patches were also pulled from early Linux kernel archives where
no other form for that version existed.
- Sadly some early releases seem lost to the sands of time, even though
I managed to dig up changelogs for them. (The final 0.96 release for example).
- Even amongst pre-patches, we seem to have lost a few along the way.
2.3.36 has prepatches 1 2 3 5 and 6 for example. pre4 is nowhere to be found.
* Some patches needed to be hand edited.
- linux-0.96a.patch1 doesn't seem to exist online in a non whitespace damaged form,
so I had to recreate it by hand.
Thankfully interdiffs were a lot smaller back in 1992.
- linux-0.97.patch5 doesn't apply on top of patch4.
The Makefile fragment that changes CC neglects to note that the previous version
had $(PROFILING) at the end of the line.
- 2.3.15pre1 tries to delete drivers/video/modedb.c, even though the file
was never in 2.3.14
- Several other variants of the above.
* Some diffs don't seem to apply to any released tree (including pre-patched ones).
In some cases, I was able to fix this up, by removing a single bogus hunk,
but some (like 2.0.34pre13 & pre14 don't make any sense at all --
It's possible they were incrementals against the missing 2.0.34pre12)
* Where a tarball exists, it was used rather than patching from the previous version.
This was done due to what I believe are a combination of bugs in diff(1) at
the time the patches were being created, and/or possibly bugs in patch(1) currently
preventing these diffs from applying.
* It's not clear what exactly happened around 2.2.0pre1
patch-2.2.0-pre1 is diffed against 2.1.132, yet there exists
five 2.1.133 prepatches (although only 4 have been found).
For the git tree, I've created a history that looks like..
.132 .133-1 .133-3 .133-4 .133-5 2.2.0pre1
* diff(1) seems to have some odd 'features'.
2.4.0test3pre3 has a hunk that adds mm/vmscan.c
However, this file has been there since 1.3.57
I converted this hunk to a vmscan.c, dropped it into the
tree and diffed from test3pre2 to find the real differences.
Seems to have done the right thing.
* Changelog entries.
- Early entries came from:
- Linus' notes at http://linus.bkbits.net:8080/linux-historic/?PAGE=changes
- Some culled from Linux-activists
- Some later changelogs from:
- Linux-kernel archives
(special thanks to uswg for sending me ancient mboxes to grep through)
Sadly there doesn't seem to be any online archives of the period between
Linux-activists ending in 1993 and Linux Kernel from 1998. Anyone?
(I find it amazing that five whole years of history have disappeared
from the net).
- Where changelogs were missing/never announced, I tried to piece
together some interesting changelog fodder from relevant discussions
from around the time. Ah, nostalgia.
- Later changelogs came from various sites such as lwn & linuxtoday,
and assorted sites that google turned up.
- Many of the changelogs that did get created are still MIA.
Entries without changelogs show up in git as something
like 'Import 2.5.5.'
If you find changelogs for entries that don't have them,
please forward, and I'll recreate history.
- Some of them were reformatted, or slightly edited to
do things like s/me/Alan Cox/ or s/me/Linus Torvalds/ where
applicable.
* Attributions.
All commits are done with a committer and author git id of
"Linus Torvalds", except for the stable kernels which were
set to "Alan Cox" or "David Weinehall" etc where applicable.