|
|
求大神给下面的程序做注解,请稍详细些,谢谢。+ m2 H# \7 |) ]* r7 _9 k
#include <linux/init.h>; J! x+ m2 Y) ^2 f
#include <linux/module.h>
3 }8 o/ ?6 a; W- L$ j#include <linux/kernel.h>5 s" ^! q* {8 F
#include <linux/types.h>
1 C3 X h& @% d7 L0 W" i' @) T#include <linux/gpio.h>% j2 W5 J) c1 t. I" N
#include <linux/leds.h>0 q) \& F6 x2 W) G
#include <linux/platform_device.h>
8 W6 c) }3 @. M: f* d# l2 o5 k9 d+ W4 H
#include <asm/mach-types.h>
% U6 ]7 n( T) @. K#include <asm/mach/arch.h>
' Q" T4 t- _# N' b#include <mach/da8xx.h>
+ }& m, y$ Z) y( q/ c#include <mach/mux.h>
9 S$ n) f! t4 F8 Z a2 B J+ q9 A# s) ]4 r4 j1 v- Q& X8 [2 L* z3 x: T
#define DA850_USER_LED0 GPIO_TO_PIN(0, 0)
6 a; T/ e" _8 b M( s( b#define DA850_USER_LED1 GPIO_TO_PIN(0, 5)
6 r2 X% `( Z2 s! `# j; E#define DA850_USER_LED2 GPIO_TO_PIN(0, 1)
! |2 N6 d6 g) g3 d2 E' X- K#define DA850_USER_LED3 GPIO_TO_PIN(0, 2)
5 {( j0 x* @! e/ [9 Y
* ^* K' m2 M' B- r; k: m& ~/* assign the tl som board LED-GPIOs*/+ N; R' o3 R& j& G7 s
static const short da850_evm_tl_user_led_pins[] = {
. e: F: ?, K' |( j) C /* These pins are definition at <mach/mux.h> file */) B9 t( w F7 {6 X3 h- T
DA850_GPIO0_0, DA850_GPIO0_1, DA850_GPIO0_2, DA850_GPIO0_5,3 G, K% i& }* L; U' T2 G+ u2 u
-1
4 C( V+ c9 ?- y R};
# R& b9 q- F- @6 D T, c) \' B0 G+ H6 }/ }+ O2 s1 H
static struct gpio_led da850_evm_tl_leds[] = {
$ F6 Q6 e) p* r2 P1 } {' }( g$ B8 B! n) O3 Y; O
.active_low = 0,
- }; p# z2 F% Z" H. M .gpio = DA850_USER_LED0,$ i7 ?3 y# t, q9 g0 o& Y# [
.name = "user_led0",
: ?+ z2 F! h5 t$ F* o7 s8 C .default_trigger = "default-on",
( E' N- R- ^0 D4 {% i8 e },- x M! e6 ?6 n8 J6 r. I% c
{
, C" N1 J5 ]. v4 R1 y; i .active_low = 0,: k- x- H8 D2 q; x- i
.gpio = DA850_USER_LED1,/ l! [. ~! j, m* N6 w4 B
.name = "user_led1",
$ e1 G1 N/ V1 h6 c .default_trigger = "default-on",% q5 ~( ^/ j9 x: P7 ~
},7 a+ d7 j/ V9 y8 A0 h; \
{$ E& ^2 J. ^- t6 a- R
.active_low = 0,4 `3 i3 }# p; |% g
.gpio = DA850_USER_LED2,
7 N( ]( Y0 ?1 H' `8 }- O: v .name = "user_led2",5 [2 [ D7 D( R% |: P+ M8 C
.default_trigger = "default-on",3 g/ R" @* S* Q/ O
},
( L0 |; }8 G& Y {
# ]1 M6 {$ {( ?8 p4 {# Q .active_low = 0,
7 B* j5 `7 {' F .gpio = DA850_USER_LED3,
6 U c* S4 r9 K# J .name = "user_led3",
# y( Y6 t& n6 V- a4 Y5 V .default_trigger = "default-on",
3 ]1 @: O' G' y b7 [ },
, k: \' B, P1 k, V};
5 F$ Q% q2 U- H1 {( U; M& C
% ]& I: H R+ K" w& p" Fstatic struct gpio_led_platform_data da850_evm_tl_leds_pdata = {
* S X0 J7 G$ @4 z; c, P .leds = da850_evm_tl_leds,8 {7 U; K% ~& r
.num_leds = ARRAY_SIZE(da850_evm_tl_leds), ?/ ^. |5 R0 D0 J& @0 h# U
};; H( [* Z, t( E, q
8 c% u: W# B" w/ J9 A/ s
static void led_dev_release(struct device *dev)7 b5 k Y* t! r2 x) O: s
{1 I; s2 p( v- P) J: U7 \7 w. v% }
};5 Q2 ?* C. m" r) ^) O: Y h4 G
6 C% D2 J9 W) @ Z G8 X% o
static struct platform_device da850_evm_tl_leds_device = {5 {* E4 E! F5 K% e3 h
.name = "leds-gpio",
1 r2 a5 r3 @1 R3 k .id = 1,( e. A; Q6 S$ ~+ U0 t
.dev = {
% i# h, a8 O6 x4 \0 l3 z .platform_data = &da850_evm_tl_leds_pdata,
% ?2 c% P) k( h2 d' X* g8 x .release = led_dev_release,
/ A, E% o) m; }3 c2 h- q/ v }
5 Q8 Z3 c! R6 H5 m5 @};+ O$ S' H& `, I, [
0 L! ~) _9 J6 ]# Pstatic int __init led_platform_init(void)
: v' B; _3 P* Z) h8 P) |! _{
% ^% {, O- R* f6 m int ret;7 y5 L8 b+ `- a7 G b9 X! E
#if 0
, ?1 c( ^# J C ret = davinci_cfg_reg_list(da850_evm_tl_user_led_pins);
2 {. x9 v9 T7 o' D+ B if (ret)
# T( G6 r8 m" H3 _1 I, n2 b/ t pr_warning("da850_evm_tl_leds_init : User LED mux failed :"
% G: s! h; K0 S# [ "%d\n", ret);
8 I7 e5 s! L+ q' [& o" N#endif F+ n( Q- `$ _% ^. x( V. n- d
ret = platform_device_register(&da850_evm_tl_leds_device);
/ w0 s; C; Z6 v8 s8 ^ C if (ret): F( }1 K2 S2 E9 O9 j6 p0 |9 z$ |
pr_warning("Could not register som GPIO expander LEDS");
! d( P1 S, ^" ^7 w! g$ x else
1 {: }& l' a2 [4 V1 |) ?) h printk(KERN_INFO "LED register sucessful!\n");
3 n B/ ^# o; v6 Y) E; W1 x- l* f/ }- ^ y. ~
return ret;
4 M! {3 H7 d0 E& N+ i g}
. {, a. P1 _/ h6 V" M& N6 D: F2 i. b. }
static void __exit led_platform_exit(void)
3 j. d0 g) j( f" C- Q9 F1 E{
7 U# V' v$ ~3 V9 }/ \ platform_device_unregister(&da850_evm_tl_leds_device);
G' M3 M l: h$ V
9 w) ~! B. f) f2 q- Y( a printk(KERN_INFO "LED unregister!\n");" f0 g9 E) I) x' N
}
; \/ @2 u/ v& I- A- V' v3 l0 D9 v8 |7 a0 u2 m
module_init(led_platform_init);
1 J* y4 L' m8 }( Q- O5 g8 tmodule_exit(led_platform_exit);; a6 n8 l* [1 n) s# ~6 E9 f
9 m, ?, E' i- A% c" K; C; A, u
MODULE_DESCRIPTION("Led platform driver");+ N3 s n$ G+ B6 n$ g8 d' q3 S
MODULE_AUTHOR("Tronlong");5 _2 F+ E, I) G( e
MODULE_LICENSE("GPL");* E; m- P+ a" l! n2 r
: B: [/ A4 H# }3 w0 {% O |
|