|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 7 ]9 P- g2 q1 S# t) m+ ^
- [code]EDMA sample test application
; b U6 e: l" j2 P0 w - /*) t; T1 Y& ?) d3 z! e2 j: u
- * edma_test.c% ~! i' f7 g; g- p+ x, R
- *' _! l; O' z: p7 M$ C
- * brief EDMA3 Test Application8 C% N \" {. ?/ ]. _* B
- *
, _. C, T6 k) e! B0 c: g4 Y& M/ a9 \$ U - * This file contains EDMA3 Test code.
. n- `1 `0 j8 z! }1 }) a - *
9 L) r8 z0 m+ K6 N3 H ~ W - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
, Q* z2 @8 d$ J( t5 {. V - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
0 R d( u! T. a; N$ C8 [ D- a7 S - * TO CHANGE.
0 I" ?- c, R; n @' E5 s, d! Q2 p - *
4 {$ M ^ J' t$ l# e2 @6 v - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/0 h D7 G6 D3 ?- }0 F
- *! `% B9 D7 a, r- e5 g/ B5 e! x
- * This program is free software; you can redistribute it and/or6 f4 d$ u# v. I! m
- * modify it under the terms of the GNU General Public License as X+ a3 k3 l8 K. e: R. ?+ e" W
- * published by the Free Software Foundation version 2.
7 F7 I6 |& D4 ~( k9 L! ?3 U - *
2 \9 `; F7 q& G/ t7 d& c - * This program is distributed "as is" WITHOUT ANY WARRANTY of any
1 o' S' k! r; P9 f! n6 E% q5 v - * kind, whether express or implied; without even the implied warranty7 G; q m8 m# T( l! ^" K
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the9 a! X0 z0 W" ~. b0 k' _
- * GNU General Public License for more details.
, t u0 |' ^2 I; w5 B* q' Q4 _ - */
6 s% W; p' z5 F { - & E6 Y0 k8 B4 \
- #include <linux/module.h># a* U. ?' {9 D) `
- #include <linux/init.h>
- ^: a: g1 U& p: r; o; f9 ? - #include <linux/errno.h>' t9 m1 v% J) Z+ I0 Q3 R& ?8 E& K
- #include <linux/types.h>
1 Z% N; b+ u7 y - #include <linux/interrupt.h>
6 U, `% W# H3 Y# w) x& v - #include <asm/io.h>7 D: J6 m' A) m9 _$ `* r: N5 ^8 u+ @
- #include <linux/moduleparam.h>
' H9 q$ J- O( D8 b! `) q' L - #include <linux/sysctl.h>7 ^* T. {8 c9 R" P+ H E* y: N
- #include <linux/mm.h>
- H& ]1 \( O, ~" E5 V' c7 S - #include <linux/dma-mapping.h>
7 L2 o" \; \# d- i - ! b s' e4 t3 W2 [( _9 [/ w
- #include <mach/memory.h>% m, X9 A# c( K0 {7 o' y
- #include <mach/hardware.h>
& O' w W ~/ j2 B; y a - #include <mach/irqs.h>4 h7 X( y5 m4 \4 t2 }
- #include <asm/hardware/edma.h>
( W0 P) o) E. Z3 i, U4 _: ~
' C$ @% J2 y) {6 c6 C- #undef EDMA3_DEBUG
' B$ y6 H w y. V+ C - /*#define EDMA3_DEBUG*/
* @3 J4 R1 l, X' G% U - $ j6 p0 w) s' B3 i6 {$ y
- #ifdef EDMA3_DEBUG
6 N7 N+ P; i9 ^+ G5 b' u - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
+ b- }+ p4 ~/ B- M. J - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)2 M8 k$ Q* c) r
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__). o1 x' |6 a1 _
- #else
" |- D% M) n% W- D3 R h* q - #define DMA_PRINTK( x... )- t! B! ?3 u, Y5 k$ \
- #define DMA_FN_IN3 e, d+ |4 E* R- T; \3 Z2 {1 g
- #define DMA_FN_OUT1 v2 n8 o2 O& }9 G
- #endif1 U8 K. s" W9 l- ^- ]9 a
- 3 K- ^8 Q% m8 W" A! H
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)8 j5 Y; X2 A' P2 p; }9 E' T1 m
- #define STATIC_SHIFT 36 C% J- }# x- [) G+ u
- #define TCINTEN_SHIFT 20
9 S. j3 l7 e/ O - #define ITCINTEN_SHIFT 218 c5 ~* J7 m6 u; J0 r8 }
- #define TCCHEN_SHIFT 22
4 p% A5 c0 }+ S7 J* z, n7 F, a+ ` - #define ITCCHEN_SHIFT 23% G/ c+ T- Q1 N* r5 V
- 9 n' A) | o2 p) C; h! x6 E- E
- static volatile int irqraised1 = 0;
' z8 I2 i# q, r6 ` - static volatile int irqraised2 = 0;0 _0 @/ I* W1 l! f) z9 G
- 6 U& e4 p( e+ b' S9 G! o$ g. _
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);: h" Y( Q Q- x0 q) w8 @
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);/ u) K1 V s3 a3 ?3 z
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
" [& ]' ~" Z- Y/ P* b - 3 \0 g/ [! n$ s
- dma_addr_t dmaphyssrc1 = 0;
6 D4 w6 ]6 x1 `$ D% l3 N - dma_addr_t dmaphyssrc2 = 0;
( Y( ^5 x& i* ?7 f - dma_addr_t dmaphysdest1 = 0;
; B5 H- m+ y+ m# G8 x& y% O - dma_addr_t dmaphysdest2 = 0;2 G) P, ]) S9 S
- & m( K3 L8 _% J# u' U
- char *dmabufsrc1 = NULL;; l" ~. y2 A+ [5 V0 Y9 v* Z
- char *dmabufsrc2 = NULL;
3 A; _0 h8 {# x7 F0 ~, O - char *dmabufdest1 = NULL;" v6 H( k- @* y* b/ z+ c! o3 H
- char *dmabufdest2 = NULL;
" K4 l: k$ Y/ [4 B" M
0 l% m7 ~1 c$ g5 I& U- static int acnt = 512;
6 a6 v& B& [- v - static int bcnt = 8;
: b w1 V. T' Y" j! P1 F d - static int ccnt = 8;0 Y' g* d7 Y* i2 _' \' }/ A
- 5 P( e1 U$ U9 h" T
- module_param(acnt, int, S_IRUGO);
7 L( V# s4 x0 [+ W- V - module_param(bcnt, int, S_IRUGO);
" u' J1 X$ i6 f0 |: K% \ - module_param(ccnt, int, S_IRUGO);
复制代码
+ A$ O/ ?6 i7 x* z0 F) R. E, w, l3 {9 z! D5 ^% V
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用; h# `; U7 }. }4 t$ r
arm-none-linux-gnueabi-gcc -I /home/tl/omapl138/linux-3.3/arch/arm/include -I /home/tl/omapl138/linux-3.3/include EDMA3test.cpp -o EDMA3这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
! V D- u3 s, S2 A ^9 D: `8 J6 m 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。7 q/ L/ n2 @. h! k* I# `. c" k
( y4 W0 o3 ^1 B- D( C; g* e2 p: B6 S
|
|