blob: 2fdd742318ba8deb080bf830128f46ce6082efe2 (
plain)
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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
.. SPDX-License-Identifier: GPL-2.0
.. _tw_submittingdrivers:
.. include:: ../disclaimer-zh_TW.rst
:Original: :ref:`Documentation/process/submitting-drivers.rst
<submittingdrivers>`
如果想評論或更新本文的內容,請直接聯繫原文檔的維護者。如果你使用英文
交流有困難的話,也可以向中文版維護者求助。如果本翻譯更新不及時或者翻
譯存在問題,請聯繫中文版維護者::
中文版維護者: 李陽 Li Yang <leoyang.li@nxp.com>
中文版翻譯者: 李陽 Li Yang <leoyang.li@nxp.com>
中文版校譯者: 陳琦 Maggie Chen <chenqi@beyondsoft.com>
王聰 Wang Cong <xiyou.wangcong@gmail.com>
張巍 Zhang Wei <wezhang@outlook.com>
胡皓文 Hu Haowen <src.res@email.cn>
如何向 Linux 內核提交驅動程序
=============================
這篇文檔將會解釋如何向不同的內核源碼樹提交設備驅動程序。請注意,如果你感
興趣的是顯卡驅動程序,你也許應該訪問 XFree86 項目(https://www.xfree86.org/)
和/或 X.org 項目 (https://x.org)。
另請參閱 Documentation/translations/zh_TW/process/submitting-patches.rst 文檔。
分配設備號
----------
塊設備和字符設備的主設備號與從設備號是由 Linux 命名編號分配權威 LANANA(
現在是 Torben Mathiasen)負責分配。申請的網址是 https://www.lanana.org/。
即使不準備提交到主流內核的設備驅動也需要在這裡分配設備號。有關詳細信息,
請參閱 Documentation/admin-guide/devices.rst。
如果你使用的不是已經分配的設備號,那麼當你提交設備驅動的時候,它將會被強
制分配一個新的設備號,即便這個設備號和你之前發給客戶的截然不同。
設備驅動的提交對象
------------------
Linux 2.0:
此內核源碼樹不接受新的驅動程序。
Linux 2.2:
此內核源碼樹不接受新的驅動程序。
Linux 2.4:
如果所屬的代碼領域在內核的 MAINTAINERS 文件中列有一個總維護者,
那麼請將驅動程序提交給他。如果此維護者沒有回應或者你找不到恰當的
維護者,那麼請聯繫 Willy Tarreau <w@1wt.eu>。
Linux 2.6:
除了遵循和 2.4 版內核同樣的規則外,你還需要在 linux-kernel 郵件
列表上跟蹤最新的 API 變化。向 Linux 2.6 內核提交驅動的頂級聯繫人
是 Andrew Morton <akpm@linux-foundation.org>。
決定設備驅動能否被接受的條件
----------------------------
許可: 代碼必須使用 GNU 通用公開許可證 (GPL) 提交給 Linux,但是
我們並不要求 GPL 是唯一的許可。你或許會希望同時使用多種
許可證發布,如果希望驅動程序可以被其他開源社區(比如BSD)
使用。請參考 include/linux/module.h 文件中所列出的可被
接受共存的許可。
版權: 版權所有者必須同意使用 GPL 許可。最好提交者和版權所有者
是相同個人或實體。否則,必需列出授權使用 GPL 的版權所有
人或實體,以備驗證之需。
接口: 如果你的驅動程序使用現成的接口並且和其他同類的驅動程序行
爲相似,而不是去發明無謂的新接口,那麼它將會更容易被接受。
如果你需要一個 Linux 和 NT 的通用驅動接口,那麼請在用
戶空間實現它。
代碼: 請使用 Documentation/process/coding-style.rst 中所描述的 Linux 代碼風
格。如果你的某些代碼段(例如那些與 Windows 驅動程序包共
享的代碼段)需要使用其他格式,而你卻只希望維護一份代碼,
那麼請將它們很好地區分出來,並且註明原因。
可移植性: 請注意,指針並不永遠是 32 位的,不是所有的計算機都使用小
尾模式 (little endian) 存儲數據,不是所有的人都擁有浮點
單元,不要隨便在你的驅動程序里嵌入 x86 彙編指令。只能在
x86 上運行的驅動程序一般是不受歡迎的。雖然你可能只有 x86
硬體,很難測試驅動程序在其他平台上是否可用,但是確保代碼
可以被輕鬆地移植卻是很簡單的。
清晰度: 做到所有人都能修補這個驅動程序將會很有好處,因爲這樣你將
會直接收到修復的補丁而不是 bug 報告。如果你提交一個試圖
隱藏硬體工作機理的驅動程序,那麼它將會被扔進廢紙簍。
電源管理: 因爲 Linux 正在被很多行動裝置和桌面系統使用,所以你的驅
動程序也很有可能被使用在這些設備上。它應該支持最基本的電
源管理,即在需要的情況下實現系統級休眠和喚醒要用到的
.suspend 和 .resume 函數。你應該檢查你的驅動程序是否能正
確地處理休眠與喚醒,如果實在無法確認,請至少把 .suspend
函數定義成返回 -ENOSYS(功能未實現)錯誤。你還應該嘗試確
保你的驅動在什麼都不乾的情況下將耗電降到最低。要獲得驅動
程序測試的指導,請參閱
Documentation/power/drivers-testing.rst。有關驅動程序電
源管理問題相對全面的概述,請參閱
Documentation/driver-api/pm/devices.rst。
管理: 如果一個驅動程序的作者還在進行有效的維護,那麼通常除了那
些明顯正確且不需要任何檢查的補丁以外,其他所有的補丁都會
被轉發給作者。如果你希望成爲驅動程序的聯繫人和更新者,最
好在代碼注釋中寫明並且在 MAINTAINERS 文件中加入這個驅動
程序的條目。
不影響設備驅動能否被接受的條件
------------------------------
供應商: 由硬體供應商來維護驅動程序通常是一件好事。不過,如果源碼
樹里已經有其他人提供了可穩定工作的驅動程序,那麼請不要期
望「我是供應商」會成爲內核改用你的驅動程序的理由。理想的情
況是:供應商與現有驅動程序的作者合作,構建一個統一完美的
驅動程序。
作者: 驅動程序是由大的 Linux 公司研發還是由你個人編寫,並不影
響其是否能被內核接受。沒有人對內核源碼樹享有特權。只要你
充分了解內核社區,你就會發現這一點。
資源列表
--------
Linux 內核主源碼樹:
ftp.??.kernel.org:/pub/linux/kernel/...
?? == 你的國家代碼,例如 "cn"、"us"、"uk"、"fr" 等等
Linux 內核郵件列表:
linux-kernel@vger.kernel.org
[可通過向majordomo@vger.kernel.org發郵件來訂閱]
Linux 設備驅動程序,第三版(探討 2.6.10 版內核):
https://lwn.net/Kernel/LDD3/ (免費版)
LWN.net:
每周內核開發活動摘要 - https://lwn.net/
2.6 版中 API 的變更:
https://lwn.net/Articles/2.6-kernel-api/
將舊版內核的驅動程序移植到 2.6 版:
https://lwn.net/Articles/driver-porting/
內核新手(KernelNewbies):
爲新的內核開發者提供文檔和幫助
https://kernelnewbies.org/
Linux USB項目:
http://www.linux-usb.org/
寫內核驅動的「不要」(Arjan van de Ven著):
http://www.fenrus.org/how-to-not-write-a-device-driver-paper.pdf
內核清潔工 (Kernel Janitor):
https://kernelnewbies.org/KernelJanitors
|