|
|
求大神给下面的程序做注解,请稍详细些,谢谢。* V) l% a# m. ^7 }& q/ e
#include <linux/init.h>
) b: R* Z" _0 e/ E5 ~2 i#include <linux/module.h>
; X9 b1 s2 T0 ?+ Z$ H/ [& J#include <linux/kernel.h>
& V, ^ h" D, |5 w/ X. Y#include <linux/types.h>
( }: a, U: o+ z#include <linux/gpio.h>
9 K5 T2 V$ r4 k" U# F#include <linux/leds.h>/ i5 R+ _7 [: U& X
#include <linux/platform_device.h>
- i* d: `) s0 J0 f- H( [1 G6 r8 z" v1 ?5 F9 J& p# @ e
#include <asm/mach-types.h>. h9 M- \2 B3 t, X% l
#include <asm/mach/arch.h>
5 e8 k* I. A: x0 t! l8 {+ u* C#include <mach/da8xx.h>
& D% F" T" `* S; x! ?5 V q#include <mach/mux.h>
" m& G. T! a/ b# r2 y. K# F: p
5 l/ D1 C! E2 H$ [- N#define DA850_USER_LED0 GPIO_TO_PIN(0, 0)% c, V( B9 E) d8 I
#define DA850_USER_LED1 GPIO_TO_PIN(0, 5)* ^* G& I6 ]& N/ Z) @/ Q
#define DA850_USER_LED2 GPIO_TO_PIN(0, 1)
3 T0 k: S1 P0 {/ G3 O9 d& s#define DA850_USER_LED3 GPIO_TO_PIN(0, 2)
; y0 `7 \# q2 r' G- [3 O/ E1 l' Q* \5 V% K7 P- E
/* assign the tl som board LED-GPIOs*/" I3 C" K/ P1 k8 [
static const short da850_evm_tl_user_led_pins[] = {
h# N& @0 u5 @8 k/ i$ B /* These pins are definition at <mach/mux.h> file */
" O* t3 k) j2 c E DA850_GPIO0_0, DA850_GPIO0_1, DA850_GPIO0_2, DA850_GPIO0_5,4 O# E8 s! w& d9 M( @
-1, R; F: Y( v3 M$ ^ R
};
6 E% ^2 ^* _. X# j
2 g6 @& }+ A6 k; H8 ~4 kstatic struct gpio_led da850_evm_tl_leds[] = {
% Q) j! A, p: ^ {* `; ]" y Z+ k( \+ H2 E2 y
.active_low = 0,* j, m& M f, p- [6 @3 B1 r; {
.gpio = DA850_USER_LED0,, M! N( C, I# f; U7 V2 a/ v4 ?5 c
.name = "user_led0",! ?% k" |; \" p! U0 J; G4 x
.default_trigger = "default-on",9 T+ B! \5 E* N2 o# B& Z" _
},2 h5 z v& V8 a, G5 m$ `5 ?% F
{; u7 c g8 O$ a, y! U( Q
.active_low = 0,* G# N* \0 P) A: K6 v6 G( v A( b
.gpio = DA850_USER_LED1,
0 R$ A' ~* m( }: M H .name = "user_led1",
) K9 Y4 E$ {% q C' d' D .default_trigger = "default-on",3 V1 z: z$ [4 A% P+ |4 u3 V; m
},
& {* `9 d& R" j! j {, Q' W0 J8 O8 |2 } O
.active_low = 0,3 p% V$ b$ @1 l# Z; D! u
.gpio = DA850_USER_LED2,
" P; S; N3 `) I .name = "user_led2", z. C) e. J$ n4 v( Q
.default_trigger = "default-on",/ g- a9 v+ i$ R3 ]2 y) ]
},# t8 a- w3 W! h, L6 O! p2 O3 [
{
0 I9 e' r; w7 w1 G) C .active_low = 0,
* |/ I7 g& V5 X( T) C8 i .gpio = DA850_USER_LED3,. i/ X! Y" H* D1 K2 R- a
.name = "user_led3",; i7 h) d# y) A+ a- u8 Z2 q# o
.default_trigger = "default-on",# a; u3 _ P* S+ m- ^
},
3 b+ @/ q6 p' \- |3 W};
: y2 m6 j: K( l6 V$ E
& _* F$ W& n& V5 s: Zstatic struct gpio_led_platform_data da850_evm_tl_leds_pdata = {- j* ~) ]3 w! }5 q5 x1 D
.leds = da850_evm_tl_leds,* R' f8 Y0 ~3 I' W3 s4 D
.num_leds = ARRAY_SIZE(da850_evm_tl_leds),
~2 j& D/ D6 I};
$ a }/ { x3 V+ b3 ^/ _$ v$ B* ^; H6 \' s8 w" y
static void led_dev_release(struct device *dev)" y3 Z" {6 F- p: {
{
$ g+ }7 b$ a9 I' s2 T};
* ^* E& Z* m9 ^. w K: z4 i' C0 e. }* V' Q
static struct platform_device da850_evm_tl_leds_device = {; g) C3 Q0 \; J; A% n4 I
.name = "leds-gpio",2 `: y! {) l. |+ v' Y) W
.id = 1,
# c# I) P' h& I: g- v M8 [ .dev = {6 ]3 I$ s& F* n' m. e- x3 h5 V
.platform_data = &da850_evm_tl_leds_pdata,) s: X4 m* k/ H( Q
.release = led_dev_release,
/ x- R, Q7 Y+ }1 c }
; @% a! o/ ], K; M};
3 q3 [6 e2 Y( q
8 p9 C) r: b0 F/ P4 j. a# Zstatic int __init led_platform_init(void)
V% W6 [' S. a& x8 _/ z9 D{. a( N: |% e/ M; {4 g; v
int ret;
9 D) Q6 G. R* n#if 0
9 s- d8 s q; E0 K* l9 G3 W ret = davinci_cfg_reg_list(da850_evm_tl_user_led_pins);5 W. p( p' A8 H. c
if (ret)
2 Y& D8 L9 H3 |$ x$ G5 M0 w4 M6 R pr_warning("da850_evm_tl_leds_init : User LED mux failed :"2 r7 g% A, d1 L; S( f+ M
"%d\n", ret);) g% a" H8 | W! ^) B3 a2 U
#endif
, M1 u- O' d0 f7 g5 I ret = platform_device_register(&da850_evm_tl_leds_device);3 G& w7 Z8 X& X6 |0 s) E8 Q" ?
if (ret), L, d# P, P* O2 q
pr_warning("Could not register som GPIO expander LEDS");9 k! i z5 }. S# u
else( t$ |1 ~- `8 M' j5 p0 {
printk(KERN_INFO "LED register sucessful!\n");
( v. d v) G" V
' A9 a. G2 o1 S9 N; E% V4 i, n return ret;
- }3 U. D* b7 X- I j}
R$ C8 s: o( `3 ?! j
4 ~7 H( E( E9 j$ d& p" a3 u3 Fstatic void __exit led_platform_exit(void)
* g; H0 _$ C& M8 i+ L, \{' s. Z1 P% `1 M
platform_device_unregister(&da850_evm_tl_leds_device);5 l& n. f( ~9 d% u2 ?7 W E
f6 i) C* g5 n printk(KERN_INFO "LED unregister!\n");
! ?3 c/ m* y# O- Z; g}& c7 G( i0 P+ n6 v0 A3 F. \9 @
' c1 z3 W# V: p, s! T1 M
module_init(led_platform_init);: j q% p3 e& J
module_exit(led_platform_exit);
; W( N U# Q% j `. I( W, X4 I9 X4 V. L7 o1 H6 P: ~
MODULE_DESCRIPTION("Led platform driver");& f# h3 O8 M* M8 a/ R5 t% ?4 Y0 b
MODULE_AUTHOR("Tronlong");
% A1 w4 U" W: {3 F' hMODULE_LICENSE("GPL");
Z5 }$ t6 v2 L$ J$ o" m) n. p9 x% ^% h6 I) c4 N3 \, X
|
|