|
|
求大神给下面的程序做注解,请稍详细些,谢谢。
( k5 z9 S# a% w/ \#include <linux/init.h>4 N1 D2 d( j0 o1 H
#include <linux/module.h>
2 t4 A; _% h6 t#include <linux/kernel.h>
0 u" U6 u" K8 t B1 ~. J0 ^#include <linux/types.h>$ g2 `- N/ M& L
#include <linux/gpio.h>
& b3 ^5 y8 q; F- T- g2 j' T+ V#include <linux/leds.h>3 g; n- r) H# p. y9 c
#include <linux/platform_device.h>- Q& h! `8 `! `. p( S. F& I
5 [9 M. _4 d/ j J7 w G& M#include <asm/mach-types.h>
. S9 i- l- }* d2 T1 g#include <asm/mach/arch.h>
; m. J" p5 e) z% I3 M' g#include <mach/da8xx.h>% T6 `; j/ _. L* O3 g
#include <mach/mux.h>
% T- A( V: F( O+ ^: v- t
$ ^* J' B& `+ i) b8 c6 h+ d#define DA850_USER_LED0 GPIO_TO_PIN(0, 0)
3 v5 m ~( b3 y5 t. f4 Z% J#define DA850_USER_LED1 GPIO_TO_PIN(0, 5)" u: C: j3 N! R
#define DA850_USER_LED2 GPIO_TO_PIN(0, 1)
& q1 r+ G2 s. E5 k* |* C#define DA850_USER_LED3 GPIO_TO_PIN(0, 2)
$ Q2 S: ?9 j2 O/ H. \* g* {, ]9 w' l! c8 o6 E
/* assign the tl som board LED-GPIOs*/. P, V0 }, k5 t4 t) Y% T7 W
static const short da850_evm_tl_user_led_pins[] = {
- {# C* W. i9 Z' z. N/ {) A /* These pins are definition at <mach/mux.h> file */
6 m6 O) d# n, }3 H) [* r DA850_GPIO0_0, DA850_GPIO0_1, DA850_GPIO0_2, DA850_GPIO0_5,$ I) _+ s8 o1 \3 F% f8 _
-1
# z4 d/ o$ Q: @9 h o, \* o, e};
+ I) @2 T" \0 o3 K& i" T f/ B2 O- g; v! [
static struct gpio_led da850_evm_tl_leds[] = {
+ M F( A8 c4 r! p {
2 [; I+ i; p/ r .active_low = 0,0 n; i* m8 x; c' }7 D* Y
.gpio = DA850_USER_LED0,9 K: x; Q/ L- N# a4 E/ s
.name = "user_led0",* \% g0 z ]* q1 \9 R
.default_trigger = "default-on",
: ?* N* V t! ~9 @ },: y/ H l1 V1 `: o1 X* z# Y
{* V/ {& K. e% c4 y% V4 m
.active_low = 0,
" \0 c h: O7 ~; Q3 z# x/ `0 t; ^ .gpio = DA850_USER_LED1,
$ U% H2 j; W5 R .name = "user_led1",% H4 ~1 I( C/ T* \' R: \7 V
.default_trigger = "default-on",
d) @ Z7 P" w- `, P8 u' G: r0 n2 A# I },
) m, r1 h0 b3 K$ d, R) S1 ~* }4 F" a K {
; y+ S6 R& p. t .active_low = 0,8 }3 V; N2 z9 ]. }: K" I
.gpio = DA850_USER_LED2,
0 F/ L" h$ F& V+ ]# d' ` .name = "user_led2",, s' r, n1 m) D" d! E" a. S; g
.default_trigger = "default-on",
+ N$ E' e. R7 g) }" V3 P$ x( U }, N( B7 s" M+ H/ Z& P
{
2 g0 S- V+ i- [; [ .active_low = 0,
# l4 N) j' Q! K .gpio = DA850_USER_LED3,+ \3 {% M9 t0 M" d) n
.name = "user_led3",( W* c- V5 ^7 f$ w
.default_trigger = "default-on",
; {1 Y' H( ~, e6 G. J8 e },+ w( T, U) a) C, H1 m5 t6 a; z# N9 a% ~
};" L9 O% a& b' h. U
; I; D6 q1 T2 k: s3 E
static struct gpio_led_platform_data da850_evm_tl_leds_pdata = {2 _9 _# ~8 p9 Y" h% o" b9 P# H
.leds = da850_evm_tl_leds,- _- M* G( v' }* J. j- A! \. q2 W
.num_leds = ARRAY_SIZE(da850_evm_tl_leds),( v+ s' M _: v* }3 n
};
: E& k1 s. u' t( I0 ?
/ ~' J4 w% s# ^. w3 g! }static void led_dev_release(struct device *dev)) u; m! u0 K$ t2 K. m" f, _8 e: A
{' h L0 g7 T) i$ d
};
5 w( B, Z% `! C( m L+ z/ b( ]" B* V* J+ K. g- W
static struct platform_device da850_evm_tl_leds_device = {
B5 j6 D/ W" @& }5 |, u: n8 h- o% ` .name = "leds-gpio",# _& s7 @3 {6 b' g" r. F
.id = 1,
l7 j1 N) h, H0 _! Z .dev = {
$ D; L, E% `' Z .platform_data = &da850_evm_tl_leds_pdata,; g. J9 c, M" C8 X/ D
.release = led_dev_release,
6 H" W) B" O7 ~" h7 G }
6 w& W, b8 X2 F6 v};" F( d/ w. }( [
3 \& a _. d/ G) ~2 X9 }
static int __init led_platform_init(void)# ^1 X1 I. i' ?0 k
{: y4 k, c6 \) j/ l$ \( o. r6 {
int ret;/ C# n) P; W4 N
#if 0
7 |% Q- ?7 W! t6 C2 k( X ret = davinci_cfg_reg_list(da850_evm_tl_user_led_pins);
; H$ n: G/ j7 ?1 @( @) f/ p if (ret)6 ?2 `, `: L$ e% v. e
pr_warning("da850_evm_tl_leds_init : User LED mux failed :"6 x. F' K0 @0 X: l
"%d\n", ret);; P- p5 e; }; p* Q
#endif4 P: L8 ^0 a [5 u1 P
ret = platform_device_register(&da850_evm_tl_leds_device);
9 J1 z: u: A6 @5 d3 ~4 q" Q if (ret)
4 v+ O& b. l! M pr_warning("Could not register som GPIO expander LEDS");
4 |$ l/ R% e) M& Q% @* I else' @4 q2 O- A2 _; @
printk(KERN_INFO "LED register sucessful!\n");5 z3 r- L4 I# T1 Q5 Q
8 Y9 s* d1 C' s8 o/ f3 y2 j! e return ret;
+ \* d9 U2 }( B9 d! }}
; z% O8 H, f' L8 q0 K1 J( H/ q# s P4 o
static void __exit led_platform_exit(void)
# }1 @, E g: _ O{
2 M" ^; H+ O! j3 }* S platform_device_unregister(&da850_evm_tl_leds_device);
. Z/ r2 t; E0 e c& f. j/ P& s# i) ^; { r9 ~1 @) H
printk(KERN_INFO "LED unregister!\n");; [ D3 c- V: [4 h
}
7 n6 H' c& k' o' @& G" v- J Y4 G# F7 m9 M- l
module_init(led_platform_init);
( r0 \2 @. S6 j; Lmodule_exit(led_platform_exit);* T; U0 P4 Y6 ^9 h8 p8 c* w( N- z
7 F; g& C" r l$ o- c* ]MODULE_DESCRIPTION("Led platform driver");
7 t9 j# f& N& [; D& }7 YMODULE_AUTHOR("Tronlong");$ A! `- U# @& L2 @( h
MODULE_LICENSE("GPL");
$ y4 {8 q+ l) l8 d4 S
# S, z, l9 h9 `+ Q; s8 `; s |
|