|
|
求大神给下面的程序做注解,请稍详细些,谢谢。2 x# ]) M5 \( J0 M2 p6 E
#include <linux/init.h>
& A1 O+ I# ~: _4 R: D$ n) Q. E#include <linux/module.h>
1 E( E2 y" u8 z#include <linux/kernel.h>
- y: H2 n c9 S#include <linux/types.h>
& Q* l0 U2 }: L+ E; j#include <linux/gpio.h>3 F) U, ~: [' B9 [; K: }8 g% u0 F
#include <linux/leds.h>3 Z0 F. g. ^- Y& \, `2 M* U4 X7 M
#include <linux/platform_device.h>
1 u( c, _4 R: }
0 {# z' K) Y% G#include <asm/mach-types.h>
; E! F* S4 I& W5 e4 d#include <asm/mach/arch.h>5 [, n. s/ q1 W$ f
#include <mach/da8xx.h>
7 ^- a/ A" X, s$ O#include <mach/mux.h>7 d/ C: ?$ G% w
7 Z" j4 }: x: m2 o( C#define DA850_USER_LED0 GPIO_TO_PIN(0, 0)# n9 c& I0 W& P( Z; g% ]
#define DA850_USER_LED1 GPIO_TO_PIN(0, 5)$ L* Y. B- t. G& A! t: s% e
#define DA850_USER_LED2 GPIO_TO_PIN(0, 1)
4 W0 p# j; N2 R: J2 x3 K+ [! t#define DA850_USER_LED3 GPIO_TO_PIN(0, 2)7 Y5 p7 D/ u' l$ N
, z t } y9 [1 M& f
/* assign the tl som board LED-GPIOs*// B% |6 d. r i) ?! L e
static const short da850_evm_tl_user_led_pins[] = {. k: {1 K% U9 U& j, [
/* These pins are definition at <mach/mux.h> file */
/ ~' a! ~0 Y& s* I- j5 @9 K DA850_GPIO0_0, DA850_GPIO0_1, DA850_GPIO0_2, DA850_GPIO0_5,. A+ B" X$ [6 f) j0 [4 L9 E5 ~
-1
; [9 s/ W O3 L& ]2 K- ^0 Q' U6 A};2 {4 G% \' ~7 R2 J& ?9 d5 n/ ^2 a6 b
7 _8 `5 L; ^, sstatic struct gpio_led da850_evm_tl_leds[] = {
+ X0 d x9 i# O7 s8 c9 Z% o {* ]% ^, q4 U3 V1 g
.active_low = 0,
: d% W! J1 ]. E$ N0 X .gpio = DA850_USER_LED0,
0 S5 J0 w b5 S# R/ o) D7 Y .name = "user_led0",
7 F. g3 Y }5 ]5 R4 q .default_trigger = "default-on",% A& |" d$ G9 b; t4 A0 b
},
9 \' K a5 Z W) G {% q$ g5 U" k7 t! H
.active_low = 0,
' v- z) D1 Z$ v4 { .gpio = DA850_USER_LED1,
( \$ T# }+ C) i5 x& r0 \, o* j .name = "user_led1",, q" c3 _9 \; @: C
.default_trigger = "default-on",
3 n7 V, m: ^3 o+ F },
! r# ?% J" s& H5 M {0 S2 G( f' w1 J! F; K) n& k
.active_low = 0,7 ~* s; b! Y( ^) `8 x+ a" W3 ~
.gpio = DA850_USER_LED2,
) \7 H% d. i# H7 t+ O9 c& G; Y .name = "user_led2",( X' w+ ]* C0 J0 D4 q
.default_trigger = "default-on",1 f2 X1 @- {+ J. u! t- J1 P1 \
},# @6 L) P1 L9 X+ @
{
y. H3 c0 l3 X4 F1 W% t$ o .active_low = 0,, X. t7 h7 j: j
.gpio = DA850_USER_LED3,
; }! q( T/ S) X9 e p7 @ .name = "user_led3",. _0 o% C. a7 C" T4 { x
.default_trigger = "default-on",# U/ M ^1 f7 s2 i$ `" n- x+ v' h5 a
},
2 [' j' S2 i' ]- t: v9 n0 m};$ j% M% ]' g: C
9 ~1 E* x( Z! u7 g! t
static struct gpio_led_platform_data da850_evm_tl_leds_pdata = {: b3 [! e6 X E
.leds = da850_evm_tl_leds,
4 w' W; G+ b% P' n i1 b. f8 a .num_leds = ARRAY_SIZE(da850_evm_tl_leds),+ Z& \' ]+ V7 i$ \0 R' H2 D
};
, l8 y1 B- d: j3 P" O9 V2 z) W9 u: P. n/ ?: Z; U
static void led_dev_release(struct device *dev)
9 T4 R9 \+ P* l4 @# {+ ^{
) n2 ^" a4 m. S4 ]1 p};5 b4 n7 l6 n _9 ~ Q H5 L
. e; k8 Q; ?9 ^3 Rstatic struct platform_device da850_evm_tl_leds_device = {
" C/ j% Y9 t$ I .name = "leds-gpio",$ i# n) Y) W y% f% M: F7 x
.id = 1,7 y7 v0 ?0 n& X
.dev = {
2 U7 T4 F1 m1 \% b& } .platform_data = &da850_evm_tl_leds_pdata,
. a- W3 L# A) ?) } .release = led_dev_release,
^# F2 H6 `0 ^, X* c& b }
2 R; p( W3 |, C7 T8 p};
9 _! w; `2 e6 x# D
+ ^" D4 f6 C9 Q/ [! \( [* X2 ~1 qstatic int __init led_platform_init(void)
/ J. T% A" S4 u8 {{
5 D9 B% O8 i" X int ret;
6 j, U+ [' q7 ^. E#if 00 R3 f. ]& u c) ]% G( ~1 Z
ret = davinci_cfg_reg_list(da850_evm_tl_user_led_pins);
1 ~2 D4 N- i4 \% d- h if (ret)
) [& w6 }. Y% ]* w* \1 z pr_warning("da850_evm_tl_leds_init : User LED mux failed :"
% R. M6 Q; v* v& Y3 ?/ Z; ^ "%d\n", ret);
% v3 B9 F' s% F#endif, W. H" G U5 b% E( i2 n
ret = platform_device_register(&da850_evm_tl_leds_device);- i1 {2 z- S$ g% ]% \* q3 c" g
if (ret). y7 M' w# [! k& E1 V
pr_warning("Could not register som GPIO expander LEDS");7 n4 t% B9 @3 i9 f# L0 {' v" v
else4 Z e1 F" c% Q
printk(KERN_INFO "LED register sucessful!\n");5 B3 m2 f' a, [
# |2 L8 H8 ]4 f% Z return ret;1 x V, m2 s9 t
}
6 H) |! N; m! t9 h9 p* s* n: ]! ]0 h
static void __exit led_platform_exit(void)+ R2 H) \2 J; D' H- v" k
{
* G2 j* R% j K0 Y p platform_device_unregister(&da850_evm_tl_leds_device);
2 }. a3 v2 G! f7 m, X2 w
# X$ ?) A2 g4 z. w) i, p printk(KERN_INFO "LED unregister!\n");2 `. F% J- J; v
}( m4 j% t& u/ J8 d
" D* e# p' _1 J. Q1 a
module_init(led_platform_init);: r! X) O: i6 @) _( l1 n
module_exit(led_platform_exit);
& k$ u! E7 b6 Q: l- D- r9 r% b! }, |) T7 o# c- ?9 q
MODULE_DESCRIPTION("Led platform driver");
5 W7 N. b8 j; @7 T) P4 `0 C; [! mMODULE_AUTHOR("Tronlong");! p( S+ W% q# r# y0 [
MODULE_LICENSE("GPL"); L1 ~$ L& I9 G* p( P2 |" I# q: |
' k. C w/ i4 P* t& a) w |
|