|
|
求大神给下面的程序做注解,请稍详细些,谢谢。
1 ^4 @, y. E, g' p b! m#include <linux/init.h>7 v! H; S- F6 A+ Q) N
#include <linux/module.h>
3 b& k, n" Y* |4 E* y#include <linux/kernel.h>% t7 K } x2 A
#include <linux/types.h>7 X' R6 q+ j' A8 i; r" E; R1 A; ~1 g( \
#include <linux/gpio.h>
: j3 r5 l4 g6 z: K#include <linux/leds.h>
9 r. Y9 t& I" \0 v4 Q' m#include <linux/platform_device.h>" d0 K9 Y6 V8 X0 W7 { q/ O
1 m% B- E: ~" `8 T
#include <asm/mach-types.h>& E/ F. n' I( J @
#include <asm/mach/arch.h># m# R. m% J7 I: V
#include <mach/da8xx.h>8 V: X: w3 i+ s4 x5 u2 @+ c. t
#include <mach/mux.h>) F9 w9 z4 _5 C, @
5 y1 Q* _8 t. @#define DA850_USER_LED0 GPIO_TO_PIN(0, 0)
, u1 y! O1 J) ?6 e7 i#define DA850_USER_LED1 GPIO_TO_PIN(0, 5)# C6 d2 W' w5 d. h: x) L" O; U
#define DA850_USER_LED2 GPIO_TO_PIN(0, 1)
' j; o. ]8 c9 h# o# W# N9 {#define DA850_USER_LED3 GPIO_TO_PIN(0, 2)
# @' [; r4 B3 o$ P' v! O {/ S# p& c. p5 r1 @
/* assign the tl som board LED-GPIOs*/
- `) |- ?3 c4 `5 y% v- Y' ostatic const short da850_evm_tl_user_led_pins[] = {
3 v% z( k3 e' C/ ?! }! C: M /* These pins are definition at <mach/mux.h> file */
# ~+ u$ Y+ P" j1 f: Q8 j; Y DA850_GPIO0_0, DA850_GPIO0_1, DA850_GPIO0_2, DA850_GPIO0_5,
/ R+ A9 @! y" ~* x f4 y |% l -1
2 M% ~; e6 U, U1 V};
4 C4 ~' E( ^2 }' d; O1 D& g0 {6 q0 e
static struct gpio_led da850_evm_tl_leds[] = {
; x+ d0 ?+ n- H1 V& a: f7 E {; C0 _0 o! ~7 L+ u
.active_low = 0,
2 r# O# m& a) n! k .gpio = DA850_USER_LED0,
% `- C( a: P1 i& P" _ .name = "user_led0",+ @ t2 R( V3 C3 J: x: M1 d6 l/ h
.default_trigger = "default-on",
* p5 ~! N" Z+ M$ g* Z! z2 r },
# x. \0 L( Q% i {2 n# y" l% W( d8 A' G/ H
.active_low = 0,9 Q# I/ W- H: K+ \$ u, x" c, H
.gpio = DA850_USER_LED1,
$ c. P6 B+ L7 z- a5 } .name = "user_led1",0 \7 K* [1 j( d0 y' I
.default_trigger = "default-on",2 g3 s6 L" D/ u6 s$ z( A4 Y0 B
},6 y# Y: N9 x) b/ N* Q
{( i7 X6 D; X6 q9 S" A$ {- K
.active_low = 0,
" v `% |$ R( o3 \! [ .gpio = DA850_USER_LED2,8 y8 q4 [# |% \/ L9 q
.name = "user_led2",% ]$ z5 k* n1 g( o: ^
.default_trigger = "default-on", G" F2 k" f( P7 M
},$ A+ J: M p4 l4 A+ _# e
{9 M! Y$ d$ Y0 j' B& N
.active_low = 0,
$ H: i/ o) u0 D: a- i! Z .gpio = DA850_USER_LED3,
7 j, Q; U9 v4 w2 z .name = "user_led3",! k; }! v6 D0 v- H9 Z
.default_trigger = "default-on",
& G2 T# E2 ^. K7 X7 w& [ },/ v5 {- J6 G/ r( F: m& g0 S V6 Y
};
0 K1 L0 Q- b% K" V9 `# i
1 [( c! `0 j7 s. R- [9 d' i5 Bstatic struct gpio_led_platform_data da850_evm_tl_leds_pdata = {) n' ~! p/ _& ^) x4 D4 J% w
.leds = da850_evm_tl_leds,
- e% w; E; E6 U9 K) d .num_leds = ARRAY_SIZE(da850_evm_tl_leds),
8 @- \6 f) V* y# c- ]};6 c0 k _8 o* O/ g5 H# N5 O
5 E L1 O0 r& N' @: bstatic void led_dev_release(struct device *dev)
9 ~2 e/ \0 G5 @{
# |. M% h7 u# a" L9 g};# }+ o7 a3 {+ R' O
% x; s) U& J/ G1 J! f. f3 dstatic struct platform_device da850_evm_tl_leds_device = {! u$ n* L9 g: n+ Y* I2 I. s
.name = "leds-gpio",$ \" y$ ]+ c( _ {
.id = 1,
) p4 D3 E; B7 A5 ]. x3 e, C .dev = { i7 g( s* a3 A2 U3 x4 Z5 Z
.platform_data = &da850_evm_tl_leds_pdata," N. G+ j& I$ x+ G9 t6 W
.release = led_dev_release,
8 q" b' W; N2 y- W }
& N) E' h, k; O& U: d% z};
5 ?3 W Y, f/ |( w" T: t, T& ~7 G
0 k3 n' Q+ m3 K3 s# c7 i& T* A: @static int __init led_platform_init(void)
& G7 f! h1 X9 V6 u9 M$ t{
( ]6 i) s4 M- _% U4 _% [) w int ret;
; H! {. V. W, h#if 09 ^4 j7 |7 `8 g! R7 i4 {
ret = davinci_cfg_reg_list(da850_evm_tl_user_led_pins);
/ L) o) l O5 B' J8 @ if (ret): F9 q$ {4 ?5 [& X: `0 n
pr_warning("da850_evm_tl_leds_init : User LED mux failed :"
6 K0 r4 p' `6 l* p0 @ "%d\n", ret);% W! i- m5 e% m2 q( H
#endif
2 @5 F+ T a B, f. o ret = platform_device_register(&da850_evm_tl_leds_device);
' j4 ~/ y3 O0 b- x0 P if (ret)
! b: O% N2 R; L/ l pr_warning("Could not register som GPIO expander LEDS");8 }( q9 y; C& v4 }
else( Z& d( S4 S4 @( K3 L
printk(KERN_INFO "LED register sucessful!\n");
7 e0 K7 f! {" k- F8 P
) E, L5 u4 E# W" k return ret;; O2 P9 M) |. Z" N
}6 Q, O3 j$ S9 ^( M
, ?+ G7 j! h4 ]8 T/ P! Kstatic void __exit led_platform_exit(void)
- t- }, A1 _, K0 \3 C# G7 ^* h% F{- q: v- a3 d S' Z; f1 S' w
platform_device_unregister(&da850_evm_tl_leds_device);
5 v' R/ r2 ]6 e' t- _+ |
- U( b0 B, q% v5 b$ L printk(KERN_INFO "LED unregister!\n");
4 }- O. G$ f" u, `& \! D c}. Y; o- ~; m" c" _0 h! p" `
: {& t9 z5 ^+ ]) r: S1 `( F1 gmodule_init(led_platform_init);; L' u T: l) f
module_exit(led_platform_exit);, D7 A( R7 p7 I- \0 k; V
V2 L8 e. X/ g1 R0 F
MODULE_DESCRIPTION("Led platform driver");
P0 w6 q K# dMODULE_AUTHOR("Tronlong");
& l8 [+ D( [8 n: ]0 J* AMODULE_LICENSE("GPL");- t7 |, y1 h, V9 e# E
Z* n6 C/ t4 }9 V" Q
|
|