xref: /openbmc/linux/Documentation/translations/zh_TW/process/2.Process.rst (revision c900529f3d9161bfde5cca0754f83b4d3c3e0220)
1390f915aSHu Haowen.. SPDX-License-Identifier: GPL-2.0
2390f915aSHu Haowen
3390f915aSHu Haowen.. include:: ../disclaimer-zh_TW.rst
4390f915aSHu Haowen
5390f915aSHu Haowen:Original: :ref:`Documentation/process/2.Process.rst <development_process>`
6390f915aSHu Haowen
7390f915aSHu Haowen:Translator:
8390f915aSHu Haowen
9390f915aSHu Haowen 時奎亮 Alex Shi <alex.shi@linux.alibaba.com>
10390f915aSHu Haowen
11390f915aSHu Haowen:校譯:
12390f915aSHu Haowen
13390f915aSHu Haowen 吳想成 Wu XiangCheng <bobwxc@email.cn>
14*44a54e25SHu Haowen 胡皓文 Hu Haowen <src.res.211@gmail.com>
15390f915aSHu Haowen
16390f915aSHu Haowen.. _tw_development_process:
17390f915aSHu Haowen
18390f915aSHu Haowen開發流程如何進行
19390f915aSHu Haowen================
20390f915aSHu Haowen
21390f915aSHu Haowen90年代早期的Linux內核開發是一件相當鬆散的事情,涉及的用戶和開發人員相對較少。
22390f915aSHu Haowen由於擁有數以百萬計的用戶羣,且每年有大約2000名開發人員參與進來,內核因此必須
23390f915aSHu Haowen發展出許多既定流程來保證開發的順利進行。要參與到流程中來,需要對此流程的進行
24390f915aSHu Haowen方式有一個紮實的理解。
25390f915aSHu Haowen
26390f915aSHu Haowen總覽
27390f915aSHu Haowen----
28390f915aSHu Haowen
29390f915aSHu Haowen內核開發人員使用一個鬆散的基於時間的發布過程,每兩到三個月發布一次新的主要
30390f915aSHu Haowen內核版本。最近的發布歷史記錄如下:
31390f915aSHu Haowen
32390f915aSHu Haowen	======  =================
33390f915aSHu Haowen	5.0	2019年3月3日
34390f915aSHu Haowen	5.1	2019年5月5日
35390f915aSHu Haowen	5.2	2019年7月7日
36390f915aSHu Haowen	5.3	2019年9月15日
37390f915aSHu Haowen	5.4	2019年11月24日
38390f915aSHu Haowen	5.5	2020年1月6日
39390f915aSHu Haowen	======  =================
40390f915aSHu Haowen
41390f915aSHu Haowen每個5.x版本都是一個主要的內核版本,具有新特性、內部API更改等等。一個典型的5.x
42390f915aSHu Haowen版本包含大約13000個變更集,變更了幾十萬行代碼。因此,5.x是Linux內核開發的前
43390f915aSHu Haowen沿;內核使用滾動開發模型,不斷集成重大變化。
44390f915aSHu Haowen
45390f915aSHu Haowen對於每個版本的補丁合併,遵循一個相對簡單的規則。在每個開發周期的開頭,「合併
46390f915aSHu Haowen窗口」被打開。這時,被認爲足夠穩定(並且被開發社區接受)的代碼被合併到主線內
47390f915aSHu Haowen核中。在這段時間內,新開發周期的大部分變更(以及所有主要變更)將以接近每天
48390f915aSHu Haowen1000次變更(「補丁」或「變更集」)的速度合併。
49390f915aSHu Haowen
50390f915aSHu Haowen(順便說一句,值得注意的是,合併窗口期間集成的更改並不是憑空產生的;它們是經
51390f915aSHu Haowen提前收集、測試和分級的。稍後將詳細描述該過程的工作方式。)
52390f915aSHu Haowen
53390f915aSHu Haowen合併窗口持續大約兩周。在這段時間結束時,LinusTorvalds將聲明窗口已關閉,並
54390f915aSHu Haowen釋放第一個「rc」內核。例如,對於目標爲5.6的內核,在合併窗口結束時發生的釋放
55390f915aSHu Haowen將被稱爲5.6-rc1。-rc1 版本是一個信號,表示合併新特性的時間已經過去,穩定下一
56390f915aSHu Haowen個內核的時間已經到來。
57390f915aSHu Haowen
58390f915aSHu Haowen在接下來的6到10周內,只有修復問題的補丁才應該提交給主線。有時會允許更大的
59390f915aSHu Haowen更改,但這種情況很少發生;試圖在合併窗口外合併新功能的開發人員往往受不到
60390f915aSHu Haowen友好的接待。一般來說,如果您錯過了給定特性的合併窗口,最好的做法是等待下一
61390f915aSHu Haowen個開發周期。(偶爾會對未支持硬體的驅動程序進行例外;如果它們不改變已有代碼,
62390f915aSHu Haowen則不會導致回歸,應該可以隨時被安全地加入)。
63390f915aSHu Haowen
64390f915aSHu Haowen隨著修復程序進入主線,補丁速度將隨著時間的推移而變慢。Linus大約每周發布一次
65390f915aSHu Haowen新的-rc內核;在內核被認爲足夠穩定並最終發布前,一般會達到-rc6到-rc9之間。
66390f915aSHu Haowen然後,整個過程又重新開始了。
67390f915aSHu Haowen
68390f915aSHu Haowen例如,這裡是5.4的開發周期進行情況(2019年):
69390f915aSHu Haowen
70390f915aSHu Haowen	==============  ==============================
71390f915aSHu Haowen	九月 15         5.3 穩定版發布
72390f915aSHu Haowen	九月 30         5.4-rc1 合併窗口關閉
73390f915aSHu Haowen	十月 6          5.4-rc2
74390f915aSHu Haowen	十月 13         5.4-rc3
75390f915aSHu Haowen	十月 20         5.4-rc4
76390f915aSHu Haowen	十月 27         5.4-rc5
77390f915aSHu Haowen	十一月 3        5.4-rc6
78390f915aSHu Haowen	十一月 10       5.4-rc7
79390f915aSHu Haowen	十一月 17       5.4-rc8
80390f915aSHu Haowen	十一月 24       5.4 穩定版發布
81390f915aSHu Haowen	==============  ==============================
82390f915aSHu Haowen
83390f915aSHu Haowen開發人員如何決定何時結束開發周期並創建穩定版本?最重要的指標是以前版本的
84390f915aSHu Haowen回歸列表。不歡迎出現任何錯誤,但是那些破壞了以前能工作的系統的錯誤被認爲是
85390f915aSHu Haowen特別嚴重的。因此,導致回歸的補丁是不受歡迎的,很可能在穩定期內刪除。
86390f915aSHu Haowen
87390f915aSHu Haowen開發人員的目標是在穩定發布之前修復所有已知的回歸。在現實世界中,這種完美是
88390f915aSHu Haowen很難實現的;在這種規模的項目中,變數太多了。需要說明的是,延遲最終版本只會
89390f915aSHu Haowen使問題變得更糟;等待下一個合併窗口的更改將變多,導致下次出現更多的回歸錯誤。
90390f915aSHu Haowen因此,大多數5.x內核都有一些已知的回歸錯誤,不過,希望沒有一個是嚴重的。
91390f915aSHu Haowen
92390f915aSHu Haowen一旦一個穩定的版本發布,它的持續維護工作就被移交給「穩定團隊」,目前由
93390f915aSHu HaowenGreg Kroah-Hartman領導。穩定團隊將使用5.x.y編號方案不定期地發布穩定版本的
94390f915aSHu Haowen更新。要合入更新版本,補丁必須(1)修復一個重要的缺陷,且(2)已經合併到
95390f915aSHu Haowen下一個開發版本主線中。內核通常會在其初始版本後的一個以上的開發周期內收到
96390f915aSHu Haowen穩定版更新。例如,5.2內核的歷史如下(2019年):
97390f915aSHu Haowen
98390f915aSHu Haowen	==============  ===============================
99390f915aSHu Haowen        七月 7 	        5.2 穩定版發布
100390f915aSHu Haowen	七月 13	        5.2.1
101390f915aSHu Haowen	七月 21	        5.2.2
102390f915aSHu Haowen	七月 26	        5.2.3
103390f915aSHu Haowen	七月 28	        5.2.4
104390f915aSHu Haowen	七月 31	        5.2.5
105390f915aSHu Haowen	...	        ...
106390f915aSHu Haowen	十月 11         5.2.21
107390f915aSHu Haowen	==============  ===============================
108390f915aSHu Haowen
109390f915aSHu Haowen5.2.21是5.2版本的最終穩定更新。
110390f915aSHu Haowen
111390f915aSHu Haowen有些內核被指定爲「長期」內核;它們將得到更長時間的支持。在本文中,當前的長期
112390f915aSHu Haowen內核及其維護者是:
113390f915aSHu Haowen
114390f915aSHu Haowen	======  ================================	================
115390f915aSHu Haowen	3.16	Ben Hutchings				(長期穩定內核)
116390f915aSHu Haowen	4.4	Greg Kroah-Hartman & Sasha Levin	(長期穩定內核)
117390f915aSHu Haowen	4.9	Greg Kroah-Hartman & Sasha Levin
118390f915aSHu Haowen	4.14	Greg Kroah-Hartman & Sasha Levin
119390f915aSHu Haowen	4.19	Greg Kroah-Hartman & Sasha Levin
120390f915aSHu Haowen	5.4	Greg Kroah-Hartman & Sasha Levin
121390f915aSHu Haowen	======  ================================	================
122390f915aSHu Haowen
123390f915aSHu Haowen長期支持內核的選擇純粹是維護人員是否有需求和時間來維護該版本的問題。
124390f915aSHu Haowen目前還沒有爲即將發布的任何特定版本提供長期支持的已知計劃。
125390f915aSHu Haowen
126390f915aSHu Haowen補丁的生命周期
127390f915aSHu Haowen--------------
128390f915aSHu Haowen
129390f915aSHu Haowen補丁不會直接從開發人員的鍵盤進入主線內核。相反,有一個稍微複雜(如果有些非
130390f915aSHu Haowen正式)的過程,旨在確保對每個補丁進行質量審查,並確保每個補丁實現了一個在主線
131390f915aSHu Haowen中需要的更改。對於小的修復,這個過程可能會很快完成,,而對於較大或有爭議的
132390f915aSHu Haowen變更,可能會持續數年。許多開發人員的沮喪來自於對這個過程缺乏理解或者試圖繞過它。
133390f915aSHu Haowen
134390f915aSHu Haowen爲了減少這種挫敗,本文將描述補丁如何進入內核。下面的介紹以一種較爲理想化的
135390f915aSHu Haowen方式描述了這個過程。更詳細的過程將在後面的章節中介紹。
136390f915aSHu Haowen
137390f915aSHu Haowen補丁通常要經歷以下階段:
138390f915aSHu Haowen
139390f915aSHu Haowen- 設計。這就是補丁的真正需求——以及滿足這些需求的方式——所在。設計工作通常
140390f915aSHu Haowen  是在不涉及社區的情況下完成的,但是如果可能的話,最好是在公開的情況下完成
141390f915aSHu Haowen  這項工作;這樣可以節省很多稍後再重新設計的時間。
142390f915aSHu Haowen
143390f915aSHu Haowen- 早期評審。補丁被發布到相關的郵件列表中,列表中的開發人員會回復他們可能有
144390f915aSHu Haowen  的任何評論。如果一切順利的話,這個過程應該會發現補丁的任何主要問題。
145390f915aSHu Haowen
146390f915aSHu Haowen- 更廣泛的評審。當補丁接近準備好納入主線時,它應該被相關的子系統維護人員
147390f915aSHu Haowen  接受——儘管這種接受並不能保證補丁會一直延伸到主線。補丁將出現在維護人員的
148390f915aSHu Haowen  子系統樹中,並進入 -next 樹(如下所述)。當流程進行時,此步驟將會對補丁
149390f915aSHu Haowen  進行更廣泛的審查,並發現由於將此補丁與其他人所做的工作合併而導致的任何
150390f915aSHu Haowen  問題。
151390f915aSHu Haowen
152390f915aSHu Haowen- 請注意,大多數維護人員也有日常工作,因此合併補丁可能不是他們的最優先工作。
153390f915aSHu Haowen  如果您的補丁得到了需要更改的反饋,那麼您應該進行這些更改,或者解釋爲何
154390f915aSHu Haowen  不應該進行這些更改。如果您的補丁沒有評審意見,也沒有被其相應的子系統或
155390f915aSHu Haowen  驅動程序維護者接受,那麼您應該堅持不懈地將補丁更新到當前內核使其可被正常
156390f915aSHu Haowen  應用,並不斷地發送它以供審查和合併。
157390f915aSHu Haowen
158390f915aSHu Haowen- 合併到主線。最終,一個成功的補丁將被合併到由LinusTorvalds管理的主線存儲庫
159390f915aSHu Haowen  中。此時可能會出現更多的評論和/或問題;對開發人員來說應對這些問題並解決
160390f915aSHu Haowen  出現的任何問題仍很重要。
161390f915aSHu Haowen
162390f915aSHu Haowen- 穩定版發布。大量用戶可能受此補丁影響,因此可能再次出現新的問題。
163390f915aSHu Haowen
164390f915aSHu Haowen- 長期維護。雖然開發人員在合併代碼後可能會忘記代碼,但這種行爲往往會給開發
165390f915aSHu Haowen  社區留下不良印象。合併代碼消除了一些維護負擔,因爲其他人將修復由API更改
166390f915aSHu Haowen  引起的問題。但是,如果代碼要長期保持可用,原始開發人員應該繼續爲代碼負責。
167390f915aSHu Haowen
168390f915aSHu Haowen內核開發人員(或他們的僱主)犯的最大錯誤之一是試圖將流程簡化爲一個「合併到
169390f915aSHu Haowen主線」步驟。這種方法總是會讓所有相關人員感到沮喪。
170390f915aSHu Haowen
171390f915aSHu Haowen補丁如何進入內核
172390f915aSHu Haowen----------------
173390f915aSHu Haowen
174390f915aSHu Haowen只有一個人可以將補丁合併到主線內核存儲庫中:LinusTorvalds。但是,在進入
175390f915aSHu Haowen2.6.38內核的9500多個補丁中,只有112個(大約1.3%)是由Linus自己直接選擇的。
176390f915aSHu Haowen內核項目已經發展到一個沒有一個開發人員可以在沒有支持的情況下檢查和選擇每個
177390f915aSHu Haowen補丁的規模。內核開發人員處理這種增長的方式是使用圍繞信任鏈構建的助理系統。
178390f915aSHu Haowen
179390f915aSHu Haowen內核代碼庫在邏輯上被分解爲一組子系統:網絡、特定體系結構支持、內存管理、視
180390f915aSHu Haowen頻設備等。大多數子系統都有一個指定的維護人員,其總體負責該子系統中的代碼。
181390f915aSHu Haowen這些子系統維護者(鬆散地)是他們所管理的內核部分的「守門員」;他們(通常)
182390f915aSHu Haowen會接受一個補丁以包含到主線內核中。
183390f915aSHu Haowen
184390f915aSHu Haowen子系統維護人員每個人都管理著自己版本的內核原始碼樹,通常(並非總是)使用Git。
185390f915aSHu HaowenGit等工具(以及Quilt或Mercurial等相關工具)允許維護人員跟蹤補丁列表,包括作者
186390f915aSHu Haowen信息和其他元數據。在任何給定的時間,維護人員都可以確定他或她的存儲庫中的哪
187390f915aSHu Haowen些補丁在主線中找不到。
188390f915aSHu Haowen
189390f915aSHu Haowen當合併窗口打開時,頂級維護人員將要求Linus從存儲庫中「拉出」他們爲合併選擇
190390f915aSHu Haowen的補丁。如果Linus同意,補丁流將流向他的存儲庫,成爲主線內核的一部分。
191390f915aSHu HaowenLinus對拉取中接收到的特定補丁的關注程度各不相同。很明顯,有時他看起來很
192390f915aSHu Haowen關注。但是一般來說,Linus相信子系統維護人員不會向上游發送壞補丁。
193390f915aSHu Haowen
194390f915aSHu Haowen子系統維護人員反過來也可以從其他維護人員那裡獲取補丁。例如,網絡樹是由首先
195390f915aSHu Haowen在專用於網絡設備驅動程序、無線網絡等的樹中積累的補丁構建的。此存儲鏈可以
196390f915aSHu Haowen任意長,但很少超過兩個或三個連結。由於鏈中的每個維護者都信任那些管理較低
197390f915aSHu Haowen級別樹的維護者,所以這個過程稱爲「信任鏈」。
198390f915aSHu Haowen
199390f915aSHu Haowen顯然,在這樣的系統中,獲取內核補丁取決於找到正確的維護者。直接向Linus發送
200390f915aSHu Haowen補丁通常不是正確的方法。
201390f915aSHu Haowen
202390f915aSHu HaowenNext 樹
203390f915aSHu Haowen-------
204390f915aSHu Haowen
205390f915aSHu Haowen子系統樹鏈引導補丁流到內核,但它也提出了一個有趣的問題:如果有人想查看爲
206390f915aSHu Haowen下一個合併窗口準備的所有補丁怎麼辦?開發人員將感興趣的是,還有什麼其他的
207390f915aSHu Haowen更改有待解決,以了解是否存在需要擔心的衝突;例如,更改核心內核函數原型的
208390f915aSHu Haowen修補程序將與使用該函數舊形式的任何其他修補程序衝突。審查人員和測試人員希望
209390f915aSHu Haowen在所有這些變更到達主線內核之前,能夠訪問它們的集成形式的變更。您可以從所有
210390f915aSHu Haowen相關的子系統樹中提取更改,但這將是一項複雜且容易出錯的工作。
211390f915aSHu Haowen
212390f915aSHu Haowen解決方案以-next樹的形式出現,在這裡子系統樹被收集以供測試和審查。這些樹中
213390f915aSHu Haowen由Andrew Morton維護的較老的一個,被稱爲「-mm」(用於內存管理,創建時爲此)。
214390f915aSHu Haowen-mm 樹集成了一長串子系統樹中的補丁;它還包含一些旨在幫助調試的補丁。
215390f915aSHu Haowen
216390f915aSHu Haowen除此之外,-mm 還包含大量由Andrew直接選擇的補丁。這些補丁可能已經發布在郵件
217390f915aSHu Haowen列表上,或者它們可能應用於內核中未指定子系統樹的部分。同時,-mm 作爲最後
218390f915aSHu Haowen手段的子系統樹;如果沒有其他明顯的路徑可以讓補丁進入主線,那麼它很可能最
219390f915aSHu Haowen終選擇-mm 樹。累積在-mm 中的各種補丁最終將被轉發到適當的子系統樹,或者直接
220390f915aSHu Haowen發送到Linus。在典型的開發周期中,大約5-10%的補丁通過-mm 進入主線。
221390f915aSHu Haowen
222390f915aSHu Haowen當前-mm 補丁可在「mmotm」(-mm of the moment)目錄中找到:
223390f915aSHu Haowen
224390f915aSHu Haowen        https://www.ozlabs.org/~akpm/mmotm/
225390f915aSHu Haowen
226390f915aSHu Haowen然而,使用MMOTM樹可能會十分令人頭疼;它甚至可能無法編譯。
227390f915aSHu Haowen
228390f915aSHu Haowen下一個周期補丁合併的主要樹是linux-next,由Stephen Rothwell 維護。根據設計
229390f915aSHu Haowenlinux-next 是下一個合併窗口關閉後主線的快照。linux-next樹在Linux-kernel 和
230390f915aSHu HaowenLinux-next 郵件列表中發布,可從以下位置下載:
231390f915aSHu Haowen
232390f915aSHu Haowen        https://www.kernel.org/pub/linux/kernel/next/
233390f915aSHu Haowen
234390f915aSHu HaowenLinux-next 已經成爲內核開發過程中不可或缺的一部分;在一個給定的合併窗口中合併
235390f915aSHu Haowen的所有補丁都應該在合併窗口打開之前的一段時間內找到進入Linux-next 的方法。
236390f915aSHu Haowen
237390f915aSHu HaowenStaging 樹
238390f915aSHu Haowen----------
239390f915aSHu Haowen
240390f915aSHu Haowen內核原始碼樹包含drivers/staging/目錄,其中有許多驅動程序或文件系統的子目錄
241390f915aSHu Haowen正在被添加到內核樹中。它們在仍然需要更多的修正的時候可以保留在driver/staging/
242390f915aSHu Haowen目錄中;一旦完成,就可以將它們移到內核中。這是一種跟蹤不符合Linux內核編碼或
243390f915aSHu Haowen質量標準的驅動程序的方法,人們可能希望使用它們並跟蹤開發。
244390f915aSHu Haowen
245390f915aSHu HaowenGreg Kroah Hartman 目前負責維護staging 樹。仍需要修正的驅動程序將發送給他,
246390f915aSHu Haowen每個驅動程序在drivers/staging/中都有自己的子目錄。除了驅動程序源文件之外,
247390f915aSHu Haowen目錄中還應該有一個TODO文件。TODO文件列出了驅動程序需要接受的暫停的工作,
248390f915aSHu Haowen以及驅動程序的任何補丁都應該抄送的人員列表。當前的規則要求,staging的驅動
249390f915aSHu Haowen程序必須至少正確編譯。
250390f915aSHu Haowen
251390f915aSHu HaowenStaging 是一種讓新的驅動程序進入主線的相對容易的方法,它們會幸運地引起其他
252390f915aSHu Haowen開發人員的注意,並迅速改進。然而,進入staging並不是故事的結尾;staging中
253390f915aSHu Haowen沒有看到常規進展的代碼最終將被刪除。經銷商也傾向於相對不願意使用staging驅動
254390f915aSHu Haowen程序。因此,在成爲一個合適的主線驅動的路上,staging 僅是一個中轉站。
255390f915aSHu Haowen
256390f915aSHu Haowen工具
257390f915aSHu Haowen----
258390f915aSHu Haowen
259390f915aSHu Haowen從上面的文本可以看出,內核開發過程在很大程度上依賴於在不同方向上聚集補丁的
260390f915aSHu Haowen能力。如果沒有適當強大的工具,整個系統將無法在任何地方正常工作。關於如何使用
261390f915aSHu Haowen這些工具的教程遠遠超出了本文檔的範圍,但還是用一點篇幅介紹一些關鍵點。
262390f915aSHu Haowen
263390f915aSHu Haowen到目前爲止,內核社區使用的主要原始碼管理系統是git。Git是在自由軟體社區中開發
264390f915aSHu Haowen的許多分布式版本控制系統之一。它非常適合內核開發,因爲它在處理大型存儲庫和
265390f915aSHu Haowen大量補丁時性能非常好。它也以難以學習和使用而著稱,儘管隨著時間的推移它變得
266390f915aSHu Haowen更好了。對於內核開發人員來說,對Git的某種熟悉幾乎是一種要求;即使他們不將它
267390f915aSHu Haowen用於自己的工作,他們也需要Git來跟上其他開發人員(以及主線)正在做的事情。
268390f915aSHu Haowen
269390f915aSHu Haowen現在幾乎所有的Linux發行版都打包了Git。Git主頁位於:
270390f915aSHu Haowen
271390f915aSHu Haowen        https://git-scm.com/
272390f915aSHu Haowen
273390f915aSHu Haowen此頁面包含了文檔和教程的連結。
274390f915aSHu Haowen
275390f915aSHu Haowen在不使用git的內核開發人員中,最流行的選擇幾乎肯定是Mercurial:
276390f915aSHu Haowen
277390f915aSHu Haowen        http://www.seleric.com/mercurial/
278390f915aSHu Haowen
279390f915aSHu HaowenMercurial與Git共享許多特性,但它提供了一個界面,許多人覺得它更易於使用。
280390f915aSHu Haowen
281390f915aSHu Haowen另一個值得了解的工具是Quilt:
282390f915aSHu Haowen
283390f915aSHu Haowen        https://savannah.nongnu.org/projects/quilt
284390f915aSHu Haowen
285390f915aSHu HaowenQuilt 是一個補丁管理系統,而不是原始碼管理系統。它不會隨著時間的推移跟蹤歷史;
286390f915aSHu Haowen相反,它面向根據不斷發展的代碼庫跟蹤一組特定的更改。一些主要的子系統維護人員
287390f915aSHu Haowen使用Quilt來管理打算向上游移動的補丁。對於某些樹的管理(例如-mm),quilt 是
288390f915aSHu Haowen最好的工具。
289390f915aSHu Haowen
290390f915aSHu Haowen郵件列表
291390f915aSHu Haowen--------
292390f915aSHu Haowen
293390f915aSHu Haowen大量的Linux內核開發工作是通過郵件列表完成的。如果不加入至少一個某個列表,
294390f915aSHu Haowen就很難成爲社區中的一個「全功能」成員。但是,Linux郵件列表對開發人員來說也是
295390f915aSHu Haowen一個潛在的危險,他們可能會被一堆電子郵件淹沒、違反Linux列表上使用的約定,
296390f915aSHu Haowen或者兩者兼而有之。
297390f915aSHu Haowen
298390f915aSHu Haowen大多數內核郵件列表都在vger.kernel.org上運行;主列表位於:
299390f915aSHu Haowen
300390f915aSHu Haowen        http://vger.kernel.org/vger-lists.html
301390f915aSHu Haowen
302390f915aSHu Haowen不過,也有一些列表託管在別處;其中一些列表位於
303390f915aSHu Haowenredhat.com/mailman/listinfo304390f915aSHu Haowen
305390f915aSHu Haowen當然,內核開發的核心郵件列表是linux-kernel。這個列表是一個令人生畏的地方:
306390f915aSHu Haowen每天的信息量可以達到500條,噪音很高,談話技術性很強,且參與者並不總是表現出
307390f915aSHu Haowen高度的禮貌。但是,沒有其他地方可以讓內核開發社區作爲一個整體聚集在一起;
308390f915aSHu Haowen不使用此列表的開發人員將錯過重要信息。
309390f915aSHu Haowen
310390f915aSHu Haowen以下一些提示可以幫助在linux-kernel生存:
311390f915aSHu Haowen
312390f915aSHu Haowen- 將郵件轉移到單獨的文件夾,而不是主郵箱文件夾。我們必須能夠持續地忽略洪流。
313390f915aSHu Haowen
314390f915aSHu Haowen- 不要試圖跟上每一次談話——沒人會這樣。重要的是要篩選感興趣的主題(但請注意
315390f915aSHu Haowen  長時間的對話可能會偏離原來的主題,儘管未改變電子郵件的主題)和參與的人。
316390f915aSHu Haowen
317390f915aSHu Haowen- 不要回復挑事的人。如果有人試圖激起憤怒,請忽略他們。
318390f915aSHu Haowen
319390f915aSHu Haowen- 當回復Linux內核電子郵件(或其他列表上的電子郵件)時,請爲所有相關人員保留
320390f915aSHu Haowen  Cc: 抄送頭。如果沒有確實的理由(如明確的請求),則不應刪除收件人。一定要
321390f915aSHu Haowen  確保你要回復的人在抄送列表中。這個慣例也使你不必在回覆郵件時明確要求被抄送。
322390f915aSHu Haowen
323390f915aSHu Haowen- 在提出問題之前,搜索列表存檔(和整個網絡)。有些開發人員可能會對那些顯然
324390f915aSHu Haowen  沒有完成家庭作業的人感到不耐煩。
325390f915aSHu Haowen
326390f915aSHu Haowen- 避免頂部回復(把你的答案放在你要回復的引文上面的做法)。這會讓你的回答更難
327390f915aSHu Haowen  理解,印象也很差。
328390f915aSHu Haowen
329390f915aSHu Haowen- 在正確的郵件列表發問。linux-kernel 可能是通用的討論場所,但它不是尋找所有
330390f915aSHu Haowen  子系統開發人員的最佳場所。
331390f915aSHu Haowen
332390f915aSHu Haowen最後一點——找到正確的郵件列表——是開發人員常出錯的地方。在linux-kernel上
333390f915aSHu Haowen提出與網絡相關的問題的人幾乎肯定會收到一個禮貌的建議,轉到netdev列表上提出,
334390f915aSHu Haowen因爲這是大多數網絡開發人員經常出現的列表。還有其他列表可用於scsi、video4linux、
335390f915aSHu Haowenide、filesystem等子系統。查找郵件列表的最佳位置是與內核原始碼一起打包的
336390f915aSHu HaowenMAINTAINERS文件。
337390f915aSHu Haowen
338390f915aSHu Haowen開始內核開發
339390f915aSHu Haowen------------
340390f915aSHu Haowen
341390f915aSHu Haowen關於如何開始內核開發過程的問題很常見——個人和公司皆然。同樣常見的是失誤,這
342390f915aSHu Haowen使得關係的開始比本應的更困難。
343390f915aSHu Haowen
344390f915aSHu Haowen公司通常希望聘請知名的開發人員來啓動開發團隊。實際上,這是一種有效的技術。
345390f915aSHu Haowen但它也往往是昂貴的,而且對增加有經驗的內核開發人員的數量沒有多大幫助。考
346390f915aSHu Haowen慮到時間投入,可以讓內部開發人員加快Linux內核的開發速度。利用這段時間可以
347390f915aSHu Haowen讓僱主擁有一批既了解內核又了解公司的開發人員,還可以幫助培訓其他人。從中期
348390f915aSHu Haowen來看,這通常是更有利可圖的方法。
349390f915aSHu Haowen
350390f915aSHu Haowen可以理解的是,單個開發人員往往對起步感到茫然。從一個大型項目開始可能會很
351390f915aSHu Haowen嚇人;人們往往想先用一些較小的東西來試試水。由此,一些開發人員開始創建修補
352390f915aSHu Haowen拼寫錯誤或輕微編碼風格問題的補丁。不幸的是,這樣的補丁會產生一定程度的噪音,
353390f915aSHu Haowen這會分散整個開發社區的注意力,因此,它們越來越被人不看重。希望向社區介紹
354390f915aSHu Haowen自己的新開發人員將無法通過這些方式獲得他們期待的反響。
355390f915aSHu Haowen
356390f915aSHu HaowenAndrew Morton 爲有抱負的內核開發人員提供了如下建議
357390f915aSHu Haowen
358390f915aSHu Haowen::
359390f915aSHu Haowen
360390f915aSHu Haowen	所有內核開發者的第一個項目肯定應該是「確保內核在您可以操作的所有
361390f915aSHu Haowen	機器上始終完美運行」。通常的方法是和其他人一起解決問題(這可能需
362390f915aSHu Haowen	要堅持!),但就是如此——這是內核開發的一部分。
363390f915aSHu Haowen
364c398488dSXueshi Hu(http://lwn.net/Articles/283982/)
365390f915aSHu Haowen
366390f915aSHu Haowen在沒有明顯問題需要解決的情況下,通常建議開發人員查看當前的回歸和開放缺陷
367390f915aSHu Haowen列表。從來都不缺少需要解決的問題;通過解決這些問題,開發人員將從該過程獲得
368390f915aSHu Haowen經驗,同時與開發社區的其他成員建立相互尊重。
369390f915aSHu Haowen
370